:root{--font-sans: "Roboto Mono", "SF Mono", "Menlo", monospace;--bg: #f5f6f8;--bg-alt: #eef0f3;--paper: #ffffff;--text: #1a1d24;--muted: #586072;--line: #d6dbe4;--accent: #2149a6;--accent-soft: rgba(33, 73, 166, .12)}[data-theme=dark]{--bg: #121417;--bg-alt: #191d22;--paper: #1a1f25;--text: #e9edf5;--muted: #98a4b9;--line: #2e3847;--accent: #80a4ff;--accent-soft: rgba(128, 164, 255, .18)}[data-theme=warm]{--bg: #f7efe2;--bg-alt: #f0e3d0;--paper: #fff7ec;--text: #32261a;--muted: #6f5d4a;--line: #d9c7af;--accent: #915a20;--accent-soft: rgba(145, 90, 32, .14)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:var(--font-sans);background:radial-gradient(circle at 15% 15%,var(--bg-alt),transparent 45%),radial-gradient(circle at 85% 10%,var(--accent-soft),transparent 30%),var(--bg);color:var(--text);line-height:1.65}a{color:inherit;text-decoration-color:color-mix(in oklab,var(--accent),transparent 40%);text-underline-offset:.22em}a:hover{color:var(--accent)}.shell{width:min(72rem,calc(100% - 2rem));margin:0 auto;padding:1.25rem 0 3rem;animation:fade-in .26s ease-out}.site-header{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:center;margin-bottom:1.75rem}.brand{text-transform:lowercase;letter-spacing:.08em;font-size:.85rem;text-decoration:none}.site-nav{display:flex;justify-content:center;gap:1rem}.site-nav a{text-decoration:none;font-size:.9rem;color:var(--muted)}.site-nav .active{color:var(--accent)}.theme-switcher{display:inline-flex;padding:.2rem;border:1px solid var(--line);border-radius:999px;background:var(--paper)}.theme-switcher button{border:0;background:transparent;color:var(--muted);border-radius:999px;padding:.35rem .75rem;font-family:inherit;font-size:.75rem;cursor:pointer}.theme-switcher button.active{background:var(--accent-soft);color:var(--accent)}.content{display:grid;gap:1.25rem}.panel{border:1px solid var(--line);border-radius:16px;background:color-mix(in oklab,var(--paper),transparent 4%);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:clamp(1.15rem,3vw,2rem);animation:rise .34s ease-out}.panel h1{margin:.25rem 0 .9rem;line-height:1.25;font-size:clamp(1.4rem,4vw,2rem)}.panel h2{margin:1.2rem 0 .6rem;font-size:1.1rem}.panel p{margin:.45rem 0;color:var(--muted)}.kicker{margin:0;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--accent)}.home-actions{margin-top:1rem}.button-link{display:inline-flex;text-decoration:none;background:var(--text);color:var(--paper);border-radius:999px;padding:.55rem 1rem;font-size:.8rem}.button-link:hover{color:var(--paper);opacity:.9}.section-divider{margin:1.2rem 0;height:1px;background:var(--line)}.post-list{list-style:none;margin:.5rem 0 0;padding:0;display:grid;gap:1rem}.post-list li{padding:.8rem;border-radius:10px;border:1px solid var(--line);background:color-mix(in oklab,var(--paper),transparent 10%)}.post-list h2,.post-list h3{margin:.2rem 0;font-size:1rem}.post-meta{margin:0;color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.1em}.tags{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.6rem}.tags span{display:inline-block;border:1px solid var(--line);border-radius:999px;padding:.2rem .55rem;font-size:.72rem;color:var(--muted)}.post-article{max-width:48rem;margin:0 auto}.markdown{color:var(--text)}.markdown>*{margin-top:.9rem;margin-bottom:0}.markdown h2,.markdown h3{margin-top:1.35rem}.markdown code{font-family:var(--font-sans);font-size:.88em;background:var(--accent-soft);border-radius:.35rem;padding:.1rem .3rem}.markdown pre{overflow:auto;border-radius:10px;border:1px solid var(--line);padding:.8rem;background:color-mix(in oklab,var(--paper),black 6%)}.markdown pre code{padding:0;background:transparent}.markdown blockquote{margin:1rem 0 0;border-left:3px solid var(--line);padding-left:.8rem;color:var(--muted)}.site-footer{margin-top:1.6rem;color:var(--muted);font-size:.75rem;text-align:center}@media (max-width: 720px){.site-header{grid-template-columns:1fr;justify-items:center;gap:.85rem}.site-nav{justify-content:center}.post-list li{padding:.75rem}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes rise{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}
