:root{--bg: oklch(.96 .015 75);--bg-elev: oklch(.93 .022 70);--bg-card: oklch(.89 .028 70);--border: oklch(.78 .04 70);--border-strong: oklch(.62 .06 60);--fg: oklch(.21 .04 50);--fg-muted: oklch(.36 .05 55);--fg-dim: oklch(.46 .05 60);--accent: oklch(.46 .16 42);--accent-soft: oklch(.46 .16 42 / .14);--font-sans: "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;--font-serif: "Lora", "Iowan Old Style", Georgia, serif;--font-mono: "JetBrains Mono", "SF Mono", Menlo, Consolas, monospace;--r-sm: 4px;--r-md: 8px;--r-lg: 12px}*{box-sizing:border-box}html,body{margin:0;padding:0;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}body{min-height:100vh;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}::selection{background:var(--accent);color:var(--bg)}:focus{outline:none}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:5px}.shell{position:relative;z-index:1;max-width:1180px;margin:0 auto;padding:0 40px}.section{padding:clamp(72px,12vw,140px) 0;position:relative;border-top:1px solid var(--border)}.section:first-of-type{border-top:none}.section-num{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;color:var(--fg-dim);text-transform:uppercase;margin-bottom:56px;display:flex;align-items:baseline;gap:16px}.section-num:before{content:"";flex:0 0 auto;width:32px;height:1px;background:var(--fg-dim);display:inline-block;transform:translateY(-3px)}.mono{font-family:var(--font-mono)}.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .25s ease,border-color .25s ease,backdrop-filter .25s ease;border-bottom:1px solid transparent}.nav--scrolled{background:color-mix(in oklch,var(--bg) 78%,transparent);backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);border-bottom-color:var(--border)}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px;gap:32px}.nav-brand{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:13px;letter-spacing:.05em;color:var(--fg)}.nav-brand-mark{font-weight:600}.nav-brand-slash{color:var(--fg-dim)}.nav-status{display:inline-flex;align-items:center;gap:8px;color:var(--fg-muted)}.nav-status-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 var(--accent);animation:nav-pulse 2.4s infinite}@keyframes nav-pulse{0%,to{box-shadow:0 0 #b2511e80}50%{box-shadow:0 0 0 6px #b2511e00}}.nav-links{display:flex;gap:28px}.nav-link{font-family:var(--font-mono);font-size:12px;color:var(--fg-muted);letter-spacing:.02em;transition:color .15s ease;position:relative}.nav-link:hover,.nav-link[aria-current=true]{color:var(--fg)}.nav-link[aria-current=true] .nav-link-num{color:var(--accent)}.nav-link-num{color:var(--fg-dim);margin-right:6px}.nav-toggle{display:none;width:44px;height:44px;align-items:center;justify-content:center;flex-direction:column;gap:4px;padding:0;margin-right:-10px}.nav-toggle span{display:block;width:18px;height:1.5px;background:var(--fg);transition:transform .2s ease,opacity .2s ease}.nav-toggle[aria-expanded=true] span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}.nav-toggle[aria-expanded=true] span:nth-child(2){opacity:0}.nav-toggle[aria-expanded=true] span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}@media (max-width: 800px){.nav-toggle{display:inline-flex}.nav-links{position:absolute;top:64px;left:0;right:0;flex-direction:column;gap:0;background:color-mix(in oklch,var(--bg) 96%,transparent);backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);border-bottom:1px solid var(--border);padding:8px 40px 16px;transform:translateY(-12px);opacity:0;pointer-events:none;transition:transform .2s ease,opacity .2s ease}.nav-links[data-open=true]{transform:translateY(0);opacity:1;pointer-events:auto}.nav-link{padding:14px 0;font-size:14px;border-top:1px solid var(--border)}.nav-link:first-child{border-top:none}}.hero{min-height:100vh;padding-top:64px;display:flex;align-items:center;position:relative}.hero-shell{width:100%}.hero-status{display:inline-flex;align-items:center;gap:10px;padding:6px 12px 6px 10px;border:1px solid var(--border-strong);border-radius:100px;font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;color:var(--fg-muted);margin-bottom:40px}.hero-status-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}.hero-name{font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;color:var(--fg-dim);text-transform:uppercase;margin-bottom:24px}.hero-pitch{font-family:var(--font-serif);font-size:clamp(38px,5.5vw,68px);line-height:1.08;letter-spacing:-.02em;font-weight:500;margin:0 0 48px;max-width:920px;text-wrap:balance}.hero-pitch .accent{color:var(--accent)}.hero-pitch .muted{color:var(--fg-muted)}.hero-meta{display:flex;flex-wrap:wrap;gap:32px;font-family:var(--font-mono);font-size:13px;color:var(--fg-muted);margin-bottom:48px;padding-bottom:48px;border-bottom:1px solid var(--border)}.hero-meta-item{display:flex;gap:8px}.hero-meta-key{color:var(--fg-dim)}.hero-meta-val{color:var(--fg)}.hero-bottom{display:block;max-width:640px}.hero-links{display:flex;flex-direction:column;gap:4px}.hero-link{display:flex;align-items:baseline;justify-content:space-between;padding:14px 0;border-top:1px solid var(--border);font-family:var(--font-mono);font-size:13px;color:var(--fg);transition:padding .2s ease,color .15s ease}.hero-link:last-child{border-bottom:1px solid var(--border)}.hero-link:hover,.hero-link:focus-visible{color:var(--accent);padding-left:8px}.hero-link--primary{border-top-color:var(--accent);border-bottom:1px solid var(--accent);color:var(--accent);font-weight:500}.hero-link--primary .hero-link-key,.hero-link--primary .hero-link-arrow{color:var(--accent)}.hero-link-key{color:var(--fg-dim)}.hero-link-val{display:inline-flex;align-items:center;gap:8px}.hero-link-arrow{color:var(--fg-dim);transition:color .15s ease,transform .2s ease}.hero-link:hover .hero-link-arrow{color:var(--accent);transform:translate(2px,-2px)}.live-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;font-family:var(--font-mono);font-size:12px}.live-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;color:var(--fg-dim);letter-spacing:.06em;text-transform:uppercase}.live-card-title{display:flex;align-items:center;gap:8px}.live-card-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:nav-pulse 2.4s infinite}.live-card-row{display:flex;justify-content:space-between;padding:8px 0;border-top:1px dashed var(--border);color:var(--fg-muted)}.live-card-row strong{color:var(--fg);font-weight:500}.live-card-cta{margin-top:16px;display:inline-flex;align-items:center;gap:6px;color:var(--accent);font-size:11px}.about-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:80px;align-items:start}@media (max-width: 800px){.about-grid{grid-template-columns:1fr;gap:48px}}.about-bio p{font-size:22px;line-height:1.45;letter-spacing:-.01em;color:var(--fg);margin:0 0 24px;max-width:62ch;text-wrap:pretty}.about-bio p:last-child{margin-bottom:0;color:var(--fg-muted)}.glance-list{display:flex;flex-direction:column;margin:0;padding:0}.glance-row{display:flex;justify-content:space-between;align-items:baseline;padding:16px 0;border-top:1px solid var(--border);font-family:var(--font-mono);font-size:13px}.glance-row:last-child{border-bottom:1px solid var(--border)}.glance-key{color:var(--fg-dim);letter-spacing:.04em}.glance-val{color:var(--fg)}.proj-list{display:flex;flex-direction:column;gap:clamp(64px,9vw,120px)}.proj-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:center;cursor:pointer}.proj-row[data-flip=true] .proj-media{order:2}.proj-row:hover .proj-name,.proj-row:focus-visible .proj-name{color:var(--accent)}.proj-row:hover .proj-arrow,.proj-row:focus-visible .proj-arrow{color:var(--accent);transform:translate(4px,-4px)}.proj-row:hover .proj-media,.proj-row:focus-visible .proj-media{transform:translateY(-4px);border-color:var(--border-strong)}.proj-media{position:relative;aspect-ratio:16 / 10;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--bg-card);transition:transform .3s cubic-bezier(.2,.8,.2,1),border-color .2s ease}.proj-media img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}.proj-media-link{display:block;position:relative;width:100%;height:100%;cursor:pointer}.proj-media-link:after{content:"↗ visit live";position:absolute;top:12px;right:12px;font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;color:var(--bg);background:var(--accent);padding:4px 8px;border-radius:var(--r-sm);opacity:0;transform:translateY(-4px);transition:opacity .2s ease,transform .2s ease;pointer-events:none}.proj-row:hover .proj-media-link:after,.proj-media-link:focus-visible:after{opacity:1;transform:translateY(0)}.proj-media--placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:radial-gradient(circle at 30% 30%,color-mix(in oklch,var(--accent) 18%,transparent),transparent 60%),var(--bg-card)}.proj-media--placeholder:before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:32px 32px;opacity:.35;pointer-events:none}.proj-media-mark{position:relative;font-size:clamp(64px,8vw,104px);font-weight:600;letter-spacing:-.04em;color:var(--fg);line-height:1}.proj-media-caption{position:relative;font-size:11px;letter-spacing:.18em;color:var(--fg-dim);text-transform:uppercase}.proj-body{display:flex;flex-direction:column;gap:14px;min-width:0}.proj-year{font-size:12px;color:var(--fg-dim);letter-spacing:.04em}.proj-name{font-family:var(--font-serif);font-size:clamp(28px,3vw,36px);letter-spacing:-.015em;font-weight:500;margin:0;display:inline-flex;align-items:baseline;gap:12px;transition:color .2s ease}.proj-arrow{color:var(--fg-dim);font-size:18px;transition:color .2s ease,transform .2s ease;display:inline-block}.proj-url{font-size:12px;color:var(--fg-dim);margin-top:-4px}.proj-tagline{font-size:17px;color:var(--fg-muted);margin:0;line-height:1.5;text-wrap:pretty}.proj-stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.proj-stack-chip{font-family:var(--font-mono);font-size:11px;letter-spacing:.02em;padding:4px 10px;border:1px solid var(--border);border-radius:100px;color:var(--fg-muted)}.proj-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:8px 0 0;padding:0}.proj-metric{border-left:1px solid var(--border);padding-left:12px}.proj-metric dt{font-family:var(--font-mono);font-size:10px;color:var(--fg-dim);letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px}.proj-metric dd{font-family:var(--font-mono);font-size:14px;color:var(--fg);margin:0}@media (max-width: 900px){.proj-row{grid-template-columns:1fr;gap:24px}.proj-row[data-flip=true] .proj-media{order:0}}.modal-backdrop{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:100;display:flex;align-items:center;justify-content:center;padding:32px;animation:fade-in .2s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-elev);border:1px solid var(--border-strong);border-radius:var(--r-lg);max-width:760px;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:modal-up .25s ease-out}@keyframes modal-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:20px;right:20px;padding:6px 10px;font-family:var(--font-mono);font-size:11px;border:1px solid var(--border-strong);border-radius:var(--r-sm);color:var(--fg-muted);display:inline-flex;align-items:center;gap:6px}.modal-close:hover{color:var(--fg);border-color:var(--fg-muted)}.modal-body{padding:48px 48px 40px}.modal-meta{font-size:11px;letter-spacing:.12em;color:var(--fg-dim);text-transform:uppercase;margin-bottom:12px}.modal-title{font-family:var(--font-serif);font-size:36px;letter-spacing:-.015em;font-weight:500;margin:0 0 4px}.modal-url{font-family:var(--font-mono);font-size:12px;color:var(--fg-dim);margin-bottom:24px}.modal-tag{font-size:18px;color:var(--fg);margin:0 0 32px;line-height:1.5}.modal-h{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;color:var(--fg-dim);text-transform:uppercase;margin:32px 0 12px}.modal-desc{font-size:15px;color:var(--fg-muted);margin:0;line-height:1.6}.modal-notes{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px}.modal-notes li{display:flex;gap:12px;font-size:14px;color:var(--fg-muted);line-height:1.55}.modal-notes li:before{content:"→";font-family:var(--font-mono);color:var(--accent);flex-shrink:0}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:0;border-top:1px solid var(--border);border-left:1px solid var(--border)}.skill-group{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:24px}.skill-group-name{font-size:11px;letter-spacing:.1em;color:var(--fg-dim);text-transform:uppercase;margin-bottom:16px;display:flex;justify-content:space-between}.skill-items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.skill-items li{font-family:var(--font-mono);font-size:13px;color:var(--fg)}.exp-row{display:grid;grid-template-columns:200px 1fr;gap:40px;padding:32px 0;border-top:1px solid var(--border)}.exp-row:last-of-type{border-bottom:1px solid var(--border)}.exp-period{font-family:var(--font-mono);font-size:12px;color:var(--fg-dim);padding-top:4px}.exp-role{font-family:var(--font-serif);font-size:22px;letter-spacing:-.005em;font-weight:500;margin:0 0 4px}.exp-company{font-family:var(--font-mono);font-size:13px;color:var(--fg-muted);margin-bottom:16px}.exp-bullets{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.exp-bullets li{display:flex;gap:12px;font-size:15px;color:var(--fg-muted);line-height:1.55}.exp-bullets li:before{content:"·";color:var(--fg-dim);font-family:var(--font-mono);flex-shrink:0}.edu-block{margin-top:80px;display:grid;grid-template-columns:200px 1fr;gap:40px}.edu-school{font-family:var(--font-serif);font-size:22px;letter-spacing:-.005em;font-weight:500;margin:0 0 4px}.edu-degree{font-family:var(--font-mono);font-size:13px;color:var(--fg-muted);margin-bottom:4px}.edu-grad{font-family:var(--font-mono);font-size:12px;color:var(--fg-dim);margin-bottom:24px}.edu-cw-label{font-size:11px;letter-spacing:.1em;color:var(--fg-dim);text-transform:uppercase;margin-bottom:12px}.edu-cw{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.edu-cw li{font-family:var(--font-mono);font-size:13px;color:var(--fg)}@media (max-width: 800px){.exp-row,.edu-block{grid-template-columns:1fr;gap:12px}}.contact-block{text-align:left}.contact-pitch{font-family:var(--font-serif);font-size:clamp(32px,4vw,48px);letter-spacing:-.015em;font-weight:500;margin:0 0 48px;line-height:1.15;max-width:760px;text-wrap:balance}.contact-pitch .muted{color:var(--fg-muted)}.contact-email{display:inline-flex;align-items:baseline;gap:12px;font-family:var(--font-mono);font-size:18px;color:var(--fg);padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);width:100%;max-width:480px;justify-content:space-between;transition:color .15s ease}.contact-email:hover{color:var(--accent)}.footer{padding:32px 0 48px;border-top:1px solid var(--border);font-family:var(--font-mono);font-size:12px;color:var(--fg-dim)}.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.footer a:hover{color:var(--fg)}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fadeUp .4s cubic-bezier(.2,.8,.2,1) backwards}.showcase-tag{position:fixed;top:0;right:0;z-index:60;display:flex;flex-direction:column;align-items:flex-end;gap:4px;padding:14px 22px 18px 28px;background:var(--accent);color:var(--bg);font-family:var(--font-mono);letter-spacing:.04em;text-transform:lowercase;text-decoration:none;cursor:pointer;clip-path:polygon(0 0,100% 0,100% 100%,28px 100%,0 calc(100% - 28px));transform-origin:top right;transition:transform .22s cubic-bezier(.2,.8,.2,1),box-shadow .22s ease;box-shadow:0 6px 18px -8px color-mix(in oklch,var(--accent) 60%,transparent);animation:showcase-tag-in .5s cubic-bezier(.2,.8,.2,1) .6s backwards}.showcase-tag-kicker{font-size:10px;letter-spacing:.18em;text-transform:uppercase;opacity:.85}.showcase-tag-label{font-size:13px;font-weight:500}.showcase-tag:hover,.showcase-tag:focus-visible{transform:rotate(-2deg) scale(1.04);box-shadow:0 14px 28px -10px color-mix(in oklch,var(--accent) 70%,transparent)}@keyframes showcase-tag-in{0%{transform:translate(20%,-40%) rotate(8deg);opacity:0}to{transform:translate(0) rotate(0);opacity:1}}@media (max-width: 720px){.showcase-tag{display:none}}@media (prefers-reduced-motion: reduce){.showcase-tag{animation:none;transition:none}.showcase-tag:hover,.showcase-tag:focus-visible{transform:none}}.showcase{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.showcase-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);color:var(--fg-muted);font-size:14px;letter-spacing:.04em}.showcase-head{border-bottom:1px solid var(--border);padding:20px 0}.showcase-head-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.showcase-back{font-family:var(--font-mono);font-size:13px;color:var(--fg-muted);transition:color .2s ease}.showcase-back:hover{color:var(--accent)}.showcase-title{font-family:var(--font-mono);font-size:13px;color:var(--fg)}.showcase-title-key{color:var(--fg-dim)}.showcase-tabs{border-bottom:1px solid var(--border);background:var(--bg-elev)}.showcase-tabs-inner{display:flex;gap:4px;flex-wrap:wrap;padding:8px 0}.showcase-tab{font-family:var(--font-mono);font-size:12px;letter-spacing:.02em;color:var(--fg-muted);padding:8px 14px;border-radius:var(--r-sm);transition:background .15s ease,color .15s ease}.showcase-tab:hover{background:var(--bg-card);color:var(--fg)}.showcase-tab.is-active{background:var(--accent);color:var(--bg)}.showcase-stage{flex:1;min-height:60vh;position:relative;background:var(--bg-card)}.showcase-stage canvas{display:block;width:100%!important;height:100%!important}.showcase-info{border-top:1px solid var(--border);background:var(--bg-elev);padding:20px 0}.showcase-info-inner{display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:baseline}.showcase-info-label{font-size:12px;color:var(--accent);white-space:nowrap}.showcase-info-blurb{margin:0;font-size:14px;color:var(--fg-muted);line-height:1.5}.showcase-info-tools{font-size:11px;color:var(--fg-dim);letter-spacing:.04em;white-space:nowrap}@media (max-width: 640px){.showcase-info-inner{grid-template-columns:1fr;gap:8px}}
