:root{--bg:#fafaf8;--bg-elev:#fff;--bg-soft:#f3f2ef;--border:#e9e6e0;--border-strong:#d8d3ca;--fg:#1a1a1a;--fg-muted:#5c5a55;--fg-dim:#8a877f;--brand:#d97757;--brand-soft:#f7ede4;--brand-fg:#9c4a2f;--accent:#2f6f5e;--code-bg:#1f1d1a;--code-fg:#f5f1ea;--code-inline-bg:#efebe3;--code-inline-fg:#5c2912;--shadow-sm:0 1px 2px #1e19140d;--shadow-md:0 8px 24px -12px #1e191426;--radius:12px;--sidebar-w:300px}[data-theme=dark]{--bg:#17161a;--bg-elev:#1f1d22;--bg-soft:#252329;--border:#2e2b32;--border-strong:#3b3740;--fg:#f3f1ee;--fg-muted:#b6b2ac;--fg-dim:#7f7a73;--brand:#e89073;--brand-soft:#3a2420;--brand-fg:#f0a387;--accent:#6ac0a4;--code-bg:#0f0e10;--code-fg:#ececec;--code-inline-bg:#2c272e;--code-inline-fg:#f0a387;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 8px 24px -10px #00000080}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--fg);letter-spacing:.01em;-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Source Han Sans CN,Inter,system-ui,sans-serif;font-size:15px;line-height:1.75}a{color:var(--brand-fg);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}kbd{background:var(--bg-soft);border:1px solid var(--border-strong);border-bottom-width:2px;border-radius:4px;padding:1px 6px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.85em}.app{grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;display:grid}.sidebar{background:var(--bg-elev);border-right:1px solid var(--border);flex-direction:column;gap:20px;height:100vh;padding:24px 20px;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.brand{cursor:pointer;align-items:center;gap:10px;padding-bottom:8px;display:flex}.brand-logo{background:var(--brand);color:#fff;width:34px;height:34px;box-shadow:var(--shadow-sm);border-radius:8px;place-items:center;font-size:16px;font-weight:700;display:grid}.brand-text{line-height:1.2}.brand-title{color:var(--fg);font-size:15px;font-weight:600}.brand-sub{color:var(--fg-dim);font-size:12px}.progress-block{background:var(--bg-soft);border-radius:var(--radius);padding:14px 14px 16px}.progress-label{color:var(--fg-muted);justify-content:space-between;margin-bottom:8px;font-size:12px;display:flex}.progress-label strong{color:var(--fg);font-weight:600}.progress-bar{background:var(--border);border-radius:999px;height:6px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--brand), #e8a889);height:100%;transition:width .4s}.search-box{position:relative}.search-box input{background:var(--bg-soft);width:100%;color:var(--fg);border:1px solid #0000;border-radius:8px;outline:none;padding:9px 12px 9px 32px;font-size:13px;transition:all .15s}.search-box input:focus{background:var(--bg-elev);border-color:var(--brand)}.search-box:before{content:"⌕";color:var(--fg-dim);font-size:16px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.nav-heading{text-transform:uppercase;letter-spacing:.12em;color:var(--fg-dim);margin:4px;font-size:11px;font-weight:600}.nav-chapter{color:var(--fg-muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;width:100%;margin-bottom:2px;padding:10px 12px;font-size:13.5px;transition:all .15s;display:block}.nav-chapter:hover{background:var(--bg-soft);color:var(--fg)}.nav-chapter.active{background:var(--brand-soft);color:var(--brand-fg);font-weight:600}.nav-chapter-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.nav-chapter-code{color:var(--fg-dim);font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:11px}.nav-chapter.active .nav-chapter-code{color:var(--brand-fg);opacity:.7}.nav-chapter-title{flex:1;line-height:1.3}.nav-chapter-progress{color:var(--fg-dim);font-size:11px}.nav-chapter.active .nav-chapter-progress{color:var(--brand-fg)}.nav-sections{border-left:1px solid var(--border);margin:4px 0 4px 8px;padding-left:12px;display:none}.nav-chapter.active+.nav-sections{display:block}.nav-section{color:var(--fg-muted);cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:5px 10px;font-size:12.5px;transition:all .12s;display:flex}.nav-section:hover{color:var(--fg);background:var(--bg-soft)}.nav-section.done{color:var(--fg-dim)}.nav-section.active{color:var(--brand-fg);font-weight:500}.nav-section-dot{background:var(--border-strong);border-radius:50%;flex-shrink:0;width:6px;height:6px}.nav-section.done .nav-section-dot{background:var(--accent)}.nav-section.active .nav-section-dot{background:var(--brand)}.sidebar-footer{border-top:1px solid var(--border);color:var(--fg-dim);justify-content:space-between;align-items:center;gap:8px;margin-top:auto;padding-top:16px;font-size:12px;display:flex}.icon-btn{border:1px solid var(--border);color:var(--fg-muted);background:0 0;border-radius:8px;place-items:center;width:32px;height:32px;transition:all .15s;display:grid}.icon-btn:hover{background:var(--bg-soft);color:var(--fg);border-color:var(--border-strong)}.main{width:100%;min-width:0;max-width:860px;margin:0 auto;padding:40px 48px 80px}.home-hero{border-bottom:1px solid var(--border);margin-bottom:36px;padding:48px 0 32px}.home-title{letter-spacing:-.01em;margin:0 0 12px;font-size:30px;font-weight:700;line-height:1.25}.home-subtitle{color:var(--fg-muted);max-width:620px;margin:0;font-size:15.5px;line-height:1.7}.home-cta{flex-wrap:wrap;gap:10px;margin-top:28px;display:flex}.btn{cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:#c96443;text-decoration:none}.btn-ghost{color:var(--fg);border-color:var(--border-strong);background:0 0}.btn-ghost:hover{background:var(--bg-soft);text-decoration:none}.home-meta{color:var(--fg-dim);gap:24px;margin-top:28px;font-size:13px;display:flex}.home-meta span strong{color:var(--fg);font-weight:600}.chapter-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.chapter-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;flex-direction:column;gap:10px;padding:22px;transition:all .18s;display:flex;position:relative;overflow:hidden}.chapter-card:hover{border-color:var(--brand);box-shadow:var(--shadow-md);transform:translateY(-2px)}.chapter-card-head{justify-content:space-between;align-items:center;display:flex}.chapter-code{color:var(--fg-dim);letter-spacing:.05em;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:11px}.chapter-title{letter-spacing:-.01em;margin:0;font-size:18px;font-weight:600;line-height:1.35}.chapter-subtitle{color:var(--fg-muted);font-size:13px;line-height:1.55}.chapter-card-footer{color:var(--fg-dim);justify-content:space-between;align-items:center;margin-top:6px;font-size:12px;display:flex}.mini-progress{background:var(--border);border-radius:2px;flex:1;height:4px;margin-right:12px;overflow:hidden}.mini-progress>div{background:var(--accent);height:100%;transition:width .3s}.chapter-header{border-bottom:1px solid var(--border);margin-bottom:36px;padding:36px 0 28px}.chapter-header h1{letter-spacing:-.02em;margin:0 0 8px;font-size:34px;font-weight:700;line-height:1.2}.chapter-header .chapter-header-sub{color:var(--fg-muted);margin-bottom:24px;font-size:16px}.chapter-hero{color:var(--fg-muted);margin:0;font-size:15.5px;line-height:1.7}.goals{margin-top:24px}.goals-label{text-transform:uppercase;letter-spacing:.12em;color:var(--fg-dim);margin-bottom:10px;font-size:12px;font-weight:600}.goals ul{gap:6px;margin:0;padding:0;list-style:none;display:grid}.goals li{color:var(--fg-muted);padding-left:18px;font-size:14px;line-height:1.65;position:relative}.goals li:before{content:"·";color:var(--fg-dim);position:absolute;top:0;left:6px}.section{margin-bottom:40px;scroll-margin-top:20px}.section-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:20px;margin-bottom:20px;padding:18px 0 12px;display:flex}.section-head h2{letter-spacing:-.01em;margin:0;font-size:22px;font-weight:700}.section-head-left{flex:1;min-width:0}.read-toggle{border:1px solid var(--border-strong);color:var(--fg-muted);background:0 0;border-radius:7px;flex-shrink:0;align-items:center;gap:6px;padding:7px 12px;font-size:12.5px;transition:all .15s;display:inline-flex}.read-toggle:hover{background:var(--bg-soft);color:var(--fg)}.read-toggle.done{background:var(--accent);border-color:var(--accent);color:#fff}.md h3{margin:1.6em 0 .6em;font-size:17px;font-weight:600}.md p{color:var(--fg);margin:.9em 0}.md strong{color:var(--fg);font-weight:600}.md ul,.md ol{margin:.9em 0;padding-left:24px}.md li{margin:.3em 0}.md li::marker{color:var(--fg-dim)}.md blockquote{border-left:2px solid var(--border-strong);color:var(--fg-muted);margin:1.2em 0;padding:2px 16px;font-size:14.5px;line-height:1.7}.md blockquote p{margin:.3em 0}.md blockquote strong{color:var(--fg)}.md code{background:var(--code-inline-bg);color:var(--code-inline-fg);border-radius:4px;padding:1px 6px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.88em;font-weight:500}.md pre{background:var(--code-bg);color:var(--code-fg);border-radius:10px;margin:1.2em 0;padding:16px 18px;font-size:13px;line-height:1.65;position:relative;overflow-x:auto}.md pre code{color:inherit;font-size:inherit;background:0 0;padding:0;font-weight:400}.md pre::-webkit-scrollbar{height:6px}.md pre::-webkit-scrollbar-thumb{background:#3a3633;border-radius:3px}.md table{border-collapse:collapse;width:100%;margin:1.2em 0;font-size:14px}.md table th,.md table td{border:1px solid var(--border);text-align:left;padding:9px 14px}.md table th{background:var(--bg-soft);color:var(--fg);font-size:13px;font-weight:600}.md table code{font-size:.85em}.copy-btn{color:#ffffffd9;opacity:.75;cursor:pointer;z-index:1;background:#ffffff1f;border:1px solid #ffffff2e;border-radius:5px;padding:4px 10px;font-family:inherit;font-size:11px;transition:all .15s;position:absolute;top:10px;right:10px}.md pre:hover .copy-btn,.exercise-cmd:hover .copy-btn{opacity:1}.copy-btn:hover{color:#fff;opacity:1;background:#ffffff38}.copy-btn.copied{background:var(--accent);color:#fff;border-color:var(--accent);opacity:1}.exercises{border-top:1px solid var(--border);margin-top:48px;padding-top:24px}.exercises h2{margin:0 0 14px;font-size:20px;font-weight:700}.exercise{border-top:1px solid var(--border);align-items:flex-start;gap:12px;padding:14px 0;display:flex}.exercise:first-of-type{border-top:none}.exercise-check{border:1.5px solid var(--border-strong);cursor:pointer;background:var(--bg-elev);border-radius:50%;flex-shrink:0;place-items:center;width:22px;height:22px;margin-top:1px;transition:all .15s;display:grid}.exercise-check:hover{border-color:var(--brand)}.exercise.done .exercise-check{background:var(--accent);border-color:var(--accent);color:#fff}.exercise.done .exercise-check:after{content:"✓";font-size:12px}.exercise-body{flex:1;min-width:0}.exercise-title{color:var(--fg);font-size:14.5px;line-height:1.55}.exercise.done .exercise-title{color:var(--fg-dim);text-decoration:line-through}.exercise-cmd{background:var(--code-bg);color:var(--code-fg);white-space:pre;border-radius:8px;margin:6px 0 0;padding:12px 14px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:12.5px;line-height:1.65;position:relative;overflow-x:auto}.exercise-cmd code{color:inherit;background:0 0;padding:0;font-family:inherit}.exercise-cmd::-webkit-scrollbar{height:6px}.exercise-cmd::-webkit-scrollbar-thumb{background:#3a3633;border-radius:3px}.install{flex-direction:column;gap:14px;margin-top:12px;display:flex}.install-desc{color:var(--fg-muted);margin:0;font-size:13.5px;line-height:1.6}.install-section{flex-direction:column;gap:4px;display:flex}.install-label{color:var(--fg-muted);letter-spacing:.02em;align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.install-files{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:6px;margin:0;padding:10px 14px;list-style:none;display:flex}.install-files li{color:var(--fg-muted);flex-wrap:wrap;align-items:center;gap:6px;font-size:13px;line-height:1.5;display:flex}.install-files code{background:var(--code-inline-bg);color:var(--code-inline-fg);border-radius:4px;padding:1px 6px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.88em}.dl-link{background:var(--brand-soft);border:1px solid #0000;border-radius:5px;align-items:center;gap:4px;padding:3px 10px;font-size:12.5px;font-weight:500;transition:all .15s;display:inline-flex;color:var(--brand-fg)!important;text-decoration:none!important}.dl-link:hover{border-color:var(--brand);background:var(--brand);color:#fff!important}.dl-arrow{color:var(--fg-dim);font-size:12px}.install-manual{background:var(--bg-elev);border:1px solid var(--border);color:var(--fg-muted);border-radius:8px;flex-direction:column;gap:4px;margin:0;padding:12px 14px 12px 34px;font-size:13.5px;line-height:1.65;display:flex}.install-manual li::marker{color:var(--fg-dim);font-variant-numeric:tabular-nums}.install-manual li{padding-left:2px}.takeaway{border-top:1px solid var(--border);margin:40px 0 0;padding-top:24px}.takeaway-label{color:var(--fg-dim);margin-bottom:6px;font-size:13px;font-weight:500}.takeaway-text{color:var(--fg);font-size:15px;line-height:1.75}.notes-block{background:var(--bg-elev);border:1px dashed var(--border-strong);border-radius:var(--radius);margin-top:36px;padding:20px}.notes-label{text-transform:uppercase;letter-spacing:.12em;color:var(--fg-dim);justify-content:space-between;margin-bottom:8px;font-size:12px;font-weight:600;display:flex}.notes-saved{color:var(--accent);letter-spacing:0;text-transform:none;font-size:11px;font-weight:500}.notes-block textarea{resize:vertical;width:100%;min-height:110px;color:var(--fg);background:0 0;border:none;outline:none;font-family:inherit;font-size:14px;line-height:1.6}.notes-block textarea::placeholder{color:var(--fg-dim)}.chapter-nav{border-top:1px solid var(--border);justify-content:space-between;gap:12px;margin-top:48px;padding-top:24px;display:flex}.chapter-nav-btn{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;flex-direction:column;gap:4px;min-width:180px;max-width:48%;padding:16px 20px;transition:all .15s;display:flex}.chapter-nav-btn:hover{border-color:var(--brand);background:var(--brand-soft)}.chapter-nav-btn.next{text-align:right;margin-left:auto}.chapter-nav-btn .nav-dir{color:var(--fg-dim);letter-spacing:.1em;text-transform:uppercase;font-size:11px}.chapter-nav-btn .nav-name{color:var(--fg);font-size:14px;font-weight:600}.search-results{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:30;max-height:60vh;margin-top:6px;padding:6px;display:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.search-results.show{display:block}.search-result{cursor:pointer;border-radius:6px;padding:10px 12px}.search-result:hover{background:var(--bg-soft)}.search-result-title{color:var(--fg);font-size:13px;font-weight:500}.search-result-ctx{color:var(--fg-dim);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:12px;overflow:hidden}.search-result mark{background:var(--brand-soft);color:var(--brand-fg);border-radius:2px;padding:0 2px}.empty{text-align:center;color:var(--fg-dim);padding:40px 20px;font-size:13px}.learners-badge{background:var(--bg-elev);border:1px solid var(--border);color:var(--fg-muted);z-index:30;box-shadow:var(--shadow-sm);-webkit-user-select:none;user-select:none;border-radius:999px;align-items:center;gap:7px;padding:6px 14px 6px 12px;font-size:12.5px;display:flex;position:fixed;top:18px;right:22px}.learners-badge strong{color:var(--fg);font-variant-numeric:tabular-nums;font-weight:600}.learners-dot{background:#3fa05a;border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2s infinite learners-pulse;box-shadow:0 0 #3fa05a80}@keyframes learners-pulse{0%{box-shadow:0 0 #3fa05a73}70%{box-shadow:0 0 0 8px #3fa05a00}to{box-shadow:0 0 #3fa05a00}}@media (max-width:900px){.learners-badge{padding:5px 11px 5px 10px;font-size:11.5px;top:12px;right:12px}}.book-btn{background:var(--fg);width:48px;height:48px;color:var(--bg);z-index:45;border:none;border-radius:50%;place-items:center;transition:transform .15s,background .15s;display:grid;position:fixed;bottom:28px;right:22px;box-shadow:0 6px 18px -4px #1e191459}.book-btn:hover{transform:translateY(-2px)}.book-btn.has-draft:after{content:"";background:var(--brand);border:2px solid var(--bg);border-radius:50%;width:8px;height:8px;position:absolute;top:8px;right:8px}.notebook-overlay{opacity:0;pointer-events:none;z-index:48;background:#00000047;transition:opacity .2s;position:fixed;inset:0}.notebook-overlay.show{opacity:1;pointer-events:auto}.notebook-drawer{background:var(--bg-elev);border-left:1px solid var(--border);z-index:49;flex-direction:column;width:440px;max-width:92vw;transition:transform .25s;display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-8px 0 32px -12px #1e19142e}.notebook-drawer.open{transform:translate(0)}.nb-head{border-bottom:1px solid var(--border);flex-direction:column;gap:6px;padding:18px 22px 14px;display:flex}.nb-head-top{justify-content:space-between;align-items:center;display:flex}.nb-title{align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.nb-close{color:var(--fg-muted);background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:20px;line-height:1}.nb-close:hover{background:var(--bg-soft);color:var(--fg)}.nb-context{color:var(--fg-muted);flex-wrap:wrap;align-items:center;gap:6px;font-size:12.5px;display:flex}.nb-context-chip{background:var(--bg-soft);color:var(--fg);border-radius:4px;padding:2px 8px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:11.5px}.nb-body{flex-direction:column;flex:1;gap:14px;padding:16px 22px 20px;display:flex;overflow-y:auto}.nb-editor{flex-direction:column;gap:8px;display:flex}.nb-editor textarea{resize:vertical;background:var(--bg);border:1px solid var(--border);width:100%;min-height:140px;color:var(--fg);border-radius:8px;outline:none;padding:12px 14px;font-family:inherit;font-size:14px;line-height:1.65;transition:border-color .15s}.nb-editor textarea:focus{border-color:var(--brand)}.nb-editor-foot{color:var(--fg-dim);justify-content:space-between;align-items:center;font-size:12px;display:flex}.nb-save{background:var(--fg);color:var(--bg);border:none;border-radius:7px;padding:7px 16px;font-size:13px;font-weight:500;transition:opacity .15s}.nb-save:disabled{opacity:.4;cursor:not-allowed}.nb-saved-flash{color:var(--accent);opacity:0;font-size:12px;font-weight:500;transition:opacity .2s}.nb-saved-flash.show{opacity:1}.nb-list-title{text-transform:uppercase;letter-spacing:.1em;color:var(--fg-dim);justify-content:space-between;align-items:center;margin-top:6px;font-size:11px;font-weight:600;display:flex}.nb-list{flex-direction:column;gap:10px;display:flex}.nb-note{border:1px solid var(--border);background:var(--bg);border-radius:8px;padding:12px 14px}.nb-note-meta{color:var(--fg-dim);justify-content:space-between;gap:8px;margin-bottom:6px;font-size:11.5px;display:flex}.nb-note-text{white-space:pre-wrap;word-break:break-word;color:var(--fg);font-size:13.5px;line-height:1.6}.nb-note-actions{gap:10px;margin-top:8px;font-size:11.5px;display:flex}.nb-note-actions button{color:var(--fg-dim);font-size:inherit;background:0 0;border:none;padding:0}.nb-note-actions button:hover{color:var(--fg);text-decoration:underline}.nb-empty{color:var(--fg-dim);text-align:center;padding:20px 0;font-size:13px}.notes-page-hero{border-bottom:1px solid var(--border);margin-bottom:28px;padding:40px 0 24px}.notes-page-hero h1{letter-spacing:-.01em;margin:0 0 8px;font-size:28px;font-weight:700}.notes-page-hero p{color:var(--fg-muted);margin:0;font-size:14.5px}.heatmap-card{margin-bottom:36px}.heatmap-head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:14px;display:flex}.heatmap-head h2{margin:0;font-size:15px;font-weight:600}.heatmap-summary{color:var(--fg-muted);font-size:12.5px}.heatmap-summary strong{color:var(--fg);font-weight:600}.heatmap-wrap{padding-bottom:6px;overflow-x:auto}.heatmap{grid-template-rows:repeat(7,11px);grid-auto-columns:11px;grid-auto-flow:column;gap:3px;width:max-content;display:grid}.heat-cell{background:var(--bg-soft);border:1px solid var(--border);cursor:default;border-radius:2px;width:11px;height:11px;transition:outline .1s}.heat-cell:hover{outline:1px solid var(--fg-muted)}.heat-cell.empty{visibility:hidden}.heat-cell[data-l="1"]{background:#d7ecd5;border-color:#c0dcbc}.heat-cell[data-l="2"]{background:#8fcf90;border-color:#7ac17b}.heat-cell[data-l="3"]{background:#46a257;border-color:#3e9150}.heat-cell[data-l="4"]{background:#1d6b33;border-color:#17582a}[data-theme=dark] .heat-cell{background:#1e1c21;border-color:#2b282f}[data-theme=dark] .heat-cell[data-l="1"]{background:#1d3b2a;border-color:#264c36}[data-theme=dark] .heat-cell[data-l="2"]{background:#286d3b;border-color:#2f7e45}[data-theme=dark] .heat-cell[data-l="3"]{background:#3fa05a;border-color:#45b065}[data-theme=dark] .heat-cell[data-l="4"]{background:#60d37e;border-color:#6cdd88}.heatmap-legend{color:var(--fg-dim);justify-content:flex-end;align-items:center;gap:6px;margin-top:12px;font-size:11px;display:flex}.heatmap-legend .heat-cell{cursor:default}.notes-page-list{flex-direction:column;gap:10px;display:flex}.notes-group{margin-bottom:24px}.notes-group-head{text-transform:uppercase;letter-spacing:.12em;color:var(--fg-dim);border-bottom:1px solid var(--border);margin-bottom:10px;padding-bottom:8px;font-size:11.5px;font-weight:600}.notes-page-empty{text-align:center;color:var(--fg-dim);padding:60px 20px;font-size:14px}.nav-link{color:var(--fg-muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;width:100%;margin-bottom:2px;padding:10px 12px;font-size:13.5px;text-decoration:none;transition:all .15s;display:block}.nav-link:hover{background:var(--bg-soft);color:var(--fg);text-decoration:none}.nav-link.active{background:var(--brand-soft);color:var(--brand-fg);font-weight:600}.menu-btn{display:none}@media (max-width:900px){.app{grid-template-columns:1fr}.sidebar{z-index:40;width:88%;max-width:320px;box-shadow:var(--shadow-md);transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main{padding:24px 20px 60px}.menu-btn{z-index:50;background:var(--brand);color:#fff;width:52px;height:52px;box-shadow:var(--shadow-md);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:22px;display:inline-flex;position:fixed;bottom:20px;right:20px}.backdrop{z-index:35;background:#0006;display:none;position:fixed;inset:0}.backdrop.show{display:block}.home-title{font-size:32px}.chapter-header h1{font-size:26px}.section-head h2{font-size:19px}.chapter-nav-btn{max-width:47%}.book-btn{width:44px;height:44px;bottom:22px;right:82px}.notebook-drawer{width:100vw;max-width:none}}
