:root{--accent:#d97757;--accent-soft:color-mix(in oklab,var(--accent) 18%,transparent);--bg:#f4efe8;--bg-elev:#ebe5dc;--bg-sink:#ece6dd;--fg:#1a1512;--fg-muted:#6b5e52;--fg-faint:#9a8c7e;--line:#d9d1c4;--line-strong:#c4b9a8;--shadow:0 1px 0 rgba(26,21,18,0.04),0 8px 30px -12px rgba(26,21,18,0.12);--radius:14px;--radius-sm:8px;--font-display:"Instrument Serif","Times New Roman",serif;--font-body:"Geist",ui-sans-serif,system-ui,-apple-system,"Helvetica Neue",Arial,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;--motion:1;--dur-fast:calc(180ms / (0.5 + 0.5 * var(--motion)));--dur-mid:calc(420ms / (0.5 + 0.5 * var(--motion)));--dur-slow:calc(900ms / (0.5 + 0.5 * var(--motion)));--ease:cubic-bezier(0.2,0.7,0.2,1);color-scheme:light}[data-theme=dark]{--bg:#110e0c;--bg-elev:#191512;--bg-sink:#0c0a09;--fg:#f0e9df;--fg-muted:#a89c8e;--fg-faint:#70655a;--line:#2a231e;--line-strong:#3a3028;--shadow:0 1px 0 rgba(0,0,0,0.4),0 8px 30px -12px rgba(0,0,0,0.5);color-scheme:dark}[data-accent=terracotta]{--accent:#d97757}[data-accent=electric]{--accent:#2f4cff}[data-accent=lime]{--accent:#c9ff3a}[data-accent=forest]{--accent:#1b4b3a}[data-accent=ember]{--accent:#ff5b1f}[data-accent=bone]{--accent:#e8e6e0}*{box-sizing:border-box}body,html{margin:0;padding:0}html{scroll-behavior:smooth}body,html{background:var(--bg)}body{font-family:var(--font-body);color:var(--fg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.55;letter-spacing:-.005em;overflow-x:hidden;transition:background-color .4s var(--ease),color .4s var(--ease)}::selection{background:var(--accent);color:var(--bg)}.serif{font-family:var(--font-display);font-weight:400;letter-spacing:-.02em}.mono{font-family:var(--font-mono);font-feature-settings:"zero","ss01"}a{color:inherit;text-decoration:none}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 32px}@media (max-width:720px){.container{padding:0 20px}}.nav{position:fixed;top:0;left:0;right:0;z-index:50;padding:18px 0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:color-mix(in oklab,var(--bg) 72%,transparent);border-bottom:1px solid transparent;transition:border-color .3s var(--ease),background .3s var(--ease)}.nav.scrolled{border-bottom-color:var(--line)}.nav-inner{justify-content:space-between;gap:24px}.nav-inner,.nav-logo{display:flex;align-items:center}.nav-logo{gap:10px;font-family:var(--font-mono);font-size:13px;font-weight:500}.nav-logo .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);animation:pulse 2.4s var(--ease) infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.nav-links{display:flex;gap:4px;align-items:center}.nav-links a{position:relative;font-family:var(--font-mono);font-size:12px;padding:8px 12px;border-radius:6px;color:var(--fg-muted);transition:color .2s var(--ease),background .2s var(--ease)}.nav-links a:hover{color:var(--fg);background:var(--bg-elev)}.nav-links .counter{color:var(--fg-faint);margin-right:4px}.nav-right{display:flex;gap:8px;align-items:center}.icon-btn{width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--line);border-radius:8px;background:transparent;color:var(--fg-muted);cursor:pointer;transition:all .2s var(--ease)}.icon-btn:hover{color:var(--fg);border-color:var(--line-strong);background:var(--bg-elev)}.icon-btn svg{width:16px;height:16px}@media (max-width:720px){.nav-links{display:none}}.hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;align-items:center;padding:120px 0 80px;overflow:hidden}.hero-canvas,.hero-grid-bg{position:absolute;inset:0;pointer-events:none;z-index:0}.hero-grid-bg{background-image:linear-gradient(to right,var(--line) 1px,transparent 1px),linear-gradient(to bottom,var(--line) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(ellipse at 50% 40%,black 20%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at 50% 40%,black 20%,transparent 70%);opacity:.4}.hero-inner{position:relative;z-index:2;width:100%}.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:12px;color:var(--fg-muted);padding:6px 12px;border:1px solid var(--line);border-radius:100px;background:color-mix(in oklab,var(--bg-elev) 60%,transparent)}.hero-eyebrow .live{width:6px;height:6px;border-radius:50%;background:#36c76b;box-shadow:0 0 0 3px color-mix(in oklab,#36c76b 22%,transparent);animation:pulse 2.4s var(--ease) infinite}.hero-title{font-family:var(--font-display);font-size:clamp(54px,12vw,192px);line-height:.9;font-weight:400;letter-spacing:-.04em;margin:28px 0 24px}.hero-title .line{display:block;overflow:hidden}.hero-title .word{display:inline-block;transform:translateY(110%);animation:rise .9s var(--ease) forwards}.hero-title .line:nth-child(2) .word{animation-delay:80ms}.hero-title .line:nth-child(3) .word{animation-delay:.16s}@keyframes rise{to{transform:translateY(0)}}.hero-title .italic{font-style:italic;color:var(--accent)}.hero-sub{max-width:620px;font-size:18px;color:var(--fg-muted);line-height:1.6;margin:8px 0 40px}.hero-sub strong{color:var(--fg);font-weight:500}.hero-actions{display:flex;gap:12px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:13px;padding:13px 20px;border-radius:100px;border:1px solid var(--line-strong);background:transparent;color:var(--fg);cursor:pointer;transition:all .22s var(--ease)}.btn:hover{transform:translateY(-1px)}.btn.primary,.btn:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}.btn.primary:hover{background:var(--accent);border-color:var(--accent);color:var(--bg)}.btn .arrow{transition:transform .22s var(--ease)}.btn:hover .arrow{transform:translate(3px,-3px)}.hero-meta{position:absolute;bottom:32px;left:32px;right:32px;display:flex;justify-content:space-between;align-items:flex-end;z-index:2;font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);text-transform:uppercase;letter-spacing:.08em;pointer-events:none}.hero-meta .group{display:flex;flex-direction:column;gap:4px}.hero-meta .label{color:var(--fg-faint)}.hero-meta .value{color:var(--fg)}@media (max-width:720px){.hero-meta{left:20px;right:20px;bottom:20px;font-size:10px}.hero-meta .group.center,.hero-meta .group.right{display:none}}.section{padding:120px 0;position:relative}.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:64px;gap:40px;flex-wrap:wrap}.section-tag{font-family:var(--font-mono);font-size:12px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.12em;display:flex;align-items:center;gap:10px}.section-tag:before{content:"";width:24px;height:1px;background:var(--accent)}.section-title{font-family:var(--font-display);font-size:clamp(36px,5.5vw,72px);line-height:1;letter-spacing:-.03em;margin:12px 0 0;max-width:14ch}.section-title .italic{font-style:italic;color:var(--accent)}.about{padding:80px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.about-grid{display:grid;grid-template-columns:1fr 2fr;grid-gap:60px;gap:60px;align-items:start}.about-grid .label{font-family:var(--font-mono);font-size:12px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.12em}.about-text{font-family:var(--font-display);font-size:clamp(24px,3vw,36px);line-height:1.35;letter-spacing:-.02em;color:color-mix(in srgb,var(--fg) 85%,transparent)}.about-text em{color:var(--accent);font-style:italic}.about-text .company{color:var(--accent);font-weight:500}.about-stats{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:24px;gap:24px;margin-top:48px;padding-top:32px;border-top:1px solid var(--line)}.stat .num{font-family:var(--font-display);font-size:40px;line-height:1;letter-spacing:-.02em}.stat .lbl{font-family:var(--font-mono);font-size:11px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:8px}@media (max-width:820px){.about-grid{grid-template-columns:1fr;gap:24px}}.timeline-wrap{position:relative}.timeline-rail{position:absolute;left:140px;top:0;bottom:0;width:1px;background:var(--line)}.timeline-rail:before{content:"";position:absolute;left:0;top:0;width:1px;height:var(--progress,0);background:linear-gradient(to bottom,var(--accent),color-mix(in oklab,var(--accent) 20%,transparent));transition:height .12s linear}.timeline-item{position:relative;display:grid;grid-template-columns:140px 1fr;grid-gap:60px;gap:60px;padding:32px 0;opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease)}.timeline-item.visible{opacity:1;transform:translateY(0)}.timeline-item:not(:last-child){border-bottom:1px solid var(--line)}.timeline-date{font-family:var(--font-mono);font-size:12px;color:var(--fg-muted);padding-top:4px}.timeline-dot{position:absolute;left:136px;top:38px;width:9px;height:9px;border-radius:50%;background:var(--bg);border:1px solid var(--line-strong);transition:all .4s var(--ease);z-index:2}.timeline-item.visible .timeline-dot{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.timeline-body{padding-left:20px}.timeline-role{font-family:var(--font-display);font-size:clamp(24px,3vw,34px);line-height:1.1;letter-spacing:-.02em;margin:0 0 6px}.timeline-company{font-family:var(--font-mono);font-size:12px;color:var(--fg-muted);display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}.timeline-company .sep{opacity:.4}.timeline-desc{color:var(--fg-muted);max-width:62ch;line-height:1.6}.timeline-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:16px}.tag{font-family:var(--font-mono);font-size:10px;padding:4px 9px;border:1px solid var(--line);border-radius:100px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.08em}@media (max-width:720px){.timeline-rail{left:8px}.timeline-item{grid-template-columns:1fr;gap:8px;padding-left:36px}.timeline-dot{left:4px;top:42px}.timeline-body{padding-left:0}}.projects-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-gap:24px;gap:24px}.project{position:relative;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:28px;display:flex;flex-direction:column;gap:20px;min-height:340px;overflow:hidden;transition:transform .4s var(--ease),border-color .3s var(--ease),background .3s var(--ease);cursor:pointer}.project:hover{transform:translateY(-4px);border-color:var(--line-strong)}.project:after{content:"";position:absolute;inset:0;background:radial-gradient(300px circle at var(--mx,50%) var(--my,50%),var(--accent-soft),transparent 70%);opacity:0;transition:opacity .4s var(--ease);pointer-events:none}.project:hover:after{opacity:1}.project.span-7{grid-column:span 7}.project.span-5{grid-column:span 5}.project.span-6{grid-column:span 6}.project.span-4{grid-column:span 4}.project.span-8{grid-column:span 8}.project-head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;position:relative;z-index:2}.project-num{letter-spacing:.08em}.project-num,.project-year{font-family:var(--font-mono);font-size:11px;color:var(--fg-faint)}.project-visual{flex:1 1;margin:0 -4px;border-radius:var(--radius-sm);min-height:160px;position:relative;overflow:hidden;background:var(--bg-sink);border:1px solid var(--line)}.project-title{font-family:var(--font-display);font-size:30px;line-height:1.05;letter-spacing:-.02em;margin:0;position:relative;z-index:2}.project-desc{font-size:14px;color:var(--fg-muted);line-height:1.55;position:relative;z-index:2}.project-foot{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;position:relative;z-index:2}.project-stack{display:flex;gap:6px;flex-wrap:wrap}.project-cta{font-family:var(--font-mono);font-size:12px;display:inline-flex;align-items:center;gap:6px;color:var(--fg);opacity:.6;transition:opacity .2s var(--ease),gap .2s var(--ease)}.project:hover .project-cta{opacity:1;gap:10px}.project-cta svg{width:12px;height:12px}@media (max-width:960px){.projects-grid{grid-template-columns:repeat(6,1fr)}.project.span-4,.project.span-5,.project.span-6,.project.span-7,.project.span-8{grid-column:span 6}}.viz{position:absolute;inset:0}.viz-graph svg{width:100%;height:100%}.viz-bars{display:flex;align-items:flex-end;gap:4px;padding:20px;height:100%}.viz-bars span{flex:1 1;background:var(--accent);border-radius:2px;animation:bars 3.2s var(--ease) infinite;opacity:.85}.viz-bars span:nth-child(2){animation-delay:.2s;background:color-mix(in oklab,var(--accent) 70%,var(--fg))}.viz-bars span:nth-child(3){animation-delay:.4s}.viz-bars span:nth-child(4){animation-delay:.6s;background:color-mix(in oklab,var(--accent) 50%,var(--fg))}.viz-bars span:nth-child(5){animation-delay:.8s}.viz-bars span:nth-child(6){animation-delay:1s;background:color-mix(in oklab,var(--accent) 70%,var(--fg))}.viz-bars span:nth-child(7){animation-delay:1.2s}@keyframes bars{0%,to{height:30%}50%{height:90%}}.viz-rings{display:grid;place-items:center;height:100%}.viz-rings .r{position:absolute;border:1px solid var(--accent);border-radius:50%;animation:rings 4s var(--ease) infinite;opacity:0}.viz-rings .r:first-child{width:60px;height:60px;animation-delay:0s}.viz-rings .r:nth-child(2){width:60px;height:60px;animation-delay:1s}.viz-rings .r:nth-child(3){width:60px;height:60px;animation-delay:2s}.viz-rings .core{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 20px var(--accent)}@keyframes rings{0%{transform:scale(.3);opacity:.8}to{transform:scale(4.5);opacity:0}}.viz-terminal{padding:18px;font-family:var(--font-mono);font-size:11px;color:var(--fg-muted);line-height:1.7;background:var(--bg-sink)}.viz-terminal .prompt{color:var(--accent)}.viz-terminal .caret{display:inline-block;width:7px;height:12px;background:var(--fg);vertical-align:-1px;animation:caret 1s steps(2) infinite}@keyframes caret{50%{opacity:0}}.viz-code{padding:18px;font-family:var(--font-mono);font-size:11px;color:var(--fg-muted);line-height:1.7}.viz-code .k{color:var(--accent)}.viz-code .s{color:color-mix(in oklab,var(--fg) 60%,var(--accent))}.viz-grid-dots{background-image:radial-gradient(circle,var(--line-strong) 1px,transparent 1px);background-size:14px 14px;-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%);mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%)}.viz-grid-dots .blob{position:absolute;top:50%;left:50%;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,var(--accent),transparent 70%);transform:translate(-50%,-50%);filter:blur(20px);animation:float 6s var(--ease) infinite}@keyframes float{0%,to{transform:translate(-60%,-40%)}50%{transform:translate(-40%,-60%)}}.interests-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:24px;gap:24px}.interest{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:32px;min-height:380px;display:flex;flex-direction:column;gap:20px;transition:transform .4s var(--ease),border-color .3s var(--ease);position:relative;overflow:hidden}.interest:hover{transform:translateY(-4px);border-color:var(--line-strong)}.interest-head{display:flex;justify-content:space-between;align-items:flex-start}.interest-num{font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);letter-spacing:.08em}.interest-kind{font-family:var(--font-mono);font-size:10px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.1em}.interest-title{font-family:var(--font-display);font-size:38px;line-height:1;letter-spacing:-.02em;margin:0}.interest-desc{font-size:14px;color:var(--fg-muted);line-height:1.6}.interest-visual{flex:1 1;position:relative;border-radius:var(--radius-sm);overflow:hidden;min-height:140px}.chess-board{display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);height:100%;width:100%;border:1px solid var(--line-strong);border-radius:6px;overflow:hidden}.chess-board .sq{background:var(--bg)}.chess-board .sq.dark{background:var(--fg)}.chess-board .sq.hl{background:var(--accent)}.music-viz{display:flex;align-items:flex-end;gap:3px;padding:20px;height:100%}.music-viz span{flex:1 1;background:var(--fg);border-radius:1px;animation:eq 1.4s var(--ease) infinite}.music-viz span:nth-child(odd){background:var(--accent)}.music-viz span:first-child{animation-delay:0s}.music-viz span:nth-child(2){animation-delay:.1s}.music-viz span:nth-child(3){animation-delay:.2s}.music-viz span:nth-child(4){animation-delay:.05s}.music-viz span:nth-child(5){animation-delay:.15s}.music-viz span:nth-child(6){animation-delay:.25s}.music-viz span:nth-child(7){animation-delay:.08s}.music-viz span:nth-child(8){animation-delay:.18s}.music-viz span:nth-child(9){animation-delay:.12s}.music-viz span:nth-child(10){animation-delay:.22s}.music-viz span:nth-child(11){animation-delay:.04s}.music-viz span:nth-child(12){animation-delay:.14s}.music-viz span:nth-child(13){animation-delay:.24s}.music-viz span:nth-child(14){animation-delay:.06s}@keyframes eq{0%,to{height:20%}50%{height:95%}}.film-strip{height:100%;background:var(--bg-sink);border-radius:6px;padding:16px;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}.film-strip:after,.film-strip:before{content:"";position:absolute;left:0;right:0;height:10px;background-image:radial-gradient(circle,var(--bg) 3px,transparent 4px);background-size:18px 10px;background-repeat:repeat-x}.film-strip:before{top:0}.film-strip:after{bottom:0}.film-strip .reel{display:flex;gap:4px;animation:reel 14s linear infinite}.film-strip .frame{flex:0 0 80px;aspect-ratio:16/10;background:var(--bg-elev);border:1px solid var(--line);border-radius:2px;display:grid;place-items:center;font-family:var(--font-mono);font-size:9px;color:var(--fg-faint);text-align:center;padding:4px}.film-strip .frame.accent{background:var(--accent);color:var(--bg);border-color:var(--accent)}@keyframes reel{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.interest-meta{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:11px;color:var(--fg-muted);padding-top:14px;border-top:1px solid var(--line)}@media (max-width:960px){.interests-grid{grid-template-columns:1fr}}.contact{padding:140px 0 60px;position:relative;overflow:hidden}.contact-inner{position:relative;z-index:2}.contact-title{font-family:var(--font-display);font-size:clamp(60px,14vw,200px);line-height:.88;letter-spacing:-.04em;margin:0}.contact-title .italic{font-style:italic;color:var(--accent)}.contact-sub{max-width:540px;font-size:18px;color:var(--fg-muted);margin:32px 0;line-height:1.55}.contact-cta{display:inline-flex;align-items:center;gap:14px;font-family:var(--font-mono);font-size:14px;padding:18px 26px;border:1px solid var(--line-strong);border-radius:100px;background:var(--fg);color:var(--bg);transition:all .24s var(--ease)}.contact-cta:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-2px)}.contact-cta .arrow{transition:transform .24s var(--ease)}.contact-cta:hover .arrow{transform:translate(3px,-3px)}.contact-links{display:flex;gap:24px;flex-wrap:wrap;margin-top:48px;padding-top:40px;border-top:1px solid var(--line)}.contact-link{font-family:var(--font-mono);font-size:13px;color:var(--fg-muted);display:flex;align-items:center;gap:8px;transition:color .2s var(--ease)}.contact-link:hover{color:var(--accent)}.footer{padding:40px 0;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);text-transform:uppercase;letter-spacing:.08em;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px}.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}.reveal.visible{opacity:1;transform:translateY(0)}.marquee-wrap{overflow:hidden;padding:20px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-elev)}.marquee{display:flex;gap:60px;animation:marquee 40s linear infinite;width:max-content;font-family:var(--font-display);font-size:32px;letter-spacing:-.02em;color:var(--fg-muted);white-space:nowrap}.marquee span{display:inline-flex;align-items:center;gap:60px}.marquee .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block}@keyframes marquee{0%{transform:translateX(0)}to{transform:translateX(-50%)}}