:root{color-scheme:light;--bg: #eff3f8;--bg-grid: rgba(28, 52, 92, .06);--surface: #f9fbff;--surface-2: #ffffff;--text: #162745;--muted: #62708a;--text-muted: #62708a;--border: #d2dbeb;--accent: #4f7cff;--accent-2: #19b28d;--accent-soft: #e7efff;--header-bg: rgba(239, 243, 248, .92);--header-bg-2: #eff3f8;--header-border: rgba(79, 124, 255, .12);--header-text: #162745;--header-nav-bg: rgba(79, 124, 255, .05);--header-input-bg: rgba(22, 39, 69, .07);--header-input-border: rgba(79, 124, 255, .22);--header-input-color: #162745;--header-pill-color: #2d3f6b;--header-pill-hover-bg: rgba(79, 124, 255, .1);--header-pill-hover-border: rgba(79, 124, 255, .3);--header-toggle-bg: rgba(79, 124, 255, .08);--header-toggle-border: rgba(79, 124, 255, .2);--header-toggle-hover: rgba(79, 124, 255, .16);--header-shadow: 0 1px 12px rgba(18, 32, 56, .08);--shadow: 0 18px 42px rgba(18, 32, 56, .12);--footer-bg: rgba(239, 243, 248, .92);--footer-border: rgba(79, 124, 255, .1);--grad-teal: rgba(29, 220, 171, .13);--grad-blue: rgba(95, 143, 255, .13)}:root[data-theme=dark]{color-scheme:dark;--bg: #000000;--bg-grid: rgba(255, 255, 255, .03);--surface: #0d0d0d;--surface-2: #161616;--text: #f0f0f5;--muted: #a8a8b0;--text-muted: #a8a8b0;--border: #2a2a2e;--accent: #87b8ff;--accent-2: #5ce0b8;--accent-soft: #0f1419;--header-bg: rgba(10, 10, 14, .92);--header-bg-2: #0a0a0d;--header-border: rgba(255, 255, 255, .06);--header-text: #f0f0f5;--header-nav-bg: rgba(255, 255, 255, .04);--header-input-bg: rgba(255, 255, 255, .06);--header-input-border: rgba(255, 255, 255, .12);--header-input-color: #e8ecff;--header-pill-color: #c8d4f0;--header-pill-hover-bg: rgba(135, 184, 255, .12);--header-pill-hover-border: rgba(135, 184, 255, .3);--header-toggle-bg: rgba(255, 255, 255, .06);--header-toggle-border: rgba(255, 255, 255, .12);--header-toggle-hover: rgba(135, 184, 255, .18);--header-shadow: 0 1px 16px rgba(0, 0, 0, .4);--shadow: 0 18px 42px rgba(0, 0, 0, .95);--footer-bg: rgba(10, 10, 14, .92);--footer-border: rgba(255, 255, 255, .06);--grad-teal: rgba(29, 220, 171, .02);--grad-blue: rgba(95, 143, 255, .025)}*{box-sizing:border-box}body{margin:0;font-family:Outfit,Segoe UI,Tahoma,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";background:radial-gradient(circle at 0% 0%,var(--grad-teal),transparent 32%),radial-gradient(circle at 100% 0%,var(--grad-blue),transparent 34%),linear-gradient(var(--bg-grid) 1px,transparent 1px),linear-gradient(90deg,var(--bg-grid) 1px,transparent 1px),var(--bg);background-size:auto,auto,28px 28px,28px 28px,auto;color:var(--text)}::selection{background:color-mix(in oklab,var(--accent) 36%,transparent);color:var(--text)}.skip-link{position:absolute;top:-48px;left:1rem;background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:.5rem .8rem;border-radius:8px;text-decoration:none;z-index:100;font-weight:600}.skip-link:focus-visible{top:.7rem}.shell-header{position:sticky;top:0;z-index:30;background:linear-gradient(var(--bg-grid) 1px,transparent 1px),linear-gradient(90deg,var(--bg-grid) 1px,transparent 1px),var(--header-bg);background-size:28px 28px,28px 28px,auto;border-bottom:1px solid var(--header-border);box-shadow:var(--header-shadow)}.header-outer{max-width:100%;margin:0 auto;padding:.6rem 1.5rem}.top-nav{display:flex;align-items:center;justify-content:space-between;gap:1rem}.brand{color:var(--header-text);text-decoration:none;font-weight:800;font-size:1.05rem;letter-spacing:-.01em;text-transform:lowercase;padding:.4rem .5rem;justify-self:start;display:inline-flex;align-items:baseline;gap:0;transition:opacity .15s ease}.brand:hover{opacity:.8}.brand-w{background:linear-gradient(135deg,var(--accent),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:1.22rem}.brand-dot{color:var(--accent-2);-webkit-text-fill-color:var(--accent-2)}.nav-links{display:flex;align-items:center;gap:.25rem}.top-actions{display:flex;align-items:center}.nav-pill{text-decoration:none;color:var(--header-pill-color);font-weight:600;font-size:.88rem;padding:.4rem .7rem;border-radius:8px;border:1px solid transparent;transition:.15s ease}.nav-pill:hover,.nav-pill.is-active{background:var(--header-pill-hover-bg);border-color:var(--header-pill-hover-border);color:var(--accent)}a:focus-visible,button:focus-visible,.nav-pill:focus-visible,.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.theme-toggle{border:1px solid var(--header-toggle-border);background:var(--header-toggle-bg);color:var(--header-text);width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:50%;font:inherit;cursor:pointer;transition:.15s ease;padding:0}.theme-toggle:hover{background:var(--header-toggle-hover);border-color:var(--accent)}.theme-icon{font-size:.95rem;line-height:1;display:inline-block;transform-origin:50% 50%;transition:transform .32s cubic-bezier(.2,.9,.3,1),color .22s ease}.theme-toggle.anim .theme-icon{animation:themeFlip .52s cubic-bezier(.2,.9,.3,1)}@keyframes themeFlip{0%{transform:rotate(0) scale(1)}30%{transform:rotate(90deg) scale(.6)}60%{transform:rotate(270deg) scale(.6)}to{transform:rotate(360deg) scale(1)}}main,.shell-footer{max-width:100%;margin:0;padding:1rem 1.5rem}.surface{background:transparent;animation:fade-in .42s ease}.docs-shell{display:grid;grid-template-columns:270px minmax(0,1fr);gap:1rem;align-items:start}.docs-sidebar-shell{position:relative}.sidebar-mobile-toggle,.sidebar-backdrop{display:none}.docs-sidebar{position:sticky;top:88px;background:#ffffff05;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:.9rem;max-height:calc(100vh - 110px);overflow-y:auto;overflow-x:hidden}.docs-sidebar h2,.docs-sidebar h3{margin:0;font-size:.95rem}.sidebar-group+.sidebar-group{margin-top:.6rem}.sidebar-group{border:1px solid rgba(255,255,255,.06);border-radius:10px;background:#ffffff03}.sidebar-summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.55rem .6rem;cursor:pointer}.sidebar-summary::-webkit-details-marker{display:none}.sidebar-summary-main{display:flex;align-items:center;gap:.48rem;min-width:0;flex:1;overflow:hidden}.sidebar-summary-main h3{min-width:0;word-wrap:break-word;overflow-wrap:break-word;white-space:normal;word-break:break-word;font-variant-emoji:text;font-size:.82rem;font-weight:600;line-height:1.35;letter-spacing:0}.sidebar-module-badge{display:inline-flex;align-items:center;justify-content:center;width:1.65rem;height:1.65rem;border-radius:6px;font-size:.7rem;font-weight:800;font-family:JetBrains Mono,Fira Code,monospace;letter-spacing:0;background:#87b8ff1f;border:1px solid rgba(135,184,255,.25);color:#87b8ff;flex-shrink:0;line-height:1}.sidebar-icon{width:18px;height:18px;display:inline-block;border-radius:5px;background:#87b8ff14;border:1px solid rgba(135,184,255,.2);position:relative;flex-shrink:0}.sidebar-icon:before{content:"";position:absolute;inset:4px;border-radius:3px;background:#87b8ff}.sidebar-icon[data-icon=tag]:before{clip-path:polygon(0 0,100% 0,62% 50%,100% 100%,0 100%)}.sidebar-icon[data-icon=list]:before{clip-path:polygon(0 12%,100% 12%,100% 28%,0 28%,0 42%,100% 42%,100% 58%,0 58%,0 72%,100% 72%,100% 88%,0 88%)}.sidebar-icon[data-icon=book]:before{clip-path:polygon(0 0,48% 0,48% 100%,0 100%,0 0,52% 0,100% 0,100% 100%,52% 100%)}.sidebar-icon[data-icon=layers]:before{clip-path:polygon(50% 0,100% 26%,50% 52%,0 26%,50% 0,50% 56%,100% 82%,50% 100%,0 82%,50% 56%)}.sidebar-icon[data-icon=filter]:before{clip-path:polygon(0 0,100% 0,62% 42%,62% 100%,38% 88%,38% 42%)}.sidebar-chevron{font-size:.9rem;transition:transform .18s ease;color:var(--muted)}.sidebar-group[open] .sidebar-chevron{transform:rotate(180deg)}.sidebar-links{list-style:none;padding:.2rem .5rem .55rem;margin:0;display:grid;gap:.28rem}.sidebar-links li{margin:0}.sidebar-link{display:flex;align-items:baseline;gap:.4rem;padding:.38rem .5rem;border-radius:8px;text-decoration:none;color:#a8a8b0;font-size:.85rem;line-height:1.35;transition:.15s ease;max-width:100%}.sidebar-lesson-num{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:1.55rem;height:1.55rem;border-radius:6px;font-size:.72rem;font-weight:700;background:#87b8ff14;border:1px solid rgba(135,184,255,.18);color:#87b8ff;line-height:1}.sidebar-lesson-num[data-lesson-status=current]{background:#87b8ff33;border-color:#87b8ff;box-shadow:0 0 6px #87b8ff40}.sidebar-lesson-num[data-lesson-status=completed]{background:#5ce0b81f;border-color:#5ce0b866;color:#5ce0b8}.sidebar-link-text{flex:1;min-width:0;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;white-space:normal}.sidebar-link[data-filter-value]{position:relative;display:flex;align-items:center;gap:.55rem;padding:.48rem .62rem;border:1px solid rgba(135,184,255,.2);background:#87b8ff0f;transition:transform .15s ease,border-color .15s ease,background .15s ease,color .15s ease}.sidebar-link[data-filter-value]:before{content:"";width:.55rem;height:.55rem;border-radius:999px;border:1.5px solid rgba(135,184,255,.4);background:transparent;box-sizing:border-box;flex-shrink:0}.sidebar-link[data-filter-kind=reset]{font-weight:600;background:#87b8ff14}.sidebar-link[data-filter-kind=reset]:before{width:.95rem;height:.95rem;border-radius:999px;border-width:0;background:radial-gradient(circle at center,#87b8ff 0 1px,transparent 2px),conic-gradient(from 210deg,transparent 0 20%,#87b8ff 20% 82%,transparent 82% 100%);mask:radial-gradient(circle at center,transparent 0 32%,#000 34% 100%)}.sidebar-link:hover{color:#87b8ff;background:#87b8ff14}.sidebar-link[data-filter-value]:hover{transform:translate(2px);border-color:#87b8ff66;background:#87b8ff1f}.sidebar-link.is-active{background:#87b8ff1f;color:#87b8ff;font-weight:700}.sidebar-link[data-filter-value].is-active{border-color:#87b8ff;background:#87b8ff26;box-shadow:inset 3px 0 #87b8ff;color:#87b8ff}.sidebar-link[data-filter-value].is-active:before{background:#87b8ff;border-color:#87b8ff;box-shadow:0 0 0 3px #87b8ff2e}.sidebar-link[data-filter-kind=reset].is-active{background:#87b8ff1f;color:#87b8ff}.docs-content{min-width:0}section{padding:.5rem .25rem}h1,h2,h3{line-height:1.2;letter-spacing:-.01em;margin:0}h1,h2,h3,h4,h5,h6,.lesson-toc-list a{font-variant-emoji:emoji}h1{font-size:clamp(1.8rem,4.8vw,2.7rem);margin-bottom:.75rem;font-weight:800}h2{font-size:clamp(1.2rem,3vw,1.7rem);margin-top:2rem}.page-intro{max-width:66ch;font-size:1.02rem}a{color:var(--accent);text-decoration-thickness:1.8px;text-underline-offset:2px;transition:.2s ease}a:hover{color:var(--accent-2)}.card-list{list-style:none;padding:0;margin:1.2rem 0;display:grid;gap:.9rem}.card{border:1px solid var(--border);border-radius:14px;padding:1rem;background:var(--surface);transition:.18s ease;overflow:hidden}.card:hover{transform:translateY(-2px);background:var(--surface-2);border-color:color-mix(in oklab,var(--accent) 40%,transparent);box-shadow:var(--shadow)}.meta-row{display:flex;gap:.6rem;flex-wrap:wrap;font-size:.9rem;color:var(--muted);font-family:IBM Plex Mono,monospace}.tag-list{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none;padding:0}.tag-list li{list-style:none}.tag{display:inline-block;padding:.25rem .65rem;border:1px solid rgba(92,224,184,.3);border-radius:999px;text-decoration:none;background:#5ce0b81a;color:#5ce0b8;font-size:.85rem;transition:.15s ease}.tag:hover{background:#5ce0b82e;border-color:#5ce0b8}.pagination{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-top:1.25rem}.pagination a{padding:.35rem .6rem;border-radius:8px;border:1px solid var(--border);text-decoration:none;background:var(--surface);color:var(--text);transition:.15s ease}.pagination a:hover{background:color-mix(in oklab,var(--accent) 12%,transparent);border-color:var(--accent);color:var(--accent)}.prose{max-width:72ch}.prose>*+*{margin-top:1rem}.prose p,.prose li{line-height:1.65}.prose h2,.prose h3{margin-top:1.7rem}.prose code{font-family:IBM Plex Mono,monospace;font-size:.88em;background:#87b8ff1f;color:#87b8ff;padding:.15em .45em;border-radius:5px;border:1px solid rgba(135,184,255,.25)}.prose pre{background:#0a0a0e;border:1px solid rgba(135,184,255,.15);border-radius:12px;padding:1rem 1.2rem;overflow-x:auto;font-family:IBM Plex Mono,monospace;font-size:.9em;line-height:1.6}.mermaid-container{position:relative;margin:1.5rem 0;border:1px solid var(--border);border-radius:14px;background:var(--surface-2);overflow:hidden;transition:border-color .2s ease}.mermaid-container:hover{border-color:var(--accent)}.mermaid-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.4rem .75rem;border-bottom:1px solid var(--border);background:var(--surface);user-select:none}.mermaid-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.mermaid-btn{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:6px;color:var(--muted);cursor:pointer;padding:.3rem;transition:all .15s ease}.mermaid-btn:hover{color:var(--accent);background:#87b8ff1a;border-color:#87b8ff40}.mermaid-scroll{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding:1rem}.mermaid-container pre.mermaid{background:transparent!important;border:none!important;border-radius:0;padding:0;margin:0;overflow:visible;text-align:center;line-height:normal}.mermaid-container svg{display:block;margin:0 auto;max-height:70vh;max-width:100%;height:auto}pre.mermaid:not(.mermaid-container pre){background:var(--surface-2);border:1px solid var(--border);border-radius:14px;padding:1.5rem 1rem;text-align:center;overflow-x:auto}pre.mermaid svg{max-width:100%;height:auto;display:inline-block}.mermaid-overlay{position:fixed;inset:0;z-index:9999;background:#000000e0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:2rem;opacity:0;transition:opacity .2s ease}:root[data-theme=light] .mermaid-overlay{background:#ffffffeb}.mermaid-overlay.active{opacity:1}.mermaid-overlay-close{position:absolute;top:1rem;right:1rem;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;padding:.5rem;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;z-index:1}:root[data-theme=light] .mermaid-overlay-close{background:#00000014;border-color:#00000026;color:#333}.mermaid-overlay-close:hover{background:#ffffff40;border-color:#fff6}:root[data-theme=light] .mermaid-overlay-close:hover{background:#00000026;border-color:#0000004d}.mermaid-overlay-content{width:92vw;max-height:85vh;overflow:auto;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--border);border-radius:16px;padding:2rem}.mermaid-overlay-content svg{display:block;max-width:88vw;max-height:78vh;height:auto;width:auto}.prose pre code{background:transparent;color:var(--text);padding:0;border:none;font-size:inherit}.code-block{margin:1.5rem 0;border-radius:10px;overflow:hidden;border:1px solid var(--border);background:#0d1117}.code-block-header{display:flex;align-items:center;justify-content:space-between;padding:.4rem 1rem;background:#ffffff0a;border-bottom:1px solid var(--border)}.code-block-lang{font-family:JetBrains Mono,Fira Code,monospace;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);font-weight:600}.code-copy-btn{background:transparent;border:1px solid var(--border);color:var(--text-muted);font-size:.72rem;padding:.2rem .6rem;border-radius:5px;cursor:pointer;font-family:inherit;transition:all .2s}.code-copy-btn:hover{background:#87b8ff1f;color:var(--accent);border-color:var(--accent)}.code-block pre{margin:0!important;border:none!important;border-radius:0!important;padding:1rem 1.2rem!important;overflow-x:auto;font-size:.88rem;line-height:1.6}.code-block pre code{background:transparent!important;padding:0!important;border:none!important;font-family:JetBrains Mono,Fira Code,monospace;font-size:.88rem;tab-size:2}.code-block .shiki{background-color:transparent!important}.code-block pre::-webkit-scrollbar{height:6px}.code-block pre::-webkit-scrollbar-track{background:transparent}.code-block pre::-webkit-scrollbar-thumb{background:#87b8ff33;border-radius:3px}.code-block pre::-webkit-scrollbar-thumb:hover{background:#87b8ff66}:root:not(.dark) .code-block{border-color:#0000001f}:root:not(.dark) .code-block-header{background:#00000008;border-bottom-color:#00000014}.prose blockquote{border-left:3px solid var(--accent);margin:0;padding:.25rem 0 .25rem 1rem;font-style:italic;color:var(--muted);background:color-mix(in oklab,var(--accent) 8%,transparent);border-radius:0 8px 8px 0}.prose hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.prose table{width:100%;border-collapse:collapse;font-size:.95em}.prose th,.prose td{padding:.5rem .8rem;border:1px solid color-mix(in oklab,var(--accent) 15%,transparent);text-align:left;color:var(--text)}.prose th{background:color-mix(in oklab,var(--accent) 12%,transparent);font-weight:700;color:var(--accent)}.prose tr:nth-child(2n) td{background:#ffffff0a}.prose img{max-width:100%;border-radius:10px;border:1px solid rgba(135,184,255,.15)}.prose .youtube-embed{position:relative;width:100%;padding-top:56.25%;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:#000}.prose .youtube-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.prose a{text-decoration-thickness:1.5px}.article-header{padding:.2rem 0 .8rem;border-bottom:1px solid var(--border);margin-bottom:1rem}.kicker{display:inline-block;font-family:IBM Plex Mono,monospace;font-size:.75rem;letter-spacing:.05em;padding:.22rem .55rem;border-radius:999px;border:1px solid rgba(135,184,255,.35);background:#87b8ff1f;color:#87b8ff}.back-link{display:inline-flex;margin-top:.6rem;font-family:IBM Plex Mono,monospace;font-size:.82rem;text-decoration:none;color:var(--accent);transition:.15s ease}.back-link:hover{color:var(--accent-2)}.lesson-nav{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:.7rem}.lesson-nav a{text-decoration:none;border:1px solid var(--border);padding:.3rem .55rem;border-radius:8px;background:var(--surface);color:var(--text);transition:.15s ease}.lesson-nav a:hover{background:color-mix(in oklab,var(--accent) 12%,transparent);border-color:var(--accent);color:var(--accent)}ul{padding-left:1.2rem}li+li{margin-top:.9rem}small,p{color:var(--muted)}.shell-footer{padding-top:0;padding-bottom:0;background:linear-gradient(var(--bg-grid) 1px,transparent 1px),linear-gradient(90deg,var(--bg-grid) 1px,transparent 1px),var(--footer-bg);background-size:28px 28px,28px 28px,auto}.footer-inner{display:flex;align-items:center;justify-content:center;padding:1.5rem;border-top:1px solid var(--footer-border);text-align:center}.footer-copy{font-family:IBM Plex Mono,monospace;font-size:.78rem;color:var(--muted);margin:0}.footer-copy a{color:var(--accent);text-decoration:none}.footer-copy a:hover{color:var(--accent-2)}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:900px){.docs-shell{grid-template-columns:1fr}.sidebar-mobile-toggle{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:.65rem;padding:.52rem .78rem;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font:inherit;font-size:.88rem;font-weight:600}.docs-sidebar-shell{position:relative}.docs-sidebar{position:fixed;top:0;left:0;bottom:0;z-index:60;width:min(86vw,320px);max-height:100dvh;overflow-y:auto;overflow-x:hidden;border-radius:0;border-left:0;transform:translate(-104%);transition:transform .22s ease;padding-top:1rem;background:var(--surface)}.docs-sidebar-shell.is-open .docs-sidebar{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;inset:0;z-index:55;border:0;background:#00000073;opacity:0;pointer-events:none;transition:opacity .22s ease}.docs-sidebar-shell.is-open .sidebar-backdrop{opacity:1;pointer-events:auto}}@media(max-width:640px){.shell-footer,main{padding:.85rem}.header-outer{padding:.7rem}.top-nav{gap:.5rem}.nav-links{gap:.1rem}.nav-pill{font-size:.8rem;padding:.35rem .5rem}}
