:root{--color-bg: #fafafa;--color-bg-alt: #f2f2f2;--color-text: #171717;--color-text-muted: #525252;--color-text-subtle: #737373;--color-accent: #171717;--color-accent-hover: #404040;--color-border: #e5e5e5;--color-border-subtle: #f0f0f0;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--leading-none: 1;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 2;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--max-width: 1040px;--content-width: 680px;--header-height: 72px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--ease-out: cubic-bezier(.25, .46, .45, .94);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .06), 0 2px 4px -1px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .06), 0 4px 6px -2px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .06), 0 10px 10px -5px rgba(0, 0, 0, .03);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px}@media (prefers-color-scheme: dark){:root{--color-bg: #0a0a0a;--color-bg-alt: #171717;--color-text: #fafafa;--color-text-muted: #a3a3a3;--color-text-subtle: #737373;--color-accent: #fafafa;--color-accent-hover: #d4d4d4;--color-border: #262626;--color-border-subtle: #1a1a1a;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -1px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -2px rgba(0, 0, 0, .2);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .4), 0 10px 10px -5px rgba(0, 0, 0, .2)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg);letter-spacing:var(--tracking-normal)}img,video{max-width:100%;height:auto;display:block}a{color:var(--color-text);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-text-muted)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}.layout{min-height:100vh;display:flex;flex-direction:column}.main{flex:1;width:100%;max-width:var(--max-width);margin:0 auto;padding:var(--space-10) var(--space-6);padding-top:calc(var(--header-height) + var(--space-10))}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:#fafafae6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border);z-index:100}@media (prefers-color-scheme: dark){.header{background:#0a0a0ae6}}.header-inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-6);height:100%;display:flex;align-items:center;justify-content:space-between}.logo{font-size:var(--text-base);font-weight:600;color:var(--color-text);letter-spacing:var(--tracking-tight)}.logo:hover{color:var(--color-text)}.nav{display:flex;gap:var(--space-8)}.nav-link{font-size:var(--text-sm);color:var(--color-text-muted);transition:color var(--transition-fast);position:relative}.nav-link:hover,.nav-link.active{color:var(--color-text)}.menu-button{display:none;background:none;border:none;padding:var(--space-2);cursor:pointer;color:var(--color-text)}.menu-button svg{width:24px;height:24px}.mobile-nav{display:none;position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background:var(--color-bg);padding:var(--space-6);z-index:99}.mobile-nav.open{display:block}.mobile-nav-link{display:block;font-size:var(--text-xl);font-weight:500;padding:var(--space-4) 0;border-bottom:1px solid var(--color-border);color:var(--color-text)}.mobile-nav-link:hover,.mobile-nav-link.active{color:var(--color-text-muted)}.footer{border-top:1px solid var(--color-border);padding:var(--space-10) var(--space-6);margin-top:var(--space-16)}.footer-inner{max-width:var(--max-width);margin:0 auto;text-align:center;color:var(--color-text-muted);font-size:var(--text-sm)}.page{max-width:var(--content-width)}.page-home{max-width:100%}.page h1{font-size:var(--text-4xl);font-weight:600;line-height:var(--leading-tight);margin-bottom:var(--space-4)}.page-intro{font-size:var(--text-lg);color:var(--color-text-muted);line-height:var(--leading-relaxed);margin-bottom:var(--space-10)}.hero{padding:var(--space-16) 0;max-width:var(--content-width)}.hero h1{font-size:var(--text-5xl);letter-spacing:-.03em;margin-bottom:var(--space-6)}.hero-subtitle{font-size:var(--text-xl);color:var(--color-text-muted);line-height:var(--leading-relaxed);max-width:560px}.hero-cta{display:flex;gap:var(--space-4);margin-top:var(--space-8)}.section{margin-top:var(--space-16)}.section h2{font-size:var(--text-2xl);font-weight:600;margin-bottom:var(--space-6)}.section-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--space-6)}.section-header h2{margin-bottom:0}.section-link{font-size:var(--text-sm);font-weight:500;color:var(--color-text-muted)}.section-link:hover{color:var(--color-text)}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-6)}.work-card,.experiment-card,.post-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.work-card a,.experiment-card a,.post-card a{color:inherit;display:block}.work-card-image,.experiment-card-image{aspect-ratio:16 / 10;background:var(--color-bg-alt);overflow:hidden}.work-card-image img,.experiment-card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.work-card:hover .work-card-image img,.experiment-card:hover .experiment-card-image img{transform:scale(1.02)}.work-card-content,.experiment-card-content,.post-card-content{padding:var(--space-5)}.work-card h3,.experiment-card h3,.post-card h3{font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-2);line-height:var(--leading-snug)}.work-card p,.experiment-card p,.post-card p{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-relaxed);margin-bottom:var(--space-4)}.work-card-meta,.post-card-meta{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-xs);color:var(--color-text-subtle)}.post-card-date{font-size:var(--text-xs);color:var(--color-text-subtle);display:block;margin-bottom:var(--space-2)}.tag{display:inline-block;font-size:var(--text-xs);padding:var(--space-1) var(--space-2);background:var(--color-bg-alt);border-radius:var(--radius-sm);color:var(--color-text-muted)}.work-card-tags,.experiment-card-tags,.post-card-tags,.detail-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.button{display:inline-block;padding:var(--space-3) var(--space-6);background:var(--color-text);color:var(--color-bg);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;transition:all var(--transition-fast)}.button:hover{background:var(--color-text-muted);color:var(--color-bg)}.button-secondary{display:inline-block;padding:var(--space-3) var(--space-6);background:transparent;color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;transition:all var(--transition-fast)}.button-secondary:hover{background:var(--color-bg-alt);color:var(--color-text);border-color:var(--color-text-muted)}.demo-reel-video{border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg-alt)}.demo-reel-video video{width:100%;display:block}.filter-bar{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-4)}.filter-button{padding:var(--space-2) var(--space-4);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.filter-button:hover{border-color:var(--color-text-muted);color:var(--color-text)}.filter-button.active{background:var(--color-text);border-color:var(--color-text);color:var(--color-bg)}.search-bar{margin-bottom:var(--space-4)}.search-input{width:100%;max-width:400px;padding:var(--space-3) var(--space-4);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--color-text);transition:border-color var(--transition-fast)}.search-input::placeholder{color:var(--color-text-subtle)}.search-input:focus{outline:none;border-color:var(--color-text-muted)}.no-results{text-align:center;color:var(--color-text-muted);padding:var(--space-10) 0}.detail-header{margin-bottom:var(--space-10)}.detail-summary{font-size:var(--text-lg);color:var(--color-text-muted);margin-top:var(--space-4);line-height:var(--leading-relaxed)}.detail-meta{display:flex;align-items:center;gap:var(--space-4);margin-top:var(--space-4);color:var(--color-text-muted);font-size:var(--text-sm)}.detail-date{display:block;margin-bottom:var(--space-3);color:var(--color-text-subtle);font-size:var(--text-sm)}.detail-role{color:var(--color-text-muted)}.detail-external-link{margin-top:var(--space-6)}.detail-hero{border-radius:var(--radius-lg);overflow:hidden}.detail-hero img,.detail-hero video{width:100%;border-radius:var(--radius-lg)}.detail-highlights ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-3)}.detail-highlights li{padding-left:var(--space-6);position:relative;line-height:var(--leading-relaxed)}.detail-highlights li:before{content:"—";position:absolute;left:0;color:var(--color-text-subtle)}.detail-section p{margin-bottom:var(--space-4);line-height:var(--leading-relaxed)}.detail-section-media{margin-top:var(--space-6);border-radius:var(--radius-lg);overflow:hidden}.detail-section-media video{max-width:50%;height:auto;display:block;margin:0 auto}.detail-hero video{max-width:50%;height:auto;display:block;margin:0 auto}.detail-source-link{font-weight:500}.experiment-embed{background:var(--color-bg-alt);border-radius:var(--radius-lg);padding:var(--space-6)}.p5-placeholder{text-align:center}.p5-canvas-mock{aspect-ratio:16 / 9;background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-bg-alt) 100%);border:2px dashed var(--color-border);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.p5-canvas-content{text-align:center}.p5-icon{font-size:var(--text-4xl);color:var(--color-text-subtle);display:block;margin-bottom:var(--space-2)}.p5-canvas-content code{background:var(--color-bg);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--text-sm)}.p5-placeholder-note{margin-top:var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted)}.experiment-no-embed{text-align:center;padding:var(--space-10);color:var(--color-text-muted)}.post-hero{margin-bottom:var(--space-10);border-radius:var(--radius-lg);overflow:hidden}.post-hero-img{width:100%;height:auto;display:block;border-radius:var(--radius-lg)}.post-hero-img.portrait{width:50%;margin:0 auto}.post-content p{margin-bottom:var(--space-6);line-height:var(--leading-relaxed)}.post-image{margin:var(--space-8) 0;text-align:center}.post-image-img{width:100%;height:auto;display:block;border-radius:var(--radius-lg);margin:0 auto}.post-image-img.portrait{width:50%}.post-image figcaption{margin-top:var(--space-3);font-size:var(--text-sm);color:var(--color-text-muted);text-align:center;font-style:italic}.post-list{display:flex;flex-direction:column;gap:var(--space-4)}.youtube-embed{position:relative;width:100%;padding-bottom:56.25%;background:var(--color-bg-alt);border-radius:var(--radius-lg);overflow:hidden}.youtube-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.before-after{position:relative;overflow:hidden;cursor:ew-resize;border-radius:var(--radius-lg)}.before-after img{width:100%;display:block}.before-after-before{position:absolute;top:0;left:0;width:100%;height:100%}.before-after-slider{position:absolute;top:0;bottom:0;width:2px;background:#fff;transform:translate(-50%)}.before-after-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;background:#fff;border-radius:50%;box-shadow:var(--shadow-md)}.about-content p{margin-bottom:var(--space-6);line-height:var(--leading-relaxed)}.about-lead{font-size:var(--text-xl);color:var(--color-text);font-weight:500}.focus-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.focus-card{padding:var(--space-6);background:var(--color-bg-alt);border-radius:var(--radius-lg)}.focus-card h3{font-size:var(--text-base);font-weight:600;margin-bottom:var(--space-2)}.focus-card p{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-relaxed);margin:0}.contact-content p{margin-bottom:var(--space-4);line-height:var(--leading-relaxed)}.contact-lead{font-size:var(--text-xl);font-weight:500}.contact-email{font-size:var(--text-2xl);font-weight:600;display:inline-block}.social-links{list-style:none}.social-link{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);border-bottom:1px solid var(--color-border);color:var(--color-text);transition:background var(--transition-fast)}.social-link:hover{background:var(--color-bg-alt);color:var(--color-text)}.social-link-name{font-weight:500}.social-link-icon{color:var(--color-text-subtle)}.page-not-found{text-align:center;padding:var(--space-24) 0}.page-not-found h1{font-size:6rem;color:var(--color-text-muted);letter-spacing:-.05em}.text-muted{color:var(--color-text-muted);font-size:var(--text-sm)}.video-fallback,.image-fallback{aspect-ratio:16 / 9;background:var(--color-bg-alt);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.video-fallback-content,.image-fallback-content{text-align:center;color:var(--color-text-subtle)}.video-fallback-icon,.image-fallback-icon{font-size:var(--text-3xl);display:block;margin-bottom:var(--space-2);opacity:.5}.video-fallback p,.image-fallback p{font-size:var(--text-sm);margin:0}@media (max-width: 768px){.main{padding:var(--space-6) var(--space-4);padding-top:calc(var(--header-height) + var(--space-6))}.hero{padding:var(--space-10) 0}.hero h1{font-size:var(--text-4xl)}.page h1{font-size:var(--text-3xl)}.nav{display:none}.menu-button{display:block}.hero-cta{flex-direction:column}.hero-cta .button,.hero-cta .button-secondary{text-align:center}.section-header{flex-direction:column;gap:var(--space-2);align-items:flex-start}.grid{grid-template-columns:1fr}.filter-bar{overflow-x:auto;flex-wrap:nowrap;padding-bottom:var(--space-2);-webkit-overflow-scrolling:touch}.filter-button{white-space:nowrap;flex-shrink:0}.focus-grid{grid-template-columns:1fr}.section{margin-top:var(--space-12)}}
