:root{--paper:#f3f1ec;--paper2:#eae6dd;--paper3:#e4dfd4;--ink:#222a36;--ink-soft:#4a5160;--muted:#838a99;--faint:#aab0bd;--slate:#2b3340;--slate2:#323c4e;--hair:rgba(43,51,64,.12);--hair2:rgba(43,51,64,.2);--card:rgba(255,255,255,.62);--signal:#d8623f;--signal-soft:rgba(216,98,63,.14);--c-cyan:#2f6f8f;--c-azure:#345b8c;--c-violet:#5b53a3;--c-emerald:#2f7d5e;--c-rose:#b04a45;--c-amber:#9a6b28;--hexclip:polygon(50% 1%,97% 26%,97% 74%,50% 99%,3% 74%,3% 26%);--fit:1;--nav-h:60px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--font-mono),ui-monospace,monospace;-webkit-font-smoothing:antialiased;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}::selection{background:var(--signal-soft)}::-webkit-scrollbar{width:9px}::-webkit-scrollbar-track{background:var(--paper2)}::-webkit-scrollbar-thumb{background:#cfc8bb;border-radius:9px}::-webkit-scrollbar-thumb:hover{background:#bcb3a3}section{scroll-margin-top:96px}.bg{position:fixed;inset:0;z-index:0;pointer-events:none}.paper{background:radial-gradient(ellipse 120% 90% at 50% -5%,#faf8f3,#efece5 55%,#e7e2d8)}.aura{inset:-12%;background:radial-gradient(460px 460px at 18% 26%,rgba(47,111,143,.13),transparent 68%),radial-gradient(540px 540px at 82% 56%,rgba(216,98,63,.11),transparent 70%),radial-gradient(400px 400px at 60% 88%,rgba(47,125,94,.11),transparent 70%);will-change:transform}#warp{display:block;-webkit-mask-image:radial-gradient(ellipse 96% 74% at 50% 32%,#000 56%,transparent 100%);mask-image:radial-gradient(ellipse 96% 74% at 50% 32%,#000 56%,transparent 100%)}.grain{opacity:.04;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}@keyframes gridDrift{0%{background-position:0 0,0 0}to{background-position:40px -40px,40px -40px}}@keyframes auraFloat{0%{transform:translate3d(-2%,-1%,0) scale(1)}to{transform:translate3d(3%,3%,0) scale(1.12)}}.topbar{position:fixed;top:0;left:0;right:0;z-index:60;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 22px;background:linear-gradient(180deg,rgba(243,241,236,.94),rgba(243,241,236,.7) 75%,transparent);backdrop-filter:blur(6px)}.brand{display:flex;align-items:center;gap:11px;font-size:11px;letter-spacing:.12em;cursor:pointer}.brand b{font-family:var(--font-archivo),sans-serif;font-weight:700;letter-spacing:.15em;background:var(--slate);color:#f2f4f8;padding:6px 12px;border-radius:6px;font-size:11px;box-shadow:0 4px 14px -6px #2b334080;transition:.25s}.brand:hover b{background:var(--signal)}.brand .role{color:var(--muted);text-transform:uppercase;font-size:10px}.nav{display:flex;align-items:center;gap:2px}.nav a{font-size:10.5px;letter-spacing:.1em;color:var(--ink-soft);padding:8px 11px;border-radius:6px;text-transform:uppercase;transition:.2s;position:relative}.nav a:hover{color:var(--ink);background:#2b33400d}.nav a.on{color:var(--signal)}.nav a.on:after{content:"";position:absolute;left:11px;right:11px;bottom:3px;height:2px;background:var(--signal);border-radius:2px}.nav .cvbtn{margin-left:8px;background:var(--slate);color:#f2f4f8;display:inline-flex;align-items:center;gap:7px}.nav .cvbtn:hover{background:var(--signal);color:#fff}.nav .cvbtn.on:after{display:none}.navtools{display:flex;align-items:center;gap:14px}.clk-wrap{display:flex;align-items:center;gap:8px;font-size:10px;letter-spacing:.1em;color:var(--muted)}.clk-wrap .live{width:7px;height:7px;border-radius:50%;background:var(--signal);box-shadow:0 0 0 3px var(--signal-soft);animation:pulse 1.8s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.menu-btn{display:none;width:34px;height:34px;border:1px solid var(--hair);border-radius:7px;flex-direction:column;align-items:center;justify-content:center;gap:4px}.menu-btn i{width:16px;height:1.6px;background:var(--ink);transition:.25s}.wrap{max-width:1140px;margin:0 auto;padding:0 clamp(24px,5vw,40px);position:relative;z-index:5}.sec{position:relative;z-index:5;padding:clamp(96px,12vw,168px) 0}.sec:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--hair)}.intro:before{display:none}.sec-head{margin-bottom:clamp(48px,6vw,76px)}.eyebrow{font-size:10px;letter-spacing:.32em;color:var(--signal);text-transform:uppercase;display:flex;align-items:center;gap:11px}.eyebrow:before{content:"";width:34px;height:1px;background:var(--signal)}.sec-head h2{font-family:var(--font-archivo),sans-serif;font-weight:800;font-size:clamp(28px,4.6vw,50px);letter-spacing:-.02em;margin:18px 0 0;color:var(--ink)}.sec-head .sub{margin-top:15px;font-size:13.5px;color:var(--muted);max-width:600px;line-height:1.78}.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}.reveal.in{opacity:1;transform:none}.load-fx{opacity:0;transform:translateY(26px);filter:blur(9px);transition:opacity 1s cubic-bezier(.16,.84,.34,1),transform 1s cubic-bezier(.16,.84,.34,1),filter 1s cubic-bezier(.16,.84,.34,1)}html.ready .load-fx{opacity:1;transform:none;filter:none}.topbar{transform:translateY(-100%);transition:transform .85s cubic-bezier(.16,.84,.34,1)}html.ready .topbar{transform:none}.name-reveal{clip-path:inset(108% 0 -8% 0);transition:clip-path 1.1s cubic-bezier(.16,.84,.34,1) .22s}html.ready .name-reveal{clip-path:inset(0 0 -8% 0)}.intro-id .kicker:before{width:0;transition:width .75s cubic-bezier(.16,.84,.34,1) .58s}html.ready .intro-id .kicker:before{width:28px}@media(prefers-reduced-motion:reduce){.load-fx,.topbar{opacity:1;transform:none;filter:none;transition:none}.name-reveal{clip-path:none}.intro-id .kicker:before{width:28px;transition:none}}.chips{display:flex;flex-wrap:wrap;gap:8px}.chips span{font-size:9.5px;letter-spacing:.05em;color:var(--ink-soft);border:1px solid var(--hair);background:#ffffff73;border-radius:20px;padding:5px 11px}.chips span.hot{border-color:var(--signal);color:var(--signal)}.hero{position:relative;z-index:5;display:flex;align-items:center;padding:calc(var(--nav-h) + 34px) 0 54px}.hero-grid{display:grid;grid-template-columns:1.7fr .82fr;gap:44px;align-items:center;width:100%}.hero .kicker{font-size:10.5px;letter-spacing:.3em;color:var(--signal);text-transform:uppercase;display:flex;align-items:center;gap:11px;margin-bottom:22px}.hero .kicker:before{content:"";width:38px;height:1px;background:var(--signal)}.hero h1{font-family:var(--font-archivo),sans-serif;font-weight:900;font-size:clamp(38px,6.6vw,84px);line-height:.93;margin:0;letter-spacing:-.025em;color:var(--ink)}.hero h1 .l2{display:block;color:var(--signal)}.hero .title{margin-top:16px;font-family:var(--font-archivo),sans-serif;font-weight:600;font-size:clamp(15px,2vw,21px);letter-spacing:.02em;color:var(--ink)}.hero .tagline{margin-top:8px;font-size:12px;letter-spacing:.06em;color:var(--muted);display:flex;align-items:center;gap:9px;height:1.4em}.hero .tagline .tw{color:var(--c-emerald);border-right:2px solid var(--c-emerald);padding-right:3px;white-space:nowrap}.loc{margin-top:20px;display:inline-flex;align-items:center;gap:9px;font-size:11px;letter-spacing:.06em;color:var(--ink-soft);border:1px solid var(--hair);background:#ffffff73;padding:7px 13px;border-radius:30px}.loc i{width:7px;height:7px;border-radius:50%;background:var(--c-emerald);box-shadow:0 0 0 3px #2f7d5e29}.contact-row{margin-top:26px;display:flex;flex-wrap:wrap;gap:10px}.cline{display:inline-flex;align-items:center;gap:9px;font-size:12px;color:var(--ink);border:1px solid var(--hair);background:#ffffff80;padding:12px 17px;border-radius:10px;transition:.22s}.cline:hover{border-color:var(--signal);transform:translateY(-2px);box-shadow:0 12px 24px -16px #d8623f80}.cline svg{width:16px;height:16px;flex:none}.btn-row{margin-top:16px;display:flex;flex-wrap:wrap;gap:10px}.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-archivo),sans-serif;font-weight:600;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;padding:12px 20px;border-radius:9px;border:1px solid var(--hair2);transition:.22s;color:var(--ink)}.btn svg{width:15px;height:15px}.btn:hover{border-color:var(--slate);background:#2b33400d;transform:translateY(-2px)}.btn.solid{background:var(--signal);color:#fff;border-color:var(--signal);box-shadow:0 14px 26px -14px #d8623f99}.btn.solid:hover{filter:brightness(1.05);background:var(--signal)}.hero .mini-stack{margin-top:22px}.hero .mini-stack .ms-l{font-size:9px;letter-spacing:.2em;color:var(--faint);text-transform:uppercase;margin-bottom:9px}.hero .mini-stack .ms-row{display:flex;flex-wrap:wrap;gap:7px}.hero .mini-stack .ms-row span{font-size:10px;letter-spacing:.04em;color:var(--ink-soft);opacity:.8}.hero .mini-stack .ms-row span:not(:last-child):after{content:"·";margin-left:7px;color:var(--faint)}.photo-wrap{position:relative;justify-self:center}.photo-wrap .ticks{position:absolute;inset:-12px;pointer-events:none}.photo-wrap .ticks span{position:absolute;width:16px;height:16px;border:1.5px solid var(--hair2)}.photo-wrap .ticks span:nth-child(1){top:0;left:0;border-right:none;border-bottom:none}.photo-wrap .ticks span:nth-child(2){top:0;right:0;border-left:none;border-bottom:none}.photo-wrap .ticks span:nth-child(3){bottom:0;left:0;border-right:none;border-top:none}.photo-wrap .ticks span:nth-child(4){bottom:0;right:0;border-left:none;border-top:none}.photo{width:clamp(168px,17vw,218px);aspect-ratio:4/5;border-radius:14px;overflow:hidden;position:relative;border:1px solid var(--hair2);filter:grayscale(1) contrast(.92);transition:filter .55s ease;box-shadow:0 30px 60px -30px #2b334080}.photo:hover{filter:grayscale(0) contrast(1)}.photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 18%;display:block;transition:transform .6s cubic-bezier(.2,.7,.2,1)}.photo:hover img{transform:scale(1.04)}.photo-cap{margin-top:16px;text-align:center;font-size:9px;letter-spacing:.16em;color:var(--faint);text-transform:uppercase}.intro{padding:calc(var(--nav-h) + clamp(80px,11vw,132px)) 0 clamp(76px,9vw,108px)}.intro-top{display:flex;align-items:center;gap:clamp(22px,3vw,38px);flex-wrap:wrap}.avatar{position:relative;flex:none;width:clamp(90px,9.5vw,116px);aspect-ratio:1/1;border-radius:16px;overflow:hidden;border:1px solid var(--hair2);filter:grayscale(1) contrast(.92);transition:filter .5s ease;box-shadow:0 22px 44px -26px #2b334099;will-change:transform}.avatar:after{content:"";position:absolute;inset:0;border:1px solid rgba(255,255,255,.12);border-radius:16px;pointer-events:none}.avatar:hover{filter:grayscale(0) contrast(1)}.avatar img{width:100%;height:100%;object-fit:cover;object-position:center 15%;display:block;transition:transform .6s cubic-bezier(.2,.7,.2,1)}.avatar:hover img{transform:scale(1.05)}.intro-id{min-width:0}.intro-id .kicker{font-size:9.5px;letter-spacing:.26em;color:var(--signal);text-transform:uppercase;display:flex;align-items:center;gap:10px;margin-bottom:11px}.intro-id .kicker:before{content:"";width:28px;height:1px;background:var(--signal)}.intro-id h1{font-family:var(--font-archivo),sans-serif;font-weight:900;font-size:clamp(34px,5.6vw,66px);line-height:.95;margin:0;letter-spacing:-.025em;color:var(--ink);will-change:transform}.intro-id h1 .l2{color:var(--signal)}.intro-id .title{margin-top:13px;font-family:var(--font-archivo),sans-serif;font-weight:600;font-size:clamp(13px,1.6vw,17px);color:var(--ink);display:flex;align-items:center;gap:9px;flex-wrap:wrap}.intro-id .title .tagline{font-family:var(--font-mono),monospace;font-weight:400;font-size:12px;color:var(--muted)}.intro-id .title .tw{color:var(--c-emerald);border-right:2px solid var(--c-emerald);padding-right:3px;white-space:nowrap}.intro-id .loc{margin-top:16px}.intro .about-lead{margin-top:clamp(60px,9vw,116px);max-width:720px;font-size:clamp(15px,1.85vw,19px);line-height:1.6}.core{margin-top:36px}.core-l{font-size:9px;letter-spacing:.22em;color:var(--faint);text-transform:uppercase;margin-bottom:13px}.core-chips{display:flex;flex-wrap:wrap;gap:9px}.cchip{display:inline-flex;align-items:center;gap:8px;padding:8px 15px 8px 11px;border:1px solid var(--hair);border-radius:30px;background:#ffffff80;transition:transform .22s cubic-bezier(.2,.7,.2,1),border-color .22s,box-shadow .22s,background .22s}.cchip svg{width:15px;height:15px;color:var(--slate);transition:color .22s}.cchip .cm{font-family:var(--font-archivo),sans-serif;font-weight:700;font-size:10px;color:var(--slate);min-width:16px;text-align:center;transition:color .22s}.cchip>span{font-family:var(--font-archivo),sans-serif;font-weight:600;font-size:12px;letter-spacing:.01em;color:var(--ink)}.cchip:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--signal) 55%,transparent);background:#fff;box-shadow:0 12px 22px -14px #28324680}.cchip:hover svg,.cchip:hover .cm{color:var(--signal)}.intro-actions{margin-top:34px;display:flex;flex-wrap:wrap;gap:13px;align-items:center}@media(max-width:560px){.intro-top{gap:16px}.avatar{width:82px}}.about-grid{display:grid;grid-template-columns:1.5fr .9fr;gap:48px;align-items:start}.about-lead{font-family:var(--font-archivo),sans-serif;font-weight:500;font-size:clamp(17px,2.3vw,23px);line-height:1.5;color:var(--ink);letter-spacing:-.01em}.about-lead b{color:var(--signal);font-weight:700}.about-body{margin-top:20px;font-size:13px;line-height:1.9;color:var(--ink-soft)}.stats{display:flex;flex-direction:column;gap:12px}.stat{border:1px solid var(--hair);background:var(--card);border-radius:12px;padding:16px 18px;backdrop-filter:blur(8px)}.stat .n{font-family:var(--font-archivo),sans-serif;font-weight:800;font-size:26px;color:var(--ink)}.stat .n .u{color:var(--signal)}.stat .l{font-size:10px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;margin-top:3px}.timeline{position:relative;padding-left:34px}.timeline:before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:linear-gradient(var(--hair2),var(--hair) 60%,transparent)}.tl-group{position:relative;margin-bottom:clamp(52px,6vw,72px)}.tl-group:before{content:"";position:absolute;left:-34px;top:5px;width:16px;height:16px;border-radius:50%;background:var(--paper);border:2px solid var(--signal);box-shadow:0 0 0 4px var(--paper),0 0 14px -2px #d8623f80}.tl-co{display:flex;flex-wrap:wrap;align-items:baseline;gap:10px}.tl-co h3{font-family:var(--font-archivo),sans-serif;font-weight:700;font-size:19px;color:var(--ink);margin:0}.tl-co .meta{font-size:10.5px;letter-spacing:.06em;color:var(--muted)}.tl-co .when{margin-left:auto;font-size:10.5px;letter-spacing:.08em;color:var(--signal);white-space:nowrap}.tl-items{margin-top:24px;display:flex;flex-direction:column;gap:20px}.tl-card{border:1px solid var(--hair);background:var(--card);border-radius:14px;padding:clamp(20px,2.4vw,26px);backdrop-filter:blur(8px);transition:.25s;position:relative;overflow:hidden}.tl-card:hover{border-color:var(--hair2);transform:translate(3px);box-shadow:0 18px 36px -26px #2b334080}.tl-card .ph-row{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.tl-card h4{font-family:var(--font-archivo),sans-serif;font-weight:700;font-size:14.5px;color:var(--ink);margin:0}.tl-card .tag-cli{font-size:9px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;border:1px solid var(--hair);border-radius:14px;padding:2px 8px}.tl-card p{font-size:12.5px;line-height:1.85;color:var(--ink-soft);margin:12px 0 15px}.tl-card .chips span{font-size:9px;padding:4px 9px}.proj-grid{display:flex;flex-direction:column;gap:clamp(60px,8vw,112px)}.proj{position:relative;display:grid;grid-template-columns:minmax(0,1.12fr) minmax(0,.88fr);align-items:center;gap:clamp(30px,4.5vw,60px)}.proj-body{min-width:0;display:flex;flex-direction:column;align-items:flex-start}.proj:nth-child(2n) .proj-thumb{order:2}.proj .p-top{display:flex;align-items:flex-start;gap:12px}.proj .p-year{font-family:var(--font-mono),monospace;font-size:10.5px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase}.proj h3{font-family:var(--font-archivo),sans-serif;font-weight:800;font-size:clamp(23px,2.8vw,33px);color:var(--ink);margin:15px 0 0;letter-spacing:-.02em;line-height:1.12}.proj .live{display:inline-flex;align-items:center;gap:7px;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--c-emerald);border:1px solid rgba(47,125,94,.3);background:#2f7d5e14;padding:5px 11px;border-radius:20px;margin-top:16px}.proj .live i{width:6px;height:6px;border-radius:50%;background:var(--c-emerald);box-shadow:0 0 8px var(--c-emerald);animation:pulse 1.8s ease-in-out infinite}.proj p{font-size:13.5px;line-height:1.85;color:var(--ink-soft);margin:20px 0 24px;max-width:52ch}.proj .chips{margin-bottom:26px}.proj .view{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-archivo),sans-serif;font-weight:600;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);border:1px solid var(--hair2);border-radius:9px;padding:12px 21px;transition:.22s}.proj .view:hover{background:var(--slate);color:#f2f4f8;border-color:var(--slate)}.proj .view svg{width:13px;height:13px}.proj-thumb{position:relative;aspect-ratio:16/11;border-radius:14px;overflow:hidden;border:1px solid var(--hair2);filter:grayscale(1) contrast(.94);transition:filter .55s ease;box-shadow:0 1px 2px #2b33400d,0 32px 64px -36px #2b334080}@media(max-width:820px){.proj{grid-template-columns:1fr;gap:22px}.proj:nth-child(2n) .proj-thumb{order:0}.proj-thumb{aspect-ratio:16/10}}.proj:hover .proj-thumb{filter:grayscale(0) contrast(1)}.proj-thumb{cursor:zoom-in}.proj-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;display:block;transition:transform .6s cubic-bezier(.2,.7,.2,1)}.proj:hover .proj-thumb img{transform:scale(1.06)}.zoom-hint{position:absolute;inset:0;z-index:4;display:grid;place-items:center;opacity:0;pointer-events:none;background:linear-gradient(180deg,#12161e0a,#12161e42);transition:opacity .3s}.proj:hover .zoom-hint{opacity:1}.zoom-hint .zh{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:#14192280;border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(4px);transform:scale(.82);transition:transform .3s cubic-bezier(.2,.7,.2,1)}.proj:hover .zoom-hint .zh{transform:scale(1)}.zoom-hint svg{width:19px;height:19px;color:#fff}.lightbox{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:5vmin;background:#10141c80;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);opacity:0;visibility:hidden;transition:opacity .35s ease,visibility .35s}.lightbox.open{opacity:1;visibility:visible}.lightbox figure{margin:0;display:flex;flex-direction:column;align-items:center;gap:14px}.lightbox img{max-width:94vw;max-height:84vh;object-fit:contain;border-radius:10px;box-shadow:0 50px 120px -30px #000000b3;transform:scale(.95) translateY(10px);transition:transform .4s cubic-bezier(.2,.7,.2,1)}.lightbox.open img{transform:scale(1) translateY(0)}.lightbox figcaption{font-family:var(--font-mono),monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#ffffffb8}.lb-close{position:fixed;top:22px;right:24px;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:#ffffff14;border:1px solid rgba(255,255,255,.22);color:#fff;backdrop-filter:blur(6px);transition:background .22s,transform .3s;cursor:pointer}.lb-close:hover{background:#ffffff2e;transform:rotate(90deg)}.lb-close svg{width:18px;height:18px}.lb-hint{position:fixed;bottom:20px;left:50%;transform:translate(-50%);font-family:var(--font-mono),monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:#ffffff75}.proj-thumb .tfill{position:absolute;inset:0;transition:transform .6s cubic-bezier(.2,.7,.2,1)}.proj:hover .proj-thumb .tfill{transform:scale(1.06)}.proj-thumb .tgrid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px);background-size:26px 26px;z-index:1}.proj-thumb .tglyph{position:absolute;inset:0;display:grid;place-items:center;z-index:2}.proj-thumb .tglyph span{font-family:var(--font-archivo),sans-serif;font-weight:800;font-size:32px;letter-spacing:.1em;color:#fffffff0;text-shadow:0 4px 20px rgba(0,0,0,.4)}.proj-thumb .ttag{position:absolute;left:11px;bottom:11px;z-index:3;font-family:var(--font-mono),monospace;font-size:8px;letter-spacing:.16em;text-transform:uppercase;color:#eef1f6;background:#1218229e;backdrop-filter:blur(3px);padding:4px 8px;border-radius:5px}.tfill-a{background:radial-gradient(circle at 28% 30%,#7fb0c9,transparent 52%),radial-gradient(circle at 78% 72%,#d8623f,transparent 56%),linear-gradient(150deg,#3a4658,#222a36)}.tfill-b{background:radial-gradient(circle at 30% 32%,#7fc9a3,transparent 52%),radial-gradient(circle at 80% 74%,#caa24e,transparent 56%),linear-gradient(150deg,#34433d,#222a36)}.stack-count{color:var(--signal);font-family:var(--font-mono),monospace;letter-spacing:.04em;white-space:nowrap}.layers{position:relative;margin-top:14px}.layers:before{content:"";position:absolute;left:27px;top:42px;bottom:42px;width:2px;background:linear-gradient(180deg,transparent,var(--hair2) 6%,var(--hair) 94%,transparent)}.layer{position:relative;display:grid;grid-template-columns:56px 1fr;gap:30px;padding:clamp(30px,3.6vw,42px) 0;border-bottom:1px dashed var(--hair)}.layer:last-child{border-bottom:none}.layer-rail{position:relative;display:flex;justify-content:center}.layer-node{position:relative;width:50px;height:45px;clip-path:var(--hexclip);background:linear-gradient(155deg,#323c4e,#1b2230);display:grid;place-items:center;box-shadow:0 0 0 6px var(--paper),0 12px 22px -8px #28324680;transition:transform .35s cubic-bezier(.2,.7,.2,1)}.layer-node .lm{font-family:var(--font-archivo),sans-serif;font-weight:800;font-size:18px;color:#fff;line-height:1}.layer-node .lx{position:absolute;bottom:5px;font-family:var(--font-mono),monospace;font-size:6.5px;letter-spacing:.08em;color:#ffffff80}.layer:hover .layer-node{transform:scale(1.07)}.layer-body{min-width:0}.layer-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:20px}.layer-head h3{font-family:var(--font-archivo),sans-serif;font-weight:800;font-size:clamp(18px,2.5vw,23px);letter-spacing:-.01em;color:var(--ink);margin:0}.layer-head .cnt{font-size:8.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);border:1px solid var(--hair2);border-radius:20px;padding:3px 9px}.layer-head .lnote{font-size:11px;letter-spacing:.03em;color:var(--muted);margin-left:auto}.techs{display:flex;flex-wrap:wrap;gap:11px}.tech{position:relative;display:inline-flex;align-items:center;gap:9px;padding:9px 14px 9px 11px;border:1px solid var(--hair);border-radius:11px;background:#ffffffb8;cursor:default;transition:transform .3s cubic-bezier(.2,.7,.2,1),border-color .25s,box-shadow .25s,background .25s}.tech .ti{display:grid;place-items:center;flex:none;width:20px}.tech .ti i{font-size:17px}.tech .ti .tm{font-family:var(--font-archivo),sans-serif;font-weight:800;font-size:11px;letter-spacing:.01em}.tech .tn{font-family:var(--font-archivo),sans-serif;font-weight:600;font-size:12.5px;letter-spacing:.01em;color:var(--ink);white-space:nowrap}.tech:hover{transform:translateY(-2px);border-color:var(--hair2);background:#fff;box-shadow:0 12px 24px -16px #28324680}.tech:after{content:attr(data-note);position:absolute;left:50%;bottom:calc(100% + 10px);transform:translate(-50%) translateY(5px);background:var(--slate);color:#eef1f6;font-family:var(--font-mono),monospace;font-size:10px;line-height:1.45;padding:7px 11px;border-radius:8px;width:max-content;max-width:230px;text-align:center;opacity:0;pointer-events:none;transition:opacity .22s,transform .22s;box-shadow:0 14px 28px -12px #2b334099;z-index:30}.tech:before{content:"";position:absolute;left:50%;bottom:calc(100% + 4px);transform:translate(-50%) rotate(45deg);width:9px;height:9px;background:var(--slate);opacity:0;transition:opacity .22s;z-index:30}.tech:hover:after{opacity:1;transform:translate(-50%) translateY(0)}.tech:hover:before{opacity:1}@media(max-width:560px){.layer{grid-template-columns:44px 1fr;gap:16px;padding:22px 0}.layers:before{left:21px}.layer-head .lnote{margin-left:0;width:100%}.tech:after{max-width:170px}}.edu-grid{display:grid;grid-template-columns:1.4fr .8fr;gap:clamp(26px,4vw,48px);align-items:start}.edu-list{display:flex;flex-direction:column;gap:14px}.edu{border:1px solid var(--hair);background:var(--card);border-radius:14px;padding:20px 24px;backdrop-filter:blur(8px);display:flex;align-items:center;gap:20px;transition:.22s}.edu:hover{border-color:var(--hair2);transform:translate(3px)}.edu .yr{font-family:var(--font-archivo),sans-serif;font-weight:800;font-size:15px;color:var(--signal);white-space:nowrap;min-width:74px}.edu .ed-b h4{font-family:var(--font-archivo),sans-serif;font-weight:700;font-size:14px;color:var(--ink);margin:0}.edu .ed-b .inst{font-size:11px;color:var(--muted);margin-top:3px}.lang-card{border:1px solid var(--hair);background:var(--card);border-radius:13px;padding:20px;backdrop-filter:blur(8px)}.lang-card .lc-h{font-size:9.5px;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;margin-bottom:16px}.lang{margin-bottom:16px}.lang .lt{display:flex;justify-content:space-between;font-size:12.5px;color:var(--ink);font-family:var(--font-archivo),sans-serif;font-weight:600}.lang .lt span{font-size:10px;color:var(--muted);font-weight:400;font-family:var(--font-mono),monospace}.lang .bar{height:5px;border-radius:4px;background:#2b33401a;margin-top:7px;overflow:hidden}.lang .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--signal),#e08a5f);border-radius:4px}.contact-sec{padding-bottom:40px}.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px}.ccard{border:1px solid var(--hair);background:#ffffff8c;border-radius:14px;padding:24px;transition:.25s;display:flex;flex-direction:column;gap:13px}.ccard:hover{border-color:var(--signal);transform:translateY(-4px);box-shadow:0 24px 44px -28px #d8623f80}.ccard svg{width:22px;height:22px;color:var(--slate)}.ccard .cl{font-size:9px;letter-spacing:.18em;color:var(--muted);text-transform:uppercase}.ccard .cv{font-family:var(--font-archivo),sans-serif;font-weight:600;font-size:14px;color:var(--ink);word-break:break-word}.contact-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,4vw,48px);align-items:start}.cform{display:flex;flex-direction:column;gap:17px;background:linear-gradient(180deg,#fff9,#fff6);border:1px solid var(--hair);border-radius:16px;padding:clamp(26px,3vw,34px);backdrop-filter:blur(8px);box-shadow:0 1px 2px #2b33400a,0 22px 50px -34px #2b334073}.field{display:flex;flex-direction:column;gap:7px}.field label{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}.field input,.field textarea{font-family:var(--font-mono),monospace;font-size:13px;color:var(--ink);background:#ffffffb3;border:1px solid var(--hair2);border-radius:10px;padding:12px 14px;transition:border-color .2s,box-shadow .2s,background .2s;resize:vertical;width:100%}.field input::placeholder,.field textarea::placeholder{color:var(--faint)}.field input:focus,.field textarea:focus{outline:none;border-color:var(--signal);background:#fff;box-shadow:0 0 0 3px var(--signal-soft)}.cform-foot{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:2px}.cform-send{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-archivo),sans-serif;font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:12px;color:#f6f3ee;background:var(--signal);padding:13px 26px;border-radius:9px;transition:transform .22s,filter .22s;box-shadow:0 16px 28px -14px #d8623f8c;cursor:pointer}.cform-send:hover{transform:translateY(-2px);filter:brightness(1.05)}.cform-send svg{width:15px;height:15px}.cform-note{font-size:10px;letter-spacing:.02em;color:var(--muted)}.contact-side{display:flex;flex-direction:column;gap:11px}@media(max-width:760px){.contact-wrap{grid-template-columns:1fr;gap:22px}}.deploy-row{margin-top:40px;display:flex;flex-wrap:wrap;align-items:center;gap:18px}.deploy{display:inline-flex;align-items:center;gap:11px;font-family:var(--font-archivo),sans-serif;font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:12px;color:#f6f3ee;background:var(--signal);padding:16px 32px;border-radius:9px;transition:.25s;box-shadow:0 16px 30px -14px #d8623f99}.deploy:hover{transform:translateY(-3px);filter:brightness(1.05)}.deploy i{width:7px;height:7px;border-radius:50%;background:#f6f3ee}.footer{position:relative;z-index:5;border-top:1px solid var(--hair);background:var(--paper2);padding:40px 0}.footer .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:9.5px;letter-spacing:.12em;color:var(--faint);text-transform:uppercase}.toast{position:fixed;z-index:120;background:var(--slate);color:#f2f4f8;font-size:11px;letter-spacing:.05em;padding:9px 14px;border-radius:8px;box-shadow:0 14px 30px -12px #2b334099;opacity:0;transform:translateY(6px);transition:.25s;pointer-events:none;white-space:nowrap}.toast.show{opacity:1;transform:none}.boot{position:fixed;inset:0;z-index:140;background:var(--paper);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;transition:opacity .7s,visibility .7s}.boot.gone{opacity:0;visibility:hidden}.boot .bt{font-size:10.5px;letter-spacing:.34em;color:var(--signal);text-transform:uppercase}.boot .bbar{width:min(300px,60vw);height:2px;background:#2b33401f;overflow:hidden}.boot .bbar i{display:block;height:100%;width:0;background:var(--signal);transition:width 1.2s cubic-bezier(.4,.1,.2,1)}@media(max-width:980px){.hero-grid{grid-template-columns:1fr;gap:34px}.photo-wrap{justify-self:start}.about-grid,.edu-grid{grid-template-columns:1fr;gap:28px}.metrics{display:none}}@media(max-width:860px){.nav{position:fixed;top:var(--nav-h);right:14px;flex-direction:column;align-items:stretch;gap:3px;background:var(--paper);border:1px solid var(--hair);border-radius:12px;padding:10px;box-shadow:0 20px 40px -20px #2b334066;transform:translateY(-8px) scale(.98);opacity:0;visibility:hidden;transition:.2s;min-width:200px}.nav.open{transform:none;opacity:1;visibility:visible}.menu-btn{display:flex}.navtools .clk-wrap,.detail{display:none}.dock{left:50%;transform:translate(-50%);width:min(360px,92vw);max-width:92vw;bottom:18px}}@media(prefers-reduced-motion:reduce){.node,.deco-rings:before,.deco-rings:after{animation:none}.flow{display:none}html{scroll-behavior:auto}}
