@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0d1117;--bg-secondary:#161b22;--bg-tertiary:#21262d;--border:#30363d;--text-primary:#e6edf3;--text-secondary:#8b949e;--text-muted:#484f58;--accent:#58a6ff;--accent-hover:#79c0ff;--error:#f85149;--success:#3fb950;--sidebar-width:260px;--professor-width:320px}html,body,#root{width:100%;height:100%;overflow:hidden}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px;transition:background .2s}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--bg-tertiary) var(--bg-primary)}.app-layout{height:100vh;display:flex}.app-sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);flex-shrink:0;padding:16px;overflow-y:auto}.app-editor{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.app-professor-divider{background:var(--border);cursor:ew-resize;flex-shrink:0;width:4px;transition:background .15s}.app-professor-divider:hover,.app-professor-divider:active{background:var(--accent,#58a6ff)}.app-professor{width:var(--professor-width);background:var(--bg-secondary);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.code-editor{flex-direction:column;height:100%;display:flex}.code-editor-header{background:var(--bg-secondary);border-bottom:1px solid var(--border);align-items:center;min-height:36px;padding:6px 14px;display:flex}.code-editor-lang{color:var(--text-muted);text-transform:uppercase;letter-spacing:1.2px;font-size:11px;font-weight:600}.code-editor-progress{align-items:center;gap:8px;margin-left:auto;display:flex}.code-editor-progress-text{color:var(--text-secondary);white-space:nowrap;font-size:11px}.code-editor-progress-bar{background:var(--bg-primary);border-radius:2px;width:80px;height:4px;overflow:hidden}.code-editor-progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .2s}.code-editor-complete{color:var(--success);font-size:11px;font-weight:600}.code-editor-split{flex-direction:column;display:flex}.code-editor-split .code-editor-top{flex-direction:column;flex:1;min-height:0;display:flex;position:relative}.code-editor-split .code-editor-bottom{flex:none;overflow:hidden}.code-editor-divider{background:var(--border);cursor:ns-resize;flex-shrink:0;height:4px;transition:background .15s;position:relative}.code-editor-divider:hover,.code-editor-divider:active{background:var(--accent,#58a6ff)}.code-editor-run-btn{color:#fff;background:var(--success);cursor:pointer;white-space:nowrap;letter-spacing:.3px;border:none;border-radius:6px;margin-left:8px;padding:3px 14px;font-family:inherit;font-size:12px;font-weight:600;transition:all .2s}.code-editor-run-btn:hover:not(:disabled){filter:brightness(1.12);transform:translateY(-1px);box-shadow:0 2px 12px #3fb95066}.code-editor-run-btn:active:not(:disabled){box-shadow:none;transform:translateY(0)}.code-editor-run-btn:disabled{opacity:.5;cursor:not-allowed}.code-editor-run-btn-pulse{background:var(--accent,#58a6ff);color:#fff;animation:1.5s infinite run-pulse}@keyframes run-pulse{0%,to{box-shadow:0 0 #58a6ff80}50%{box-shadow:0 0 8px 4px #58a6ff4d}}.output-panel{background:var(--bg-primary);flex-direction:column;height:100%;display:flex}.output-panel-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:6px 12px;display:flex}.output-panel-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-size:11px}.output-panel-actions{align-items:center;gap:8px;display:flex}.output-panel-status{color:var(--accent);font-size:11px}.output-panel-clear{color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:3px;padding:1px 8px;font-size:11px}.output-panel-clear:hover{color:var(--text-primary);border-color:var(--text-secondary)}.output-panel-body{flex:1;padding:8px 12px;font-family:Cascadia Code,Fira Code,monospace;font-size:13px;line-height:1.5;overflow-y:auto}.output-panel-placeholder{color:var(--text-muted);font-size:12px}.output-stdout{color:var(--text-primary);white-space:pre-wrap;word-break:break-word;margin:0}.output-stderr{color:#d29922;white-space:pre-wrap;word-break:break-word;margin:0}.output-error{color:var(--error);white-space:pre-wrap;word-break:break-word;margin:0}.output-panel-footer{margin-top:4px}.output-panel-duration{color:var(--text-muted);font-size:11px}.terminal-panel{background:#0d1117;flex-direction:column;height:100%;display:flex}.terminal-panel-header{background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:6px 12px;display:flex}.terminal-panel-header-left{align-items:center;gap:6px;display:flex}.terminal-panel-chevron{color:var(--text-muted);font-size:10px}.terminal-panel-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:10px;font-weight:700}.terminal-panel-collapsed .terminal-panel-body{display:none}.terminal-panel-actions{align-items:center;gap:8px;display:flex}.terminal-panel-status{opacity:.8;font-size:10px;font-weight:500}.terminal-panel-btn{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;border-radius:4px;padding:2px 8px;font-size:11px}.terminal-panel-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.terminal-panel-body{flex:1;padding:4px;overflow:hidden}.terminal-panel-body .xterm{height:100%}.user-profile{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:8px;padding:12px;display:flex}.user-profile-avatar{color:#fff;background:linear-gradient(135deg,#58a6ff 0%,#79c0ff 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex;box-shadow:0 2px 8px #58a6ff4d}.user-profile-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.user-profile-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-profile-plan{text-transform:uppercase;letter-spacing:1px;border-radius:3px;width:fit-content;padding:1px 6px;font-size:10px;font-weight:700}.user-profile-plan.free{background:var(--bg-tertiary);color:var(--text-secondary)}.user-profile-plan.pro{color:#3fb950;background:#1a3a2a}.user-profile-expires{color:var(--text-muted);font-size:10px}.user-profile-logout{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:4px;font-size:18px;line-height:1}.user-profile-logout:hover{color:var(--error)}.project-list-title{text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:12px;font-size:11px;font-weight:600}.project-list-empty{color:var(--text-muted);font-size:13px}.project-list-items{list-style:none}.project-list-item{width:100%;color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;border-left:2px solid #0000;border-radius:0 6px 6px 0;flex-direction:column;margin-bottom:3px;padding:10px 12px;transition:background .18s,border-color .18s,transform .15s;display:flex}.project-list-item:hover{background:#21262db3;border-left-color:#58a6ff66}.project-list-item.active{border-left-color:var(--accent);background:linear-gradient(90deg,#58a6ff14 0%,#0000 100%)}.project-list-item-title{font-size:14px;font-weight:500}.project-list-item-meta{color:var(--text-secondary);margin-top:2px;font-size:11px}.professor-panel{background:var(--bg-secondary);flex-direction:column;height:100%;display:flex}.professor-header{background:#161b2280;border-bottom:1px solid #30363dcc;flex-shrink:0;align-items:center;gap:10px;padding:10px 14px;display:flex}.professor-avatar{color:#fff;background:linear-gradient(135deg,#58a6ff,#bc8cff);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;animation:3s ease-in-out infinite professor-glow;display:flex}@keyframes professor-glow{0%,to{box-shadow:0 0 6px #58a6ff4d,0 0 12px #bc8cff26}50%{box-shadow:0 0 10px #58a6ff8c,0 0 20px #bc8cff4d}}.professor-header-info{flex-direction:column;min-width:0;display:flex}.professor-header-info h2{color:var(--text-primary);letter-spacing:.2px;margin:0;font-size:12px;font-weight:600}.professor-remaining{color:var(--text-muted);font-size:11px}.professor-chat-messages{flex-direction:column;flex:1;gap:12px;min-height:0;padding:16px 12px;display:flex;overflow-y:auto}.professor-chat-empty{color:var(--text-muted);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;font-size:13px;display:flex}.professor-chat-empty p{margin:0;line-height:1.5}.professor-chat-empty-icon{color:#fff;opacity:.7;background:linear-gradient(135deg,#58a6ff,#bc8cff);border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:12px;font-size:22px;font-weight:700;display:flex;box-shadow:0 4px 20px #58a6ff40,0 4px 20px #bc8cff33}.professor-chat-msg{word-wrap:break-word;white-space:pre-wrap;border-radius:12px;max-width:92%;padding:10px 14px;font-size:13px;line-height:1.6}.professor-chat-msg-user{background:var(--accent);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.professor-chat-msg-assistant{background:var(--bg-tertiary);color:var(--text-primary);border-bottom-left-radius:4px;align-self:flex-start}.professor-line-hint{border-left:3px solid var(--accent);background:#58a6ff14;transition:opacity .2s}.professor-line-badge{text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-bottom:6px;font-size:10px;font-weight:600;display:block}.professor-line-text{margin:0;line-height:1.5}.professor-chat-typing span{background:var(--text-muted);border-radius:50%;width:6px;height:6px;margin-right:4px;animation:1.2s infinite typing-dot;display:inline-block}.professor-chat-typing span:nth-child(2){animation-delay:.2s}.professor-chat-typing span:nth-child(3){animation-delay:.4s}@keyframes typing-dot{0%,60%,to{opacity:.3}30%{opacity:1}}.professor-chat-error{color:var(--error);background:#ff7b721a;border-radius:8px;padding:6px 14px;font-size:12px}.professor-chat-limit{color:var(--accent);border:1px solid var(--accent);text-align:center;background:#58a6ff1a;border-radius:8px;padding:10px 14px;font-size:12px}.professor-chat-input{border-top:1px solid var(--border);background:var(--bg-secondary);gap:8px;padding:12px;display:flex}.professor-chat-input input{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);border-radius:20px;outline:none;flex:1;padding:10px 14px;font-size:13px;transition:border-color .15s}.professor-chat-input input:focus{border-color:var(--accent)}.professor-chat-input button{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:20px;padding:10px 18px;font-size:13px;font-weight:500;transition:background .15s}.professor-chat-input button:hover{background:var(--accent-hover)}.professor-chat-input button:disabled{opacity:.4;cursor:not-allowed}.project-list-filters{flex-wrap:wrap;gap:4px;margin-bottom:12px;display:flex}.project-filter-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;letter-spacing:.2px;background:0 0;border-radius:20px;padding:4px 12px;font-family:inherit;font-size:11px;font-weight:500;transition:all .18s}.project-filter-btn:hover{color:var(--accent);background:#58a6ff0f;border-color:#58a6ff99}.project-filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600;box-shadow:0 2px 8px #58a6ff4d}.project-list-item-progress{align-items:center;gap:8px;margin-top:4px;display:flex}.project-list-progress-bar{background:var(--bg-primary);border-radius:2px;flex:1;height:3px;overflow:hidden}.project-list-progress-fill{background:var(--success);border-radius:2px;height:100%;transition:width .2s}.project-list-item-step{color:var(--text-muted);white-space:nowrap;font-size:10px}.login-container{background:var(--bg-primary);background-image:radial-gradient(80% 60% at 50% 0,#58a6ff12 0%,#0000 70%),radial-gradient(50% 40% at 80% 80%,#bc8cff0d 0%,#0000 60%);justify-content:center;align-items:center;height:100vh;display:flex;position:relative;overflow:hidden}.login-container:before{content:"";pointer-events:none;background-image:linear-gradient(#30363d40 1px,#0000 1px),linear-gradient(90deg,#30363d40 1px,#0000 1px);background-size:40px 40px;position:absolute;inset:0}.login-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1;background:#161b22d9;border:1px solid #30363dcc;border-radius:16px;flex-direction:column;align-items:center;width:100%;max-width:380px;padding:40px 32px;display:flex;position:relative;box-shadow:0 0 0 1px #58a6ff0d,0 24px 48px #00000080,0 8px 16px #0000004d}.login-title{background:linear-gradient(135deg,#e6edf3 0%,#79c0ff 100%);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;margin-bottom:4px;font-size:28px;font-weight:700}.login-subtitle{color:var(--text-secondary);margin-bottom:28px;font-size:14px}.login-form{flex-direction:column;gap:12px;width:100%;display:flex}.login-input{background:var(--bg-tertiary);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:6px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.login-input:focus{border-color:var(--accent)}.login-error{color:var(--error);text-align:center;font-size:13px}.login-button{cursor:pointer;border:none;border-radius:8px;width:100%;padding:10px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s}.login-button.primary{background:var(--accent);color:#fff;letter-spacing:.2px;margin-top:4px}.login-button.primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 16px #58a6ff59}.login-button.primary:active{transform:translateY(0)}.login-button.primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-button.google{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);margin-top:12px}.login-button.google:hover{background:var(--border)}.login-toggle{color:var(--accent);cursor:pointer;background:0 0;border:none;margin-top:16px;font-size:13px}.login-toggle:hover{color:var(--accent-hover)}.ghost-char{opacity:.8;color:#6e7681!important}.ghost-char-level2{opacity:.6;font-style:italic;color:var(--text-muted)!important}.ghost-char-level3{opacity:.35;font-style:italic;color:var(--text-muted)!important}.ghost-char-level4{opacity:.2;font-style:italic;color:var(--text-muted)!important}.ghost-char-level5{opacity:0}.ghost-confirmed{opacity:1;font-style:normal}.ghost-error{-webkit-text-decoration:underline wavy var(--error);text-decoration:underline wavy var(--error);color:var(--error)!important}.ghost-hidden{opacity:0}.ghost-blanked{-webkit-text-decoration:underline dotted var(--text-muted);text-decoration:underline dotted var(--text-muted);color:#0000!important}.ghost-wrong-key{background-color:#f851494d;border-radius:2px}.inline-feedback{z-index:100;pointer-events:none;white-space:nowrap;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600;animation:.2s ease-out feedback-pop,.3s ease-in 1.5s forwards feedback-fade;position:absolute}.inline-feedback-correct{border:1px solid var(--color-success,#3fb950);color:var(--color-success,#3fb950);background:#3fb95026}.inline-feedback-error{border:1px solid var(--color-error,#ff7b72);color:var(--color-error,#ff7b72);background:#f8514926}.inline-feedback-streak{border:1px solid var(--color-accent,#58a6ff);color:var(--color-accent,#58a6ff);background:#58a6ff26;font-size:14px}@keyframes feedback-pop{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes feedback-fade{0%{opacity:1}to{opacity:0}}.loading-screen{height:100vh;color:var(--text-secondary);background:var(--bg-primary);justify-content:center;align-items:center;font-size:16px;display:flex}.project-list-item.locked{opacity:.6}.project-list-lock{color:var(--bg-primary);background:var(--accent);vertical-align:middle;letter-spacing:.5px;border-radius:3px;margin-right:6px;padding:1px 5px;font-size:9px;font-weight:700;display:inline-block}.completion-overlay{z-index:200;background:#0009;justify-content:center;align-items:center;animation:.3s ease-out completion-fade-in;display:flex;position:fixed;inset:0}@keyframes completion-fade-in{0%{opacity:0}to{opacity:1}}.completion-modal{background:var(--bg-secondary);text-align:center;border:1px solid #3fb950;border-radius:16px;width:90%;max-width:400px;padding:32px 40px;animation:.3s ease-out completion-scale-in;box-shadow:0 8px 32px #3fb95026,0 4px 16px #0006}@keyframes completion-scale-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.completion-star{color:#f0c040;margin-bottom:8px;font-size:48px;display:block}.completion-title{color:var(--text-primary);margin:0 0 6px;font-size:18px;font-weight:400}.completion-subtitle{color:var(--text-secondary);margin:0 0 24px;font-size:13px}.completion-actions{flex-direction:column;gap:10px;display:flex}.completion-btn{cursor:pointer;border:none;border-radius:8px;padding:10px 16px;font-size:14px;font-weight:600;transition:background .15s,transform .1s}.completion-btn:hover{transform:translateY(-1px)}.completion-btn:active{transform:translateY(0)}.completion-btn-primary{color:#000;background:#3fb950}.completion-btn-primary:hover{background:#56d364}.completion-btn-secondary{background:var(--accent);color:#000}.completion-btn-secondary:hover{background:var(--accent-hover)}.completion-btn-ghost{color:var(--text-secondary);border:1px solid var(--border);background:0 0;font-weight:400}.completion-btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.track-list{flex:1;padding:12px 0;overflow-y:auto}.track-list-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;padding:0 12px 10px;font-size:10px;font-weight:700}.track-list-langs{flex-wrap:wrap;gap:4px;padding:0 12px 12px;display:flex}.track-lang-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;text-transform:uppercase;letter-spacing:.3px;background:0 0;border-radius:10px;padding:3px 9px;font-family:inherit;font-size:10px;font-weight:600;transition:all .15s}.track-lang-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 1px 6px #58a6ff4d}.track-lang-btn:hover:not(.active){color:var(--text-secondary);background:#58a6ff0d;border-color:#58a6ff66}.track-list-tracks{flex-direction:column;gap:4px;padding:0 8px;display:flex}.track-card{border:1px solid #0000;border-radius:8px;transition:border-color .15s;overflow:hidden}.track-card.expanded{border-color:var(--border);background:var(--bg-secondary)}.track-card.locked{opacity:.5}.track-card-header{width:100%;color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;justify-content:space-between;align-items:center;padding:9px 10px;font-family:inherit;transition:background .15s;display:flex}.track-card-header:hover{background:#21262dcc}.track-card-info{flex:1;align-items:center;gap:10px;min-width:0;display:flex;overflow:hidden}.track-card-info>div{min-width:0;overflow:hidden}.track-card-icon{text-align:center;flex-shrink:0;width:28px;font-size:20px}.track-card-title{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;display:block;overflow:hidden}.track-card-meta{color:var(--text-secondary);font-size:11px;display:block}.track-card-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.track-card-lock{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px}.track-card-chevron{color:var(--text-muted);font-size:10px}.track-card-ring{width:28px;height:28px}.track-ring-svg{width:100%;height:100%;transform:rotate(-90deg)}.track-ring-bg{fill:none;stroke:var(--bg-tertiary);stroke-width:3px}.track-ring-fill{fill:none;stroke:#3fb950;stroke-width:3px;stroke-linecap:round;transition:stroke-dasharray .3s}.track-levels{padding:0 8px 8px}.track-level{margin-bottom:4px}.track-level.locked{opacity:.5}.track-level-header{align-items:center;gap:8px;padding:6px 8px;display:flex}.track-level-badge{color:var(--accent);white-space:nowrap;background:#58a6ff1a;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:600}.track-level-title{color:var(--text-secondary);font-size:12px;font-weight:500}.track-level-check{color:#3fb950;margin-left:auto;font-size:14px}.track-level-items{list-style:none}.track-exercise{width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-left:2px solid #0000;border-radius:0 4px 4px 0;align-items:center;gap:7px;padding:5px 10px 5px 18px;font-family:inherit;font-size:12px;transition:background .12s,border-color .12s;display:flex}.track-exercise:hover{color:var(--text-primary);background:#21262db3;border-left-color:#58a6ff4d}.track-exercise.active{border-left-color:var(--accent);color:var(--text-primary);background:#58a6ff12}.track-exercise.done{color:var(--text-muted)}.track-exercise.locked{color:var(--text-muted);opacity:.5;cursor:default}.track-exercise-dot{text-align:center;opacity:.7;flex-shrink:0;width:14px;font-size:11px}.track-exercise.done .track-exercise-dot{color:var(--success);opacity:1}.track-exercise.active .track-exercise-dot{opacity:1}.track-exercise-title{white-space:nowrap;text-overflow:ellipsis;flex:1;line-height:1.4;overflow:hidden}.track-exercise-step{color:var(--accent);background:#58a6ff1a;border-radius:3px;flex-shrink:0;padding:1px 4px;font-size:10px}.upgrade-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.upgrade-modal{background:var(--bg-secondary);border:1px solid var(--border);text-align:center;border-radius:12px;width:90%;max-width:400px;padding:32px}.upgrade-modal h2{margin-bottom:8px;font-size:24px;font-weight:700}.upgrade-modal p{color:var(--text-secondary);margin-bottom:20px;font-size:14px}.upgrade-features{text-align:left;margin-bottom:20px;list-style:none}.upgrade-features li{color:var(--text-primary);padding:4px 0;font-size:13px}.upgrade-features li:before{content:"+ ";color:var(--success);font-weight:700}.upgrade-toggle{background:var(--bg-tertiary);border-radius:8px;margin-bottom:16px;padding:3px;display:flex}.upgrade-toggle-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:8px 16px;font-size:13px;font-weight:600;position:relative}.upgrade-toggle-btn.active{background:var(--accent);color:var(--bg-primary)}.upgrade-badge{background:var(--success);color:var(--bg-primary);border-radius:4px;margin-left:6px;padding:1px 5px;font-size:10px;font-weight:700}.upgrade-toggle-btn.active .upgrade-badge{background:var(--bg-primary);color:var(--accent)}.upgrade-prices{flex-wrap:wrap;justify-content:center;align-items:baseline;gap:4px;margin-bottom:20px;display:flex}.upgrade-price{color:var(--accent);font-size:28px;font-weight:700}.upgrade-price-period{color:var(--text-muted);font-size:14px}.upgrade-price-detail{text-align:center;width:100%;color:var(--text-secondary);font-size:12px}.upgrade-error{color:var(--error);margin-bottom:12px;font-size:12px}.upgrade-buttons{flex-direction:column;gap:8px;margin-bottom:8px;display:flex}.upgrade-btn{background:var(--accent);width:100%;color:var(--bg-primary);cursor:pointer;border:none;border-radius:6px;padding:12px;font-size:14px;font-weight:600}.upgrade-btn:disabled{opacity:.5;cursor:not-allowed}.upgrade-btn-alt{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.upgrade-btn-alt:hover{background:var(--border)}.upgrade-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:8px;font-size:13px}.upgrade-close:hover{color:var(--text-primary)}.mode-selector{gap:4px;margin-left:16px;display:flex}.mode-selector-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;transition:all .15s;display:flex}.mode-selector-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.mode-selector-btn.active{background:var(--accent);border-color:var(--accent);color:var(--bg-primary)}.mode-selector-btn.locked{opacity:.4;cursor:not-allowed}.mode-selector-number{font-size:12px;font-weight:700}.mode-selector-name{font-weight:400}.mode-selector-pro{background:var(--accent);color:var(--bg-primary);letter-spacing:.5px;border-radius:2px;padding:1px 4px;font-size:8px;font-weight:700}.mode-selector-btn.active .mode-selector-pro{background:var(--bg-primary);color:var(--accent)}.xp-bar{margin-bottom:12px}.xp-bar-header{justify-content:space-between;margin-bottom:4px;display:flex}.xp-bar-level{color:var(--accent);font-size:12px;font-weight:600}.xp-bar-total{color:var(--text-secondary);font-size:11px}.xp-bar-track{background:var(--bg-primary);border-radius:3px;height:6px;overflow:hidden}.xp-bar-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .3s}.xp-bar-remaining{color:var(--text-muted);font-size:10px}.star-rating{gap:2px;font-size:14px;display:inline-flex}.star-filled{color:#f0c040}.star-empty{color:var(--text-muted)}.streak-badge{color:var(--success);background:#3fb95026;border-radius:4px;padding:2px 6px;font-size:11px;font-weight:600}.celebration-overlay{z-index:200;background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.celebration-card{text-align:center;background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;max-width:360px;padding:40px}.celebration-title{color:var(--success);margin-bottom:8px;font-size:24px;font-weight:700}.celebration-project{color:var(--text-primary);margin-bottom:16px;font-size:16px}.celebration-stars{justify-content:center;gap:8px;margin-bottom:12px;font-size:32px;display:flex}.celebration-star-filled{color:#f0c040}.celebration-star-empty{color:var(--text-muted)}.celebration-xp{color:var(--accent);margin-bottom:20px;font-size:20px;font-weight:700}.celebration-btn{background:var(--accent);color:var(--bg-primary);cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600}.celebration-btn:hover{background:var(--accent-hover)}.progress-dashboard{border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:12px}.progress-dashboard-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.progress-dashboard-title{text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);font-size:12px}.progress-dashboard-stats{color:var(--text-muted);margin-top:4px;font-size:11px}.review-queue{border-top:1px solid var(--border);padding:12px}.review-queue-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.review-queue-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-size:11px;font-weight:600}.review-queue-count{background:var(--accent);color:var(--bg-primary);border-radius:8px;padding:1px 6px;font-size:10px;font-weight:700}.review-queue-empty{color:var(--text-muted);font-size:12px}.review-queue-list{flex-direction:column;gap:4px;display:flex}.review-queue-item{background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;color:var(--text-primary);text-align:left;border-radius:4px;justify-content:space-between;align-items:center;width:100%;padding:4px 8px;font-size:12px;display:flex}.review-queue-item:hover{border-color:var(--accent)}.review-queue-concept{text-transform:capitalize}.review-queue-confidence{color:var(--text-muted);font-size:11px}.review-queue-more{color:var(--text-muted);text-align:center;margin-top:4px;font-size:11px}.onboarding-overlay{background:var(--bg-primary);z-index:1000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.onboarding-card{text-align:center;width:100%;max-width:480px;padding:40px}.onboarding-stepper{justify-content:center;gap:8px;margin-bottom:32px;display:flex}.onboarding-stepper-dot{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:50%;width:8px;height:8px}.onboarding-stepper-dot-active{background:var(--accent);border-color:var(--accent)}.onboarding-stepper-dot-done{background:var(--success);border-color:var(--success)}.onboarding-step{flex-direction:column;align-items:center;gap:16px;display:flex}.onboarding-title{color:var(--text-primary);font-size:24px;font-weight:700}.onboarding-subtitle{color:var(--text-secondary);max-width:400px;font-size:14px;line-height:1.6}.onboarding-btn{color:var(--bg-primary);background:var(--accent);cursor:pointer;border:none;border-radius:6px;margin-top:8px;padding:10px 32px;font-size:14px;font-weight:600}.onboarding-btn:hover{background:var(--accent-hover)}.onboarding-hint{color:var(--text-muted);margin-top:8px;font-size:11px;display:block}.onboarding-lang-key{background:var(--bg-tertiary);color:var(--text-muted);border-radius:3px;margin-top:4px;padding:1px 6px;font-family:monospace;font-size:10px;display:inline-block}.onboarding-ghost-animation{gap:4px;margin-bottom:8px;display:flex}.onboarding-ghost-char{color:var(--accent);font-size:32px;font-weight:700;animation:2s ease-in-out infinite ghost-fade}.onboarding-ghost-char:nth-child(2){animation-delay:.2s}.onboarding-ghost-char:nth-child(3){animation-delay:.4s}.onboarding-ghost-char:nth-child(4){animation-delay:.6s}@keyframes ghost-fade{0%,to{opacity:.3}50%{opacity:1}}.onboarding-languages{gap:16px;margin-top:8px;display:flex}.onboarding-lang-btn{background:var(--bg-secondary);border:2px solid var(--border);cursor:pointer;min-width:160px;color:var(--text-primary);border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:20px 24px;display:flex}.onboarding-lang-btn:hover{border-color:var(--accent)}.onboarding-lang-icon{color:var(--accent);font-size:24px;font-weight:700}.onboarding-lang-name{font-size:16px;font-weight:600}.onboarding-lang-desc{color:var(--text-muted);font-size:11px}.onboarding-exercise{width:100%;max-width:400px}.onboarding-exercise-editor{background:var(--bg-secondary);border:1px solid var(--border);text-align:left;border-radius:8px;min-height:48px;padding:16px;font-family:Cascadia Code,Fira Code,monospace;font-size:16px}.onboarding-exercise-line{position:relative}.onboarding-exercise-typed{color:var(--text-primary)}.onboarding-exercise-ghost{color:var(--text-muted);opacity:.5}.onboarding-exercise-cursor{background:var(--accent);vertical-align:text-bottom;width:2px;height:18px;animation:1s step-end infinite cursor-blink;display:inline-block}@keyframes cursor-blink{0%,50%{opacity:1}51%,to{opacity:0}}.onboarding-exercise-input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.onboarding-exercise-input:focus{outline:none}.onboarding-exercise-status{color:var(--text-muted);justify-content:space-between;margin-top:8px;font-size:11px;display:flex}.onboarding-exercise-errors{color:var(--error)}.onboarding-celebration{gap:8px;margin-bottom:8px;display:flex}.onboarding-star{color:#f0c040;font-size:28px;animation:.5s ease-out star-pop}.onboarding-star:nth-child(2){animation-delay:.15s}.onboarding-star:nth-child(3){animation-delay:.3s}@keyframes star-pop{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.3)}to{opacity:1;transform:scale(1)}}.user-profile-avatar{background:var(--bg-tertiary);cursor:pointer;border:2px solid #58a6ff80;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;line-height:1;transition:border-color .2s,transform .15s;display:flex}.user-profile-avatar:hover{border-color:var(--accent);transform:scale(1.05)}.user-profile-meta{align-items:center;gap:6px;display:flex}.user-profile-level{color:var(--accent);letter-spacing:.3px;background:#58a6ff1f;border-radius:4px;padding:1px 5px;font-size:10px;font-weight:700}.user-profile-xp-bar{background:#30363dcc;border-radius:2px;width:100%;height:3px;margin-top:5px;overflow:hidden}.user-profile-xp-fill{background:linear-gradient(90deg, var(--accent), #79c0ff);border-radius:2px;height:100%;transition:width .5s}.xp-toast{background:var(--bg-secondary);border:1px solid var(--accent);z-index:9999;border-radius:8px;flex-direction:column;align-items:center;padding:12px 20px;animation:.3s ease-out toast-slide;display:flex;position:fixed;bottom:24px;right:24px}.xp-toast-amount{color:var(--accent);font-size:1.2rem;font-weight:700}.xp-toast-source{color:var(--text-secondary);font-size:.75rem}@keyframes toast-slide{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.levelup-overlay{z-index:10000;background:#000c;justify-content:center;align-items:center;animation:.3s fade-in;display:flex;position:fixed;inset:0}.levelup-modal{background:var(--bg-secondary);border:1px solid var(--accent);text-align:center;border-radius:16px;max-width:360px;padding:40px;animation:.4s scale-in}.levelup-star{color:#f0c040;margin-bottom:12px;font-size:3rem;animation:.5s ease-out star-pop;display:block}.levelup-title{color:var(--accent);margin-bottom:8px;font-size:1.8rem;font-weight:700}.levelup-level{color:var(--text-secondary);margin-bottom:24px;font-size:1rem}.levelup-btn{background:var(--accent);color:var(--bg-primary);cursor:pointer;border:none;border-radius:8px;padding:10px 28px;font-size:.95rem;font-weight:600}.levelup-btn:hover{background:var(--accent-hover,#79c0ff)}@keyframes scale-in{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.badge-unlock{background:var(--bg-secondary);z-index:9998;border:1px solid #f0c040;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;animation:.3s ease-out toast-slide;display:flex;position:fixed;bottom:80px;right:24px}.badge-unlock-icon{font-size:1.5rem}.badge-unlock-info{flex-direction:column;display:flex}.badge-unlock-title{color:#f0c040;font-size:.9rem;font-weight:600}.badge-unlock-desc{color:var(--text-secondary);font-size:.75rem}.profile-page{background:var(--bg-primary);color:var(--text-primary);max-width:720px;min-height:100vh;margin:0 auto;padding:24px;font-family:Inter,sans-serif}.profile-header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.profile-back{border:1px solid var(--border);color:var(--text-primary);cursor:pointer;background:0 0;border-radius:6px;padding:6px 12px;font-size:.9rem}.profile-back:hover{background:var(--bg-tertiary)}.profile-header h1{font-size:1.4rem;font-weight:600}.profile-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;align-items:center;gap:16px;margin-bottom:20px;padding:20px;display:flex}.profile-avatar-large{background:var(--bg-tertiary);border:2px solid var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-size:2rem;display:flex}.profile-meta-row{align-items:center;gap:8px;margin-top:4px;display:flex}.profile-level-pill{color:var(--accent);font-size:.7rem;font-weight:600}.profile-join{color:var(--text-muted);margin-top:2px;font-size:.7rem}.profile-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;margin-bottom:20px;padding:20px}.profile-section h3{margin-bottom:16px;font-size:1rem}.profile-saving{color:var(--text-muted);margin-left:8px;font-size:.7rem;font-weight:400}.profile-avatar-grid{grid-template-columns:repeat(6,1fr);gap:8px;display:grid}.profile-avatar-btn{background:var(--bg-tertiary);cursor:pointer;text-align:center;border:2px solid #0000;border-radius:10px;padding:10px;font-size:1.6rem;transition:transform .15s,border-color .2s}.profile-avatar-btn:hover{border-color:var(--border);transform:scale(1.1)}.profile-avatar-btn.selected{border-color:var(--accent);box-shadow:0 0 0 2px #58a6ff4d}.profile-badge-check{color:#48c78e;font-size:.6rem;position:absolute;top:4px;right:4px}.profile-badge-item{position:relative}.profile-name{font-size:1.2rem;font-weight:600}.profile-plan{text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:.7rem;font-weight:700}.profile-plan.pro{background:var(--accent);color:var(--bg-primary)}.profile-plan.free{background:var(--bg-tertiary);color:var(--text-secondary)}.profile-xp{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;align-items:center;gap:16px;margin-bottom:20px;padding:20px;display:flex}.profile-level-badge{flex-direction:column;align-items:center;min-width:60px;display:flex}.profile-level-number{color:var(--accent);font-size:2rem;font-weight:700;line-height:1}.profile-level-name{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.7rem}.profile-xp-bar-container{flex:1}.profile-xp-bar{background:var(--bg-tertiary);border-radius:4px;width:100%;height:8px;margin-bottom:4px;overflow:hidden}.profile-xp-bar-fill{background:linear-gradient(90deg, var(--accent), #79c0ff);border-radius:4px;height:100%;transition:width .5s}.profile-xp-text{color:var(--text-secondary);font-size:.75rem}.profile-xp-total{color:var(--accent);white-space:nowrap;font-size:.8rem;font-weight:600}.profile-stats{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}.profile-stat{background:var(--bg-secondary);border:1px solid var(--border);text-align:center;border-radius:8px;padding:16px 12px}.profile-stat-value{color:var(--text-primary);font-size:1.4rem;font-weight:700;display:block}.profile-stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.7rem}.profile-badges{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;margin-bottom:20px;padding:20px}.profile-badges h3{margin-bottom:16px;font-size:1rem}.profile-badge-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px;display:grid}.profile-badge-item{background:var(--bg-tertiary);text-align:center;border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;transition:opacity .2s;display:flex}.profile-badge-item.locked{opacity:.3;filter:grayscale()}.profile-badge-item.earned{border:1px solid #f0c040}.profile-badge-icon{font-size:1.5rem}.profile-badge-title{color:var(--text-secondary);font-size:.7rem}.profile-tracks{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:20px}.profile-tracks h3{margin-bottom:16px;font-size:1rem}.profile-lang-group{margin-bottom:16px}.profile-lang-group:last-child{margin-bottom:0}.profile-lang-title{color:var(--text-secondary);text-transform:capitalize;margin-bottom:8px;font-size:.85rem;font-weight:600}.profile-track-row{align-items:center;gap:12px;padding:8px 0;display:flex}.profile-track-title{min-width:120px;color:var(--text-primary);font-size:.8rem}.profile-track-bar{background:var(--bg-tertiary);border-radius:3px;flex:1;height:6px;overflow:hidden}.profile-track-bar-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .5s}.profile-track-percent{color:var(--text-secondary);text-align:right;min-width:36px;font-size:.75rem}.contract-page{background:var(--bg-primary);color:var(--text-primary);max-width:640px;min-height:100vh;margin:0 auto;padding:32px 24px;font-family:Inter,sans-serif}.contract-header{text-align:center;margin-bottom:24px}.contract-badge{color:#fff;letter-spacing:1px;background:linear-gradient(135deg,#e65555,#c44040);border-radius:4px;margin-bottom:12px;padding:4px 12px;font-size:.65rem;font-weight:700;display:inline-block}.contract-header h1{margin-bottom:4px;font-size:1.6rem;font-weight:700}.contract-subtitle{color:var(--text-secondary);font-size:.85rem}.contract-intro{background:var(--bg-secondary);border-left:3px solid #48c78e;border-radius:8px;margin-bottom:20px;padding:16px 20px;font-size:.9rem;line-height:1.6}.contract-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;margin-bottom:16px;padding:20px 24px}.contract-card h3{margin-bottom:12px;font-size:.95rem;font-weight:600}.contract-card ul{padding-left:20px;list-style:outside}.contract-card li{color:var(--text-secondary);margin-bottom:4px;font-size:.85rem;line-height:1.6}.contract-card p{color:var(--text-secondary);font-size:.85rem;line-height:1.6}.contract-card-rule{border-width:2px;border-color:#e65555}.contract-card-benefit{border-color:#48c78e}.contract-note{margin-top:8px;font-style:italic;color:var(--text-muted)!important}.contract-signature{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;margin-top:24px;padding:24px}.contract-signature h3{margin-bottom:16px;font-size:1rem}.contract-field{margin-bottom:16px}.contract-field label{color:var(--text-secondary);margin-bottom:6px;font-size:.8rem;font-weight:600;display:block}.contract-field input{background:var(--bg-tertiary);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:6px;padding:10px 12px;font-size:.9rem}.contract-field input:focus{border-color:var(--accent);outline:none}.contract-consent{cursor:pointer;align-items:flex-start;gap:10px;margin:16px 0;display:flex}.contract-consent input[type=checkbox]{accent-color:var(--accent);flex-shrink:0;margin-top:3px}.contract-consent span{color:var(--text-secondary);font-size:.8rem;line-height:1.5}.contract-guarantee{text-align:center;color:var(--text-muted);border:1px dashed var(--border);border-radius:6px;margin:16px 0;padding:12px;font-size:.75rem}.contract-actions{justify-content:flex-end;gap:12px;display:flex}.contract-btn{cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-size:.9rem;font-weight:600;transition:opacity .2s}.contract-btn:disabled{opacity:.4;cursor:not-allowed}.contract-btn-decline{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.contract-btn-decline:hover{background:var(--bg-tertiary)}.contract-btn-accept{color:var(--bg-primary);background:#48c78e}.contract-btn-accept:hover:not(:disabled){background:#3db87e}.profile-links{text-align:center;margin-top:8px}.profile-link{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;padding:10px 20px;font-size:.85rem;transition:background .2s}.profile-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}
