@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap";:root{--bg-base:#0d1117;--bg-surface:#161b22;--bg-elevated:#21262d;--bg-overlay:#30363d;--border-subtle:#21262d;--border-default:#30363d;--border-muted:#484f58;--fg-default:#e6edf3;--fg-muted:#8b949e;--fg-subtle:#6e7681;--fg-onaccent:#0d1117;--accent-green:#3fb950;--accent-green-dim:#238636;--accent-green-subtle:#0d2818;--accent-blue:#58a6ff;--accent-amber:#d29922;--accent-amber-subtle:#272115;--accent-red:#f85149;--accent-red-subtle:#2d1b1b;--accent-purple:#bc8cff;--syntax-keyword:#ff7b72;--syntax-string:#a5d6ff;--syntax-comment:#8b949e;--syntax-number:#79c0ff;--syntax-path:#58a6ff;--syntax-exec:#3fb950;--syntax-error:#f85149;--syntax-output:#e6edf3;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--radius-sm:4px;--radius-md:6px;--radius-lg:10px;--sidebar-width:240px;--sidebar-collapsed:56px;--transition:.15s ease}[data-theme=light]{--bg-base:#fff;--bg-surface:#f6f8fa;--bg-elevated:#eaeef2;--bg-overlay:#d0d7de;--border-subtle:#eaeef2;--border-default:#d0d7de;--border-muted:#afb8c1;--fg-default:#1f2328;--fg-muted:#57606a;--fg-subtle:#6e7781;--fg-onaccent:#fff;--accent-green:#1a7f37;--accent-green-dim:#2da44e;--accent-green-subtle:#dafbe1;--accent-blue:#0969da;--accent-amber:#9a6700;--accent-amber-subtle:#fff8c5;--accent-red:#cf222e;--accent-red-subtle:#ffebe9;--accent-purple:#8250df;--syntax-keyword:#cf222e;--syntax-string:#0a3069;--syntax-comment:#57606a;--syntax-number:#0550ae;--syntax-path:#0969da;--syntax-exec:#1a7f37;--syntax-error:#cf222e;--syntax-output:#1f2328}*,:before,:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--bg-base);color:var(--fg-default);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}a{color:var(--accent-blue);text-decoration:none}a:hover{text-decoration:underline}code,pre,.mono{font-family:var(--font-mono)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--fg-subtle)}.app-layout{height:100vh;display:flex;overflow:hidden}.main-content{flex:1;min-width:0;overflow-y:auto}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border-subtle);transition:width var(--transition), min-width var(--transition);flex-direction:column;display:flex;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed);min-width:var(--sidebar-collapsed)}.sidebar-logo{border-bottom:1px solid var(--border-subtle);white-space:nowrap;align-items:center;gap:10px;height:56px;padding:16px;display:flex;overflow:hidden}.sidebar-logo-icon{width:24px;min-width:24px;height:24px;color:var(--accent-green)}.sidebar-logo-text{color:var(--fg-default);font-size:15px;font-weight:700;font-family:var(--font-mono);letter-spacing:-.3px}.sidebar-nav{flex:1;padding:8px;overflow-y:auto}.sidebar-nav-item{border-radius:var(--radius-md);cursor:pointer;color:var(--fg-muted);white-space:nowrap;transition:color var(--transition), background var(--transition);-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:8px 10px;font-size:13px;font-weight:500;text-decoration:none;display:flex;overflow:hidden}.sidebar-nav-item:hover{background:var(--bg-elevated);color:var(--fg-default);text-decoration:none}.sidebar-nav-item.active{background:var(--accent-green-subtle);color:var(--accent-green)}.sidebar-nav-item svg{min-width:16px}.sidebar-footer{border-top:1px solid var(--border-subtle);flex-direction:column;gap:4px;padding:8px;display:flex}.nav-section-label{text-transform:uppercase;letter-spacing:.8px;color:var(--fg-subtle);white-space:nowrap;padding:8px 10px 4px;font-size:10px;font-weight:600}.page-header{border-bottom:1px solid var(--border-subtle);background:var(--bg-base);z-index:10;padding:24px 32px 0;position:sticky;top:0}.page-title{color:var(--fg-default);margin:0 0 4px;font-size:20px;font-weight:700}.page-subtitle{color:var(--fg-muted);margin:0 0 16px;font-size:13px}.card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:16px}.card:hover{border-color:var(--border-muted)}.badge{letter-spacing:.3px;text-transform:uppercase;white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-green{background:var(--accent-green-subtle);color:var(--accent-green);border:1px solid var(--accent-green-dim)}.badge-amber{background:var(--accent-amber-subtle);color:var(--accent-amber)}.badge-red{background:var(--accent-red-subtle);color:var(--accent-red)}.badge-blue{color:var(--accent-blue);background:#0d2137}.badge-muted{background:var(--bg-elevated);color:var(--fg-muted)}.progress-bar{background:var(--bg-elevated);border-radius:2px;height:4px;overflow:hidden}.progress-bar-fill{background:var(--accent-green);border-radius:2px;height:100%;transition:width .4s}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);white-space:nowrap;font-size:13px;font-weight:500;font-family:var(--font-sans);border:1px solid #0000;align-items:center;gap:6px;padding:7px 14px;text-decoration:none;display:inline-flex}.btn-primary{background:var(--accent-green);color:var(--fg-onaccent);border-color:var(--accent-green)}.btn-primary:hover{background:var(--accent-green-dim);border-color:var(--accent-green-dim);text-decoration:none}.btn-secondary{color:var(--fg-default);border-color:var(--border-default);background:0 0}.btn-secondary:hover{background:var(--bg-elevated);border-color:var(--border-muted);text-decoration:none}.btn-ghost{color:var(--fg-muted);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg-elevated);color:var(--fg-default)}.btn-sm{padding:4px 10px;font-size:12px}.btn-icon{padding:6px}.code-block{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:13px;line-height:1.6;overflow-x:auto}.code-block-header{background:var(--bg-overlay);border-bottom:1px solid var(--border-default);color:var(--fg-subtle);justify-content:space-between;align-items:center;padding:6px 12px;font-size:11px;display:flex}.code-block-body{padding:12px 16px;overflow-x:auto}.code-block-actions{gap:4px;display:flex}.terminal{border:1px solid var(--border-default);border-radius:var(--radius-lg);font-family:var(--font-mono);background:#0a0d10;flex-direction:column;height:100%;font-size:13px;display:flex;overflow:hidden}.terminal-header{background:var(--bg-elevated);border-bottom:1px solid var(--border-default);align-items:center;gap:8px;padding:8px 12px;display:flex}.terminal-dot{border-radius:50%;width:10px;height:10px}.terminal-dot-red{background:#ff5f56}.terminal-dot-yellow{background:#ffbd2e}.terminal-dot-green{background:#27c93f}.terminal-title{color:var(--fg-subtle);font-size:12px;font-family:var(--font-mono);margin-left:4px}.terminal-output{flex:1;padding:12px;line-height:1.6;overflow-y:auto}.terminal-line{white-space:pre-wrap;word-break:break-all;margin:0}.terminal-prompt{color:var(--accent-green)}.terminal-cmd{color:var(--fg-default)}.terminal-input-row{border-top:1px solid var(--border-default);align-items:center;padding:8px 12px;display:flex}.terminal-input{color:var(--fg-default);font-family:var(--font-mono);caret-color:var(--accent-green);background:0 0;border:none;outline:none;flex:1;font-size:13px}.callout-warning{background:var(--accent-amber-subtle);border-left:3px solid var(--accent-amber);border-radius:0 var(--radius-md) var(--radius-md) 0;margin:16px 0;padding:12px 16px;font-size:13px}.callout-warning-title{font-family:var(--font-mono);color:var(--accent-amber);margin-bottom:4px;font-size:12px;font-weight:600}.callout-error{background:var(--accent-red-subtle);border-left:3px solid var(--accent-red);border-radius:0 var(--radius-md) var(--radius-md) 0;font-size:13px;font-family:var(--font-mono);margin:16px 0;padding:12px 16px}.lesson-body{max-width:720px;color:var(--fg-default);line-height:1.7}.lesson-body h1{margin:0 0 8px;font-size:22px;font-weight:700}.lesson-body h2{border-bottom:1px solid var(--border-subtle);margin:28px 0 10px;padding-bottom:6px;font-size:17px;font-weight:600}.lesson-body h3{margin:20px 0 8px;font-size:15px;font-weight:600}.lesson-body p{margin:0 0 12px}.lesson-body ul,.lesson-body ol{margin:0 0 12px;padding-left:20px}.lesson-body li{margin-bottom:4px}.lesson-body code{font-family:var(--font-mono);background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--accent-green);border-radius:3px;padding:1px 5px;font-size:12px}.lesson-body pre{margin:12px 0}.lesson-body pre code{color:inherit;background:0 0;border:none;padding:0;font-size:13px}.lesson-body table{border-collapse:collapse;width:100%;margin:12px 0;font-size:13px}.lesson-body th{background:var(--bg-elevated);text-align:left;border:1px solid var(--border-default);padding:8px 12px;font-weight:600}.lesson-body td{border:1px solid var(--border-default);padding:7px 12px}.lesson-body tr:nth-child(2n) td{background:var(--bg-surface)}.lesson-source{color:var(--fg-subtle);font-size:11px;font-family:var(--font-mono);border-top:1px solid var(--border-subtle);margin-top:32px;padding-top:12px}.quiz-option{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);text-align:left;width:100%;font-size:14px;font-family:var(--font-sans);color:var(--fg-default);align-items:flex-start;gap:10px;padding:12px 16px;display:flex}.quiz-option:hover,.quiz-option.selected,.quiz-option.correct{border-color:var(--accent-green);background:var(--accent-green-subtle)}.quiz-option.incorrect{border-color:var(--accent-red);background:var(--accent-red-subtle);color:var(--accent-red)}.heatmap-cell{background:var(--bg-elevated);cursor:pointer;border-radius:2px;width:10px;height:10px}.heatmap-cell[data-level="1"]{background:var(--accent-green-subtle)}.heatmap-cell[data-level="2"]{background:#0d3d1e}.heatmap-cell[data-level="3"]{background:#1a6632}.heatmap-cell[data-level="4"]{background:var(--accent-green)}.palette-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#000000b3;justify-content:center;align-items:flex-start;padding-top:120px;display:flex;position:fixed;inset:0}.palette-dialog{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);width:560px;max-width:90vw;overflow:hidden;box-shadow:0 16px 48px #00000080}.palette-input{width:100%;color:var(--fg-default);font-size:15px;font-family:var(--font-sans);border:none;border-bottom:1px solid var(--border-default);background:0 0;outline:none;padding:14px 16px}.palette-results{max-height:360px;overflow-y:auto}.palette-item{cursor:pointer;transition:background var(--transition);align-items:center;gap:10px;padding:10px 16px;font-size:13px;display:flex}.palette-item:hover,.palette-item.active{background:var(--bg-elevated)}.palette-item-label{color:var(--fg-default);flex:1}.palette-item-category{color:var(--fg-subtle);font-size:11px}.kbd{background:var(--bg-elevated);border:1px solid var(--border-default);font-family:var(--font-mono);color:var(--fg-muted);border-radius:3px;align-items:center;padding:1px 5px;font-size:11px;line-height:1.6;display:inline-flex}.sparkline{align-items:flex-end;gap:2px;height:24px;display:flex}.sparkline-bar{background:var(--accent-green-dim);border-radius:1px;width:4px;min-height:2px}.achievement-badge{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:all var(--transition);flex-direction:column;align-items:center;gap:6px;padding:16px 12px;display:flex}.achievement-badge:hover,.achievement-badge.unlocked{border-color:var(--accent-amber);background:var(--accent-amber-subtle)}.achievement-badge.locked{opacity:.4;cursor:default}.achievement-badge .icon-wrap{background:var(--bg-elevated);width:40px;height:40px;color:var(--fg-muted);border-radius:50%;justify-content:center;align-items:center;display:flex}.achievement-badge.unlocked .icon-wrap{background:var(--accent-amber-subtle);color:var(--accent-amber)}.resize-handle{background:var(--border-default);cursor:col-resize;width:4px;transition:background var(--transition);flex-shrink:0}.resize-handle:hover{background:var(--accent-green)}.search-input{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--fg-default);font-size:13px;font-family:var(--font-sans);width:100%;transition:border-color var(--transition);outline:none;padding:7px 12px 7px 32px}.search-input:focus{border-color:var(--accent-green)}.search-wrapper{position:relative}.search-icon{color:var(--fg-subtle);pointer-events:none;position:absolute;top:50%;left:9px;transform:translateY(-50%)}.chip{border:1px solid var(--border-default);color:var(--fg-muted);cursor:pointer;transition:all var(--transition);white-space:nowrap;font-size:12px;font-weight:500;font-family:var(--font-sans);background:0 0;border-radius:20px;padding:4px 12px}.chip:hover{background:var(--bg-elevated);color:var(--fg-default)}.chip.active{background:var(--accent-green-subtle);border-color:var(--accent-green-dim);color:var(--accent-green)}.toast{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--fg-default);z-index:200;align-items:center;gap:8px;padding:10px 16px;font-size:13px;animation:.2s slideUp;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 16px #0006}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.stat-number{font-size:28px;font-weight:700;font-family:var(--font-mono);color:var(--fg-default);line-height:1}.stat-label{color:var(--fg-subtle);margin-top:4px;font-size:12px}.divider{background:var(--border-subtle);height:1px;margin:16px 0}.grid-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.p-4{padding:16px}.p-6{padding:24px}.px-4{padding-left:16px;padding-right:16px}.py-4{padding-top:16px;padding-bottom:16px}.text-muted{color:var(--fg-muted)}.text-subtle{color:var(--fg-subtle)}.text-green{color:var(--accent-green)}.text-amber{color:var(--accent-amber)}.text-red{color:var(--accent-red)}.text-mono{font-family:var(--font-mono)}.text-sm{font-size:12px}.text-xs{font-size:11px}.font-600{font-weight:600}.font-700{font-weight:700}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.rounded{border-radius:var(--radius-md)}.border{border:1px solid var(--border-default)}.w-full{width:100%}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.flex-1{flex:1}.min-w-0{min-width:0}@media (width<=900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-header{padding:16px 16px 0}.p-6{padding:16px}}
