:root{--bg:#0a0e1a;--fg:#e6e9f2;--muted:#9aa0b3;--accent:#38bdf8;--border:#252b42;--surface:#11141f;--surface2:#161b2e;--code-bg:#0d1018;--code-head:#0a0d15;--header-h:56px;color-scheme:dark}:root[data-theme=light]{--bg:#ffffff;--fg:#1a1f2e;--muted:#6b7280;--accent:#0284c7;--border:#e5e7eb;--surface:#f9fafb;--surface2:#f3f4f6;--code-bg:#f8fafc;--code-head:#f1f5f9;color-scheme:light}*{box-sizing:border-box}html{scroll-padding-top:calc(var(--header-h) + 1rem)}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--fg);min-height:100vh;display:flex;flex-direction:column}a{color:var(--accent)}.post-body a{text-decoration:underline;text-underline-offset:.15em}.post-body a:hover{text-decoration:none}.post-cover{display:block;width:100%;height:auto;border-radius:8px;margin-bottom:2rem}picture:has(>.post-cover){display:block;margin-bottom:2rem}picture>.post-cover{margin-bottom:0}.archive-subcats{display:flex;flex-wrap:wrap;gap:.5rem;margin:0 0 1.75rem}.archive-subcat{display:inline-block;padding:.3rem .85rem;border:1px solid var(--border);border-radius:999px;font-size:.9em;color:var(--fg);text-decoration:none}.archive-subcat:hover{border-color:var(--accent);color:var(--accent)}.sidebar-cat-tree .sidebar-cat-tree{margin:.25rem 0 .25rem .85rem;padding-left:.7rem;border-left:1px solid var(--border)}.archive-empty{color:var(--muted);padding:1.5rem 0}.skip-link{position:absolute;top:-100px;left:1rem;background:var(--accent);color:var(--bg);padding:.5rem 1rem;border-radius:4px;text-decoration:none;font-weight:600;z-index:1000}.skip-link:focus{top:.5rem}.container{max-width:860px;margin:0 auto;padding:2rem 1.5rem;line-height:1.6;width:100%}.container.wide{max-width:1200px}.container.tight{max-width:600px}.site-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--border);height:var(--header-h);display:flex;align-items:center}.site-header-inner{max-width:1200px;margin:0 auto;width:100%;padding:0 1.5rem;gap:1.5rem}.site-brand,.site-header-inner{display:flex;align-items:center}.site-brand{font-weight:700;font-size:1rem;color:var(--fg);text-decoration:none;gap:.5rem}.site-brand img{width:28px;height:28px;border-radius:4px}.site-nav{display:flex;gap:1rem;align-items:center;flex:1 1}.site-nav a{color:var(--muted);text-decoration:none;font-size:.9em;padding:.5rem .25rem;border-bottom:2px solid transparent;display:inline-flex;align-items:center;gap:.35rem;min-height:32px}.site-nav a:hover{color:var(--fg)}.site-nav a[aria-current=page]{color:var(--fg);border-bottom-color:var(--accent)}.site-nav-spacer{flex:1 1}.nav-item-has-children{position:relative}.nav-item-has-mega{position:static}.site-nav{position:relative}.nav-trigger{background:none;color:var(--muted);font-size:.9em;padding:.5rem .25rem;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem;border:none;border-bottom:2px solid transparent;min-height:32px;font-family:inherit}.nav-item-has-children.open .nav-trigger,.nav-item-has-mega.open .nav-trigger,.nav-trigger:hover{color:var(--fg)}.nav-caret{font-size:.7em;opacity:.7;transition:transform .2s}.nav-item-has-children.open .nav-caret,.nav-item-has-mega.open .nav-caret{transform:rotate(180deg)}.nav-dropdown{position:absolute;top:100%;left:0;min-width:220px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:.5rem;box-shadow:0 8px 24px rgba(0,0,0,.3);display:none;z-index:50}.nav-item-has-children.open .nav-dropdown{display:block}.nav-mega{position:absolute;top:100%;left:50%;transform:translateX(-50%);background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:1.25rem;box-shadow:0 8px 24px rgba(0,0,0,.3);display:none;z-index:50;width:min(960px,calc(100vw - 2rem));max-width:calc(100vw - 2rem)}.nav-item-has-mega.open .nav-mega{display:block}.nav-mega-grid{display:grid;grid-template-columns:repeat(var(--cols,3),minmax(0,1fr));gap:1.5rem}.nav-mega-col{min-width:0}.nav-mega-heading{font-size:.7em;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:.5rem;font-weight:600}.nav-sublink{display:flex!important;align-items:flex-start;gap:.6rem;padding:.5rem!important;border-radius:6px;border:none!important;width:100%}.nav-sublink:hover{background:var(--surface2,rgba(255,255,255,.05))}.nav-sublink-icon{font-size:1.1em;flex-shrink:0;line-height:1.2}.nav-sublink-body{display:flex;flex-direction:column;min-width:0}.nav-sublink-label{color:var(--fg);font-size:.9em;font-weight:500}.nav-sublink-desc{color:var(--muted);font-size:.78em;margin-top:.15rem;line-height:1.4}.nav-backdrop{position:fixed;inset:var(--header-h,56px) 0 0 0;background:rgba(0,0,0,.4);z-index:40;animation:navBdFadeIn .15s ease-out}@keyframes navBdFadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:640px){.nav-item-has-children,.nav-item-has-mega{width:100%}.nav-trigger{width:100%;padding:.75rem 1.5rem;border-bottom:1px solid var(--border);text-align:left;justify-content:space-between}.nav-dropdown,.nav-mega{position:static;transform:none;box-shadow:none;border:none;border-radius:0;padding:0;background:var(--surface2,rgba(255,255,255,.03))}.nav-mega{min-width:0}.nav-mega-grid{grid-template-columns:1fr;gap:.5rem}.nav-mega-col{padding:.5rem 1.5rem}.nav-mega-heading{padding:.5rem 0}.nav-sublink{padding:.75rem 1.5rem!important;border-radius:0}.nav-backdrop{display:none}}.menu-toggle{display:none;background:none;border:none;color:var(--fg);font-size:1.25rem;cursor:pointer;padding:.25rem}@media (max-width:640px){.menu-toggle{display:block}.site-nav{display:none;position:absolute;top:var(--header-h);left:0;right:0;background:var(--bg);border-bottom:1px solid var(--border);flex-direction:column;gap:0;padding:.5rem 0}.site-nav.open{display:flex}.site-nav a{padding:.75rem 1.5rem;width:100%;border-bottom:1px solid var(--border)}.site-nav a[aria-current=page]{border-left:3px solid var(--accent);border-bottom-color:var(--border)}}.site-footer{margin-top:auto;border-top:1px solid var(--border);background:color-mix(in srgb,var(--fg) 2%,transparent);color:var(--muted)}.site-footer a{color:var(--muted);text-decoration:none}.site-footer a:hover{color:var(--fg)}.site-footer-inner{max-width:1200px;margin:0 auto;padding:3rem 1.5rem 1.5rem}@media (max-width:768px){.site-footer-inner{padding:2rem 1.5rem 1.25rem}}.site-footer-top{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(0,2fr);gap:3rem;padding-bottom:2rem}@media (max-width:768px){.site-footer-top{grid-template-columns:1fr;gap:2rem}}.site-footer-brand{max-width:320px}@media (max-width:768px){.site-footer-brand{max-width:none}}.site-footer-logo{display:inline-flex;align-items:center;gap:.5rem;color:var(--fg)!important;font-size:1.05em;margin-bottom:.5rem}.site-footer-logo img{width:28px;height:28px;border-radius:4px}.site-footer-tagline{font-size:.9em;line-height:1.5;margin:.5rem 0 .75rem;color:var(--muted)}.site-footer-contact{display:inline-block;font-size:.85em;padding:.4rem .75rem;border:1px solid var(--border);border-radius:4px;margin-top:.5rem}.site-footer-social{display:flex;gap:.5rem;margin-top:1rem}.site-footer-social a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border);border-radius:50%;color:var(--fg)!important;font-size:1em;transition:border-color .15s ease,transform .12s ease}.site-footer-social a:hover{border-color:var(--accent);transform:translateY(-1px)}.site-footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}@media (max-width:640px){.site-footer-cols{grid-template-columns:repeat(2,1fr);gap:1.5rem}}@media (max-width:400px){.site-footer-cols{grid-template-columns:1fr}}.site-footer-col h3{font-size:.7em;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--fg);margin:0 0 .75rem}.site-footer-col ul{list-style:none;padding:0;margin:0}.site-footer-col li{padding:.3rem 0;font-size:.9em;line-height:1.4}.site-footer-bottom{padding-top:.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;font-size:.8em}.site-footer-copy strong{color:var(--fg)}.site-footer-meta{display:inline-flex;gap:.25rem;align-items:center}@media (max-width:600px){.site-footer-bottom{justify-content:center;text-align:center}}.site-main{flex:1 1}.with-sidebar{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:2.5rem}@media (max-width:900px){.with-sidebar{grid-template-columns:1fr;gap:2rem}}.blog-sidebar{font-size:.9em}.sidebar-widget{margin-bottom:2rem}.sidebar-heading{font-size:.75em;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:0 0 .75rem}.sidebar-list{list-style:none;padding:0;margin:0}.sidebar-list li{padding:.3rem 0;line-height:1.4}.sidebar-list a{color:var(--fg);text-decoration:none}.sidebar-list a:hover{color:var(--accent)}.sidebar-count{color:var(--muted);font-size:.85em;margin-left:.5em}.tag-cloud{line-height:1.8}.tag-cloud a{display:inline-block;margin-right:.5rem;color:var(--accent);text-decoration:none}.tag-cloud a:hover{text-decoration:underline}.post-with-toc{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:2.5rem}@media (max-width:1100px){.post-with-toc{grid-template-columns:1fr}.post-toc{display:none}}.post-toc{font-size:.85em}.post-toc h2{font-size:.75em;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:0 0 .5rem}.post-toc ul{list-style:none;padding:0;margin:0}.post-toc li{padding:.25rem 0;line-height:1.4}.post-toc li.lvl-3{padding-left:1rem;font-size:.95em}.post-toc a{color:var(--muted);text-decoration:none;border-left:2px solid transparent;padding-left:.5rem;display:block}.post-toc a:hover{color:var(--fg)}.post-toc a.active{color:var(--accent);border-left-color:var(--accent)}.post-sidebar{display:flex;flex-direction:column;gap:1.5rem;position:sticky;top:calc(var(--header-h) + 1.5rem);align-self:start}@media (max-width:1100px){.post-sidebar{display:none}}.home-hero{border-bottom:1px solid var(--border);padding:4rem 0 3.5rem;background:radial-gradient(ellipse at top,color-mix(in srgb,var(--accent) 8%,transparent),transparent 60%),var(--bg);text-align:center}.home-hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;margin:0 0 .75rem;letter-spacing:-.02em}.home-hero-tagline{color:var(--muted);font-size:clamp(1rem,2vw,1.25rem);margin:0 auto 1.75rem;max-width:600px;line-height:1.5}.home-hero-cta{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap}.btn-ghost,.btn-primary{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.25rem;border-radius:6px;font-weight:600;text-decoration:none;font-size:.95em;transition:transform .12s ease,background-color .12s ease}.btn-primary{background:var(--accent);color:var(--bg)}.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.08)}.btn-ghost{border:1px solid var(--border);color:var(--fg)}.btn-ghost:hover{background:color-mix(in srgb,var(--fg) 5%,transparent)}.home-section{margin:3.5rem 0}.home-section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:1.25rem}.home-section-head h2{font-size:1.3rem;font-weight:700;margin:0}.home-section-link{color:var(--accent);text-decoration:none;font-size:.9em}.home-featured-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}@media (max-width:900px){.home-featured-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.home-featured-grid{grid-template-columns:1fr}}.home-card{background:color-mix(in srgb,var(--fg) 3%,transparent);border:1px solid var(--border);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;transition:transform .15s ease,border-color .15s ease}.home-card:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent) 50%,var(--border))}.home-card-cover{display:block;aspect-ratio:16/9;background:var(--border);overflow:hidden}.home-card-cover img{width:100%;height:100%;object-fit:cover}.home-card-body{padding:1rem 1.25rem 1.25rem}.home-card-cat{display:inline-block;font-size:.7em;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);text-decoration:none;margin-bottom:.5rem}.home-card h3{font-size:1.1rem;font-weight:700;line-height:1.3;margin:0 0 .5rem}.home-card h3 a{color:var(--fg);text-decoration:none}.home-card p{color:#b3b8c8;font-size:.92em;line-height:1.5;margin:0 0 .75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.home-card-meta{color:var(--muted);font-size:.8em}.home-cats{display:flex;flex-wrap:wrap;gap:.5rem}.home-cat-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid var(--border);border-radius:999px;color:var(--fg);text-decoration:none;font-size:.9em;transition:border-color .15s ease,transform .12s ease}.home-cat-chip:hover{border-color:var(--accent);transform:translateY(-1px)}.home-cat-count{color:var(--muted);font-size:.85em;padding:.1rem .45rem;background:var(--border);border-radius:999px}.home-recent-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:0}@media (max-width:700px){.home-recent-list{grid-template-columns:1fr}}.home-recent-list li{padding:1rem 0;border-bottom:1px solid var(--border)}.home-recent-list li:nth-child(2n){padding-left:1.5rem}@media (max-width:700px){.home-recent-list li:nth-child(2n){padding-left:0}}.home-recent-list a{display:block;font-weight:600;color:var(--fg);text-decoration:none;margin-bottom:.2rem;line-height:1.4}.home-recent-list a:hover{color:var(--accent)}.home-recent-meta{color:var(--muted);font-size:.8em}.home-empty{background:color-mix(in srgb,var(--fg) 5%,transparent);padding:2rem;border-radius:8px;margin:2rem 0}.home-empty h2{font-size:1.2rem;margin-top:0;color:var(--accent)}.home-empty ul{padding-left:1.25rem;color:#b3b8c8;line-height:1.7}.home-empty a{color:var(--accent)}.ad-slot{display:flex;justify-content:center;align-items:center;margin:1.5rem auto;width:100%;background:color-mix(in srgb,var(--fg) 3%,transparent);border:1px dashed var(--border);border-radius:6px;overflow:hidden;position:relative;font-size:.8em;color:var(--muted)}.ad-slot:before{content:"Advertisement";position:absolute;top:.25rem;right:.5rem;font-size:.65em;text-transform:uppercase;letter-spacing:.1em;color:color-mix(in srgb,var(--muted) 70%,transparent);pointer-events:none}.ad-slot-inner{width:100%;text-align:center}.ad-slot iframe,.ad-slot img,.ad-slot ins.adsbygoogle,.ad-slot>*{max-width:100%!important;height:auto}.ad-slot--footer-banner,.ad-slot--header-banner{min-height:90px;max-width:970px}@media (max-width:768px){.ad-slot--footer-banner,.ad-slot--header-banner{min-height:50px}}.ad-slot--sidebar-top{min-height:250px;max-width:300px}.ad-slot--sidebar-mid{min-height:600px;max-width:300px}@media (max-width:900px){.ad-slot--sidebar-mid,.ad-slot--sidebar-top{max-width:336px;position:static;margin:1rem auto}}.ad-slot--in-article-1,.ad-slot--in-article-2{min-height:250px;max-width:728px;margin:2rem auto}@media (max-width:500px){.ad-slot--in-article-1,.ad-slot--in-article-2{min-height:150px}}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}@media (max-width:480px){.form-row-2{grid-template-columns:1fr}}.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--bg);border-top:1px solid var(--border);padding:1rem 1.25rem;box-shadow:0 -4px 20px rgba(0,0,0,.3)}.cookie-banner-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap}.cookie-banner-text{flex:1 1;min-width:280px;font-size:.9em;line-height:1.5;color:var(--fg)}.cookie-banner-text a{color:var(--accent)}.cookie-banner-actions{display:flex;gap:.5rem;flex-wrap:wrap}.cookie-btn-ghost,.cookie-btn-primary{padding:.6rem 1.25rem;border-radius:6px;font-weight:600;font-size:.9em;cursor:pointer;border:1px solid transparent}.cookie-btn-primary{background:var(--accent);color:var(--bg)}.cookie-btn-ghost{background:transparent;color:var(--fg);border-color:var(--border)}.cookie-btn-ghost:hover{background:color-mix(in srgb,var(--fg) 5%,transparent)}@media (max-width:640px){.cookie-banner-actions{width:100%}.cookie-btn-ghost,.cookie-btn-primary{flex:1 1}}.ad-slot--mobile-anchor{display:none}@media (max-width:640px){.ad-slot--mobile-anchor{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:40;margin:0;border-radius:0;background:var(--bg);border-top:1px solid var(--border);border-bottom:none;min-height:60px;max-width:none}body{padding-bottom:60px}}.ad-anchor-close{position:absolute;top:4px;right:6px;width:24px;height:24px;background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:50%;font-size:16px;line-height:1;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;z-index:2}.ad-anchor-close:hover{background:rgba(0,0,0,.85)}#back-to-top{position:fixed;right:1.5rem;bottom:1.5rem;width:44px;height:44px;border-radius:999px;background:rgba(13,16,24,.85);color:#e6e9f2;border:1px solid #252b42;font-size:18px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;z-index:50;box-shadow:0 8px 24px -4px rgba(0,0,0,.4);opacity:0;transform:translateY(8px);pointer-events:none;transition:opacity .2s,transform .2s,background .15s,border-color .15s}#back-to-top.show{opacity:1;transform:none;pointer-events:auto}#back-to-top:hover{background:#0d1018;border-color:#38bdf8;color:#38bdf8}@media (max-width:640px){#back-to-top{right:1rem;bottom:5rem}}#quick-edit{position:fixed;left:1.5rem;bottom:1.5rem;padding:0 14px;height:40px;border-radius:999px;background:rgba(56,189,248,.12);color:#38bdf8;border:1px solid rgba(56,189,248,.35);font-size:13px;font-weight:600;text-decoration:none;display:none;align-items:center;gap:6px;z-index:50;box-shadow:0 8px 24px -4px rgba(0,0,0,.4);transition:background .15s,border-color .15s,transform .15s}#quick-edit.show{display:inline-flex}#quick-edit:hover{background:rgba(56,189,248,.22);border-color:#38bdf8;transform:translateY(-1px)}@media (max-width:640px){#quick-edit{left:1rem;bottom:5rem}}.header-search-trigger{margin-left:auto;display:inline-flex;align-items:center;gap:8px;padding:6px 10px 6px 12px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:8px;color:var(--muted);font-size:.85em;cursor:pointer;min-width:220px;font-family:inherit;transition:border-color .15s,background .15s}.header-search-trigger:hover{border-color:var(--accent);color:var(--fg)}.header-search-trigger>span:nth-child(2){flex:1 1;text-align:left}.header-search-trigger kbd{font-family:ui-monospace,Menlo,monospace;font-size:.75em;padding:2px 6px;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:4px;color:var(--muted)}.header-search-overlay{position:fixed;inset:0;background:rgba(5,8,16,.65);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:9000;display:flex;justify-content:center;padding-top:12vh;animation:hsFade .15s ease-out}@keyframes hsFade{0%{opacity:0}to{opacity:1}}.header-search-panel{width:min(680px,92vw);height:-moz-fit-content;height:fit-content;background:#11141f;border:1px solid #2a3151;border-radius:12px;box-shadow:0 30px 80px -10px rgba(0,0,0,.7),0 0 0 1px rgba(56,189,248,.08);overflow:hidden;animation:hsPop .2s cubic-bezier(.16,1,.3,1)}@keyframes hsPop{0%{opacity:0;transform:scale(.97) translateY(-6px)}to{opacity:1;transform:none}}.header-search-inputrow{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid #1d2440;background:#0a0d15}.header-search-inputrow input{flex:1 1;background:transparent;border:0;outline:none;color:var(--fg);font-size:1.05em;font-family:inherit}.header-search-close{background:transparent;border:1px solid var(--border);color:var(--muted);border-radius:6px;width:26px;height:26px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.header-search-close:hover{color:var(--fg);border-color:var(--accent)}.header-search-status{padding:8px 16px;font-size:.8em;color:var(--muted)}.header-search-results{list-style:none;padding:0;margin:0;max-height:60vh;overflow-y:auto}.header-search-results a{display:block;padding:10px 16px;text-decoration:none;color:var(--fg);border-left:2px solid transparent}.header-search-results a.active{background:rgba(56,189,248,.08);border-left-color:var(--accent)}.hsr-title{display:block;font-weight:500;font-size:.95em}.hsr-meta{display:block;margin-top:2px;font-size:.75em;color:var(--muted)}.header-search-all{display:block;padding:12px 16px;border-top:1px solid #1d2440;background:#0a0d15;color:var(--accent);font-size:.85em;text-decoration:none}.header-search-all:hover{background:#0d1018}@media (max-width:640px){.header-search-trigger{min-width:0;padding:6px 10px}.header-search-trigger kbd,.header-search-trigger>span:nth-child(2){display:none}.header-search-overlay{padding-top:4vh}}:root[data-theme=light] body{background:var(--bg);color:var(--fg)}:root[data-theme=light] .site-header{background:color-mix(in srgb,var(--bg) 92%,transparent)}:root[data-theme=light] .site-brand,:root[data-theme=light] .site-header-inner{color:var(--fg)}:root[data-theme=light] .site-nav a{color:var(--muted)}:root[data-theme=light] .site-nav a:hover,:root[data-theme=light] .site-nav a[aria-current=page]{color:var(--fg)}:root[data-theme=light] .nav-trigger{color:var(--muted)}:root[data-theme=light] .nav-item-has-children.open .nav-trigger,:root[data-theme=light] .nav-item-has-mega.open .nav-trigger,:root[data-theme=light] .nav-trigger:hover{color:var(--fg)}:root[data-theme=light] .nav-dropdown,:root[data-theme=light] .nav-mega{background:var(--bg);border-color:var(--border);box-shadow:0 8px 24px rgba(0,0,0,.08)}:root[data-theme=light] .nav-sublink-label{color:var(--fg)}:root[data-theme=light] .nav-sublink-desc{color:var(--muted)}:root[data-theme=light] .nav-sublink:hover{background:var(--surface2)}:root[data-theme=light] .nav-backdrop{background:rgba(0,0,0,.12)}:root[data-theme=light] .menu-toggle{color:var(--fg)}:root[data-theme=light] .header-search-trigger{background:var(--surface);border-color:var(--border);color:var(--muted)}:root[data-theme=light] .header-search-trigger:hover{color:var(--fg);border-color:var(--accent)}:root[data-theme=light] .header-search-trigger kbd{background:var(--surface2);color:var(--muted);border-color:var(--border)}:root[data-theme=light] .header-search-overlay{background:rgba(15,23,42,.4)}:root[data-theme=light] .header-search-panel{background:var(--bg);border-color:var(--border)}:root[data-theme=light] .header-search-inputrow{background:var(--surface);border-color:var(--border)}:root[data-theme=light] .header-search-inputrow input{color:var(--fg)}:root[data-theme=light] .header-search-close{color:var(--muted);border-color:var(--border)}:root[data-theme=light] .header-search-close:hover{color:var(--fg);border-color:var(--accent)}:root[data-theme=light] .header-search-results a{color:var(--fg)}:root[data-theme=light] .header-search-results a.active{background:rgba(2,132,199,.08);border-left-color:var(--accent)}:root[data-theme=light] .hsr-meta{color:var(--muted)}:root[data-theme=light] .header-search-all{background:var(--surface);border-color:var(--border);color:var(--accent)}:root[data-theme=light] #back-to-top{background:var(--bg);border-color:var(--border);color:var(--fg)}:root[data-theme=light] #back-to-top:hover{background:var(--surface);border-color:var(--accent);color:var(--accent)}:root[data-theme=light] #quick-edit{background:rgba(2,132,199,.1);color:var(--accent);border-color:rgba(2,132,199,.35)}:root[data-theme=light] .site-footer{background:var(--surface);border-color:var(--border);color:var(--muted)}:root[data-theme=light] .site-footer a{color:var(--accent)}:root[data-theme=light] .site-footer-bottom{border-color:var(--border)}.theme-toggle{background:transparent;border:1px solid var(--border);color:var(--fg);width:36px;height:36px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:16px;line-height:1;padding:0;transition:border-color .15s,background .15s,transform .15s}.theme-toggle:hover{border-color:var(--accent);transform:scale(1.05)}body:has([data-route=archive]) #footer-banner,body:has([data-route=archive]) .ad-slot,body:has([data-route=archive]) [id*=anchor].ad-slot,body:has([data-route=home]) #footer-banner,body:has([data-route=home]) .ad-slot,body:has([data-route=home]) [id*=anchor].ad-slot,body:has([data-route=utility]) #footer-banner,body:has([data-route=utility]) .ad-slot,body:has([data-route=utility]) [id*=anchor].ad-slot{display:none!important}.home-custom{padding-top:1rem}.home-custom h1{font-size:clamp(2rem,5vw,3.5rem);line-height:1.1;margin:2rem 0 1rem;letter-spacing:-.02em}.home-custom h2{font-size:clamp(1.5rem,3vw,2.1rem);margin:3rem 0 1rem;letter-spacing:-.01em}.home-custom h3{font-size:1.35rem;margin:2rem 0 .75rem}.home-custom p{font-size:1.075rem;line-height:1.7;margin:0 0 1.25rem;color:var(--fg)}.home-custom>.container.wide>p:first-of-type{font-size:1.2rem;color:var(--muted)}.home-custom ol,.home-custom ul{font-size:1.05rem;line-height:1.7}.home-custom img{width:100%;height:auto;border-radius:12px;margin:2rem 0}.home-custom .figure.img{margin:2.5rem 0}.home-custom blockquote{border-left:4px solid var(--accent);padding:.5rem 1.5rem;margin:2rem 0;font-size:1.15rem;font-style:italic;color:var(--muted)}.home-custom .cols-2,.home-custom .cols-3,.home-custom .cols-4{gap:2rem;margin:2.5rem 0}.home-custom .callout{margin:2.5rem 0;padding:1.5rem;font-size:1.05rem}.home-custom a{color:var(--accent);text-decoration:none;font-weight:500}.home-custom a:hover{text-decoration:underline}.archive-crumbs{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;font-size:.85em;color:var(--muted);margin-bottom:1rem}.archive-crumbs a{color:var(--muted);text-decoration:none}.archive-crumbs a:hover{color:var(--fg)}.archive-crumbs span[aria-hidden]{opacity:.4}.archive-header{position:relative;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.archive-kicker{display:inline-block;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:.5rem}.archive-title{font-size:clamp(2rem,4vw,2.75rem);font-weight:800;line-height:1.1;margin:0 0 .5rem}.archive-meta{color:var(--muted);margin:0;font-size:.9rem}.archive-rss{color:var(--accent);text-decoration:none}.archive-rss:hover{text-decoration:underline}.archive-featured{display:grid;grid-template-columns:1.1fr 1fr;gap:0;margin-bottom:2.5rem;border-radius:14px;overflow:hidden;border:1px solid var(--border);background:var(--surface);text-decoration:none;color:inherit;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.archive-featured:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 12px 32px -16px rgba(0,0,0,.5)}.archive-featured-media{min-height:280px;background-size:cover;background-position:50%;background-color:var(--surface2)}.archive-featured-body{padding:1.75rem 2rem;display:flex;flex-direction:column;justify-content:center}.archive-featured-body h2{font-size:1.5rem;font-weight:700;line-height:1.3;margin:.5rem 0 .75rem}.archive-featured-body p{color:var(--muted);margin:0 0 1rem;line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}@media (max-width:760px){.archive-featured{grid-template-columns:1fr}.archive-featured-media{min-height:200px}.archive-featured-body{padding:1.25rem}}.archive-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:.5rem}.post-card{display:flex;flex-direction:column;border-radius:12px;overflow:hidden;background:var(--surface);border:1px solid var(--border);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.post-card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 14px 30px -18px rgba(0,0,0,.55)}.post-card-media{display:block;aspect-ratio:16/9;background:var(--surface2);overflow:hidden;line-height:0}.post-card-media img{transition:transform .4s ease}.post-card:hover .post-card-media img{transform:scale(1.04)}.post-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--surface2),var(--surface));color:var(--muted);font-size:3rem;font-weight:800}.post-card-body{padding:1.1rem 1.25rem 1.25rem;display:flex;flex-direction:column;gap:.5rem;flex:1 1}.post-card-cat{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:700;text-decoration:none}.post-card-cat:hover{text-decoration:underline}.post-card-title{font-size:1.05rem;font-weight:700;line-height:1.35;margin:0}.post-card-title a{color:var(--fg);text-decoration:none}.post-card-title a:hover{color:var(--accent)}.post-card-desc{color:var(--muted);margin:0;font-size:.9rem;line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-card-meta{margin-top:auto;padding-top:.5rem;color:var(--muted);font-size:.8rem;display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.post-card-meta span[aria-hidden]{opacity:.4}[data-theme-variant=magazine]{--accent:#c8956d;--accent-hover:#d9a87b;--font-display:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--font-body:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--measure:72ch}[data-theme-variant=magazine] body{font-family:var(--font-body);font-size:1.05rem;line-height:1.75}[data-theme-variant=magazine] .archive-title,[data-theme-variant=magazine] .home-hero-title,[data-theme-variant=magazine] .post-card-title,[data-theme-variant=magazine] h1,[data-theme-variant=magazine] h2,[data-theme-variant=magazine] h3{font-family:var(--font-display);font-weight:800;letter-spacing:-.02em}[data-theme-variant=magazine] .archive-title{font-size:clamp(2.5rem,5vw,4rem);line-height:1.05}[data-theme-variant=magazine] .archive-kicker{font-family:var(--font-body);font-style:italic;text-transform:none;letter-spacing:0;color:var(--accent)}[data-theme-variant=magazine] .post-body>p:first-of-type:first-letter{font-family:var(--font-display);font-size:4.5rem;line-height:1;float:left;padding:.1em .15em 0 0;margin-top:.1em;color:var(--accent);font-weight:800}[data-theme-variant=magazine] .archive-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2.5rem 2rem}[data-theme-variant=magazine] .post-card{background:transparent;border:none;border-bottom:1px solid var(--border);border-radius:0;padding-bottom:1.5rem}[data-theme-variant=magazine] .post-card-body{padding:1rem 0 0}[data-theme-variant=magazine] .post-card-media{border-radius:4px}[data-theme-variant=magazine] .post-card-cat{font-family:var(--font-body);font-style:italic;text-transform:none;letter-spacing:0;font-size:.85rem}[data-theme-variant=magazine] .post-card-title{font-size:1.4rem;line-height:1.25}[data-theme-variant=magazine] .post-body h2{border-bottom:2px solid var(--accent);padding-bottom:.4rem;margin-top:3rem}[data-theme-variant=magazine] .post-body blockquote{font-family:var(--font-display);font-style:italic;font-size:1.4rem;border-left:4px solid var(--accent);padding-left:1.5rem;margin:2rem 0;color:var(--fg)}[data-theme-variant=magazine] .archive-featured{grid-template-columns:1fr;border:none;background:transparent;margin-bottom:4rem}[data-theme-variant=magazine] .archive-featured-media{min-height:420px;border-radius:4px}[data-theme-variant=magazine] .archive-featured-body h2{font-size:clamp(1.75rem,3vw,2.5rem);font-family:var(--font-display)}[data-theme-variant=portfolio]{--accent:#ec4899;--accent-hover:#f472b6;--font-display:"Inter Display","Inter",system-ui,sans-serif;--font-body:"Inter",system-ui,sans-serif;--font-mono:"JetBrains Mono","Fira Code",ui-monospace,monospace;--bg:#f7f7f5;--surface:#ffffff;--surface2:#eeeeec;--fg:#18181b;--muted:#71717a;--border:#e4e4e7}[data-theme-variant=portfolio] body{font-family:var(--font-body);font-feature-settings:"ss01","cv11"}[data-theme-variant=portfolio] .site-header{background:var(--bg);-webkit-backdrop-filter:none;backdrop-filter:none;border-bottom:1px solid var(--border)}[data-theme-variant=portfolio] .archive-kicker,[data-theme-variant=portfolio] .post-card-cat{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.05em}[data-theme-variant=portfolio] .post-card-meta span,[data-theme-variant=portfolio] .post-card-meta time{font-family:var(--font-mono);font-size:.75rem}[data-theme-variant=portfolio] .archive-title{font-family:var(--font-display);font-size:clamp(3rem,7vw,6rem);font-weight:900;letter-spacing:-.04em;line-height:.9}[data-theme-variant=portfolio] .archive-grid{grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:4rem 2rem}[data-theme-variant=portfolio] .post-card{background:transparent;border:none;border-radius:0;box-shadow:none;overflow:visible}[data-theme-variant=portfolio] .post-card:hover{transform:none;border:none;box-shadow:none}[data-theme-variant=portfolio] .post-card-media{aspect-ratio:4/3;border-radius:2px;overflow:hidden}[data-theme-variant=portfolio] .post-card:hover .post-card-media img{transform:scale(1.02)}[data-theme-variant=portfolio] .post-card-body{padding:.9rem 0 0;gap:.35rem}[data-theme-variant=portfolio] .post-card-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;letter-spacing:-.02em}[data-theme-variant=portfolio] .post-card-title a{background:linear-gradient(transparent 60%,var(--accent) 60%);background-size:0 100%;background-repeat:no-repeat;transition:background-size .3s ease}[data-theme-variant=portfolio] .post-card-title a:hover{background-size:100% 100%;color:var(--fg)}[data-theme-variant=portfolio] .archive-featured{grid-template-columns:1fr;border:none;background:var(--surface);border-radius:2px;margin-bottom:4rem;overflow:hidden}[data-theme-variant=portfolio] .archive-featured-media{min-height:480px;aspect-ratio:16/9}[data-theme-variant=portfolio] .archive-featured-body{padding:3rem}[data-theme-variant=portfolio] .archive-featured-body h2{font-family:var(--font-display);font-size:clamp(2rem,4vw,3.5rem);font-weight:800;letter-spacing:-.03em;line-height:1.05}[data-theme-variant=portfolio] .site-header-nav a{font-family:var(--font-mono);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}[data-theme-variant=portfolio] .post-body h1,[data-theme-variant=portfolio] .post-body h2,[data-theme-variant=portfolio] .post-body h3{font-family:var(--font-display);letter-spacing:-.02em}[data-theme-variant=portfolio] .post-body img{border-radius:2px}[data-theme-variant=portfolio] .post-body code{font-family:var(--font-mono);background:var(--surface2);color:var(--accent);padding:.1em .35em;border-radius:2px}[data-theme-variant=noir]{--bg:#000000;--fg:#fafafa;--muted:#888888;--accent:#00e5ff;--accent-hover:#5cefff;--border:#1a1a1a;--surface:#0a0a0a;--surface2:#141414;--font-display:"Helvetica Neue","Arial",system-ui,sans-serif}[data-theme-variant=noir] body{letter-spacing:.01em}[data-theme-variant=noir] .archive-title,[data-theme-variant=noir] .home-hero-title,[data-theme-variant=noir] .post-body h1,[data-theme-variant=noir] .post-body h2,[data-theme-variant=noir] .post-card-title{font-family:var(--font-display);font-weight:900;text-transform:uppercase;letter-spacing:-.01em}[data-theme-variant=noir] .archive-title{font-size:clamp(2.5rem,6vw,5rem)}[data-theme-variant=noir] .archive-kicker{color:var(--accent);letter-spacing:.3em}[data-theme-variant=noir] .archive-featured,[data-theme-variant=noir] .archive-featured-media,[data-theme-variant=noir] .post-body img,[data-theme-variant=noir] .post-card,[data-theme-variant=noir] .post-card-media{border-radius:0}[data-theme-variant=noir] .post-card{background:var(--surface);border:1px solid var(--border)}[data-theme-variant=noir] .post-card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 12px 40px -12px rgba(0,229,255,.25)}[data-theme-variant=noir] .post-card-cat{color:var(--accent)}[data-theme-variant=noir] .site-header{background:rgba(0,0,0,.85);border-bottom:1px solid var(--border)}[data-theme-variant=noir] a{color:var(--accent)}[data-theme-variant=noir] .btn-primary{background:var(--accent);color:#000;border-radius:0;font-weight:700}[data-theme-variant=warm]{--bg:#faf6ef;--fg:#3a3027;--muted:#8a7d6b;--accent:#b06a3b;--accent-hover:#c47d4d;--border:#e8ddca;--surface:#fffdf8;--surface2:#f3ecdf;--font-display:"Lora",Georgia,"Times New Roman",serif;--font-body:"Lora",Georgia,serif;color-scheme:light}[data-theme-variant=warm] body{font-family:var(--font-body);font-size:1.08rem;line-height:1.8}[data-theme-variant=warm] .archive-title,[data-theme-variant=warm] .home-hero-title,[data-theme-variant=warm] .post-body h1,[data-theme-variant=warm] .post-body h2,[data-theme-variant=warm] .post-body h3,[data-theme-variant=warm] .post-card-title{font-family:var(--font-display);font-weight:700}[data-theme-variant=warm] .archive-kicker{font-style:italic;text-transform:none;letter-spacing:0;color:var(--accent)}[data-theme-variant=warm] .post-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:0 2px 12px -6px rgba(58,48,39,.12)}[data-theme-variant=warm] .post-card:hover{border-color:var(--accent);box-shadow:0 12px 28px -12px rgba(176,106,59,.3)}[data-theme-variant=warm] .archive-featured-media,[data-theme-variant=warm] .post-card-media{border-radius:12px 12px 0 0}[data-theme-variant=warm] .post-body blockquote{font-family:var(--font-display);font-style:italic;border-left:3px solid var(--accent);color:var(--accent)}[data-theme-variant=warm] .site-header{background:rgba(250,246,239,.9);border-bottom:1px solid var(--border)}[data-theme-variant=terminal]{--bg:#0c0f0c;--fg:#c8e6c8;--muted:#5a7a5a;--accent:#39ff14;--accent-hover:#6cff52;--border:#1c2a1c;--surface:#0f140f;--surface2:#141c14;--font-display:"JetBrains Mono","Fira Code",ui-monospace,monospace;--font-body:"JetBrains Mono",ui-monospace,monospace}[data-theme-variant=terminal] body{font-family:var(--font-body);font-size:.95rem;line-height:1.7}[data-theme-variant=terminal] *{font-family:inherit}[data-theme-variant=terminal] .archive-title,[data-theme-variant=terminal] .home-hero-title,[data-theme-variant=terminal] .post-card-title{font-family:var(--font-display);font-weight:700}[data-theme-variant=terminal] .archive-title:before{content:"$ ";color:var(--accent)}[data-theme-variant=terminal] .post-body h2:before{content:"## ";color:var(--accent);opacity:.6}[data-theme-variant=terminal] .post-body h3:before{content:"### ";color:var(--accent);opacity:.5}[data-theme-variant=terminal] .archive-kicker{color:var(--accent)}[data-theme-variant=terminal] .archive-kicker:before{content:"> "}[data-theme-variant=terminal] .post-card{background:var(--surface);border:1px solid var(--border);border-radius:4px}[data-theme-variant=terminal] .post-card:hover{border-color:var(--accent);box-shadow:0 0 16px -4px rgba(57,255,20,.3)}[data-theme-variant=terminal] .post-card-cat{color:var(--accent)}[data-theme-variant=terminal] .post-card-cat:before{content:"#"}[data-theme-variant=terminal] a{color:var(--accent);text-decoration:underline}[data-theme-variant=terminal] .site-header{background:rgba(12,15,12,.92);border-bottom:1px solid var(--accent)}[data-theme-variant=terminal] .post-card-media{filter:brightness(.92) contrast(1.05)}[data-theme-variant=pastel]{--bg:#fdfbff;--fg:#44405a;--muted:#9b95b3;--accent:#a78bfa;--accent-hover:#b9a3fc;--border:#ece8f8;--surface:#ffffff;--surface2:#f6f3fd;--font-display:"Quicksand","Nunito",system-ui,sans-serif;--font-body:"Nunito",system-ui,sans-serif;color-scheme:light}[data-theme-variant=pastel] body{font-family:var(--font-body)}[data-theme-variant=pastel] .archive-title,[data-theme-variant=pastel] .home-hero-title,[data-theme-variant=pastel] .post-body h1,[data-theme-variant=pastel] .post-body h2,[data-theme-variant=pastel] .post-card-title{font-family:var(--font-display);font-weight:700}[data-theme-variant=pastel] .archive-title{background:linear-gradient(120deg,#a78bfa,#f0a6ca);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}[data-theme-variant=pastel] .archive-kicker{color:var(--accent);text-transform:none;letter-spacing:.05em}[data-theme-variant=pastel] .post-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;box-shadow:0 4px 16px -8px rgba(167,139,250,.2)}[data-theme-variant=pastel] .post-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 16px 32px -12px rgba(167,139,250,.35)}[data-theme-variant=pastel] .archive-featured-media,[data-theme-variant=pastel] .post-card-media{border-radius:16px 16px 0 0}[data-theme-variant=pastel] .post-card-cat{background:var(--surface2);color:var(--accent);padding:.2em .7em;border-radius:999px;text-transform:none;letter-spacing:0;font-weight:700}[data-theme-variant=pastel] .btn-primary{background:linear-gradient(120deg,#a78bfa,#f0a6ca);border-radius:999px;color:#fff;border:none;font-weight:700}[data-theme-variant=pastel] .site-header{background:rgba(253,251,255,.9);border-bottom:1px solid var(--border)}[data-theme-variant=pastel] .post-body img{border-radius:16px}.post-body h1,.post-body h2,.post-body h3,.post-body h4{font-weight:700;line-height:1.3;margin:2rem 0 .75rem}.post-body h2{font-size:1.5rem}.post-body h3{font-size:1.25rem}.post-body h4{font-size:1.1rem}.post-body ol,.post-body p,.post-body ul{margin:0 0 1rem}.post-body ol,.post-body ul{padding-left:1.5rem}.post-body li{margin-bottom:.25rem}.post-body a{color:#38bdf8}.post-body code{background:#171b2e;padding:.15em .4em;border-radius:4px;font-size:.9em;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.post-body pre{background:#0a0e1a;border:1px solid #252b42;border-radius:6px;padding:1rem;overflow-x:auto;margin:0 0 1rem}.post-body pre code{background:transparent;padding:0;font-size:.85em}.post-body blockquote{border-left:3px solid #38bdf8;padding-left:1rem;margin:0 0 1rem;color:#b3b8c8}.post-body img{max-width:100%;height:auto;border-radius:6px;margin:1.5rem 0}.post-body hr{border:none;border-top:1px solid #252b42;margin:2rem 0}.post-body table{border-collapse:collapse;margin:0 0 1rem;width:100%}.post-body td,.post-body th{border:1px solid #252b42;padding:.5rem .75rem}.post-body th{background:#171b2e;text-align:left}.post-body video{max-width:100%;height:auto}.post-body picture,.post-body video{display:block;margin:1.5rem auto}.post-body picture img{margin:0 auto}.post-body a,.post-body code{word-wrap:break-word;overflow-wrap:anywhere}@media (max-width:600px){.post-body table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}}.post-body iframe{display:block;max-width:100%;margin:1.5rem auto;aspect-ratio:16/9;width:100%;height:auto;border:0}.post-body .code-block,.post-preview .code-block{position:relative;margin:1rem 0;border:1px solid #1d2440;border-radius:8px;background:#0d1018;overflow:hidden;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.code-block-head{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-bottom:1px solid #1d2440;background:#0a0d15;color:#7c8294;font-size:.78em;min-height:2rem}.code-block.tall:not(.expanded) pre{max-height:480px;overflow:hidden;position:relative}.code-block.tall:not(.expanded):after{content:"";position:absolute;left:0;right:0;bottom:36px;height:80px;background:linear-gradient(180deg,rgba(13,16,24,0) 0,#0d1018);pointer-events:none}.code-expand{display:none;width:100%;border:0;border-top:1px solid #1d2440;background:#0a0d15;color:#7c8294;font-size:.78em;padding:.5rem;cursor:pointer;font-family:inherit}.code-expand:hover{color:#e6e9f2;background:#0f1422}.code-block.tall .code-expand{display:block}.code-fullscreen,.code-wrap{background:transparent;border:1px solid #1d2440;color:#7c8294;border-radius:4px;width:24px;height:24px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:14px;line-height:1;padding:0}.code-wrap{margin-left:auto}.code-fullscreen:hover,.code-wrap:hover{color:#e6e9f2;border-color:#38bdf8}.code-block.wrap pre,.code-block.wrap pre code{white-space:pre-wrap;word-break:break-word}.code-wrap.active{color:#38bdf8;border-color:#38bdf8}.code-block-head .code-copy{margin-left:0}.code-fullscreen-overlay{position:fixed;inset:0;background:rgba(5,8,16,.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:2.5rem;animation:codeFsFade .18s ease-out}@keyframes codeFsFade{0%{opacity:0}to{opacity:1}}.code-fullscreen-overlay .code-block{width:min(1100px,95vw);max-height:88vh;display:flex;flex-direction:column;border-radius:10px;border:1px solid #252b42;box-shadow:0 30px 80px -10px rgba(0,0,0,.6),0 0 0 1px rgba(56,189,248,.06);overflow:hidden;animation:codeFsPop .22s cubic-bezier(.16,1,.3,1)}@keyframes codeFsPop{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:none}}.code-fullscreen-overlay .code-block pre{flex:1 1;max-height:none;overflow:auto;margin:0;padding:1rem 1.25rem;font-size:.95em;line-height:1.55}.code-fullscreen-overlay .code-block pre>code{padding:0!important;margin:0!important}.code-fullscreen-overlay .code-block .code-block-head{padding:.75rem 1.25rem;background:#0c0f1a;border-bottom:1px solid #1d2440;font-size:.8em}.code-fullscreen-overlay .code-block .code-block-lang{padding:3px 10px;background:rgba(56,189,248,.08);border:1px solid rgba(56,189,248,.25);color:#38bdf8;border-radius:999px;letter-spacing:.08em;font-weight:600}.code-fullscreen-close{position:fixed;top:1.25rem;right:1.25rem;background:rgba(13,16,24,.85);border:1px solid #252b42;color:#e6e9f2;border-radius:999px;width:38px;height:38px;font-size:16px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}.code-fullscreen-close:hover{background:#0d1018;border-color:#38bdf8;color:#38bdf8;transform:scale(1.05)}.code-block-title{font-weight:500;color:#b3b8c8;flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.code-block-lang{text-transform:uppercase;letter-spacing:.08em;font-size:.72em;color:#7c8294}.code-block-lang:empty,.code-block-title:empty{display:none}.code-copy{margin-left:auto;background:transparent;border:1px solid #252b42;border-radius:4px;color:#9aa1b5;height:1.6rem;padding:0 .55rem;font-size:.7em;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem;transition:color .15s,border-color .15s,background .15s}.code-copy:before{content:"";width:.85rem;height:.85rem;background-color:currentColor;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='9' y='9' width='13' height='13' rx='2'/><path d='M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='9' y='9' width='13' height='13' rx='2'/><path d='M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1'/></svg>") center/contain no-repeat}.code-copy:after{content:"Copy"}.code-copy.copied{color:#4ade80;border-color:#4ade80;background:rgba(74,222,128,.08)}.code-copy.copied:after{content:"Copied"}.code-copy.copied:before{-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center/contain no-repeat}.code-copy:hover{color:#e6e9f2;border-color:#38bdf8;background:rgba(56,189,248,.06)}.post-body .code-block pre,.post-preview .code-block pre{margin:0;padding:.85rem 1rem;background:#0d1018;border:0;border-radius:0;overflow-x:auto}.code-line{display:block;padding:0 .25rem;min-height:1.25em}.code-line--hl{background:rgba(56,189,248,.1);box-shadow:inset 2px 0 0 #38bdf8}.code-block--ln pre code{counter-reset:ln}.code-block--ln .code-line{position:relative;padding-left:3rem}.code-block--ln .code-line:before{counter-increment:ln;content:counter(ln);position:absolute;left:0;width:2.25rem;text-align:right;color:#3b4263;padding-right:.75rem;-webkit-user-select:none;user-select:none}.hljs{color:#abb2bf;background:transparent}.hljs-comment,.hljs-quote{color:#5c6370;font-style:italic}.hljs-doctag,.hljs-formula,.hljs-keyword{color:#c678dd}.hljs-deletion,.hljs-name,.hljs-section,.hljs-selector-tag,.hljs-subst{color:#e06c75}.hljs-literal,.hljs-number{color:#d19a66}.hljs-addition,.hljs-attribute,.hljs-meta-string,.hljs-regexp,.hljs-string{color:#98c379}.hljs-built_in,.hljs-class .hljs-title{color:#e6c07b}.hljs-attr,.hljs-number,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-pseudo,.hljs-template-variable,.hljs-type,.hljs-variable{color:#d19a66}.hljs-bullet,.hljs-link,.hljs-meta,.hljs-selector-id,.hljs-symbol,.hljs-title{color:#61afef}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-link{text-decoration:underline}.hljs-addition{color:#98c379;background:rgba(152,195,121,.1)}.hljs-deletion{color:#e06c75;background:rgba(224,108,117,.1)}.code-line:has(>.hljs-addition){background:rgba(152,195,121,.08)}.code-line:has(>.hljs-deletion){background:rgba(224,108,117,.08)}@media (max-width:640px){.code-block-head{font-size:.72em;padding:.3rem .5rem}.post-body .code-block pre,.post-preview .code-block pre{padding:.6rem;font-size:.78em}}.post-body .cols-2,.post-body .cols-3,.post-body .cols-4{display:grid;gap:1.25rem;margin:1.5rem 0}.post-body .cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.post-body .cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.post-body .cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.post-body .cols-2>div>:first-child,.post-body .cols-3>div>:first-child,.post-body .cols-4>div>:first-child{margin-top:0}@media (max-width:540px){.post-body .cols-2,.post-body .cols-3,.post-body .cols-4{grid-template-columns:1fr;gap:.75rem}}@media (min-width:541px) and (max-width:720px){.post-body .cols-3,.post-body .cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}}.post-body .callout{margin:1.25rem 0;padding:.85rem 1rem .85rem 2.5rem;border:1px solid;border-radius:6px;position:relative;line-height:1.6}.post-body .callout:before{position:absolute;left:.85rem;top:.85rem;font-size:1.1em;line-height:1}.post-body .callout>:first-child{margin-top:0}.post-body .callout>:last-child{margin-bottom:0}.post-body .callout-info{background:rgba(56,189,248,.08);border-color:rgba(56,189,248,.35)}.post-body .callout-info:before{content:"ℹ️"}.post-body .callout-tip{background:rgba(52,211,153,.08);border-color:rgba(52,211,153,.35)}.post-body .callout-tip:before{content:"💡"}.post-body .callout-warn{background:rgba(251,191,36,.08);border-color:rgba(251,191,36,.35)}.post-body .callout-warn:before{content:"⚠️"}.post-body .callout-danger{background:rgba(248,113,113,.08);border-color:rgba(248,113,113,.35)}.post-body .callout-danger:before{content:"🚨"}.post-body iframe.embed{display:block;width:100%;aspect-ratio:16/9;border:0;border-radius:8px;margin:1.5rem 0;background:#000}.post-body .gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem;margin:1.5rem 0}.post-body .gallery img{width:100%;height:100%;aspect-ratio:4/3;object-fit:cover;border-radius:4px;display:block;margin:0}.post-body figure.img{margin:1.5rem 0}.post-body figure.img img{display:block;max-width:100%;height:auto;margin:0}.post-body figure.img figcaption{font-size:.85em;color:var(--muted,#888);text-align:center;margin-top:.5rem;line-height:1.4}.post-body figure.img-left{float:left;margin-right:1.25rem;max-width:45%}.post-body figure.img-right{float:right;margin-left:1.25rem;max-width:45%}.post-body figure.img-left+*,.post-body figure.img-right+*{clear:none}.post-body figure.img-center img{margin-inline:auto}.post-body figure.img-center figcaption{text-align:center}.post-body figure.img-full img{width:100%}.post-body figure.radius-sm img{border-radius:4px}.post-body figure.radius-lg img{border-radius:12px}.post-body figure.radius-full img{border-radius:9999px;aspect-ratio:1;object-fit:cover}.post-body figure.border-1 img{border:1px solid var(--border,#e5e7eb)}.post-body figure.border-2 img{border:2px solid var(--border,#e5e7eb)}@media (max-width:540px){.post-body figure.img-left,.post-body figure.img-right{float:none;margin:1.25rem 0;max-width:100%}}.post-body [class*=cols-]{align-items:start}.post-body [class*=cols-].gap-sm{gap:.5rem}.post-body [class*=cols-].gap-md{gap:1rem}.post-body [class*=cols-].gap-lg{gap:2rem}.post-body [class*=cols-].valign-center{align-items:center}.post-body [class*=cols-].valign-bottom{align-items:end}.post-body .cols-2.ratio-1-2{grid-template-columns:1fr 2fr}.post-body .cols-2.ratio-2-1{grid-template-columns:2fr 1fr}.post-body .cols-2.ratio-1-3{grid-template-columns:1fr 3fr}.post-body .cols-2.ratio-3-1{grid-template-columns:3fr 1fr}@media (max-width:540px){.post-body .cols-2.mobile-keep{grid-template-columns:1fr 1fr;gap:.5rem}.post-body .cols-3.mobile-keep{grid-template-columns:repeat(3,minmax(0,1fr))}.post-body .cols-4.mobile-keep{grid-template-columns:repeat(4,minmax(0,1fr))}}:root[data-theme=light] .post-body code{background:rgba(0,0,0,.06);color:var(--fg)}:root[data-theme=light] .post-body blockquote{color:var(--muted);border-left-color:var(--accent)}:root[data-theme=light] .post-body table th{background:var(--surface2)}:root[data-theme=light] .post-body hr,:root[data-theme=light] .post-body table td,:root[data-theme=light] .post-body table th{border-color:var(--border)}:root[data-theme=light] .code-fullscreen-overlay{background:rgba(15,23,42,.55)}:root[data-theme=light] .callout-info{background:rgba(56,189,248,.08);border-color:rgba(56,189,248,.25)}:root[data-theme=light] .callout-tip{background:rgba(16,185,129,.08);border-color:rgba(16,185,129,.25)}:root[data-theme=light] .callout-warn{background:rgba(245,158,11,.1);border-color:rgba(245,158,11,.3)}:root[data-theme=light] .callout-danger{background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.25)}:root[data-theme=light] .post-toc{border-color:var(--border)}:root[data-theme=light] .post-toc a{color:var(--muted)}:root[data-theme=light] .post-toc a.active,:root[data-theme=light] .post-toc a:hover{color:var(--accent)}:root[data-theme=light] input[type=email],:root[data-theme=light] input[type=search],:root[data-theme=light] input[type=text],:root[data-theme=light] select,:root[data-theme=light] textarea{background:var(--bg)!important;color:var(--fg)!important;border-color:var(--border)!important}