*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f7f8fa;--surface:#fff;--surface2:#f1f3f5;--border:#e4e7ec;--border2:#d0d5dd;--text:#101828;--text-muted:#475467;--text-dim:#98a2b3;--accent:#2563eb;--accent-hover:#1d4ed8;--success:#15803d;--success-bg:#f0fdf4;--success-border:#86efac;--error:#b91c1c;--error-bg:#fef2f2;--error-border:#fca5a5}html,body,#root{height:100%;overflow:hidden}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;font-size:14px;line-height:1.6}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:99px}.app{flex-direction:column;height:100vh;display:flex;overflow:hidden}.topbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;height:52px;padding:0 16px;display:flex}.topbar-center{flex-direction:column;flex:1;align-items:center;gap:5px;display:flex}.lesson-title{align-items:center;gap:6px;font-size:13px;display:flex}.lesson-num{color:var(--text-muted);font-weight:500}.lesson-sep{color:var(--text-dim)}.lesson-name{color:var(--text);font-weight:600}.progress-dots{gap:5px;display:flex}.dot{border:1.5px solid var(--border2);cursor:pointer;background:0 0;border-radius:50%;width:7px;height:7px;padding:0;transition:border-color .15s,background .15s}.dot:hover{border-color:var(--accent)}.dot-active{background:var(--accent);border-color:var(--accent)}.dot-done{background:var(--border2);border-color:var(--border2)}.nav-btn{color:var(--text-muted);border:1px solid var(--border);cursor:pointer;white-space:nowrap;background:0 0;border-radius:7px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.nav-btn:hover:not(:disabled){border-color:var(--border2);color:var(--text);background:var(--surface2)}.nav-btn:disabled{opacity:.3;cursor:default}.main-layout{flex:1;display:flex;overflow:hidden}.left-panel{background:var(--surface);border-right:none;flex-shrink:0;min-width:0;overflow-y:auto}.resize-handle{background:var(--border);cursor:col-resize;flex-shrink:0;width:5px;transition:background .15s;position:relative}.resize-handle:hover,.resize-handle:active{background:var(--accent)}.readme-panel{padding:28px 26px 48px}.readme-panel h1{color:var(--text);letter-spacing:-.02em;margin-bottom:4px;font-size:17px;font-weight:700}.readme-panel h2{color:var(--text-dim);text-transform:uppercase;letter-spacing:.09em;border-top:1px solid var(--border);margin:22px 0 8px;padding-top:14px;font-size:10px;font-weight:700}.readme-panel h3{color:var(--text-muted);margin:12px 0 4px;font-size:13px;font-weight:600}.readme-panel p{color:var(--text-muted);margin-bottom:10px;font-size:13.5px;line-height:1.7}.readme-panel ul,.readme-panel ol{margin-bottom:10px;padding-left:16px}.readme-panel li{color:var(--text-muted);margin-bottom:4px;font-size:13.5px;line-height:1.65}.readme-panel strong{color:var(--text);font-weight:600}.readme-panel a{color:var(--accent);text-decoration:none}.readme-panel a:hover{text-decoration:underline}.readme-panel table{border-collapse:collapse;width:100%;margin-bottom:12px;font-size:13px}.readme-panel th{color:var(--text-muted);border-bottom:1px solid var(--border);text-align:left;text-transform:uppercase;letter-spacing:.05em;padding:6px 8px;font-size:11px;font-weight:600}.readme-panel td{color:var(--text-muted);border-bottom:1px solid var(--border);padding:6px 8px;font-size:13px}.cta-heading{border-left:3px solid var(--accent);background:#f0f4ff;border-radius:0 4px 4px 0;color:var(--accent)!important;border-top:none!important;margin-left:-13px!important;padding-top:6px!important;padding-bottom:6px!important;padding-left:10px!important}.inline-code{color:#1e40af;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;padding:1px 5px;font-family:JetBrains Mono,monospace;font-size:12.5px}.code-block-wrapper{margin:8px 0 14px}.readme-code-block{border:1px solid var(--border);background:#f8fafc;border-radius:7px;padding:0;position:relative;overflow:hidden}.code-lang{text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);background:var(--surface2);border-bottom:1px solid var(--border);padding:4px 12px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;display:block}.readme-code-block code{color:var(--text);white-space:pre;padding:12px 14px;font-family:JetBrains Mono,monospace;font-size:12.5px;line-height:1.7;display:block;overflow-x:auto}.right-panel{background:var(--bg);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.tab-bar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:7px 14px;display:flex}.tab-group{align-items:center;gap:3px;display:flex}.tab-group-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.07em;margin-right:4px;font-size:10px;font-weight:600}.tab{border:1px solid var(--border);width:26px;height:26px;color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;font-family:inherit;font-size:11px;font-weight:600;transition:all .12s}.tab:hover{border-color:var(--border2);color:var(--text-muted);background:var(--surface2)}.tab-active{background:var(--surface2);border-color:var(--accent);color:var(--accent)}.tab-active.tab-active-exercise{border-color:var(--accent);color:var(--accent);background:#eff6ff}.tab-divider{background:var(--border);width:1px;height:18px;margin:0 2px}.tab-filename{background:var(--surface2);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:8px;min-height:28px;padding:4px 14px;display:flex}.mode-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:9px;font-weight:700}.badge-read{background:var(--surface);color:var(--text-dim);border:1px solid var(--border)}.badge-edit{color:var(--accent);background:#eff6ff;border:1px solid #bfdbfe}.filename-text{color:var(--text-muted);flex:1;font-family:JetBrains Mono,monospace;font-size:11.5px}.reset-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:5px;flex-shrink:0;padding:2px 8px;font-family:inherit;font-size:11px;font-weight:500;transition:all .12s}.reset-btn:hover{border-color:var(--error);color:var(--error);background:var(--error-bg)}.editor-wrapper{border-bottom:1px solid var(--border);flex:1;min-height:0;overflow:hidden}.code-editor-container{height:100%}.stdin-toggle{border:none;border-bottom:1px solid var(--border);color:var(--text-dim);text-align:left;cursor:pointer;background:0 0;flex-shrink:0;width:100%;padding:5px 14px;font-family:inherit;font-size:11.5px;transition:color .12s,background .12s}.stdin-toggle:hover{color:var(--text-muted);background:var(--surface2)}.stdin-box{background:var(--surface2);border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text);resize:none;outline:none;flex-shrink:0;padding:8px 14px;font-family:JetBrains Mono,monospace;font-size:12.5px;line-height:1.6}.stdin-box::placeholder{color:var(--text-dim)}.run-btn{background:var(--accent);color:#fff;cursor:pointer;letter-spacing:.01em;border:none;flex-shrink:0;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:background .15s;display:flex}.run-btn:hover:not(:disabled){background:var(--accent-hover)}.run-btn:disabled{opacity:.5;cursor:default}.run-loading{opacity:.7}.run-shortcut{opacity:.6;margin-left:auto;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:400}.output-panel{border-top:3px solid #0000;flex-shrink:0;max-height:200px;padding:10px 14px;overflow-y:auto}.output-success{border-color:var(--success);background:var(--success-bg)}.output-error{border-color:var(--error);background:var(--error-bg)}.output-label{text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px;font-size:10px;font-weight:700}.output-success .output-label{color:var(--success)}.output-error .output-label{color:var(--error)}.output-text{white-space:pre-wrap;word-break:break-word;color:var(--text);font-family:JetBrains Mono,monospace;font-size:12.5px;line-height:1.65}
