:root{--bg: #0a0b0e;--surface: #111318;--surface2: #181b22;--border: #1e2230;--border2: #252a38;--text: #e2e6f0;--muted: #6b7591;--accent: #4f8fff;--accent2: #7c5cfc;--green: #2dd672;--amber: #f5a623;--red: #ff5f5f;--cyan: #26d9d9;--pink: #ff5fa0;--tag-bg: #1a2040}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:Space Grotesk,sans-serif}.shell{display:flex;height:100vh;overflow:hidden}aside{width:280px;min-width:280px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.logo{padding:20px 18px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.logo-title{font-family:Syne,sans-serif;font-size:15px;font-weight:800;color:#fff;letter-spacing:.5px;line-height:1.2}.logo-sub{font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-top:3px}.nav-scroll{overflow-y:auto;flex:1;padding:8px 0 20px}.nav-scroll::-webkit-scrollbar{width:3px}.nav-scroll::-webkit-scrollbar-thumb{background:var(--border2)}.nav-group-label{font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);padding:14px 18px 5px;font-family:JetBrains Mono,monospace}.nav-item{padding:7px 18px 7px 28px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);transition:all .15s;border-left:2px solid transparent;margin:1px 0}.nav-item:hover{color:var(--text);background:var(--surface2);border-left-color:var(--border2)}.nav-item.active{color:#fff;background:#4f8fff14;border-left-color:var(--accent);font-weight:500}.nav-dot{width:5px;height:5px;border-radius:50%;background:var(--border2);flex-shrink:0;transition:background .15s}.nav-item.active .nav-dot,.nav-item:hover .nav-dot{background:var(--accent)}.nav-super{padding:4px 10px;margin:8px 10px 4px;border-radius:6px;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;text-align:center;transition:all .2s}.nav-super.dsa{background:#4f8fff26;color:var(--accent);border:1px solid rgba(79,143,255,.3)}.nav-super.dsa:hover{background:#4f8fff40}.nav-super.sd{background:#7c5cfc26;color:var(--accent2);border:1px solid rgba(124,92,252,.3)}.nav-super.sd:hover{background:#7c5cfc40}.main{flex:1;overflow-y:auto;padding:0;scroll-behavior:smooth}.main::-webkit-scrollbar{width:4px}.main::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.sec-header{padding:36px 44px 4px;position:sticky;top:0;background:var(--bg);z-index:10}.sec-meta{display:flex;align-items:center;gap:10px;margin-bottom:8px}.sec-badge{font-family:JetBrains Mono,monospace;font-size:10px;padding:3px 9px;border-radius:4px;font-weight:700;letter-spacing:.5px}.sec-badge.dsa{background:#4f8fff26;color:var(--accent);border:1px solid rgba(79,143,255,.25)}.sec-badge.sd{background:#7c5cfc26;color:var(--accent2);border:1px solid rgba(124,92,252,.25)}.sec-title{font-family:Syne,sans-serif;font-size:26px;font-weight:800;color:#fff;line-height:1.1}.sec-lead{font-size:14px;line-height:1.7;color:#9ba8c5;max-width:820px;padding:10px 44px 0}.sec-divider{height:1px;background:var(--border);margin:16px 44px 0}.sec-body{padding:24px 44px 60px}.h2{font-family:Syne,sans-serif;font-size:16px;font-weight:700;color:#fff;margin:28px 0 12px;padding-left:10px;border-left:3px solid var(--accent)}.h3{font-size:13px;font-weight:600;color:#c8d0e8;margin:20px 0 8px;letter-spacing:.3px}p{font-size:13.5px;line-height:1.75;color:#9ba8c5;margin-bottom:10px}p code,li code{font-family:JetBrains Mono,monospace;font-size:11.5px;background:var(--surface2);padding:1px 6px;border-radius:3px;color:#c8d0e8;border:1px solid var(--border)}.lang-toggle{display:flex;gap:6px;margin-bottom:8px;align-items:center}.lang-btn{font-family:JetBrains Mono,monospace;font-size:10px;padding:4px 10px;border-radius:4px;border:1px solid var(--border2);background:transparent;color:var(--muted);cursor:pointer;transition:all .15s;font-weight:600;letter-spacing:.5px}.lang-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.lang-btn.py.active{background:var(--green);color:#0a0b0e;border-color:var(--green)}.code-wrap{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;margin:0 0 14px}.code-hdr{background:var(--surface2);padding:8px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.code-lbl{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--muted);font-weight:600;letter-spacing:.5px}.code-diff{font-family:JetBrains Mono,monospace;font-size:10px;padding:2px 8px;border-radius:3px;font-weight:700}.diff-easy{background:#2dd67226;color:var(--green)}.diff-med{background:#f5a62326;color:var(--amber)}.diff-hard{background:#ff5f5f26;color:var(--red)}pre{padding:14px 16px;overflow-x:auto;font-family:JetBrains Mono,monospace;font-size:12px;line-height:1.65;color:#c8d0e8}pre::-webkit-scrollbar{height:3px}pre::-webkit-scrollbar-thumb{background:var(--border2)}.kw{color:#7c9fff}.fn{color:#79d4f5}.str{color:#79dca0}.num{color:#f5a86a}.cmt{color:#445570;font-style:italic}.cls{color:#f5c26b}.dec{color:#b080ff}.py-kw{color:#ff9eb5}.py-fn{color:#79d4f5}.py-str{color:#79dca0}.py-cmt{color:#445570;font-style:italic}.py-cls{color:#f5c26b}.py-dec{color:#b080ff}.py-num{color:#f5a86a}.lang-panel{display:none}.lang-panel.active{display:block}.diag{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px;margin:0 0 14px;overflow-x:auto}.diag pre{padding:0;font-size:11.5px;color:#7a8db3;background:none;border:none;line-height:1.6}.tbl-wrap{overflow-x:auto;margin:0 0 14px;border-radius:8px;border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:12.5px}th{background:var(--surface2);padding:9px 14px;text-align:left;font-weight:600;color:#c8d0e8;border-bottom:1px solid var(--border);font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.3px}td{padding:8px 14px;border-bottom:1px solid var(--border);color:#9ba8c5}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff05}.o-great{color:var(--green);font-weight:600;font-family:JetBrains Mono,monospace}.o-good{color:#79d4f5;font-weight:600;font-family:JetBrains Mono,monospace}.o-ok{color:var(--amber);font-weight:600;font-family:JetBrains Mono,monospace}.o-bad{color:var(--red);font-weight:600;font-family:JetBrains Mono,monospace}.problems-grid{display:flex;flex-direction:column;gap:12px;margin:0 0 14px}problem-card,.problem-card{display:block;background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .2s}problem-card:hover,.problem-card:hover{border-color:var(--border2)}.prob-header{padding:12px 16px;background:var(--surface2);display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none;gap:12px}.prob-num{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--muted);font-weight:700;min-width:24px}.prob-title{font-size:13px;font-weight:600;color:#c8d0e8;flex:1}.prob-tags{display:flex;gap:6px;flex-wrap:wrap}.prob-tag{font-family:JetBrains Mono,monospace;font-size:9px;padding:2px 6px;border-radius:3px;background:var(--tag-bg);color:var(--muted);border:1px solid var(--border);font-weight:600}.diff-badge{font-family:JetBrains Mono,monospace;font-size:9px;padding:3px 8px;border-radius:3px;font-weight:700}.diff-e{background:#2dd6721f;color:var(--green);border:1px solid rgba(45,214,114,.2)}.diff-m{background:#f5a6231f;color:var(--amber);border:1px solid rgba(245,166,35,.2)}.diff-h{background:#ff5f5f1f;color:var(--red);border:1px solid rgba(255,95,95,.2)}.prob-expand{color:var(--muted);font-size:16px;transition:transform .2s;font-family:monospace}.prob-body{display:none;padding:16px;border-top:1px solid var(--border)}.prob-body.open{display:block}.prob-desc{font-size:13px;line-height:1.7;color:#9ba8c5;margin-bottom:12px}.prob-example{background:var(--surface2);border-radius:6px;padding:10px 14px;margin-bottom:12px;font-family:JetBrains Mono,monospace;font-size:11.5px;color:#79d4f5;border-left:3px solid var(--accent)}.approach-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.approach{background:var(--surface2);border-radius:6px;padding:10px 14px;border-left:3px solid var(--border2)}.approach.best{border-left-color:var(--green)}.approach-name{font-size:11px;font-weight:700;color:#c8d0e8;font-family:JetBrains Mono,monospace;letter-spacing:.5px;margin-bottom:4px;display:flex;gap:8px;align-items:center}.approach-tc{font-size:10px;font-family:JetBrains Mono,monospace;color:var(--muted)}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;margin:0 0 14px}.card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px}.card-title{font-size:12px;font-weight:700;margin-bottom:6px;letter-spacing:.3px;font-family:JetBrains Mono,monospace}.card-title.green{color:var(--green)}.card-title.blue{color:var(--accent)}.card-title.amber{color:var(--amber)}.card-title.red{color:var(--red)}.card-title.cyan{color:var(--cyan)}.card-title.purple{color:var(--accent2)}.card p{font-size:12px;color:#7a8db3;margin:0;line-height:1.5}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:0 0 14px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:0 0 14px}.alert{border-radius:8px;padding:12px 16px;margin:0 0 14px;display:flex;gap:10px;align-items:flex-start;font-size:13px;line-height:1.6}.alert.tip{background:#4f8fff14;border:1px solid rgba(79,143,255,.2);color:#9bafdc}.alert.warn{background:#f5a62314;border:1px solid rgba(245,166,35,.2);color:#d9b880}.alert.key{background:#2dd67214;border:1px solid rgba(45,214,114,.2);color:#80c9a0}.alert-icon{font-size:16px;flex-shrink:0;margin-top:1px}.arch-box{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:20px;margin:0 0 14px;overflow-x:auto}.arch-box pre{font-size:12px;color:#6b7ea8;line-height:1.7;font-family:JetBrains Mono,monospace;background:none;padding:0}.progress-bar{position:fixed;bottom:0;left:280px;right:0;height:3px;background:var(--border);z-index:100}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .3s;width:2.7%}.section{display:none}.section.active{display:block}.steps{counter-reset:step;display:flex;flex-direction:column;gap:8px;margin:0 0 14px}.step{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 16px 12px 48px;position:relative;font-size:13px;color:#9ba8c5;line-height:1.65}.step:before{counter-increment:step;content:counter(step);position:absolute;left:14px;top:12px;width:22px;height:22px;background:var(--accent);border-radius:50%;font-size:11px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;font-family:JetBrains Mono,monospace}.step strong{color:#c8d0e8;font-weight:600}.cheatsheet{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;margin:0 0 14px}.cs-item{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:10px 12px}.cs-label{font-family:JetBrains Mono,monospace;font-size:9px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}.cs-val{font-family:JetBrains Mono,monospace;font-size:13px;font-weight:700;color:#fff}.cs-note{font-size:11px;color:var(--muted);margin-top:2px}.check-summary{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 18px;margin:0 0 18px;flex-wrap:wrap}.check-count{font-family:JetBrains Mono,monospace;font-size:13px;color:#c8d0e8;font-weight:700;white-space:nowrap}.check-count #ck-done{color:var(--green);font-size:18px}.check-count-sep{color:var(--muted);margin:0 2px}.check-count-label{color:var(--muted);font-weight:600;font-size:11px;letter-spacing:.5px}.check-meter{flex:1;min-width:140px;height:7px;background:var(--surface2);border-radius:4px;overflow:hidden}.check-meter-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--accent),var(--green));transition:width .3s}.check-reset{font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;letter-spacing:.5px;padding:6px 12px;border-radius:5px;border:1px solid var(--border2);background:transparent;color:var(--muted);cursor:pointer;transition:all .15s}.check-reset:hover{color:var(--red);border-color:#ff5f5f66}.check-group{display:flex;flex-direction:column;gap:4px;margin:0 0 14px}.check-item{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:9px 14px;cursor:pointer;transition:border-color .15s,background .15s}.check-item:hover{border-color:var(--border2);background:var(--surface2)}.check-item input[type=checkbox]{width:16px;height:16px;flex-shrink:0;accent-color:var(--green);cursor:pointer}.check-name{flex:1;font-size:13px;color:#c8d0e8;font-weight:500}.check-item:has(input:checked) .check-name{color:var(--muted);text-decoration:line-through}.check-item:has(input:checked){background:#2dd6720d}.check-lc{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--muted);background:var(--tag-bg);border:1px solid var(--border);border-radius:3px;padding:2px 7px;flex-shrink:0}@media (max-width: 900px){aside{width:240px;min-width:240px}.sec-header,.sec-lead,.sec-body{padding-left:24px;padding-right:24px}.grid-2{grid-template-columns:1fr}}@media (max-width: 640px){aside{display:none}.progress-bar{left:0}}
