:root{color-scheme:dark;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;--bg: #0a0a0a;--surface: #141414;--surface-2: #1a1a1a;--border: rgba(255, 255, 255, .08);--border-light: rgba(255, 255, 255, .12);--text: #e8e8e8;--text-muted: rgba(255, 255, 255, .5);--accent: #4f9cf7;--accent-hover: #3b82f6;--accent-dim: rgba(79, 156, 247, .12);--green: #34d399;--green-dim: rgba(52, 211, 153, .12);--orange: #fb923c;--orange-dim: rgba(251, 146, 60, .12);--red: #f87171;--sidebar-w: 280px;--radius: 8px}*{box-sizing:border-box;margin:0}html,body,#root{min-height:100vh;background:var(--bg);color:var(--text)}.app{display:flex;min-height:100vh;padding-top:40px}.top-banner{position:fixed;top:0;left:0;right:0;z-index:300;height:40px;display:flex;align-items:center;justify-content:center;gap:1rem;padding:0 1rem;background:linear-gradient(90deg,#1a1030,#0d1b2a);border-bottom:1px solid rgba(167,139,250,.25);font-size:.72rem;color:#ffffffbf;letter-spacing:.02em}.banner-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.banner-text code,.banner-text .ca-addr{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.68rem;color:#a78bfab3}.banner-buy-btn{flex-shrink:0;padding:.25rem .85rem;background:linear-gradient(135deg,var(--accent),#a78bfa);border-radius:4px;color:#fff;font-size:.7rem;font-weight:700;text-decoration:none;letter-spacing:.04em;transition:all .15s;white-space:nowrap}.banner-buy-btn:hover{filter:brightness(1.2);transform:translateY(-1px)}.sidebar{width:var(--sidebar-w);min-height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:40px;left:0;bottom:0;z-index:100;overflow-y:auto}.sidebar-header{padding:1.5rem 1.25rem 1rem;border-bottom:1px solid var(--border)}.sidebar-header h2{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,var(--accent),#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-subtitle{font-size:.75rem;color:var(--text-muted);margin-top:.15rem}.progress-bar-container{padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.progress-bar{height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden;margin-bottom:.4rem}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--green));border-radius:3px;transition:width .4s ease}.progress-text{font-size:.7rem;color:var(--text-muted)}.sidebar-nav{flex:1;padding:.75rem 0;overflow-y:auto}.chapter-group{margin-bottom:.25rem}.chapter-title{padding:.5rem 1.25rem .35rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);display:flex;align-items:center;gap:.5rem}.chapter-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;font-size:.6rem;font-weight:700;border-radius:4px;background:var(--accent-dim);color:var(--accent)}.chapter-group ul{list-style:none;padding:0}.lesson-btn{width:100%;text-align:left;background:none;border:none;color:var(--text-muted);font-size:.82rem;padding:.4rem 1.25rem .4rem 1.75rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .15s;font-family:inherit}.lesson-btn:hover{color:var(--text);background:#ffffff08}.lesson-btn.active{color:var(--accent);background:var(--accent-dim);font-weight:500}.lesson-btn.completed{color:var(--green)}.lesson-btn.completed.active{color:var(--accent)}.lesson-check{font-size:.7rem;width:14px;flex-shrink:0}.buy-link{display:block;margin:1rem 1.25rem .5rem;padding:.55rem;background:linear-gradient(135deg,var(--accent),#a78bfa);border-radius:var(--radius);color:#fff;font-size:.78rem;font-weight:700;text-align:center;text-decoration:none;letter-spacing:.04em;transition:all .15s}.buy-link:hover{filter:brightness(1.15);transform:translateY(-1px)}.reset-btn{margin:0 1.25rem 1rem;padding:.5rem;background:none;border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-muted);font-size:.72rem;cursor:pointer;font-family:inherit;transition:all .15s}.reset-btn:hover{color:var(--red);border-color:var(--red)}.sidebar-overlay{display:none}.sidebar-toggle{display:none;position:fixed;top:48px;left:.75rem;z-index:200;width:36px;height:36px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text);font-size:1.1rem;cursor:pointer;align-items:center;justify-content:center}.main{flex:1;margin-left:var(--sidebar-w);min-height:100vh;display:flex;flex-direction:column}.lesson-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:50}.breadcrumb{font-size:.78rem;color:var(--text-muted)}.nav-buttons{display:flex;gap:.5rem}.nav-btn{padding:.35rem .85rem;background:var(--surface-2);border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text);font-size:.78rem;cursor:pointer;font-family:inherit;transition:all .15s}.nav-btn:hover:not(:disabled){background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.nav-btn:disabled{opacity:.3;cursor:default}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);background:var(--surface);padding:0 2rem}.tab{padding:.65rem 1.25rem;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:.82rem;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.learn-content{max-width:52rem;padding:2rem;flex:1}.learn-content h1{font-size:1.75rem;font-weight:700;letter-spacing:-.03em;margin-bottom:1.5rem}.explanation{margin-bottom:2rem}.explanation p{margin-bottom:.6rem;font-size:.92rem;color:#ffffffc7;line-height:1.7}.explanation code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem;background:var(--accent-dim);color:var(--accent);padding:.15rem .4rem;border-radius:4px}.explanation strong{color:var(--text);font-weight:600}.explanation .list-item{display:block;padding-left:1rem;position:relative}.explanation .list-item:before{content:"•";position:absolute;left:0;color:var(--accent)}.example-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:2rem;overflow:hidden}.example-header{display:flex;justify-content:space-between;align-items:center;padding:.6rem 1rem;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.try-btn{padding:.25rem .65rem;background:var(--accent-dim);border:1px solid rgba(79,156,247,.2);border-radius:4px;color:var(--accent);font-size:.72rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.try-btn:hover{background:#4f9cf733}.example-code{padding:1rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem;line-height:1.7;color:var(--text);overflow-x:auto;white-space:pre;margin:0}.start-btn{padding:.7rem 1.5rem;background:var(--accent);border:none;border-radius:var(--radius);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.start-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}.practice-content{flex:1;display:flex;flex-direction:column;padding:1.5rem 2rem;gap:1.25rem}.exercise-prompt{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem}.exercise-prompt h3{font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:.5rem}.exercise-text{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem;line-height:1.65;color:#ffffffb3;margin:0;white-space:pre-wrap}.editor-section{flex:1;display:flex;flex-direction:column;min-height:0}.editor-toolbar{display:flex;justify-content:space-between;align-items:center;padding:.6rem 1rem;background:var(--surface-2);border:1px solid var(--border);border-bottom:none;border-radius:var(--radius) var(--radius) 0 0;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.editor-actions{display:flex;gap:.5rem}.hint-btn,.solution-btn{padding:.3rem .65rem;background:none;border:1px solid var(--border-light);border-radius:4px;color:var(--text-muted);font-size:.72rem;cursor:pointer;font-family:inherit;transition:all .15s}.hint-btn:hover{color:var(--orange);border-color:var(--orange)}.solution-btn:hover{color:var(--text);border-color:var(--text-muted)}.run-btn{padding:.3rem .75rem;background:var(--green);border:none;border-radius:4px;color:#0a0a0a;font-size:.72rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s}.run-btn:hover{filter:brightness(1.1)}.hint-box{padding:.75rem 1rem;background:var(--orange-dim);border:1px solid rgba(251,146,60,.2);border-radius:var(--radius);margin-bottom:.5rem;font-size:.82rem;color:var(--orange);line-height:1.6}.hint-box strong{color:var(--orange)}.code-editor{flex:1;min-height:180px;padding:1rem;background:var(--bg);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem;line-height:1.7;resize:vertical;outline:none;-moz-tab-size:2;tab-size:2}.code-editor:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim)}.output-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.output-header{display:flex;justify-content:space-between;align-items:center;padding:.6rem 1rem;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.clear-btn{padding:.2rem .5rem;background:none;border:1px solid var(--border-light);border-radius:4px;color:var(--text-muted);font-size:.68rem;cursor:pointer;font-family:inherit}.clear-btn:hover{color:var(--text)}.output-area{padding:.75rem 1rem;min-height:3rem;max-height:12rem;overflow-y:auto}.output-empty{font-size:.8rem;color:var(--text-muted);font-style:italic}.output-line{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem;line-height:1.7;color:var(--green);padding:.1rem 0}.complete-section{display:flex;align-items:center;gap:1rem;padding-top:.5rem}.complete-btn{padding:.6rem 1.25rem;background:var(--green-dim);border:1px solid rgba(52,211,153,.25);border-radius:var(--radius);color:var(--green);font-size:.85rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.complete-btn:hover{background:#34d39933}.completed-badge{font-size:.85rem;color:var(--green);font-weight:600}.next-lesson-btn{padding:.6rem 1.25rem;background:var(--accent);border:none;border-radius:var(--radius);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.next-lesson-btn:hover{background:var(--accent-hover)}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform .25s ease}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:90}.sidebar-toggle{display:flex}.main{margin-left:0}.lesson-header{padding-left:3.5rem}.learn-content,.practice-content{padding:1.25rem}.tabs{padding:0 1.25rem}.learn-content h1{font-size:1.35rem}.editor-actions{flex-wrap:wrap;justify-content:flex-end}}
