:root{--bg:#0d1117;--bg-card:#161b22;--bg-hover:#1c2129;--border:#21262d;--border-active:#58a6ff;--text:#e6edf3;--text-secondary:#8b949e;--text-muted:#484f58;--accent:#58a6ff;--green:#3fb950;--red:#f85149;--yellow:#d29922;--purple:#bc8cff;--orange:#f0883e;--cyan:#39d2c0;--font-mono:"SF Mono","Fira Code","Cascadia Code","JetBrains Mono",monospace;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--radius:8px;--transition:.25s ease}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);height:100vh;overflow:hidden}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:var(--font-sans);cursor:pointer;color:var(--text);background:0 0;border:none}code,pre{font-family:var(--font-mono)}#root{height:100vh}.app{grid-template:"nav"56px"main"1fr/1fr;height:100vh;display:grid}.app.with-sidebar{grid-template:"nav nav"56px"side main"1fr/300px 1fr}.nav-bar{border-bottom:1px solid var(--border);background:var(--bg-card);z-index:100;grid-area:nav;align-items:center;gap:16px;padding:0 20px;display:flex}.logo{color:var(--accent);white-space:nowrap;cursor:pointer;font-size:16px;font-weight:700}.mode-switcher{gap:0;margin-left:8px;display:flex}.mode-tab{color:var(--text-secondary);border:1px solid var(--border);transition:all var(--transition);cursor:pointer;background:0 0;padding:6px 14px;font-size:13px}.mode-tab:first-child{border-radius:6px 0 0 6px}.mode-tab:last-child{border-left:none;border-radius:0 6px 6px 0}.mode-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.mode-tab:not(.active):hover{background:var(--bg-hover)}.nav-spacer{flex:1}.search-trigger{border:1px solid var(--border);background:var(--bg);color:var(--text-secondary);white-space:nowrap;cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:13px;display:flex}.search-trigger:hover{border-color:var(--border-active)}.search-trigger kbd{font-family:var(--font-sans);background:var(--bg-card);border:1px solid var(--border);border-radius:3px;padding:1px 5px;font-size:11px}.side-panel{border-right:1px solid var(--border);background:var(--bg-card);grid-area:side;padding:20px;overflow-y:auto}.side-panel h3{text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);margin-bottom:12px;font-size:11px}.main-content{scroll-behavior:smooth;grid-area:main;padding:32px 40px;overflow-y:auto}.main-content:has(>.codebase-layout){padding:0;overflow:hidden}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--transition), box-shadow var(--transition);padding:16px}.card:hover{border-color:var(--border-active);box-shadow:0 0 20px #58a6ff14}.card-title{margin-bottom:4px;font-size:14px;font-weight:600}.card-sub{color:var(--text-secondary);font-size:12px}.parts-grid{grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:32px;display:grid}.part-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--transition), box-shadow var(--transition);padding:24px;position:relative;overflow:hidden}.part-card:before{content:"";width:4px;position:absolute;top:0;bottom:0;left:0}.part-card:hover{border-color:var(--border-active);box-shadow:0 0 20px #58a6ff14}.part-card .part-number{text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-size:11px;font-weight:600}.part-card .part-title{margin-bottom:6px;font-size:18px;font-weight:700}.part-card .part-desc{color:var(--text-secondary);margin-bottom:12px;font-size:13px;line-height:1.5}.part-card .part-chapters{color:var(--text-muted);font-size:12px}.chapters-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-top:16px;display:grid}.chapter-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--transition), box-shadow var(--transition);padding:16px}.chapter-card:hover{border-color:var(--border-active);box-shadow:0 0 20px #58a6ff14}.chapter-card .ch-number{color:var(--text-muted);margin-bottom:4px;font-size:11px;font-weight:600}.chapter-card .ch-title{margin-bottom:4px;font-size:14px;font-weight:600}.chapter-card .ch-subtitle{color:var(--text-secondary);margin-bottom:8px;font-size:12px;font-style:italic}.chapter-card .ch-outcomes{color:var(--text-muted);font-size:11px}.chapter-header{margin-bottom:32px}.chapter-header .ch-num-badge{color:var(--accent);margin-bottom:8px;font-size:12px;font-weight:600}.chapter-header .title{margin-bottom:4px;font-size:28px;font-weight:700}.chapter-header .subtitle{color:var(--yellow);font-size:14px;font-style:italic}.learning-outcomes{border-left:3px solid var(--green);border-radius:0 var(--radius) var(--radius) 0;background:#3fb9500f;margin-bottom:24px;padding:16px 20px}.learning-outcomes h4{text-transform:uppercase;letter-spacing:1px;color:var(--green);margin-bottom:10px;font-size:12px}.learning-outcomes ul{padding:0;list-style:none}.learning-outcomes li{color:var(--text-secondary);padding-left:20px;font-size:13px;line-height:1.7;position:relative}.learning-outcomes li:before{content:"✓";color:var(--green);font-weight:600;position:absolute;left:0}.section-heading{border-top:1px solid var(--border);margin:32px 0 16px;padding-top:16px;font-size:20px;font-weight:700}.content-text{color:var(--text-secondary);max-width:780px;margin-bottom:16px;font-size:14px;line-height:1.8}.content-text strong{color:var(--text)}.content-concept{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:16px}.content-concept .concept-title{margin-bottom:4px;font-size:15px;font-weight:600}.content-concept .concept-analogy{color:var(--yellow);margin-bottom:8px;font-size:12px;font-style:italic}.content-concept .concept-explanation{color:var(--text-secondary);font-size:13px;line-height:1.7}.callout{border-radius:0 var(--radius) var(--radius) 0;color:var(--text-secondary);margin-bottom:16px;padding:16px 20px;font-size:13px;line-height:1.7}.callout strong{color:var(--text)}.callout.info{border-left:3px solid var(--accent);background:#58a6ff0f}.callout.warning{border-left:3px solid var(--red);background:#f851490f}.callout.key-insight{border-left:3px solid var(--yellow);background:#d299220f}.content-table{border-collapse:collapse;width:100%;margin-bottom:24px}.content-table th{text-align:left;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);border-bottom:1px solid var(--border);padding:8px 12px;font-size:11px}.content-table td{border-bottom:1px solid var(--border);padding:10px 12px;font-size:13px}.content-table td:first-child{font-family:var(--font-mono);color:var(--accent);font-size:12px}.content-table tr:hover td{background:var(--bg-hover)}.code-container{border-radius:var(--radius);border:1px solid var(--border);background:#1e1e2e;margin-bottom:24px;position:relative;overflow:hidden}.code-explanation{color:var(--text-secondary);background:var(--bg-card);border-bottom:1px solid var(--border);padding:12px 16px;font-size:12px;line-height:1.6}.code-container pre{margin:0;padding:16px 20px;font-size:13px;line-height:1.7;overflow-x:auto;background:0 0!important}.code-container code{background:0 0!important}.code-line{min-height:22px;padding:0 40px 0 0;display:flex}.code-line.annotated{cursor:pointer;position:relative}.code-line.annotated:hover{background:#58a6ff14}.code-line .line-num{text-align:right;color:#6e7681;-webkit-user-select:none;user-select:none;flex-shrink:0;width:48px;padding-right:16px;font-size:12px}.code-line .line-content{white-space:pre;flex:1;min-width:0}.annotation-dot{background:var(--accent);opacity:.7;border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:7px;margin-left:8px;transition:opacity .2s,transform .2s}.code-line.annotated:hover .annotation-dot{opacity:1;transform:scale(1.3)}.annotation-panel{background:var(--bg-card);border-top:1px solid var(--border);color:var(--text-secondary);padding:16px 20px;font-size:13px;line-height:1.6}.annotation-panel .ann-line-ref{font-family:var(--font-mono);color:var(--accent);margin-bottom:6px;font-size:11px}.flow-steps{margin-bottom:24px;padding-left:32px;position:relative}.flow-steps:before{content:"";background:var(--border);width:2px;position:absolute;top:0;bottom:0;left:11px}.flow-step{border-radius:var(--radius);border:1px solid #0000;margin-bottom:8px;padding:12px 16px;position:relative}.flow-step:before{content:"";background:var(--bg);border:2px solid var(--text-muted);z-index:1;border-radius:50%;width:12px;height:12px;position:absolute;top:18px;left:-25px}.flow-step-title{margin-bottom:4px;font-size:14px;font-weight:600}.flow-step-desc{color:var(--text-secondary);font-size:12px;line-height:1.5}.flow-step-code{font-family:var(--font-mono);color:var(--purple);margin-top:4px;font-size:11px}.section-nav{list-style:none}.section-nav li{color:var(--text-secondary);cursor:pointer;transition:all var(--transition);border-radius:4px;margin-bottom:2px;padding:6px 12px;font-size:13px}.section-nav li:hover{color:var(--text);background:var(--bg-hover)}.section-nav li.active{color:var(--accent);background:#58a6ff14}.codebase-layout{grid-template-columns:320px 1fr;height:100%;display:grid;overflow:hidden}.codebase-layout.with-panel{grid-template-columns:280px 1fr 340px}.tree-panel{border-right:1px solid var(--border);background:var(--bg-card);padding:16px;overflow-y:auto}.source-panel{padding:0;overflow-y:auto}.behavior-panel{border-left:1px solid var(--border);background:var(--bg-card);padding:20px;overflow-y:auto}.tree-root-label{color:var(--text);border-bottom:1px solid var(--border);margin-bottom:4px;padding:8px 0;font-size:13px;font-weight:600}.tree-node{-webkit-user-select:none;user-select:none}.tree-node-header{cursor:pointer;transition:background var(--transition);border-radius:4px;align-items:center;gap:6px;padding:3px 8px;font-size:13px;display:flex}.tree-node-header:hover{background:var(--bg-hover)}.tree-node-header.active{color:var(--accent);background:#58a6ff1a}.tree-node-header .icon{text-align:center;flex-shrink:0;width:16px;font-size:14px}.tree-node-header .name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.tree-children{padding-left:16px}.tree-file{cursor:pointer;color:var(--text-secondary);transition:background var(--transition);border-radius:4px;align-items:center;gap:6px;padding:3px 8px;font-size:12px;display:flex}.tree-file:hover{background:var(--bg-hover);color:var(--text)}.tree-file.active{color:var(--accent);background:#58a6ff1a}.tree-file .icon{text-align:center;flex-shrink:0;width:16px;font-size:12px}.file-header{border-bottom:1px solid var(--border);background:var(--bg-card);padding:16px 20px}.file-header .file-path{font-family:var(--font-mono);color:var(--text-muted);font-size:12px}.file-header .file-desc{color:var(--text-secondary);margin-top:6px;font-size:13px;line-height:1.5}.file-source{overflow-x:auto}.file-source pre{margin:0;padding:16px 20px;font-size:13px;line-height:1.7;background:0 0!important}.behavior-panel h3{text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);margin-bottom:12px;font-size:11px}.behavior-panel .file-overview{color:var(--text-secondary);margin-bottom:20px;font-size:13px;line-height:1.7}.func-list-item{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--transition), background var(--transition);margin-bottom:6px;padding:10px 12px}.func-list-item:hover{border-color:var(--accent);background:var(--bg-hover)}.func-list-item.active{border-color:var(--accent);background:#58a6ff0f}.func-list-item .func-name{font-family:var(--font-mono);color:var(--accent);margin-bottom:2px;font-size:12px}.func-list-item .func-sig{font-family:var(--font-mono);color:var(--text-muted);margin-bottom:4px;font-size:11px}.func-list-item .func-explanation{color:var(--text-secondary);font-size:12px;line-height:1.5;display:none}.func-list-item.active .func-explanation{margin-top:6px;display:block}.related-chapter-badge{color:var(--accent);cursor:pointer;transition:background var(--transition);background:#58a6ff1a;border-radius:4px;align-items:center;gap:4px;margin-top:4px;padding:3px 8px;font-size:11px;display:inline-flex}.related-chapter-badge:hover{background:#58a6ff33}.search-modal{z-index:1000;justify-content:center;align-items:flex-start;padding-top:120px;display:none;position:fixed;inset:0}.search-modal.visible{display:flex}.search-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;position:absolute;inset:0}.search-dialog{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:560px;max-height:400px;position:relative;overflow:hidden;box-shadow:0 16px 48px #0006}.search-input{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text);font-size:15px;font-family:var(--font-sans);background:0 0;outline:none;padding:16px 20px}.search-results{max-height:320px;overflow-y:auto}.search-result{cursor:pointer;align-items:center;gap:10px;padding:10px 20px;transition:background .15s;display:flex}.search-result:hover,.search-result.selected{background:var(--bg-hover)}.search-result-type{text-transform:uppercase;letter-spacing:.8px;white-space:nowrap;border-radius:3px;padding:2px 6px;font-size:9px;font-weight:600}.search-result-type.chapter{color:var(--green);background:#3fb95026}.search-result-type.section{color:var(--yellow);background:#d2992226}.search-result-type.package{color:var(--purple);background:#bc8cff26}.search-result-type.file{color:var(--accent);background:#58a6ff26}.search-result-type.function{color:var(--orange);background:#f0883e26}.search-result-title{font-size:13px}.search-result-desc{color:var(--text-muted);font-size:11px}.search-empty{text-align:center;color:var(--text-muted);padding:20px;font-size:13px}.breadcrumb{align-items:center;gap:6px;min-width:0;font-size:13px;display:flex}.breadcrumb-item{color:var(--text-secondary);cursor:pointer;white-space:nowrap}.breadcrumb-item:hover{color:var(--accent)}.breadcrumb-item.active{color:var(--text);cursor:default}.breadcrumb-sep{color:var(--text-muted);font-size:11px}.badge{border-radius:4px;margin-right:4px;padding:2px 6px;font-size:10px;font-weight:600;display:inline-block}.badge-blue{color:var(--accent);background:#58a6ff1f}.badge-green{color:var(--green);background:#3fb9501f}.badge-yellow{color:var(--yellow);background:#d299221f}.badge-purple{color:var(--purple);background:#bc8cff1f}.badge-red{color:var(--red);background:#f851491f}.section-title{margin-bottom:8px;font-size:24px;font-weight:700}.section-desc{color:var(--text-secondary);max-width:700px;margin-bottom:24px;font-size:14px;line-height:1.6}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.fade-in{animation:.3s fadeIn}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (width<=900px){.app.with-sidebar{grid-template:"nav"56px"main"1fr/1fr}.app.with-sidebar .side-panel{display:none}.main-content{padding:20px}.parts-grid,.codebase-layout{grid-template-columns:1fr}.codebase-layout .tree-panel{display:none}.codebase-layout.with-panel{grid-template-columns:1fr}.codebase-layout.with-panel .behavior-panel{display:none}}.home-hero{max-width:800px;margin:0 auto;padding:40px 0}.home-hero h1{margin-bottom:12px;font-size:32px;font-weight:700}.home-hero .hero-desc{color:var(--text-secondary);max-width:600px;margin-bottom:32px;font-size:15px;line-height:1.7}.home-divider{border:none;border-top:1px solid var(--border);margin:24px 0}.home-section-title{text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);margin-bottom:16px;font-size:12px}.codebase-links{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.codebase-link-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--transition);padding:16px}.codebase-link-card:hover{border-color:var(--border-active)}.codebase-link-card .link-title{font-family:var(--font-mono);margin-bottom:4px;font-size:14px;font-weight:600}.codebase-link-card .link-desc{color:var(--text-secondary);font-size:12px}code[class*=language-],pre[class*=language-]{color:#ccc;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;tab-size:4;-webkit-hyphens:none;hyphens:none;background:0 0;font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;font-size:1em;line-height:1.5}pre[class*=language-]{margin:.5em 0;padding:1em;overflow:auto}:not(pre)>code[class*=language-],pre[class*=language-]{background:#2d2d2d}:not(pre)>code[class*=language-]{white-space:normal;border-radius:.3em;padding:.1em}.token.comment,.token.block-comment,.token.prolog,.token.doctype,.token.cdata{color:#999}.token.punctuation{color:#ccc}.token.tag,.token.attr-name,.token.namespace,.token.deleted{color:#e2777a}.token.function-name{color:#6196cc}.token.boolean,.token.number,.token.function{color:#f08d49}.token.property,.token.class-name,.token.constant,.token.symbol{color:#f8c555}.token.selector,.token.important,.token.atrule,.token.keyword,.token.builtin{color:#cc99cd}.token.string,.token.char,.token.attr-value,.token.regex,.token.variable{color:#7ec699}.token.operator,.token.entity,.token.url{color:#67cdcc}.token.important,.token.bold{font-weight:700}.token.italic{font-style:italic}.token.entity{cursor:help}.token.inserted{color:green}
