:root{--font-display:"Space Grotesk", "Inter", system-ui, sans-serif;--font-body:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Cascadia Code", Consolas, monospace;--max-width:68rem;--header-height:4.25rem;--radius:14px;--radius-sm:9px;--ease:cubic-bezier(.22, 1, .36, 1)}:root,:root[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#0b0f14;--bg-raised:#10161d;--surface:#ffffff08;--surface-hover:#ffffff0f;--border:#ffffff17;--border-strong:#ffffff2e;--text:#e9eef4;--text-muted:#93a1b0;--accent:#3be0b0;--accent-strong:#6ceac6;--accent-contrast:#04241a;--accent-2:#5ba8ff;--life-cell:#2fc9a0;--canvas-opacity:.55;--glow:0 0 32px #3be0b024;--header-bg:#0b0f14d1}:root[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f7f9fa;--bg-raised:#fff;--surface:#0b233309;--surface-hover:#0b233312;--border:#0b23331f;--border-strong:#0b233342;--text:#15202b;--text-muted:#51606e;--accent:#0c8a6a;--accent-strong:#0a7257;--accent-contrast:#fff;--accent-2:#2563eb;--life-cell:#11a47e;--canvas-opacity:.4;--glow:0 0 32px #0c8a6a1f;--header-bg:#f7f9fad9}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-height) + 1rem)}body{background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;margin:0;font-size:1.0625rem;line-height:1.7;transition:background-color .35s,color .35s}::selection{background:var(--accent);color:var(--accent-contrast)}h1,h2,h3{font-family:var(--font-display);text-wrap:balance;margin:0 0 .75em;line-height:1.15}p{margin:0 0 1em}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-strong)}img{max-width:100%;display:block}button{font:inherit;color:inherit}.mono{font-family:var(--font-mono);letter-spacing:.02em;font-size:.8125rem}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}.skip-link{z-index:100;background:var(--accent);color:var(--accent-contrast);border-radius:var(--radius-sm);padding:.5rem 1rem;transition:top .2s;position:absolute;top:-3rem;left:1rem}.skip-link:focus{top:1rem}.site-header{z-index:50;height:var(--header-height);border-bottom:1px solid #0000;align-items:center;gap:1.5rem;padding:0 clamp(1rem,4vw,2.5rem);transition:background-color .3s,border-color .3s;display:flex;position:fixed;inset:0 0 auto}.site-header.scrolled{background:var(--header-bg);border-bottom-color:var(--border);-webkit-backdrop-filter:blur(14px)}.brand{margin-right:auto}.brand-mark{font-family:var(--font-mono);color:var(--text);border:1px solid var(--border-strong);border-radius:var(--radius-sm);place-items:center;padding:.35rem .6rem;font-size:.9rem;font-weight:500;transition:border-color .2s,color .2s,box-shadow .2s;display:inline-grid}.brand:hover .brand-mark{color:var(--accent);border-color:var(--accent);box-shadow:var(--glow)}.site-nav{gap:1.75rem;display:flex}.site-nav a{color:var(--text-muted);font-size:.9375rem;font-weight:500;transition:color .2s}.site-nav a:hover{color:var(--text)}.theme-toggle{border:1px solid var(--border-strong);cursor:pointer;background:0 0;border-radius:50%;place-items:center;width:2.4rem;height:2.4rem;transition:border-color .2s,color .2s,transform .2s;display:grid}.theme-toggle:hover{color:var(--accent);border-color:var(--accent);transform:rotate(15deg)}:root[data-theme=dark] .icon-moon,:root[data-theme=light] .icon-sun{display:none}.hero{min-height:100svh;padding:calc(var(--header-height) + 2rem) clamp(1rem, 4vw, 2.5rem) 5rem;place-items:center;display:grid;position:relative;overflow:hidden}#life-canvas{width:100%;height:100%;opacity:var(--canvas-opacity);position:absolute;inset:0;-webkit-mask-image:linear-gradient(#000 0% 62%,#0000 96%);mask-image:linear-gradient(#000 0% 62%,#0000 96%)}#life-canvas.is-3d{opacity:.92}.hero-inner{text-align:center;max-width:52rem;position:relative}.hero-eyebrow{color:var(--accent);text-transform:uppercase;letter-spacing:.18em;margin-bottom:1.25rem}.hero-title{letter-spacing:-.025em;text-shadow:0 2px 24px var(--bg);margin-bottom:1.25rem;font-size:clamp(3.25rem,10vw,6.75rem);font-weight:700}.hero-tagline{color:var(--text-muted);text-wrap:balance;max-width:38ch;text-shadow:0 1px 12px var(--bg);margin:0 auto 2rem;font-size:clamp(1.125rem,2.2vw,1.375rem)}.hero-tagline strong{color:var(--text);font-weight:600}.hero-actions{flex-wrap:wrap;justify-content:center;gap:.9rem;display:flex}.hero-caption{width:max-content;max-width:calc(100vw - 2rem);color:var(--text-muted);align-items:center;gap:.9rem;margin:0;font-size:.75rem;display:flex;position:absolute;bottom:1.25rem;left:50%;transform:translate(-50%)}.reseed-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:999px;padding:.2rem .75rem;font-size:.75rem;transition:color .2s,border-color .2s}.reseed-btn:hover{color:var(--accent);border-color:var(--accent)}.btn{border-radius:var(--radius-sm);transition:transform .2s var(--ease), box-shadow .2s ease, background-color .2s ease, border-color .2s ease, color .2s ease;border:1px solid #0000;padding:.72rem 1.4rem;font-size:.9375rem;font-weight:600;line-height:1.4;display:inline-block}.btn:hover{transform:translateY(-2px)}.btn-primary{background:var(--accent);color:var(--accent-contrast)}.btn-primary:hover{background:var(--accent-strong);color:var(--accent-contrast);box-shadow:var(--glow)}.btn-ghost{border-color:var(--border-strong);color:var(--text);background:var(--surface);-webkit-backdrop-filter:blur(8px)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.metrics{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface)}.metrics-grid{max-width:var(--max-width);grid-template-columns:repeat(4,1fr);margin:0 auto;padding:0;display:grid}.metric{text-align:center;padding:2.25rem 1.5rem}.metric+.metric{border-left:1px solid var(--border)}.metric dt{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.8125rem}.metric dd{color:var(--text);margin:0 0 .35rem;font-size:clamp(1.9rem,3.5vw,2.6rem);font-weight:500;line-height:1}.metric-suffix{color:var(--accent);font-size:.6em}.section{max-width:var(--max-width);margin:0 auto;padding:clamp(4rem,9vw,7rem) clamp(1rem,4vw,2.5rem) 0}.section h2{letter-spacing:-.02em;align-items:baseline;gap:.9rem;font-size:clamp(1.75rem,4vw,2.4rem);display:flex}.section-num{color:var(--accent);font-size:.9rem}.section-sub{color:var(--text-muted);margin-top:-.5rem;margin-bottom:2.5rem}.about-layout{grid-template-columns:1fr 260px;align-items:start;gap:3rem;display:grid}.about-text p{max-width:62ch}.about-education{color:var(--text-muted);border-top:1px solid var(--border);margin-top:1.75rem;padding-top:1.25rem}.about-photo{margin:0;position:relative}.about-photo img{border-radius:var(--radius);border:1px solid var(--border-strong);width:100%;height:auto}.about-photo:after{content:"";border:1px solid var(--accent);border-radius:var(--radius);opacity:.35;z-index:-1;position:absolute;inset:.75rem -.75rem -.75rem .75rem}.timeline{border-left:1px solid var(--border);margin:0;padding:0 0 0 1.75rem;list-style:none}.timeline-item{padding-bottom:3rem;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-item:before{content:"";background:var(--accent);width:10px;height:10px;box-shadow:0 0 0 4px var(--bg), var(--glow);border-radius:50%;position:absolute;top:.45rem;left:calc(-1.75rem - 5.5px)}.timeline-date{color:var(--accent);margin-bottom:.4rem}.timeline-item h3{margin-bottom:.2rem;font-size:1.3rem}.timeline-org{color:var(--text-muted);margin-bottom:1rem;font-size:.9375rem}.timeline-item ul{color:var(--text-muted);margin:0 0 1.1rem;padding-left:1.2rem}.timeline-item ul li{margin-bottom:.45rem}.timeline-item ul li::marker{color:var(--accent)}.timeline-tags{color:var(--text-muted);opacity:.85}.projects-grid{grid-template-columns:repeat(2,1fr);gap:1.4rem;display:grid}.project-card,.teaching-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transform:perspective(900px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(var(--lift,0));transition:transform .25s var(--ease), border-color .3s ease, background-color .3s ease, box-shadow .3s ease;padding:1.85rem;position:relative}.project-card:after,.teaching-card:after{content:"";border-radius:inherit;background:radial-gradient(260px circle at var(--mx,50%) var(--my,50%), #3be0b014, transparent 70%);opacity:0;pointer-events:none;transition:opacity .3s;position:absolute;inset:0}.project-card:hover:after,.teaching-card:hover:after{opacity:1}.project-card:hover{--lift:-4px;border-color:var(--accent);background:var(--surface-hover);box-shadow:var(--glow)}.project-featured{background:linear-gradient(var(--bg-raised), var(--bg-raised)) padding-box, linear-gradient(120deg, var(--accent), var(--accent-2)) border-box;border:1px solid #0000;grid-column:1/-1}.project-featured:hover{background:linear-gradient(var(--bg-raised), var(--bg-raised)) padding-box, linear-gradient(120deg, var(--accent-strong), var(--accent-2)) border-box}.project-featured p:not(.project-meta):not(.project-tags){max-width:68ch}.project-meta{color:var(--accent);margin-bottom:.8rem}.project-card h3,.teaching-card h3{margin-bottom:.6rem;font-size:1.25rem}.project-featured h3{font-size:1.55rem}.project-card p,.teaching-card p{color:var(--text-muted);font-size:.9688rem}.project-tags{color:var(--text-muted);opacity:.8;margin-bottom:0}.project-tags+.project-link{margin-top:1rem}.project-link{margin-top:.4rem;font-size:.9375rem;font-weight:600;display:inline-block}.project-link:hover span{margin-left:.25rem}.project-link span{transition:margin-left .2s var(--ease);display:inline-block}.teaching-card{background:var(--surface)}.teaching-card p:not(.project-meta){max-width:72ch}.skills-grid{grid-template-columns:repeat(2,1fr);gap:2.25rem 3rem;display:grid}.skill-group h3{color:var(--accent);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.12em;margin-bottom:1rem;font-size:.85rem;font-weight:500}.chip-list{flex-wrap:wrap;gap:.55rem;margin:0;padding:0;list-style:none;display:flex}.chip-list li{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);border-radius:999px;padding:.32rem .85rem;font-size:.875rem;transition:border-color .2s,color .2s}.chip-list li:hover{border-color:var(--accent);color:var(--text)}.section-contact{text-align:center;padding-bottom:clamp(4rem,9vw,7rem)}.section-contact h2{justify-content:center}.contact-lead{color:var(--text-muted);max-width:42ch;margin:0 auto 2.25rem;font-size:1.15rem}.contact-links{flex-wrap:wrap;justify-content:center;gap:.9rem;display:flex}.site-footer{border-top:1px solid var(--border);text-align:center;color:var(--text-muted);padding:2rem clamp(1rem,4vw,2.5rem)}.site-footer p{margin:0;font-size:.78rem}html.js .reveal{opacity:0;transition:opacity .7s var(--ease), transform .7s var(--ease);transform:translateY(20px)}html.js .reveal.is-visible{opacity:1;transform:none}@media (width<=880px){.metrics-grid{grid-template-columns:repeat(2,1fr)}.metric:nth-child(3){border-left:none}.metric:nth-child(n+3){border-top:1px solid var(--border)}.about-layout{grid-template-columns:1fr}.about-photo{order:-1;max-width:240px}.projects-grid,.skills-grid{grid-template-columns:1fr}}@media (width<=660px){.site-nav,.hero-caption span:first-child{display:none}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}html.js .reveal{opacity:1;transform:none}}.ch{display:contents}#cinema-canvas,.cine-rail,.cine-scrollcue{display:none}html.cinema{scroll-behavior:smooth}html.cinema body{background:0 0}html.cinema #cinema-canvas{z-index:0;width:100%;height:100%;animation:1.6s ease-out both cine-fade-in;display:block;position:fixed;inset:0}@keyframes cine-fade-in{0%{opacity:0}to{opacity:1}}html.cinema main{z-index:1;position:relative}html.cinema[data-theme=dark] body:after{content:"";z-index:2;pointer-events:none;background:radial-gradient(#0000 55%,#02040761 100%);position:fixed;inset:0}html.cinema .ch{display:block;position:relative}html.cinema .ch:after{content:"";height:75vh;display:block}html.cinema .ch[data-ch=boot]:after{height:110vh}html.cinema .ch[data-ch=signal]:after{height:150vh}html.cinema .ch[data-ch=touchdown]:after{height:170vh}html.cinema .ch>.section,html.cinema .ch>.hero{will-change:opacity, transform}html.cinema .ch[data-ch=signal]>*,html.cinema .ch[data-ch=network]>*,html.cinema .ch[data-ch=touchdown]>*{position:sticky;top:clamp(4.75rem,13vh,9rem)}html.cinema .ch>.section{background:color-mix(in srgb, var(--bg) 74%, transparent);-webkit-backdrop-filter:blur(16px)saturate(1.25);border:1px solid var(--border);border-radius:var(--radius);width:min(620px,92vw);max-width:none;margin-left:clamp(1.25rem,7vw,6.5rem);margin-right:0;padding:2.1rem 2.3rem;box-shadow:0 24px 70px #00000059}html[data-theme=light].cinema .ch>.section{box-shadow:0 24px 70px #0b23331f}html.cinema .ch[data-ch=touchdown]>.section{text-align:center;margin-left:auto;margin-right:auto}html.cinema .ch[data-ch=touchdown] .contact-links{justify-content:center}html.cinema .reveal{opacity:1!important;transition:none!important;transform:none!important}html.cinema .project-card,html.cinema .teaching-card{transform:none!important}html.cinema .ch[data-ch=boot]>.hero{background:0 0;min-height:100vh}html.cinema #life-canvas,html.cinema .hero-caption{display:none}html.cinema .cine-scrollcue{letter-spacing:.22em;text-transform:uppercase;color:var(--text-muted);align-items:center;gap:.6rem;font-size:.72rem;display:flex;position:absolute;bottom:2.2rem;left:50%;transform:translate(-50%)}html.cinema .cine-scrollcue .cue-arrow{animation:cue-bob 2.1s var(--ease) infinite;color:var(--accent);display:inline-block}@keyframes cue-bob{0%,to{opacity:.55;transform:translateY(0)}50%{opacity:1;transform:translateY(7px)}}html.cinema .cine-rail{z-index:3;flex-direction:column;gap:1.1rem;display:flex;position:fixed;top:50%;right:clamp(.9rem,2.2vw,2rem);transform:translateY(-50%)}html.cinema .cine-rail-track{background:var(--border);width:1px;position:absolute;top:-1rem;bottom:-1rem;right:4px}html.cinema .cine-rail-fill{background:linear-gradient(var(--accent), var(--accent-2));width:100%;height:0%;position:absolute;top:0;left:0}html.cinema .cine-rail a{color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.16em;text-transform:uppercase;opacity:.6;transition:opacity .3s var(--ease), color .3s var(--ease);justify-content:flex-end;align-items:center;gap:.55rem;font-size:.62rem;text-decoration:none;display:flex}html.cinema .cine-rail a .rail-label{opacity:0;transition:opacity .3s var(--ease), transform .3s var(--ease);transform:translate(6px)}html.cinema .cine-rail a .rail-dot{border:1px solid var(--border-strong);width:9px;height:9px;transition:background .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease);background:0 0;border-radius:50%}html.cinema .cine-rail a:hover,html.cinema .cine-rail a.is-active{opacity:1;color:var(--text)}html.cinema .cine-rail a:hover .rail-label,html.cinema .cine-rail a.is-active .rail-label{opacity:1;transform:translate(0)}html.cinema .cine-rail a.is-active .rail-dot{background:var(--accent);border-color:var(--accent);box-shadow:0 0 12px var(--accent)}@media (width<=760px){html.cinema .cine-rail .rail-label{display:none}}html.cinema .site-footer{z-index:1;position:relative}@media (width<=760px){html.cinema .ch>.section{background:color-mix(in srgb, var(--bg) 88%, transparent);-webkit-backdrop-filter:none;width:min(560px,94vw);margin-left:auto;margin-right:auto;padding:1.5rem 1.3rem}html.cinema .ch:after{height:55vh}}
