:root{--orange:#e95420;--orange-hover:#c34113;--aubergine:#77216f;--aubergine-hover:#5e2750;--aubergine-light:#9b4d8c;--bg:#faf8f5;--bg-elevated:#fff;--bg-muted:#f2efe8;--text:#2c2c2c;--text-muted:#5c5c5c;--border:#e0dcd4;--border-subtle:#ebe8e2;--accent:var(--orange);--accent-alt:var(--aubergine);--focus-ring:var(--orange);--code-bg:#f4f1eb;--code-border:#e8e4dc;--code-text:#3d3d3d;--shadow-sm:0 1px 2px rgba(0, 0, 0, 0.05);--shadow:0 2px 8px rgba(0, 0, 0, 0.06);--shadow-lg:0 4px 16px rgba(0, 0, 0, 0.08);--font-sans:"Ubuntu", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;--radius:6px;--radius-sm:4px;--sidebar-width:260px;--toc-width:220px;--header-height:56px;--max-content:75ch}.dark{--bg:#1a1814;--bg-elevated:#242119;--bg-muted:#2d2a24;--text:#e8e4dd;--text-muted:#a8a49c;--border:#3d3932;--border-subtle:#35322b;--accent:#f08b5c;--accent-alt:#c77fb8;--code-bg:#2a2722;--code-border:#3d3932;--code-text:#ddd9d2;--shadow-sm:0 1px 2px rgba(0, 0, 0, 0.3);--shadow:0 2px 8px rgba(0, 0, 0, 0.4);--shadow-lg:0 4px 16px rgba(0, 0, 0, 0.5)}*,*::before,*::after{box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{margin:0;font-family:var(--font-sans);color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}.kokoro-body{display:flex;min-height:calc(100vh - var(--header-height))}.skip-link{position:absolute;top:-100%;left:.5rem;padding:.5rem 1rem;background:var(--accent);color:#fff;z-index:100;border-radius:var(--radius-sm);transition:top .2s}.skip-link:focus{top:.5rem}.kokoro-header{position:sticky;top:0;z-index:50;height:var(--header-height);background:var(--bg-elevated);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}.header-inner{display:flex;align-items:center;gap:1.5rem;max-width:1600px;margin:0 auto;padding:0 1.25rem;height:100%}.brand-link{display:flex;align-items:center;color:var(--text);text-decoration:none;font-weight:600;flex-shrink:0}.brand-link:hover{color:var(--accent)}.brand-name{font-size:1.1rem}.brand-logo{height:28px}.header-nav{display:flex;gap:1.5rem}.header-nav .nav-link{color:var(--text-muted);text-decoration:none;font-size:.95rem}.header-nav .nav-link:hover{color:var(--accent)}.header-actions{margin-left:auto;display:flex;align-items:center;gap:.5rem}.btn-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:0 0;border:none;border-radius:var(--radius);color:var(--text-muted);cursor:pointer;transition:color .15s,background .15s}.btn-icon:hover{color:var(--accent);background:var(--bg-muted)}.btn-icon:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.dark .icon-sun{display:block}.dark .icon-moon{display:none}:not(.dark) .icon-moon{display:none}.btn-sidebar-toggle{display:none}@media(max-width:768px){.has-sidebar .btn-sidebar-toggle{display:flex}}.header-nav{display:none}@media(min-width:640px){.header-nav{display:flex}}.kokoro-sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--bg-elevated);border-right:1px solid var(--border);overflow-y:auto;position:sticky;top:var(--header-height);height:calc(100vh - var(--header-height))}.sidebar-header{display:none}.sidebar-nav{padding:1rem 0}.sidebar-nav-list{list-style:none;margin:0;padding:0}.sidebar-nav-item{margin:0}.sidebar-nav-link{display:block;padding:.4rem 1.25rem;color:var(--text-muted);text-decoration:none;font-size:.9rem;transition:color .15s,background .15s}.sidebar-nav-link:hover{color:var(--accent)}.sidebar-nav-link.is-current{color:var(--accent);font-weight:600}.sidebar-nav-item.has-children .sidebar-nav-link{padding-left:1rem}.sidebar-nav-toggle{position:absolute;left:.5rem;top:.35rem;width:24px;height:24px;padding:0;background:0 0;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm)}.sidebar-nav-toggle:hover{color:var(--accent)}.sidebar-nav-toggle:focus-visible{outline:2px solid var(--focus-ring)}.nav-toggle-icon{display:block;width:8px;height:8px;border-right:2px solid;border-bottom:2px solid;transform:rotate(45deg);margin:6px auto;transition:transform .2s}.sidebar-nav-item.is-expanded .nav-toggle-icon{transform:rotate(-135deg)}.sidebar-nav-item.has-children{position:relative;padding-left:2rem}.sidebar-nav-item.has-children>.sidebar-nav-list{padding-left:.5rem;border-left:1px solid var(--border-subtle);margin-left:.75rem;margin-top:.25rem}.sidebar-nav-item:not(.is-expanded)>.sidebar-nav-list{display:none}.sidebar-overlay{display:none}@media(max-width:768px){.kokoro-sidebar{position:fixed;left:0;top:0;height:100vh;z-index:60;transform:translateX(-100%);transition:transform .25s ease;box-shadow:var(--shadow-lg)}.kokoro-sidebar.is-open{transform:translateX(0)}.sidebar-header{display:flex;align-items:center;gap:.5rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.sidebar-title{font-weight:600}.btn-sidebar-close{margin-left:auto}.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:55}.sidebar-overlay.is-visible{display:block}}.kokoro-main{flex:1;min-width:0;padding:1.5rem 1.5rem 3rem}.has-sidebar .kokoro-main{padding-left:2rem}.has-toc .kokoro-main{padding-right:2rem}@media(max-width:768px){.kokoro-main{padding:1rem}}.kokoro-toc{width:var(--toc-width);flex-shrink:0;position:sticky;top:calc(var(--header-height) + 1rem);align-self:flex-start;padding:1rem 0 1rem 1.5rem;border-left:1px solid var(--border);max-height:calc(100vh - var(--header-height) - 2rem);overflow-y:auto}.toc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.toc-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0}.btn-toc-toggle{display:none}.toc-nav{font-size:.85rem}.toc-nav ul{list-style:none;margin:0;padding-left:1rem;border-left:1px solid var(--border-subtle)}.toc-nav ul ul{padding-left:.75rem}.toc-nav a{color:var(--text-muted);text-decoration:none;display:block;padding:.2rem 0}.toc-nav a:hover{color:var(--accent)}@media(max-width:1024px){.kokoro-toc{position:relative;top:0;width:100%;max-height:none;margin-top:2rem;padding:1rem;background:var(--bg-muted);border-radius:var(--radius);border-left:none}.toc-nav{max-height:200px;overflow-y:auto}.btn-toc-toggle{display:flex}.kokoro-toc.is-collapsed .toc-nav{display:none}}.kokoro-content{max-width:var(--max-content)}.content-header{margin-bottom:1.5rem}.content-title{font-size:2rem;font-weight:700;margin:0 0 .25rem;line-height:1.3}.content-subtitle{font-size:1.1rem;color:var(--text-muted);margin:0}.content-meta{font-size:.9rem;color:var(--text-muted);margin-top:.5rem}.content-body h1,.content-body h2,.content-body h3,.content-body h4{margin-top:2rem;margin-bottom:.75rem;font-weight:600;line-height:1.3}.content-body h1{font-size:1.75rem;margin-top:0}.content-body h2{font-size:1.4rem}.content-body h3{font-size:1.15rem}.content-body h4{font-size:1rem}.content-body p{margin:0 0 1rem}.content-body ul,.content-body ol{margin:0 0 1rem;padding-left:1.5rem}.content-body a{color:var(--accent);text-decoration:none}.content-body a:hover{text-decoration:underline}.content-body a:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.content-body blockquote{margin:1rem 0;padding:1rem 1.25rem;border-left:4px solid var(--accent);background:var(--bg-muted);border-radius:0 var(--radius)var(--radius)0;color:var(--text-muted)}.content-body code{font-family:var(--font-mono);font-size:.9em;padding:.15em .35em;background:var(--code-bg);border-radius:var(--radius-sm);border:1px solid var(--code-border)}.content-body pre{margin:1rem 0;padding:1rem 1.25rem;overflow-x:auto;background:var(--code-bg);border:1px solid var(--code-border);border-radius:var(--radius)}.content-body pre code{padding:0;background:0 0;border:none}.chroma-wrap{position:relative;margin:1rem 0}.chroma-wrap pre{margin:0;padding:2.5rem 1.25rem 1.25rem}.chroma-header{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:var(--code-border);border-radius:var(--radius)var(--radius)0 0;font-size:.8rem;font-family:var(--font-mono);color:var(--text-muted)}.btn-copy{padding:.25rem .5rem;font-size:.75rem;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all .15s}.btn-copy:hover{background:var(--bg);color:var(--text)}.btn-copy.copied{background:var(--accent);color:#fff;border-color:var(--accent)}.chroma .err{color:#c65d5d}.chroma .c,.chroma .ch,.chroma .cm,.chroma .c1{color:#6b6b5c}.chroma .k,.chroma .kc,.chroma .kd,.chroma .kn,.chroma .kp,.chroma .kr,.chroma .kt{color:var(--aubergine)}.chroma .n,.chroma .nb,.chroma .ni,.chroma .no{color:var(--code-text)}.chroma .nf,.chroma .nn{color:var(--orange)}.chroma .s,.chroma .s1,.chroma .s2{color:#5a7a4a}.chroma .na,.chroma .nc{color:var(--aubergine-light)}.dark .chroma .c,.dark .chroma .ch,.dark .chroma .cm,.dark .chroma .c1{color:#8a8a7a}.dark .chroma .s,.dark .chroma .s1,.dark .chroma .s2{color:#8ab478}.callout{margin:1rem 0;padding:1rem 1.25rem;border-radius:var(--radius);border-left:4px solid;background:var(--bg-muted)}.callout-note{border-color:var(--aubergine)}.callout-tip{border-color:#5a7a4a}.callout-warn{border-color:#c67c3d}.callout-info{border-color:var(--orange)}.callout-title{font-weight:600;margin-bottom:.5rem}.badge{display:inline-block;padding:.2em .5em;font-size:.8rem;font-weight:500;border-radius:999px;background:var(--bg-muted);color:var(--text-muted);border:1px solid var(--border)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;font-family:inherit;font-size:.95rem;font-weight:500;border-radius:var(--radius);text-decoration:none;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.btn-primary{background:var(--orange);color:#fff;border:1px solid var(--orange)}.btn-primary:hover{background:var(--orange-hover)}.btn-secondary{background:0 0;color:var(--accent);border:1px solid var(--accent)}.btn-secondary:hover{background:var(--bg-muted)}.kokoro-home{max-width:900px;margin:0 auto}.home-hero{text-align:center;padding:3rem 1rem 4rem}.hero-title{font-size:2.5rem;font-weight:700;margin:0 0 .5rem}.hero-tagline{font-size:1.2rem;color:var(--text-muted);margin:0 0 2rem}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.home-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-top:3rem}.home-card{padding:1.5rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s}.home-card:hover{border-color:var(--accent);box-shadow:var(--shadow)}.kokoro-posts{display:flex;flex-direction:column;gap:2rem}.kokoro-post-card{padding:1.5rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius)}.post-card-title{font-size:1.25rem;margin:0 0 .5rem}.post-card-title a{color:inherit;text-decoration:none}.post-card-title a:hover{color:var(--accent)}.post-card-meta{font-size:.9rem;color:var(--text-muted);margin-bottom:.5rem}.post-card-summary{margin:0;color:var(--text-muted)}.section-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.section-card{padding:1.5rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s}.section-card:hover{border-color:var(--accent);box-shadow:var(--shadow)}.section-card-title{font-size:1.15rem;margin:0 0 .5rem}.section-card-desc,.section-card-summary{font-size:.95rem;color:var(--text-muted);margin:0}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}.prevnext{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border)}.prevnext-inner{display:flex;justify-content:space-between;gap:1rem}.prevnext-link{color:var(--accent);text-decoration:none;max-width:45%}.prevnext-link:hover{text-decoration:underline}.prevnext-link.next{text-align:right;margin-left:auto}.prevnext-placeholder{flex:1}.breadcrumbs{margin-bottom:1rem;font-size:.9rem}.breadcrumbs-list{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none;margin:0;padding:0}.breadcrumbs-list li:not(:last-child)::after{content:"›";margin-left:.5rem;color:var(--text-muted)}.breadcrumbs-list a{color:var(--text-muted)}.breadcrumbs-list a:hover{color:var(--accent)}.kokoro-footer{padding:1.5rem 1.25rem;background:var(--bg-muted);border-top:1px solid var(--border);font-size:.9rem;color:var(--text-muted)}.footer-inner{max-width:1600px;margin:0 auto;display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.footer-link{color:var(--accent);text-decoration:none}.footer-link:hover{text-decoration:underline}.search-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:flex-start;justify-content:center;padding:10vh 1rem 0;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .15s,visibility .15s}.search-modal[aria-hidden=false]{pointer-events:auto;opacity:1;visibility:visible}.search-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5)}.search-dialog{position:relative;width:100%;max-width:560px;max-height:70vh;background:var(--bg-elevated);border-radius:var(--radius);box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.search-input-wrap{display:flex;align-items:center;gap:.75rem;padding:1rem;border-bottom:1px solid var(--border)}.search-icon{flex-shrink:0;color:var(--text-muted)}.search-input{flex:1;padding:.5rem 0;font-family:inherit;font-size:1rem;background:0 0;border:none;color:var(--text)}.search-input:focus{outline:none}.search-input::placeholder{color:var(--text-muted)}.search-results{overflow-y:auto;max-height:400px}.search-result-item{display:block;padding:.75rem 1rem;color:inherit;text-decoration:none;border-bottom:1px solid var(--border-subtle);cursor:pointer}.search-result-item:hover,.search-result-item[aria-selected=true]{background:var(--bg-muted)}.search-result-item:focus{outline:none}.search-result-title{font-weight:600;margin-bottom:.25rem}.search-result-path{font-size:.8rem;color:var(--text-muted);margin-bottom:.25rem}.search-result-snippet{font-size:.85rem;color:var(--text-muted)}.search-footer{padding:.5rem 1rem;font-size:.8rem;color:var(--text-muted);border-top:1px solid var(--border)}.search-hint kbd{padding:.1em .35em;font-size:.85em;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-sm)}.search-empty{padding:1rem;color:var(--text-muted)}