:root{--bg: oklch(.165 .006 264);--bg-2: oklch(.205 .007 264);--bg-3: oklch(.235 .008 264);--text: oklch(.945 .004 250);--muted: oklch(.64 .006 255);--faint: oklch(.5 .006 255);--line: oklch(.32 .007 264);--line-soft: oklch(.27 .007 264);--accent: oklch(.82 .14 78);--accent-fg: oklch(.18 .02 70);--accent-fg-2: oklch(.25 .04 70);--accent-dim: color-mix(in oklch, var(--accent) 16%, transparent);--nav-bg: oklch(.165 .006 264 / .72);--body-soft: oklch(.86 .005 250);--body-softer: oklch(.82 .005 250);--body-skill: oklch(.85 .005 250);--sans: "Space Grotesk", system-ui, sans-serif;--mono: "JetBrains Mono", ui-monospace, monospace;--shell: 1120px}:root[data-theme=light]{--bg: oklch(.96 .015 75);--bg-2: oklch(.93 .022 70);--bg-3: oklch(.89 .028 70);--text: oklch(.21 .04 50);--muted: oklch(.36 .05 55);--faint: oklch(.46 .05 60);--line: oklch(.78 .04 70);--line-soft: oklch(.85 .03 70);--accent: oklch(.46 .16 42);--accent-fg: oklch(.98 .015 75);--accent-fg-2: oklch(.98 .015 75);--accent-dim: color-mix(in oklch, var(--accent) 14%, transparent);--nav-bg: oklch(.96 .015 75 / .78);--body-soft: oklch(.3 .04 55);--body-softer: oklch(.32 .04 55);--body-skill: oklch(.3 .04 55)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;transition:background-color .2s ease,color .2s ease}a{color:inherit;text-decoration:none}.mono{font-family:var(--mono)}.accent{color:var(--accent)}.muted{color:var(--muted)}.shell{width:100%;max-width:var(--shell);margin:0 auto;padding:0 32px}.showcase-tag{position:fixed;top:84px;right:0;z-index:40;display:flex;flex-direction:column;gap:2px;padding:10px 16px 10px 14px;background:var(--accent);color:var(--accent-fg);border-radius:6px 0 0 6px;font-family:var(--mono);box-shadow:-6px 8px 24px #00000059;transition:transform .25s ease}.showcase-tag:hover{transform:translate(-4px)}.showcase-tag-kicker{font-size:10px;font-weight:600;letter-spacing:.12em;opacity:.7}.showcase-tag-label{font-size:13px;font-weight:600;letter-spacing:.02em}.nav{position:fixed;top:0;left:0;right:0;z-index:50;backdrop-filter:blur(14px);background:var(--nav-bg);border-bottom:1px solid var(--line-soft)}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px}.nav-brand{display:flex;align-items:center;gap:10px;font-family:var(--mono)}.nav-brand-mark{font-weight:600;font-size:16px}.nav-brand-slash{color:var(--accent);font-weight:600}.nav-status{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--muted);padding-left:12px;margin-left:2px;border-left:1px solid var(--line)}.nav-links{display:flex;align-items:center;gap:26px}.nav-link{font-family:var(--mono);font-size:13px;color:var(--muted);display:inline-flex;align-items:baseline;gap:6px;transition:color .18s ease;background:none;border:0;cursor:pointer}.nav-link:hover,.nav-link[aria-current=true]{color:var(--text)}.nav-link-num{font-size:10px;color:var(--faint)}.nav-link--showcase{color:var(--accent)}.nav-link--showcase:hover{color:var(--accent);opacity:.8}.nav-theme{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--line);border-radius:8px;background:transparent;color:var(--muted);cursor:pointer;transition:color .18s ease,border-color .18s ease}.nav-theme:hover{color:var(--text);border-color:var(--accent)}.nav-theme svg{width:16px;height:16px}.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}.nav-toggle span{width:22px;height:2px;background:var(--text);transition:.25s}.hero{padding-top:112px;padding-bottom:88px;position:relative;border-bottom:1px solid var(--line-soft)}.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(620px 380px at 78% 8%,var(--accent-dim),transparent 70%),linear-gradient(transparent 0,transparent calc(100% - 1px));pointer-events:none}.hero-shell{position:relative}.hero-name{font-family:var(--mono);font-size:13px;letter-spacing:.04em;color:var(--faint);text-transform:lowercase}.hero-pitch{margin-top:18px;font-size:clamp(38px,6.4vw,76px);line-height:1.04;font-weight:600;letter-spacing:-.025em;max-width:16ch}.hero-pitch .accent{display:inline-block;transition:opacity .32s ease,filter .32s ease,transform .32s ease}.hero-pitch .muted{font-size:clamp(20px,2.6vw,30px);font-weight:500;letter-spacing:-.01em}.hero-meta{margin-top:44px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft);border-radius:12px;overflow:hidden}.hero-meta-item{background:var(--bg);padding:18px 20px;display:flex;flex-direction:column;gap:7px}.hero-meta-key{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}.hero-meta-val{font-size:15px;color:var(--text)}.hero-links{margin-top:28px;display:flex;flex-wrap:wrap;gap:10px}.hero-link{display:inline-flex;flex-direction:column;gap:3px;padding:12px 18px;border:1px solid var(--line);border-radius:10px;background:var(--bg-2);transition:border-color .18s ease,transform .18s ease,background .18s ease}.hero-link:hover{border-color:var(--accent);transform:translateY(-2px)}.hero-link-key{font-family:var(--mono);font-size:11px;color:var(--faint)}.hero-link-val{font-size:14px;font-weight:500;display:inline-flex;align-items:center;gap:6px}.hero-link-arrow{color:var(--accent);font-size:12px}.hero-link--primary{background:var(--accent);border-color:var(--accent)}.hero-link--primary .hero-link-key{color:var(--accent-fg-2)}.hero-link--primary .hero-link-val,.hero-link--primary .hero-link-arrow{color:var(--accent-fg)}.section{padding:92px 0;border-bottom:1px solid var(--line-soft)}.section-num{display:flex;align-items:center;gap:20px;margin-bottom:52px;font-weight:500}.section-num-num{font-family:var(--mono);font-size:13px;color:var(--accent)}.section-num-line{flex:0 0 56px;height:1px;background:var(--line)}.section-num-label{font-family:var(--mono);font-size:14px;letter-spacing:.04em;text-transform:lowercase;color:var(--muted)}.lead{font-size:clamp(18px,2.1vw,22px);line-height:1.5;letter-spacing:-.01em;max-width:52ch}.lead .accent{color:var(--accent)}.b-list{margin-top:32px;display:flex;flex-direction:column;gap:20px}.b-item{position:relative;padding-left:24px;font-size:17.5px;line-height:1.55;color:var(--body-soft);max-width:62ch}.b-item b{font-weight:600;color:var(--text)}.b-item:before{content:"";position:absolute;left:0;top:12px;width:7px;height:7px;border-radius:50%;background:var(--accent)}.proj-list{display:flex;flex-direction:column;gap:28px}.proj-row{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line-soft);border-radius:16px;overflow:hidden;background:var(--bg-2);cursor:pointer;transition:border-color .22s ease,transform .22s ease}.proj-row:hover{border-color:var(--line);transform:translateY(-3px)}.proj-row[data-flip=true] .proj-media{order:2}.proj-media{position:relative;min-height:320px;background:var(--bg-3);display:flex;align-items:center;justify-content:center;border-right:1px solid var(--line-soft);overflow:hidden}.proj-row[data-flip=true] .proj-media{border-right:0;border-left:1px solid var(--line-soft)}.proj-media img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .35s ease}.proj-row:hover .proj-media img{transform:scale(1.03)}.proj-body{padding:38px 40px;display:flex;flex-direction:column}.proj-year{font-size:12px;color:var(--faint);letter-spacing:.04em}.proj-name{margin-top:10px;font-size:30px;font-weight:600;letter-spacing:-.02em;display:inline-flex;align-items:center;gap:8px}.proj-arrow{color:var(--accent);font-size:18px;transition:transform .2s ease}.proj-row:hover .proj-arrow{transform:translate(3px,-3px)}.proj-url{margin-top:5px;font-size:12.5px;color:var(--muted)}.proj-tagline{margin-top:16px;color:var(--body-softer);max-width:46ch;font-size:15.5px}.proj-stack{margin-top:20px;display:flex;flex-wrap:wrap;gap:7px}.proj-stack-chip{font-family:var(--mono);font-size:11.5px;padding:4px 10px;border:1px solid var(--line);border-radius:100px;color:var(--muted)}.proj-metrics{margin-top:auto;padding-top:26px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.proj-metric dt{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);margin-bottom:5px}.proj-metric dd{font-size:13.5px;font-weight:500;line-height:1.35}.skills-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft);border-radius:14px;overflow:hidden}.skill-group{background:var(--bg);padding:24px 22px}.skill-group-name{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--mono);font-size:12px;color:var(--accent);margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--line-soft)}.skill-group-name span:last-child{color:var(--faint)}.skill-items{list-style:none;display:flex;flex-direction:column;gap:10px}.skill-items li{font-size:14px;color:var(--body-skill)}.certs{margin-top:44px}.certs-head{display:flex;align-items:baseline;gap:10px;margin-bottom:18px}.certs-title{font-family:var(--mono);font-size:13px;color:var(--muted);letter-spacing:.04em}.certs-issuer{font-family:var(--mono);font-size:12px;color:var(--faint)}.certs-issuer:before{content:"· "}.cert-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.cert-card{display:flex;flex-direction:column;gap:12px;padding:20px;border:1px solid var(--line-soft);border-radius:12px;background:var(--bg-2);transition:border-color .18s ease,transform .18s ease}.cert-card:hover{border-color:var(--accent);transform:translateY(-2px)}.cert-issuer{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}.cert-name{font-size:16px;font-weight:600;line-height:1.3;letter-spacing:-.01em}.cert-foot{margin-top:auto;display:flex;justify-content:space-between;align-items:baseline;padding-top:8px}.cert-date{font-family:var(--mono);font-size:12px;color:var(--faint)}.cert-verify{font-family:var(--mono);font-size:12px;color:var(--muted);transition:color .18s ease}.cert-card:hover .cert-verify{color:var(--accent)}.exp-row,.edu-block{display:grid;grid-template-columns:200px 1fr;gap:32px;padding:28px 0;border-top:1px solid var(--line-soft)}.exp-period{font-family:var(--mono);font-size:13px;color:var(--muted)}.exp-role,.edu-school{font-size:21px;font-weight:600;letter-spacing:-.01em}.exp-company{font-family:var(--mono);font-size:13px;color:var(--accent);margin-top:4px}.exp-dek{color:var(--muted);font-size:14px;line-height:1.5;margin-top:7px;margin-bottom:18px;max-width:66ch}.inline-link{color:var(--accent);font-family:var(--mono);font-size:.92em;border-bottom:1px solid var(--accent-dim);transition:border-color .18s ease}.inline-link:hover{border-color:var(--accent)}.exp-bullets{list-style:none;display:flex;flex-direction:column;gap:10px}.exp-bullets li{position:relative;padding-left:22px;color:var(--body-softer);font-size:15px;max-width:64ch}.exp-bullets li:before{content:"→";position:absolute;left:0;color:var(--accent)}.edu-degree{color:var(--muted);margin-top:6px}.exp-venues{margin-top:24px;border-top:1px solid var(--line-soft)}.venue{display:grid;grid-template-columns:1fr auto;gap:10px 28px;align-items:baseline;padding:16px 0;border-bottom:1px solid var(--line-soft)}.venue-name{font-size:15px;font-weight:600}.venue-tag{font-family:var(--mono);font-size:11.5px;color:var(--faint);margin-left:10px;letter-spacing:.01em}.venue-desc{color:var(--muted);font-size:13.5px;line-height:1.5;margin-top:5px;max-width:62ch}.venue-date{font-family:var(--mono);font-size:12px;color:var(--muted);white-space:nowrap;text-align:right}.contact-block{display:flex;flex-direction:column}.contact-pitch{font-size:clamp(26px,3.6vw,44px);font-weight:600;letter-spacing:-.02em;max-width:20ch;line-height:1.12}.contact-email{margin-top:40px;display:inline-flex;align-items:center;justify-content:space-between;gap:20px;align-self:flex-start;padding:20px 30px;border:1px solid var(--line);border-radius:14px;font-size:clamp(18px,2.4vw,26px);font-weight:500;transition:border-color .2s ease,background .2s ease}.contact-email:hover{border-color:var(--accent);background:var(--accent-dim)}.contact-email .mono{color:var(--accent);font-size:16px}.contact-main{display:grid;grid-template-columns:auto 1fr;gap:46px;align-items:center}.portrait{position:relative;overflow:hidden;background:var(--bg-3)}.portrait img{display:block;width:100%;height:100%;object-fit:cover}.contact-portrait{width:158px;height:158px;border-radius:18px;border:1px solid var(--line);flex:none}.contact-main .contact-email{margin-top:26px}.footer{padding:40px 0 56px}.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-family:var(--mono);font-size:12.5px;color:var(--faint)}.footer-inner a{transition:color .18s ease}.footer-inner a:hover{color:var(--text)}.fade-up,.reveal{opacity:1;transform:none}@media (prefers-reduced-motion: no-preference){.fade-up{transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}body.preload .fade-up{opacity:0;transform:translateY(18px)}.reveal{transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}.reveal.pre:not(.in){opacity:0;transform:translateY(24px)}}.showcase{min-height:100vh;background:var(--bg);color:var(--text);display:flex;flex-direction:column}.showcase-head{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);background:var(--nav-bg);border-bottom:1px solid var(--line-soft)}.showcase-head-inner{display:flex;align-items:center;justify-content:space-between;height:64px}.showcase-back{font-family:var(--mono);font-size:13px;color:var(--muted);transition:color .18s ease}.showcase-back:hover{color:var(--text)}.showcase-title{font-family:var(--mono);font-size:13px;color:var(--text);letter-spacing:.04em}.showcase-title-key{color:var(--accent)}.showcase-title-tag{display:inline-block;margin-left:10px;padding:3px 10px;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--accent-fg);background:var(--accent);border-radius:100px;vertical-align:middle}.showcase-tabs{border-bottom:1px solid var(--line-soft);background:var(--bg)}.showcase-tabs-inner{display:flex;gap:4px;height:56px;align-items:stretch;overflow-x:auto}.showcase-tab{background:none;border:0;border-bottom:2px solid transparent;color:var(--muted);font-family:var(--mono);font-size:13px;letter-spacing:.01em;padding:0 18px;cursor:pointer;white-space:nowrap;transition:color .18s ease,border-color .18s ease}.showcase-tab:hover{color:var(--text)}.showcase-tab.is-active{color:var(--accent);border-bottom-color:var(--accent)}.showcase-stage{position:relative;flex:1;min-height:520px;background:var(--bg-2);border-bottom:1px solid var(--line-soft)}.showcase-stage canvas{display:block;width:100%!important;height:100%!important}.showcase-info{padding:36px 0 56px}.showcase-info-inner{display:flex;flex-direction:column;gap:10px}.showcase-info-label{font-size:12px;color:var(--accent);letter-spacing:.05em}.showcase-info-blurb{font-size:17px;line-height:1.55;color:var(--text);max-width:64ch}.showcase-info-tools{margin-top:8px;font-size:12px;color:var(--faint);letter-spacing:.04em}.showcase-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;font-family:var(--mono);color:var(--muted);background:var(--bg)}@media (max-width: 880px){body{font-size:16px}.nav-toggle{display:flex}.nav-status{display:none}.nav-links{position:absolute;top:64px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:0;background:var(--bg-2);border-bottom:1px solid var(--line);padding:0 32px 16px;max-height:0;overflow:hidden;transition:max-height .3s ease}.nav-links[data-open=true]{max-height:520px}.nav-link{width:100%;padding:16px 0;border-bottom:1px solid var(--line-soft)}.nav-theme{margin-top:12px;align-self:flex-start}.hero-meta,.proj-row,.proj-row[data-flip=true] .proj-media{grid-template-columns:1fr}.proj-media{min-height:220px;border-right:0;border-bottom:1px solid var(--line-soft);order:0!important;border-left:0!important}.proj-metrics{grid-template-columns:repeat(3,1fr)}.skills-grid{grid-template-columns:repeat(2,1fr)}.exp-row,.edu-block{grid-template-columns:1fr;gap:12px}.showcase-tag{top:72px}.showcase-stage{min-height:420px}}@media (max-width: 760px){.cert-grid{grid-template-columns:1fr}}@media (max-width: 640px){.venue{grid-template-columns:1fr;gap:4px}.venue-date{text-align:left}.venue-tag{display:block;margin-left:0;margin-top:3px}.contact-main{grid-template-columns:1fr;gap:28px}}@media (max-width: 520px){.shell{padding:0 20px}.proj-body{padding:28px 24px}.proj-metrics{grid-template-columns:1fr;gap:12px}.skills-grid{grid-template-columns:1fr}}
