*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fafaf9;--bg-alt:#f5f5f4;--text:#1c1917;--text-muted:#57534e;--border:#e7e5e4;--accent:#b91c1c;--accent-hover:#991b1b;--link:#1d4ed8;--link-hover:#1e40af;--code-bg:#1e1e1e;--code-text:#d4d4d4;--success:#16a34a;--font-serif:"Source Serif 4",Georgia,"Times New Roman",serif;--font-mono:"JetBrains Mono","Fira Code",Consolas,monospace;--content-width:720px;--sidebar-width:280px}[data-theme=dark]{--bg:#1c1917;--bg-alt:#292524;--text:#fafaf9;--text-muted:#a8a29e;--border:#44403c;--accent:#ef4444;--accent-hover:#dc2626;--link:#60a5fa;--link-hover:#93c5fd}html{scroll-behavior:smooth;font-size:18px;line-height:1.7}body{font-family:var(--font-serif);background:var(--bg);color:var(--text);min-height:100vh}.app{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-alt);border-right:1px solid var(--border);z-index:100;padding:2rem 1.5rem;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.main{margin-left:var(--sidebar-width);max-width:calc(var(--content-width) + var(--sidebar-width) + 6rem);flex:1;padding:2rem 3rem}.sidebar-header{margin-bottom:2rem}.sidebar-title{color:var(--text);align-items:center;gap:.5rem;font-size:1.25rem;font-weight:600;text-decoration:none;display:flex}.sidebar-title:hover{color:var(--accent)}.sidebar-subtitle{color:var(--text-muted);margin-top:.25rem;font-size:.875rem}.nav-section{margin-bottom:1.5rem}.nav-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.75rem;font-family:var(--font-mono);margin-bottom:.5rem}.nav-list{list-style:none}.nav-item{margin-bottom:.25rem}.nav-link{color:var(--text);border-radius:.375rem;align-items:center;gap:.5rem;padding:.375rem .75rem;font-size:.9375rem;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-link:hover{background:var(--border)}.nav-link.active{background:var(--accent);color:#fff}.nav-link .chapter-num{font-family:var(--font-mono);color:var(--text-muted);min-width:1.5rem;font-size:.8125rem}.nav-link.active .chapter-num{color:#ffffffb3}.nav-link .check{color:var(--success);margin-left:auto;font-size:.875rem}.theme-toggle{border-top:1px solid var(--border);align-items:center;gap:.5rem;margin-top:2rem;padding-top:1rem;display:flex}.theme-toggle button{border:1px solid var(--border);cursor:pointer;color:var(--text);background:0 0;border-radius:.375rem;padding:.5rem .75rem;font-size:.875rem;transition:background .15s}.theme-toggle button:hover{background:var(--border)}.content{max-width:var(--content-width)}.content h1{margin-bottom:.5rem;font-size:2.5rem;font-weight:600;line-height:1.2}.content h2{border-bottom:1px solid var(--border);margin-top:3rem;margin-bottom:1rem;padding-bottom:.5rem;font-size:1.75rem;font-weight:600}.content h3{margin-top:2rem;margin-bottom:.75rem;font-size:1.25rem;font-weight:600}.content p{margin-bottom:1.25rem}.content a{color:var(--link);text-underline-offset:2px;text-decoration:underline}.content a:hover{color:var(--link-hover)}.content ul,.content ol{margin-bottom:1.25rem;padding-left:1.5rem}.content li{margin-bottom:.5rem}.content blockquote{border-left:4px solid var(--accent);color:var(--text-muted);margin:1.5rem 0;padding-left:1rem;font-style:italic}.content code{font-family:var(--font-mono);background:var(--bg-alt);border-radius:.25rem;padding:.125em .375em;font-size:.875em}.content pre{background:var(--code-bg);color:var(--code-text);border-radius:.5rem;margin:1.5rem 0;padding:1rem 1.25rem;font-size:.9375rem;line-height:1.5;overflow-x:auto}.content pre code{font-size:inherit;background:0 0;padding:0}.playground{border:1px solid var(--border);border-radius:.5rem;margin:2rem 0;overflow:hidden}.playground-header{background:var(--bg-alt);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.playground-title{font-family:var(--font-mono);color:var(--text-muted);font-size:.875rem}.playground-actions{gap:.5rem;display:flex}.playground-editor{min-height:200px}.playground-output{border-top:1px solid var(--border);background:var(--code-bg);color:var(--code-text);font-family:var(--font-mono);white-space:pre-wrap;min-height:100px;max-height:300px;padding:1rem;font-size:.875rem;overflow-y:auto}.btn{cursor:pointer;border:none;border-radius:.375rem;align-items:center;gap:.375rem;padding:.5rem 1rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-alt);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn:disabled{opacity:.6;cursor:not-allowed}.spinner{border:2px solid;border-right-color:#0000;border-radius:50%;width:1rem;height:1rem;animation:.75s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.chapter-nav{border-top:1px solid var(--border);justify-content:space-between;margin-top:4rem;padding-top:2rem;display:flex}.chapter-nav a{background:var(--bg-alt);color:var(--text);border-radius:.375rem;align-items:center;gap:.5rem;padding:.75rem 1rem;text-decoration:none;transition:background .15s;display:flex}.chapter-nav a:hover{background:var(--border)}.chapter-nav .direction{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.hero{text-align:center;padding:4rem 0}.hero h1{margin-bottom:1rem;font-size:3rem}.hero-emoji{margin-bottom:1rem;font-size:4rem}.hero p{color:var(--text-muted);max-width:600px;margin:0 auto 2rem;font-size:1.25rem}.hero .btn{padding:.75rem 2rem;font-size:1rem}@media (width<=900px){.sidebar{transition:transform .3s;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main{margin-left:0;padding:1.5rem}.menu-toggle{z-index:101;background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:.375rem;padding:.5rem;display:block;position:fixed;top:1rem;left:1rem}}@media (width>=901px){.menu-toggle{display:none}}.progress-bar{background:var(--border);z-index:1000;height:3px;position:fixed;top:0;left:0;right:0}.progress-bar-fill{background:var(--accent);height:100%;transition:width .3s}#console{background:var(--code-bg);color:var(--code-text);font-family:var(--font-mono);white-space:pre-wrap;word-wrap:break-word;font-size:.875rem}.playground-output:empty:before{content:"Output will appear here...";color:#666;font-style:italic}