:root{--bg: #07080c;--bg-2: #0c0e15;--surface: rgba(255, 255, 255, .04);--surface-2: rgba(255, 255, 255, .06);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .16);--fg: #f4f4f6;--fg-2: #b9bcc7;--fg-3: #7e8392;--accent: #7c5cff;--accent-2: #22d3ee;--accent-3: #f472b6;--glow: 124, 92, 255;--code-bg: rgba(255, 255, 255, .03);--font-display: "Instrument Serif", "Times New Roman", serif;--font-sans: "Geist", "SF Pro Display", -apple-system, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", monospace;--r-sm: 10px;--r-md: 16px;--r-lg: 24px;--r-xl: 32px;--ease: cubic-bezier(.2, 0, .1, 1);--ease-out: cubic-bezier(.16, 1, .3, 1)}[data-theme=light]{--bg: #f7f6f2;--bg-2: #efece4;--surface: rgba(255, 255, 255, .6);--surface-2: rgba(255, 255, 255, .85);--border: rgba(20, 14, 38, .08);--border-strong: rgba(20, 14, 38, .16);--fg: #14122b;--fg-2: #43425a;--fg-3: #75748a;--accent: #5b3df5;--accent-2: #0891b2;--accent-3: #db2777;--glow: 91, 61, 245;--code-bg: rgba(20, 14, 38, .04)}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--fg);font-family:var(--font-sans);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;scroll-behavior:smooth}body{transition:background .6s var(--ease),color .4s var(--ease)}@media (hover: hover) and (pointer: fine){html,body,a,button,[role=button],input,textarea,[data-cursor]{cursor:none}}::selection{background:rgba(var(--glow),.35);color:var(--fg)}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;background:none;border:0}.shell{position:relative;max-width:1240px;margin:20px auto 0;padding:0 32px}@media (max-width: 720px){.shell{padding:0 20px}}section{padding:120px 0;position:relative}section+section{padding-top:60px}.italic{font-style:italic}.gradient-text{background:linear-gradient(110deg,var(--accent),var(--accent-2) 50%,var(--accent-3));-webkit-background-clip:text;background-clip:text;color:transparent}.eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-3);display:inline-flex;align-items:center;gap:8px}.eyebrow:before{content:"";width:28px;height:1px;background:var(--border-strong)}h1.display,h2.display{font-family:var(--font-display);font-weight:400;letter-spacing:-.03em;line-height:.95;color:var(--fg)}h1.display{font-size:clamp(56px,11vw,156px)}h2.display{font-size:clamp(40px,7vw,88px);line-height:.98}.lede{font-size:clamp(18px,1.5vw,22px);line-height:1.5;color:var(--fg-2);max-width:56ch;letter-spacing:-.01em}.mono{font-family:var(--font-mono);font-size:13px;color:var(--fg-3)}.glass{background:var(--surface);-webkit-backdrop-filter:blur(20px) saturate(140%);backdrop-filter:blur(20px) saturate(140%);border:1px solid var(--border);border-radius:var(--r-lg)}.section-head{display:grid;grid-template-columns:220px 1fr;gap:60px;margin-bottom:64px;align-items:start}.section-head .label{position:sticky;top:90px}@media (max-width: 880px){.section-head{grid-template-columns:1fr;gap:24px}.section-head .label{position:static}}.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}.reveal.in{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;transition-duration:.001ms!important}.hero h1 .line span{transform:none}.hero-bottom{opacity:1}.reveal{opacity:1;transform:none}}.aurora{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;background:var(--bg);overflow:hidden;pointer-events:none}.aurora:before{content:"";position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;background:radial-gradient(40% 30% at 18% 22%,rgba(124,92,255,.55),transparent 60%),radial-gradient(35% 28% at 82% 18%,rgba(34,211,238,.45),transparent 60%),radial-gradient(45% 40% at 60% 85%,rgba(244,114,182,.35),transparent 60%),radial-gradient(30% 30% at 10% 80%,rgba(124,92,255,.3),transparent 60%);filter:blur(60px) saturate(140%);animation:drift 24s linear infinite alternate}[data-theme=light] .aurora:before{background:radial-gradient(40% 30% at 18% 22%,rgba(124,92,255,.35),transparent 60%),radial-gradient(35% 28% at 82% 18%,rgba(8,145,178,.3),transparent 60%),radial-gradient(45% 40% at 60% 85%,rgba(219,39,119,.22),transparent 60%);opacity:.7}@keyframes drift{0%{transform:translate3d(-3%,-2%,0) rotate(0)}50%{transform:translate3d(2%,4%,0) rotate(8deg)}to{transform:translate3d(4%,-3%,0) rotate(-6deg)}}.grain{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;opacity:.06;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.6'/></svg>")}.cursor-dot,.cursor-ring{position:fixed;left:0;top:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);will-change:transform}.cursor-dot{width:6px;height:6px;border-radius:50%;background:var(--fg);mix-blend-mode:difference}.cursor-ring{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--fg);mix-blend-mode:difference;transition:width .28s var(--ease-out),height .28s var(--ease-out),border-color .2s var(--ease),background .2s var(--ease),opacity .2s var(--ease)}.cursor-ring.is-hover{width:64px;height:64px;background:rgba(var(--glow),.18);border-color:rgba(var(--glow),.6);mix-blend-mode:normal}.cursor-ring.is-text{width:4px;height:28px;border-radius:2px;background:var(--fg);mix-blend-mode:difference}.cursor-ring.is-down{width:24px;height:24px}@media (hover: none),(pointer: coarse){.cursor-dot,.cursor-ring{display:none}}.nav{position:fixed;top:18px;left:50%;transform:translate(-50%);z-index:100;display:flex;align-items:center;gap:6px;padding:8px;background:var(--surface-2);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--border);border-radius:999px;box-shadow:0 10px 40px #00000040}.nav a{font-size:13px;font-weight:500;letter-spacing:-.01em;padding:8px 14px;border-radius:999px;color:var(--fg-2);transition:color .2s var(--ease),background .2s var(--ease)}.nav a:hover{color:var(--fg);background:var(--surface)}.nav .brand{font-family:var(--font-display);font-size:16px;color:var(--fg);padding-left:12px}.nav .dot{width:6px;height:6px;border-radius:50%;background:#4ade80;box-shadow:0 0 12px #4ade80;margin-left:4px}@media (max-width: 720px){.nav .navlink{display:none}.nav .brand{padding-left:8px;padding-right:8px}}.theme-toggle{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:var(--surface);border:1px solid var(--border);color:var(--fg-2)}.theme-toggle:hover{color:var(--fg)}.hero{min-height:100vh;padding-block:140px 80px;display:flex;flex-direction:column;justify-content:center;position:relative}.hero h1 .line{display:block;overflow:hidden}.hero h1 .line span{display:inline-block;transform:translateY(110%);animation:rise 1.1s var(--ease-out) forwards;animation-delay:.1s}.hero-split{position:relative;padding-block:130px 90px;overflow:hidden}.hero-grid{margin-top:40px;display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center}.hero-text .hero-title{font-size:clamp(48px,6.4vw,92px);line-height:1.02;letter-spacing:-.03em;font-weight:300;margin:0}.hero-greet{font-style:italic;font-family:var(--font-display);font-weight:300;color:var(--fg-2);letter-spacing:-.02em}.name-strong{font-family:var(--font-display);font-style:italic;font-weight:400;color:var(--accent);position:relative;display:inline-block}.name-strong:after{content:"";position:absolute;left:0;right:0;bottom:.05em;height:.12em;background:var(--accent-2);opacity:.35;border-radius:2px;z-index:-1}.name-dot{font-family:var(--font-display);color:var(--accent-2);font-weight:400;margin-left:.02em}.hero-lede{margin-top:32px;font-size:clamp(16px,1.25vw,19px);max-width:46ch;color:var(--fg-2);line-height:1.55}.hero-tags{margin-top:28px;display:flex;flex-wrap:wrap;gap:10px 14px;font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;color:var(--fg-3);text-transform:uppercase}.hero-actions{margin-top:36px;display:flex;flex-wrap:wrap;gap:12px}.hero-portrait{position:relative;height:560px;display:flex;align-items:center;justify-content:center}.portrait-backdrop{position:absolute;top:8%;right:0;bottom:0;left:8%;border-radius:4px;overflow:hidden;z-index:0;opacity:.85;mask-image:linear-gradient(180deg,#000 50%,transparent 100%);-webkit-mask-image:linear-gradient(180deg,#000 50%,transparent 100%)}.halftone{width:100%;height:100%;display:block}.portrait-frame{position:relative;z-index:1;width:100%;max-width:540px;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;overflow:visible}.portrait-img{width:115%;height:auto;max-height:110%;object-fit:contain;filter:drop-shadow(0 30px 50px rgba(var(--glow),.35));transition:transform .6s var(--ease-out),filter .6s var(--ease-out)}.portrait-img:hover{transform:scale(1.03);filter:drop-shadow(0 40px 60px rgba(var(--glow),.5))}.portrait-blob{position:absolute;border-radius:999px;filter:blur(40px);opacity:.55;z-index:-1;pointer-events:none}.portrait-blob.blob-a{width:220px;height:220px;background:var(--accent-2);top:-40px;left:-50px;animation:blob-float 14s ease-in-out infinite}.portrait-blob.blob-b{width:180px;height:180px;background:var(--accent-3);bottom:-30px;right:-40px;animation:blob-float 18s ease-in-out infinite reverse}@keyframes blob-float{0%,to{transform:translate(0) scale(1)}50%{transform:translate(20px,-20px) scale(1.08)}}.portrait-arc{position:absolute;width:140%;height:140%;top:-20%;left:-20%;z-index:-1;animation:spin-slow 60s linear infinite}@keyframes spin-slow{to{transform:rotate(360deg)}}@media (max-width: 900px){.hero-grid{grid-template-columns:1fr;gap:40px}.hero-portrait{height:440px;order:-1}.hero-text .hero-title{font-size:clamp(44px,11vw,72px)}}.hero-meta{display:flex;gap:28px;flex-wrap:wrap;margin-bottom:36px;font-family:var(--font-mono);font-size:12px;color:var(--fg-3);letter-spacing:.05em;text-transform:uppercase}.hero-meta span{display:inline-flex;align-items:center;gap:8px}.hero-bottom{margin-top:64px;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:end;opacity:0;animation:fadeUp 1s .7s var(--ease-out) forwards}@media (max-width: 720px){.hero-bottom{grid-template-columns:1fr}}.scroll-cue{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-3);display:flex;flex-direction:column;align-items:center;gap:10px}.scroll-cue .bar{width:1px;height:40px;background:var(--border-strong);position:relative;overflow:hidden}.scroll-cue .bar:after{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:var(--fg);animation:scrollPulse 2s ease-in-out infinite}@keyframes rise{to{transform:translateY(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scrollPulse{0%{transform:translateY(-100%)}to{transform:translateY(200%)}}.about-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:start}@media (max-width: 880px){.about-grid{grid-template-columns:1fr}}.about-text p{font-size:20px;line-height:1.55;color:var(--fg-2);margin-bottom:20px;max-width:56ch;letter-spacing:-.005em}.about-text p strong{color:var(--fg);font-weight:500}.about-text p em{font-style:italic;color:var(--fg);font-family:var(--font-display);font-size:1.1em}.id-card{padding:28px;display:flex;flex-direction:column;gap:18px}.id-card .row{display:flex;justify-content:space-between;gap:20px;padding:12px 0;border-bottom:1px dashed var(--border);font-size:13px}.id-card .row:last-child{border-bottom:0}.id-card .row .k{color:var(--fg-3);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;font-size:11px}.id-card .row .v{color:var(--fg);font-weight:500}.timeline{position:relative}.tl-item{display:grid;grid-template-columns:160px 1fr;gap:40px;padding:32px 0;border-top:1px solid var(--border);position:relative;transition:padding .4s var(--ease)}.tl-item:last-child{border-bottom:1px solid var(--border)}.tl-item .when{font-family:var(--font-mono);font-size:12px;color:var(--fg-3);padding-top:6px;letter-spacing:.04em}.tl-item h3{font-size:26px;font-weight:500;letter-spacing:-.02em;color:var(--fg);margin-bottom:6px;font-family:var(--font-display)}.tl-item .company{font-size:14px;color:var(--fg-2);margin-bottom:16px;display:inline-flex;align-items:center;gap:10px}.tl-item .company .pill{padding:3px 10px;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-size:11px;font-family:var(--font-mono);color:var(--fg-3)}.tl-item ul{list-style:none}.tl-item ul li{font-size:15px;color:var(--fg-2);line-height:1.6;padding-left:18px;position:relative;margin-bottom:8px;max-width:64ch}.tl-item ul li:before{content:"";position:absolute;left:0;top:11px;width:6px;height:1px;background:var(--fg-3)}.tl-item .arrow{position:absolute;right:0;top:32px;width:40px;height:40px;border-radius:50%;border:1px solid var(--border);display:grid;place-items:center;transition:all .4s var(--ease);color:var(--fg-3)}.tl-item:hover .arrow{background:var(--fg);color:var(--bg);border-color:var(--fg);transform:rotate(-45deg)}@media (max-width: 720px){.tl-item{grid-template-columns:1fr;gap:12px;padding:28px 0}.tl-item .arrow{display:none}}.projects-list{display:flex;flex-direction:column;border-top:1px solid var(--border)}.proj{position:relative;display:grid;grid-template-columns:90px 1fr 1.2fr;gap:40px;padding:44px 8px;border-bottom:1px solid var(--border);align-items:start;transition:padding .5s var(--ease),background .4s var(--ease);cursor:none}.proj:before{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;background:linear-gradient(90deg,var(--accent),var(--accent-2),var(--accent-3));transform:scaleX(0);transform-origin:left;transition:transform .7s var(--ease-out);z-index:1}.proj:hover{padding-left:24px;padding-right:24px}.proj:hover:before{transform:scaleX(1)}.proj:hover .proj-sub{background:linear-gradient(110deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent;transition:color .4s var(--ease)}.proj:hover .proj-arrow{background:var(--fg);color:var(--bg);border-color:var(--fg);transform:rotate(-45deg) scale(1.1)}.proj:hover .proj-tags .tag{border-color:var(--border-strong);color:var(--fg)}.proj-num{font-family:var(--font-mono);font-size:13px;color:var(--fg-3);letter-spacing:.12em;padding-top:12px}.proj-head{grid-column:2/3;display:flex;align-items:flex-start;justify-content:space-between;gap:20px}.proj-title{font-family:var(--font-display);font-weight:400;font-size:clamp(36px,5vw,64px);line-height:.98;letter-spacing:-.025em;color:var(--fg);display:flex;flex-direction:column;gap:6px}.proj-sub{font-style:italic;font-size:.5em;color:var(--fg-3);letter-spacing:-.01em;font-weight:400}.proj-arrow{flex-shrink:0;width:44px;height:44px;border-radius:50%;border:1px solid var(--border);display:grid;place-items:center;color:var(--fg-3);transition:all .5s var(--ease-out)}.proj-meta{grid-column:3/4;display:grid;grid-template-columns:repeat(2,1fr);gap:16px 24px;padding-top:14px}.proj-meta>div{display:flex;flex-direction:column;gap:4px;padding-bottom:10px;border-bottom:1px dashed var(--border)}.proj-k{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-3)}.proj-v{font-size:14px;color:var(--fg);font-weight:500;letter-spacing:-.005em}.proj-blurb{grid-column:2/4;font-size:17px;color:var(--fg-2);line-height:1.55;max-width:70ch;margin-top:20px;letter-spacing:-.005em}.proj-tags{grid-column:2/4;display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.proj-tags .tag{font-family:var(--font-mono);font-size:11px;color:var(--fg-2);padding:5px 11px;border:1px solid var(--border);border-radius:999px;background:var(--surface);transition:all .3s var(--ease)}@media (max-width: 880px){.proj{grid-template-columns:1fr;gap:18px;padding:36px 0}.proj:hover{padding-left:0;padding-right:0}.proj-num,.proj-head,.proj-meta,.proj-blurb,.proj-tags{grid-column:1/-1}.proj-title{font-size:clamp(32px,7vw,48px)}.proj-meta{grid-template-columns:1fr 1fr;padding-top:0}.proj-blurb{margin-top:8px;font-size:15px}}.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}.marquee:hover .marquee-track{animation-play-state:paused}.marquee-track{display:flex;gap:16px;animation:scroll 40s linear infinite;width:max-content}@keyframes scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.skill-chip{flex-shrink:0;padding:14px 24px;border:1px solid var(--border);border-radius:999px;font-family:var(--font-mono);font-size:14px;background:var(--surface);color:var(--fg);display:inline-flex;align-items:center;gap:10px}.skill-chip .glyph{font-family:var(--font-display);font-style:italic;color:var(--accent-2);font-size:18px}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:32px}.skill-cat{padding:22px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface)}.skill-cat .h{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-3);margin-bottom:12px}.skill-cat ul{list-style:none;display:flex;flex-direction:column;gap:6px}.skill-cat li{font-size:14px;color:var(--fg)}.edu-card{padding:40px;display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.edu-card h3{font-family:var(--font-display);font-size:32px;font-weight:400;letter-spacing:-.02em}.edu-card .deg{color:var(--fg-2);margin-top:6px;font-size:15px}.edu-card .when{font-family:var(--font-mono);font-size:13px;color:var(--fg-3)}.edu-card .grade{font-family:var(--font-display);font-style:italic;font-size:24px;color:var(--accent-2)}@media (max-width: 720px){.edu-card{grid-template-columns:1fr;padding:28px}}.contact{padding:120px 0;text-align:center}.contact h2{font-family:var(--font-display);font-size:clamp(60px,12vw,180px);font-weight:400;letter-spacing:-.04em;line-height:.95;margin:0 auto 40px}.contact .em-link{font-family:var(--font-display);font-style:italic;background:linear-gradient(110deg,var(--accent),var(--accent-2),var(--accent-3));-webkit-background-clip:text;background-clip:text;color:transparent;position:relative;white-space:nowrap}.contact .em-link:after{content:"";position:absolute;left:0;right:0;bottom:.04em;height:2px;background:linear-gradient(110deg,var(--accent),var(--accent-2),var(--accent-3));transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease-out)}.contact .em-link:hover:after{transform:scaleX(1)}.contact-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:24px}.btn{padding:14px 24px;border-radius:999px;font-size:14px;font-weight:500;border:1px solid var(--border-strong);background:var(--surface-2);display:inline-flex;align-items:center;gap:10px;transition:all .3s var(--ease)}.btn:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}.btn.btn-primary{background:var(--fg);color:var(--bg)}.btn.btn-primary:hover{background:transparent;color:var(--fg);border-color:var(--fg)}.footer{padding:32px 0 40px;border-top:1px solid var(--border);display:flex;justify-content:space-between;flex-wrap:wrap;gap:20px;font-family:var(--font-mono);font-size:12px;color:var(--fg-3)}.footer .links{display:flex;gap:24px}.footer a:hover{color:var(--fg)}
