*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--black: #0a0a0a;--white: #f5f5f0;--gray-50: #fafaf8;--gray-100: #e8e8e4;--gray-200: #d0d0cc;--gray-300: #b0b0ac;--gray-400: #888884;--gray-500: #68685f;--gray-600: #48483f;--gray-700: #2a2a24;--gray-800: #1a1a16;--gray-900: #0f0f0c;--color-bg: var(--black);--color-text: var(--white);--color-text-muted: var(--gray-400);--color-hairline: rgba(255, 255, 255, .1);--font-body: "Inter", system-ui, -apple-system, sans-serif;--font-display: "Space Grotesk", system-ui, sans-serif;--font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;--size-display: clamp(3rem, 6vw, 5rem);--size-h1: clamp(2rem, 4vw, 3rem);--size-h2: clamp(1.5rem, 2.5vw, 2.25rem);--size-h3: clamp(1.125rem, 1.5vw, 1.5rem);--size-body: 1rem;--size-body-lg: 1.125rem;--size-caption: .875rem;--size-label: .75rem;--ls-tight: -.02em;--ls-normal: 0em;--ls-wide: .06em;--ls-caps: .1em;--grid-columns: 12;--grid-gutter: 24px;--grid-max: 1400px;--sp-1: 8px;--sp-2: 16px;--sp-3: 24px;--sp-4: 32px;--sp-5: 48px;--sp-6: 64px;--sp-7: 96px;--sp-8: 128px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--ease-out: cubic-bezier(.16, 1, .3, 1);--duration-fast: .2s;--duration-normal: .3s;--duration-slow: .5s}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}body{min-height:100vh;font-family:var(--font-body);font-size:var(--size-body);line-height:1.6;background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit}img,video{display:block;max-width:100%}.landing{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--color-bg);display:flex;align-items:center;justify-content:center;transition:opacity .6s var(--ease-out),visibility .6s var(--ease-out)}.landing.dismissed{opacity:0;visibility:hidden;pointer-events:none}.landing-intro{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;transition:opacity .4s var(--ease-out)}.landing-intro.fade-out{opacity:0}.landing-letters{display:flex;align-items:baseline}.landing-letter,.landing-dot{font-family:var(--font-display);font-size:clamp(5rem,15vw,12rem);font-weight:700;color:var(--color-text);opacity:0;transform:translateY(24px);transition:opacity .35s var(--ease-out),transform .35s var(--ease-out);line-height:1}.landing-letter.visible,.landing-dot.visible{opacity:1;transform:translateY(0)}.landing-dot{font-size:clamp(3rem,10vw,8rem);color:var(--color-text-muted);margin:0 .05em}.landing-splat-bg{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity 1s ease}.landing-splat-bg.visible{opacity:1}.landing-splat-bg canvas{width:100%!important;height:100%!important;display:block}.landing-content{position:absolute;bottom:clamp(2rem,6vh,5rem);left:50%;transform:translate(-50%) translateY(12px);display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);opacity:0;transition:opacity .8s ease,transform .8s ease;padding:var(--sp-3) var(--sp-4);z-index:2;background:#0a0a0a80;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--color-hairline);border-radius:var(--radius-lg)}.landing-content.visible{opacity:1;transform:translate(-50%) translateY(0)}.landing-tagline{font-family:var(--font-body);font-size:clamp(.875rem,1.5vw,1.25rem);color:var(--color-text-muted);text-align:center;max-width:580px;line-height:1.5}.landing-hint{font-family:var(--font-mono);font-size:var(--size-label);color:var(--gray-500);text-transform:uppercase;letter-spacing:var(--ls-caps)}.global-nav.hidden,.app-container.hidden{opacity:0;pointer-events:none}.global-nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:var(--sp-2) var(--grid-gutter);background:linear-gradient(to bottom,rgba(10,10,10,.85) 0%,transparent 100%);transition:opacity var(--duration-fast) ease}.nav-inner{max-width:var(--grid-max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4)}.nav-logo{font-family:var(--font-display);font-size:1rem;font-weight:700;text-decoration:none;color:var(--color-text);letter-spacing:var(--ls-wide)}.nav-links{display:flex;gap:var(--sp-4)}.nav-link{font-family:var(--font-body);font-size:var(--size-label);font-weight:500;text-decoration:none;text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--color-text);opacity:.5;transition:opacity var(--duration-fast) ease}.nav-link:hover,.nav-link.active{opacity:1}.app-container{min-height:100vh;padding-top:64px}.route-content{opacity:0;transition:opacity .22s ease}.route-content.visible{opacity:1}.overlay-panel{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity var(--duration-normal),visibility var(--duration-normal)}.overlay-panel.open{opacity:1;visibility:visible}.overlay-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0a0a0ae6}.overlay-content{position:relative;width:90%;max-width:800px;max-height:90vh;overflow-y:auto;background:var(--gray-900);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--sp-5);transform:translateY(16px);transition:transform var(--duration-normal) var(--ease-out)}.overlay-panel.open .overlay-content{transform:translateY(0)}.overlay-close{position:absolute;top:var(--sp-3);right:var(--sp-3);width:32px;height:32px;background:transparent;border:1px solid var(--color-hairline);border-radius:50%;color:var(--color-text);font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color var(--duration-fast) ease}.overlay-close:hover{border-color:var(--color-text)}.display{font-family:var(--font-display);font-size:var(--size-display);font-weight:700;letter-spacing:var(--ls-tight);line-height:1.05}.h1{font-family:var(--font-display);font-size:var(--size-h1);font-weight:700;letter-spacing:var(--ls-tight);line-height:1.1}.h2{font-family:var(--font-display);font-size:var(--size-h2);font-weight:700;letter-spacing:var(--ls-tight);line-height:1.2}.h3{font-family:var(--font-display);font-size:var(--size-h3);font-weight:600;line-height:1.3}.kicker{display:block;font-family:var(--font-body);font-size:var(--size-label);font-weight:500;text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--color-text-muted);margin-bottom:var(--sp-1)}.body-text{color:var(--color-text-muted);line-height:1.7;max-width:65ch}.btn{display:inline-flex;align-items:center;gap:var(--sp-1);font-family:var(--font-body);font-size:var(--size-label);font-weight:500;text-transform:uppercase;letter-spacing:var(--ls-caps);text-decoration:none;padding:.75rem 1.5rem;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast) ease;border:1px solid transparent}.btn-primary{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}.btn-primary:hover{background:transparent;color:var(--color-text)}.btn-ghost{background:transparent;color:var(--color-text);border-color:var(--color-hairline)}.btn-ghost:hover{border-color:var(--color-text)}.grid-container{width:100%;max-width:var(--grid-max);margin:0 auto;padding:0 var(--grid-gutter)}@media (max-width: 768px){:root{--grid-gutter: 16px}.nav-links{gap:var(--sp-2)}.nav-link{font-size:.6875rem}.overlay-content{width:100%;height:100%;max-height:100%;border-radius:0;padding:var(--sp-3)}}@media (max-width: 480px){.nav-links{gap:var(--sp-1)}}.home-page{padding-bottom:var(--sp-8)}.home-hero{min-height:80vh;display:flex;align-items:center;padding:var(--sp-8) 0 var(--sp-7)}.home-hero-inner{max-width:720px}.home-hero .display{margin-bottom:var(--sp-3)}.home-hero-subtitle{font-size:var(--size-body-lg);color:var(--color-text-muted);line-height:1.7;max-width:520px;margin-bottom:var(--sp-5)}.home-hero-ctas{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.home-work{padding:var(--sp-7) 0;border-top:1px solid var(--color-hairline)}.home-work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-3)}.home-project-card{text-decoration:none;color:inherit;display:block;transition:transform var(--duration-fast) ease}.home-project-card:hover{transform:translateY(-4px)}.home-project-image{width:100%;aspect-ratio:4/3;background:var(--gray-800);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-2);transition:background var(--duration-fast) ease}.home-project-card:hover .home-project-image{background:var(--gray-700)}.home-project-id{font-family:var(--font-mono);font-size:var(--size-label);color:var(--color-text-muted);letter-spacing:var(--ls-wide)}.home-project-info{padding:0 var(--sp-1)}.home-project-title{font-family:var(--font-display);font-size:var(--size-h3);font-weight:600;margin-bottom:4px}.home-project-meta{font-size:var(--size-label);color:var(--color-text-muted);letter-spacing:var(--ls-wide)}.home-about{padding:var(--sp-7) 0;border-top:1px solid var(--color-hairline)}.home-about-inner{max-width:600px}.home-about-text{font-size:var(--size-h3);line-height:1.6;color:var(--color-text-muted);margin-bottom:var(--sp-4)}.work-page{padding:var(--sp-7) 0 var(--sp-8)}.work-header{margin-bottom:var(--sp-6)}.work-header .h1{margin-top:var(--sp-1)}.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-3)}.work-card{cursor:pointer;transition:transform var(--duration-fast) ease;border:none;background:none;color:inherit;text-align:left;padding:0}.work-card:hover{transform:translateY(-4px)}.work-card-image{width:100%;aspect-ratio:16/9;background:var(--gray-800);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-2);transition:background var(--duration-fast) ease}.work-card:hover .work-card-image{background:var(--gray-700)}.work-card-id{font-family:var(--font-mono);font-size:var(--size-label);color:var(--color-text-muted);letter-spacing:var(--ls-wide)}.work-card-body{padding:0 var(--sp-1)}.work-card-title{font-family:var(--font-display);font-size:var(--size-h3);font-weight:600;margin-bottom:4px}.work-card-meta{font-size:var(--size-label);color:var(--color-text-muted);letter-spacing:var(--ls-wide)}.project-detail-media{width:100%;aspect-ratio:16/9;background:var(--gray-800);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-4)}.project-detail-id{font-family:var(--font-mono);font-size:var(--size-caption);color:var(--color-text-muted);letter-spacing:var(--ls-wide)}.project-detail-header{margin-bottom:var(--sp-3)}.project-detail-meta{display:block;font-size:var(--size-label);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--ls-caps);margin-top:var(--sp-1)}.project-detail-summary{color:var(--color-text-muted);line-height:1.7;max-width:60ch;margin-bottom:var(--sp-3)}.project-detail-bullets{list-style:none;margin-bottom:var(--sp-3)}.project-detail-bullets li{position:relative;padding-left:var(--sp-2);color:var(--color-text-muted);margin-bottom:var(--sp-1);line-height:1.6}.project-detail-bullets li:before{content:"—";position:absolute;left:0;color:var(--gray-600)}.project-detail-tools{display:flex;flex-wrap:wrap;gap:var(--sp-1);margin-bottom:var(--sp-3)}.tool-tag{font-size:var(--size-label);font-weight:500;padding:4px 12px;border:1px solid var(--color-hairline);border-radius:var(--radius-sm);color:var(--color-text-muted)}.project-detail-items{display:flex;flex-direction:column;margin-bottom:var(--sp-3)}.project-detail-item{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) 0;border-top:1px solid var(--color-hairline);text-decoration:none;color:inherit;transition:opacity var(--duration-fast) ease}.project-detail-item:last-child{border-bottom:1px solid var(--color-hairline)}.project-detail-item:hover{opacity:.7}.project-detail-item-title{font-size:var(--size-body)}.project-detail-item-arrow{font-size:var(--size-caption);color:var(--color-text-muted)}.project-detail-links{display:flex;gap:var(--sp-2)}.contact-page{min-height:80vh;display:flex;align-items:center;padding:var(--sp-7) 0}.contact-layout{max-width:560px}.contact-header{margin-bottom:var(--sp-5)}.contact-header .h1{margin:var(--sp-1) 0 var(--sp-2)}.contact-links{display:flex;flex-direction:column}.contact-row{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) 0;border-top:1px solid var(--color-hairline);text-decoration:none;color:inherit;transition:opacity var(--duration-fast) ease}.contact-row:last-child{border-bottom:1px solid var(--color-hairline)}.contact-row:hover{opacity:.7}.contact-row-label{font-size:var(--size-caption);font-weight:500;text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--color-text-muted)}.contact-row-value{font-size:var(--size-body);color:var(--color-text)}@media (max-width: 900px){.home-work-grid,.work-grid{grid-template-columns:1fr;gap:var(--sp-4)}}@media (max-width: 600px){.home-hero{min-height:60vh;padding:var(--sp-6) 0 var(--sp-5)}.home-hero-ctas{flex-direction:column}.home-hero-ctas .btn{text-align:center;justify-content:center}}.lab-page{padding:var(--sp-7) 0 var(--sp-8)}.lab-header{margin-bottom:var(--sp-6)}.lab-header .h1{margin-top:var(--sp-1)}.lab-subtitle{color:var(--color-text-muted);margin-top:var(--sp-1)}.specimen-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--sp-3)}.specimen-card{background:var(--gray-900);border:1px solid var(--color-hairline);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:transform var(--duration-fast) ease,border-color var(--duration-fast) ease}.specimen-card:hover{border-color:var(--gray-600);transform:translateY(-2px)}.specimen-media{width:100%;aspect-ratio:4/3;background:var(--gray-800);display:flex;align-items:center;justify-content:center}.specimen-id{font-family:var(--font-mono);font-size:var(--size-label);color:var(--color-text-muted);letter-spacing:var(--ls-wide)}.specimen-body{padding:var(--sp-3)}.specimen-label{display:block;font-size:.625rem;font-weight:500;text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--color-text-muted);margin-bottom:var(--sp-1)}.specimen-title{font-family:var(--font-display);font-size:var(--size-h3);font-weight:600;margin-bottom:var(--sp-1)}.specimen-summary{font-size:var(--size-caption);color:var(--color-text-muted);line-height:1.5;margin-bottom:var(--sp-2)}.specimen-constraints{display:flex;flex-wrap:wrap;gap:6px}.constraint-tag{font-size:.6875rem;font-weight:500;padding:3px 10px;border:1px solid var(--color-hairline);border-radius:var(--radius-sm);color:var(--color-text-muted)}.experiment-detail{max-width:100%}.experiment-media{width:100%;aspect-ratio:16/9;background:var(--gray-800);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-4)}.experiment-id{font-family:var(--font-mono);font-size:var(--size-caption);color:var(--color-text-muted);letter-spacing:var(--ls-wide)}.experiment-label{display:block;font-size:var(--size-label);font-weight:500;text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--color-text-muted);margin-bottom:var(--sp-1)}.experiment-summary{color:var(--color-text-muted);line-height:1.7;max-width:60ch;margin-bottom:var(--sp-3)}.experiment-constraints{margin-bottom:var(--sp-3)}.experiment-constraints-title{font-size:var(--size-label);font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-caps);margin-bottom:var(--sp-1)}.experiment-constraints-list{display:flex;flex-wrap:wrap;gap:var(--sp-1)}.experiment-notes{padding-top:var(--sp-3);border-top:1px solid var(--color-hairline);font-size:var(--size-caption);color:var(--color-text-muted);font-style:italic;line-height:1.6}@media (max-width: 600px){.specimen-grid{grid-template-columns:1fr}}
