:root{--bg:#FFFFFF;--surface:#FFFFFF;--surface-soft:#F7F8FA;--ink:#0A0A0F;--ink-soft:#1F2330;--muted:#5C6370;--line:#E6E8EE;--line-strong:#CFD3DC;--accent:#2D4FE0;--accent-soft:#E8EDFE;--accent-hover:#1E3CC9;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-display:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--measure:72ch;--wrap:1080px;--wrap-text:760px;--radius-sm:6px;--radius:12px;--radius-lg:16px;--shadow-card:0 1px 2px rgba(15, 23, 42, 0.04), 0 4px 12px rgba(15, 23, 42, 0.04);--shadow-card-hover:0 2px 4px rgba(15, 23, 42, 0.06), 0 12px 28px rgba(15, 23, 42, 0.08);--space-1:0.5rem;--space-2:1rem;--space-3:1.5rem;--space-4:2rem;--space-5:3rem;--space-6:4.5rem;--space-7:6rem}[data-theme=dark]{--bg:#0B0D12;--surface:#11141B;--surface-soft:#14181F;--ink:#F2F4F8;--ink-soft:#DCDFE7;--muted:#8A91A1;--line:#1F242E;--line-strong:#2C3340;--accent:#7E97FF;--accent-soft:rgba(126, 151, 255, 0.12);--accent-hover:#A4B6FF;--shadow-card:0 1px 2px rgba(0, 0, 0, 0.3), 0 4px 12px rgba(0, 0, 0, 0.25);--shadow-card-hover:0 2px 4px rgba(0, 0, 0, 0.4), 0 12px 28px rgba(0, 0, 0, 0.35)}*,*::before,*::after{box-sizing:border-box}html,body{margin:0;padding:0}img,svg{max-width:100%;height:auto;display:block}button,input,select,textarea{font:inherit;color:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}html{font-family:var(--font-sans);font-size:17px;line-height:1.65;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.15;letter-spacing:-.022em;color:var(--ink);margin:0 0 var(--space-3)}p{margin:0 0 var(--space-3)}a{color:var(--accent);text-decoration:none;transition:color 120ms ease}a:hover{color:var(--accent-hover)}code{font-family:var(--font-mono);font-size:.9em;background:var(--surface-soft);border:1px solid var(--line);padding:.1em .4em;border-radius:var(--radius-sm)}pre{font-family:var(--font-mono);font-size:.9em;line-height:1.6;background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);padding:var(--space-3);overflow-x:auto;margin:var(--space-3)0}pre code{background:0 0;padding:0;border:0}blockquote{border-left:3px solid var(--accent);padding:0 var(--space-3);margin:var(--space-3)0;color:var(--muted);font-style:italic}.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding-left:var(--space-3);padding-right:var(--space-3)}.wrap-text{width:100%;max-width:var(--wrap-text);margin:0 auto;padding-left:var(--space-3);padding-right:var(--space-3)}.site-main{flex:1;padding-top:var(--space-5);padding-bottom:var(--space-7)}.site-header{border-bottom:1px solid var(--line);padding:.875rem 0;background:color-mix(in srgb,var(--bg) 85%,transparent);backdrop-filter:saturate(180%)blur(8px);-webkit-backdrop-filter:saturate(180%)blur(8px);position:sticky;top:0;z-index:50}.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.brand{font-weight:700;font-size:.9375rem;color:var(--ink);letter-spacing:-.01em}.brand:hover{color:var(--accent)}.site-nav{display:flex;align-items:center;gap:1.25rem;font-size:.9375rem;font-weight:500}.site-nav a{color:var(--muted)}.site-nav a:hover{color:var(--ink)}.theme-toggle{appearance:none;background:0 0;border:1px solid var(--line);border-radius:999px;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;transition:color 120ms ease,border-color 120ms ease,background 120ms ease;padding:0;margin-left:.25rem}.theme-toggle:hover{color:var(--ink);border-color:var(--line-strong);background:var(--surface-soft)}.theme-toggle svg{width:14px;height:14px;display:block}.theme-toggle .icon-sun{display:none}.theme-toggle .icon-moon{display:block}[data-theme=dark] .theme-toggle .icon-sun{display:block}[data-theme=dark] .theme-toggle .icon-moon{display:none}.hero{display:grid;grid-template-columns:minmax(0,1fr)auto;gap:var(--space-5);align-items:center;padding-top:var(--space-6);padding-bottom:var(--space-5)}.hero-eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:500;color:var(--muted);background:var(--surface-soft);border:1px solid var(--line);padding:.35rem .75rem;border-radius:999px;margin-bottom:var(--space-3)}.hero-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.hero-name{font-size:clamp(2.5rem,5.5vw,3.75rem);font-weight:800;letter-spacing:-.03em;margin:0 0 var(--space-2);background:linear-gradient(180deg,var(--ink) 0%,var(--ink-soft) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero-tagline{font-size:clamp(1.125rem,1.8vw,1.25rem);line-height:1.55;color:var(--muted);max-width:72ch;margin:0 0 var(--space-4);text-wrap:pretty}.hero-portrait img{width:clamp(140px,20vw,200px);height:clamp(140px,20vw,200px);border-radius:var(--radius-lg);object-fit:cover;border:1px solid var(--line);box-shadow:var(--shadow-card)}.social{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;padding:0;margin:0}.social a{display:inline-flex;align-items:center;gap:.4rem;font-size:.875rem;font-weight:500;color:var(--ink-soft);background:var(--surface);border:1px solid var(--line);padding:.45rem .85rem;border-radius:999px;transition:color 120ms ease,border-color 120ms ease,background 120ms ease,transform 120ms ease}.social a:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-4)}.section-eyebrow{font-size:.75rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 var(--space-1)}.section-title{font-size:clamp(1.75rem,3vw,2.25rem);font-weight:700;letter-spacing:-.02em;margin:0}.section-sub{font-size:.9375rem;color:var(--muted);max-width:38ch;margin:0}.section{padding-top:var(--space-6)}.about-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:var(--space-3)}.prose{max-width:var(--measure);font-size:1.0625rem;line-height:1.75;color:var(--ink-soft);text-wrap:pretty}.prose .nowrap,.nowrap{white-space:nowrap}.prose p:last-child{margin-bottom:0}.prose h2{font-size:1.5rem;margin-top:var(--space-5)}.prose h3{font-size:1.1875rem;margin-top:var(--space-4)}.prose ul,.prose ol{margin:0 0 var(--space-3);padding-left:1.4rem}.prose li{margin-bottom:.4rem}.prose a{border-bottom:1px solid color-mix(in srgb,var(--accent) 35%,transparent)}.prose a:hover{border-bottom-color:var(--accent-hover)}.prose img{margin:var(--space-3)0;border-radius:var(--radius);border:1px solid var(--line)}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-3)}.project-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;text-decoration:none;color:inherit;transition:transform 200ms ease,box-shadow 200ms ease,border-color 200ms ease;box-shadow:var(--shadow-card)}.project-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card-hover);border-color:var(--line-strong)}.project-card-media{aspect-ratio:16/9;background:var(--surface-soft);overflow:hidden;border-bottom:1px solid var(--line)}.project-card-media img{width:100%;height:100%;object-fit:cover;transition:transform 600ms ease}.project-card:hover .project-card-media img{transform:scale(1.03)}.project-card-body{padding:var(--space-3);display:flex;flex-direction:column;gap:.5rem;flex:1}.project-card-meta{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--muted);letter-spacing:.04em}.project-card-cat{display:inline-block;font-weight:600;font-size:.6875rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:.2rem .55rem;border-radius:999px}.project-card-year{font-family:var(--font-mono);font-size:.75rem}.project-card-title{font-size:1.1875rem;font-weight:700;letter-spacing:-.018em;line-height:1.25;color:var(--ink);margin:0}.project-card-sub{font-size:.9375rem;color:var(--muted);line-height:1.5;margin:0}.project-card-arrow{margin-top:auto;display:inline-flex;align-items:center;gap:.4rem;font-size:.875rem;font-weight:500;color:var(--accent);padding-top:var(--space-1)}.project-card-arrow .arrow{transition:transform 200ms ease}.project-card:hover .project-card-arrow .arrow{transform:translateX(4px)}.post{padding-top:var(--space-3)}.post-header{margin-bottom:var(--space-4)}.post-meta{display:inline-flex;align-items:center;gap:.6rem;font-size:.8125rem;color:var(--muted);margin:0 0 var(--space-2)}.post-meta .post-cat{font-weight:600;font-size:.6875rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:.2rem .55rem;border-radius:999px}.post-meta time{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.04em}.post-title{font-size:clamp(2rem,4vw,2.75rem);font-weight:800;letter-spacing:-.025em;margin:0 0 var(--space-2)}.post-subtitle{font-size:1.1875rem;color:var(--muted);margin:0}.post-banner{margin:0 0 var(--space-5)}.post-banner img{width:100%;border:1px solid var(--line);border-radius:var(--radius)}.post-foot{margin-top:var(--space-6);padding-top:var(--space-3);border-top:1px solid var(--line)}.back-link{font-size:.9375rem;color:var(--muted);font-weight:500}.back-link:hover{color:var(--accent)}.list{padding-top:var(--space-3)}.list-header{margin-bottom:var(--space-4)}.list-title{margin-bottom:var(--space-2)}.list-desc{color:var(--muted);font-size:1.0625rem}.notfound{text-align:center;padding-top:var(--space-6)}.notfound-code{font-family:var(--font-mono);font-size:.8125rem;color:var(--muted);letter-spacing:.2em;margin:0 0 var(--space-2)}.notfound-title{margin-bottom:var(--space-2)}.notfound-text{color:var(--muted);margin-bottom:var(--space-4)}.site-footer{border-top:1px solid var(--line);padding:var(--space-3)0;font-size:.8125rem;color:var(--muted)}.site-footer .wrap{display:flex;gap:.5rem;align-items:center}.site-footer .dot{color:var(--line-strong)}@media(max-width:720px){html{font-size:16px}.hero{grid-template-columns:1fr;gap:var(--space-3);padding-top:var(--space-4)}.hero-portrait{order:-1}.hero-portrait img{width:96px;height:96px;border-radius:var(--radius)}.project-grid{grid-template-columns:1fr}}