:root{--text:#f2efe6;--muted:#b7afa0;--faint:#6e685f;--line:#31302c;--accent:#ece4d3}.blog-layout{grid-template-columns:220px minmax(0,720px);justify-content:center;align-items:start;gap:3rem;width:100%;padding:2rem 0 4rem;display:grid}.blog-side{position:sticky;top:1.5rem}.back-link{color:var(--muted);margin-bottom:2rem;font-style:italic;text-decoration:none;display:inline-block}.blog-toc h2{color:var(--faint);letter-spacing:.08em;text-transform:uppercase;margin:0 0 .9rem;font-size:.82rem;font-weight:600}.blog-toc ul{border-left:1px solid var(--line);margin:0;padding:0;list-style:none}.blog-toc li{margin:0}.blog-toc a{color:var(--muted);padding:.38rem 0 .38rem 1rem;line-height:1.35;text-decoration:none;display:block}.blog-toc a:hover{color:var(--text)}.blog-toc .toc-level-1 a,.blog-toc .toc-level-2 a,.blog-toc .toc-level-3 a,.blog-toc .toc-level-4 a,.blog-toc .toc-level-5 a,.blog-toc .toc-level-6 a{padding-left:1rem}.blog-content{min-width:0;color:var(--text)}.post-header{margin-bottom:3rem}.post-header h1{margin:0;font-size:clamp(2rem,3vw,2.7rem);line-height:1.08}.post-date{color:var(--faint);margin:.75rem 0 0}.post-description{max-width:54ch;color:var(--muted);margin:2rem 0 0;line-height:1.8}.post-meta{color:var(--faint);flex-wrap:wrap;gap:1rem;margin-top:1rem;font-size:.92rem;display:flex}.blog-content h1,.blog-content h2,.blog-content h3,.blog-content h4,.blog-content h5,.blog-content h6{color:var(--text);margin-top:2.25rem;margin-bottom:.9rem;font-weight:700;line-height:1.2}.blog-content h1{font-size:2.2rem}.blog-content h2{font-size:1.55rem}.blog-content h3{font-size:1.25rem}.blog-content h4,.blog-content h5,.blog-content h6{font-size:1rem}.blog-content p,.blog-content li{color:var(--muted);line-height:1.85}.blog-content p{margin:1rem 0}.blog-content ul,.blog-content ol{margin:1rem 0;padding-left:1.4rem}.blog-content li+li{margin-top:.35rem}.blog-content a{color:var(--accent);text-underline-offset:.18em;text-decoration:underline}.blog-content :not(pre)>code{border:1px solid var(--line);color:var(--text);background:rgba(255,255,255,.03);border-radius:.35rem;padding:.12rem .38rem;font-family:Consolas,Courier New,monospace;font-size:.92em}.blog-content pre{border:1px solid var(--line);background:rgba(255,255,255,.03);border-radius:.85rem;margin:1.5rem 0;padding:1rem 1.1rem;overflow-x:auto}.blog-content pre code{color:var(--text);background:0 0;border:0;padding:0;font-family:Consolas,Courier New,monospace;font-size:.92rem}.blog-content blockquote{border-left:2px solid var(--line);color:var(--text);margin:1.5rem 0;padding-left:1rem}.blog-content hr{border:0;border-top:1px solid var(--line);margin:2rem 0}.blog-content img{border-radius:.85rem;max-width:100%;height:auto;margin:1.5rem 0;display:block}.blog-content table{border-collapse:collapse;width:100%;margin:1.5rem 0}.blog-content th,.blog-content td{border:1px solid var(--line);text-align:left;padding:.75rem .8rem}.blog-content .anchor{opacity:0;text-decoration:none;position:absolute;transform:translate(-1rem)}.blog-content h1:hover .anchor,.blog-content h2:hover .anchor,.blog-content h3:hover .anchor,.blog-content h4:hover .anchor,.blog-content h5:hover .anchor,.blog-content h6:hover .anchor{opacity:1}@media (width<=960px){.blog-layout{grid-template-columns:1fr;gap:2rem;width:min(720px,100%);margin:0 auto}.blog-side{position:static}}