@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-x: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:100dvh;display:flex;overflow:hidden}.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;position:relative}.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}.code-editor-monaco-wrapper{flex:1;min-height:0;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}}.run-hint-toast{background:var(--bg-secondary);border:1px solid var(--accent);color:var(--text-secondary);z-index:50;border-radius:8px;max-width:240px;margin-top:4px;padding:8px 12px;font-size:12px;line-height:1.4;animation:.3s ease-out run-hint-in;position:absolute;top:100%;right:14px;box-shadow:0 4px 16px #0006}.run-hint-toast strong{color:var(--accent)}.run-hint-arrow{color:var(--accent);margin-right:4px;font-weight:700}@keyframes run-hint-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.code-editor-symbol-btn{color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:6px;margin-left:8px;padding:3px 10px;font-family:Cascadia Code,Fira Code,monospace;font-size:12px;font-weight:600;transition:all .2s}.code-editor-symbol-btn:hover{color:var(--text-primary);border-color:var(--accent);background:var(--bg-secondary)}.code-editor-symbol-btn-active{color:var(--accent);border-color:var(--accent);background:#58a6ff1a}.symbol-keyboard{z-index:1000;background:var(--bg-secondary);border:1px solid var(--border);touch-action:none;-webkit-user-select:none;user-select:none;border-radius:10px;width:320px;position:fixed;box-shadow:0 8px 32px #00000080}.symbol-keyboard-header{cursor:grab;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:6px 10px;display:flex}.symbol-keyboard-header:active{cursor:grabbing}.symbol-keyboard-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.symbol-keyboard-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:14px;line-height:1}.symbol-keyboard-close:hover{color:var(--text-primary);background:var(--bg-tertiary)}.symbol-keyboard-grid{flex-direction:column;gap:4px;padding:6px;display:flex}.symbol-keyboard-row{gap:4px;display:flex}.symbol-key{aspect-ratio:1;color:var(--text-primary);background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;border-radius:6px;flex:1;justify-content:center;align-items:center;min-height:36px;padding:0;font-family:Cascadia Code,Fira Code,monospace;font-size:16px;font-weight:500;transition:all .1s;display:flex}.symbol-key:hover{background:var(--bg-primary);border-color:var(--accent);color:var(--accent);transform:scale(1.05)}.symbol-key:active{background:#58a6ff26;transform:scale(.95)}@media (width<=767px){.symbol-keyboard{width:calc(100vw - 16px);max-width:360px}.symbol-key{min-height:42px;font-size:18px}}.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-plan.beta{color:var(--accent);background:#1a2a3a}.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:#161b2299;border-bottom:1px solid #30363dcc;flex-shrink:0;align-items:center;gap:10px;padding:10px 12px;display:flex}.professor-header-photo{object-fit:cover;border:2px solid #58a6ff59;border-radius:50%;flex-shrink:0;width:40px;height:40px}.professor-emotion-badge{flex-shrink:0;margin-left:auto;animation:3s ease-in-out infinite ghos-float}.professor-status{color:#3fb950;margin:0;font-size:11px}@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}}@keyframes ghos-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes ghos-celebrate{0%{transform:translateY(0)rotate(0)}20%{transform:translateY(-10px)rotate(-6deg)}40%{transform:translateY(-8px)rotate(6deg)}60%{transform:translateY(-12px)rotate(-4deg)}80%{transform:translateY(-6px)rotate(4deg)}to{transform:translateY(0)rotate(0)}}@keyframes ghos-worried{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}@keyframes ghos-thinking{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-4px)scale(1.03)}}.ghos-avatar{object-fit:contain;filter:drop-shadow(0 4px 12px #58a6ff40);flex-shrink:0;animation:3s ease-in-out infinite ghos-float;display:block}.ghos-avatar--celebrate{animation:.8s ease-in-out ghos-celebrate}.ghos-avatar--worried{animation:.4s ease-in-out 3 ghos-worried}.ghos-avatar--thinking{animation:2s ease-in-out infinite ghos-thinking}.ghos-avatar--exhausted{opacity:.8;animation:5s ease-in-out infinite ghos-float}.professor-avatar-img{width:48px;height:48px}.graduation-overlay{z-index:1100;background:#000000bf;justify-content:center;align-items:center;animation:.3s fade-in;display:flex;position:fixed;inset:0}.graduation-modal{background:var(--bg-secondary);text-align:center;border:1px solid #58a6ff4d;border-radius:16px;width:90%;max-width:400px;padding:40px 48px;box-shadow:0 8px 40px #58a6ff33}.graduation-ghos{filter:drop-shadow(0 4px 20px #58a6ff59);width:160px;height:160px;margin:0 auto 20px;animation:1s ease-in-out 2 ghos-celebrate,3s ease-in-out 2s infinite ghos-float;display:block}.graduation-title{color:var(--text-primary);margin:0 0 8px;font-size:22px;font-weight:700}.graduation-subtitle{color:var(--text-secondary);margin:0 0 28px;font-size:14px}.graduation-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#58a6ff,#bc8cff);border:none;border-radius:8px;padding:10px 28px;font-size:14px;font-weight:600;transition:opacity .2s}.graduation-btn:hover{opacity:.88}.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}.chat-msg{align-items:flex-end;gap:8px;max-width:100%;display:flex}.chat-msg-assistant{flex-direction:row;align-self:flex-start}.chat-msg-user{flex-direction:row-reverse;align-self:flex-end}.chat-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex;overflow:hidden}.chat-avatar-ghos{object-fit:cover;border:1.5px solid #58a6ff4d}.chat-avatar-user{background:var(--bg-tertiary);border:1.5px solid #ffffff1a;font-size:16px}.chat-bubble{word-wrap:break-word;white-space:pre-wrap;border-radius:14px;max-width:calc(100% - 44px);padding:9px 13px;font-size:13px;line-height:1.6}.chat-bubble-assistant{background:var(--bg-tertiary);color:var(--text-primary);border-bottom-left-radius:4px}.chat-bubble-user{background:var(--accent);color:#fff;white-space:normal;border-bottom-right-radius:4px}.professor-md p{margin:0 0 8px}.professor-md p:last-child{margin-bottom:0}.professor-md strong{color:var(--text-primary);font-weight:600}.professor-md em{color:var(--text-secondary)}.professor-md code{background:var(--bg-primary);color:var(--accent);border-radius:3px;padding:1px 5px;font-family:Cascadia Code,Fira Code,monospace;font-size:.9em}.professor-md pre{background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;margin:8px 0;padding:10px 12px;overflow-x:auto}.professor-md pre code{color:var(--text-primary);background:0 0;padding:0}.professor-md ul,.professor-md ol{margin:4px 0 8px;padding-left:20px}.professor-md li{margin-bottom:2px}.professor-md h1,.professor-md h2,.professor-md h3{color:var(--text-primary);margin:10px 0 4px;font-size:14px;font-weight:700}.professor-md blockquote{border-left:3px solid var(--accent);color:var(--text-secondary);margin:8px 0;padding:4px 10px}.professor-line-hint{border-left:3px solid var(--accent);background:#58a6ff14;animation:.3s ease-out hint-fadein}@keyframes hint-fadein{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.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;min-height:100dvh;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}.ghost-scrambled{-webkit-text-decoration:underline wavy var(--error);text-decoration:underline wavy var(--error);opacity:.9;font-style:italic;color:var(--error)!important}.inline-feedback{z-index:100;pointer-events:none;white-space:nowrap;font-size:11px;font-weight:500;line-height:19px;font-family:var(--font-mono,"Cascadia Code", "Fira Code", monospace);border-radius:4px;padding:2px 8px;animation:.15s ease-out feedback-slide,.3s ease-in 1.5s forwards feedback-fade;position:absolute}.inline-feedback-correct{color:var(--color-success,#3fb950);opacity:.8;background:0 0;border:none}.inline-feedback-error{border-left:2px solid var(--color-error,#ff7b72);color:var(--color-error,#ff7b72);background:#f851491a;border-radius:0 4px 4px 0}.inline-feedback-streak{color:var(--color-accent,#58a6ff);background:0 0;border:none;font-size:12px;font-weight:600}@keyframes feedback-slide{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}@keyframes feedback-fade{0%{opacity:1}to{opacity:0}}.tutorial-overlay{z-index:9999;position:fixed;inset:0}.tutorial-backdrop{cursor:pointer;background:#0009;position:absolute;inset:0}.tutorial-tooltip{z-index:10001;pointer-events:auto;flex-direction:row;align-items:flex-end;gap:0;animation:.3s ease-out tutorial-appear;display:flex;position:fixed}.tutorial-professor-aside{z-index:1;flex-shrink:0;justify-content:center;align-items:flex-end;width:160px;display:flex;position:relative;overflow:visible}.tutorial-professor-aside img{object-fit:contain;filter:drop-shadow(0 8px 24px #00000080);width:160px;height:auto;max-height:280px;animation:3s ease-in-out infinite ghos-float;display:block}.tutorial-card{background:var(--bg-secondary);border:1px solid #58a6ff66;border-radius:16px;flex-shrink:0;width:300px;padding:16px 20px 20px;position:relative;box-shadow:0 12px 40px #0009,0 0 0 1px #58a6ff14}.tutorial-step-dots{justify-content:center;gap:5px;margin-bottom:10px;display:flex}.tutorial-dot{background:var(--text-muted);border-radius:50%;width:6px;height:6px;transition:background .2s,transform .2s}.tutorial-dot.active{background:var(--color-accent,#58a6ff);transform:scale(1.3)}.tutorial-dot.done{background:#58a6ff66}.tutorial-title{color:var(--text-primary);text-align:center;margin:0 0 6px;font-size:15px;font-weight:700}.tutorial-description{color:var(--text-secondary);text-align:center;margin:0 0 14px;font-size:12.5px;line-height:1.55}.tutorial-actions{justify-content:space-between;align-items:center;gap:12px;display:flex}.tutorial-skip{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:6px 0;font-size:12px}.tutorial-skip:hover{color:var(--text-secondary)}.tutorial-next{background:var(--color-accent,#58a6ff);color:#000;cursor:pointer;border:none;border-radius:8px;flex:1;padding:8px 20px;font-size:13px;font-weight:600}.tutorial-next:hover{filter:brightness(1.1)}.tutorial-card:before{content:"";background:var(--bg-secondary);border:1px solid var(--color-accent,#58a6ff);width:12px;height:12px;display:none;position:absolute;transform:rotate(45deg)}.tutorial-arrow-up .tutorial-card:before{border-bottom:none;border-right:none;margin-left:-6px;display:block;top:-7px;left:50%}.tutorial-arrow-down .tutorial-card:before{border-top:none;border-left:none;margin-left:-6px;display:block;bottom:-7px;left:50%}.tutorial-arrow-left .tutorial-card:before{border-top:none;border-right:none;margin-top:-6px;display:block;top:50%;left:-7px}.tutorial-arrow-right .tutorial-card:before{border-bottom:none;border-left:none;margin-top:-6px;display:block;top:50%;right:-7px}.tutorial-professor-right{flex-direction:row-reverse}@keyframes tutorial-appear{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.loading-screen{height:100dvh;color:var(--text-secondary);background:var(--bg-primary);justify-content:center;align-items:center;font-size:16px;display:flex}.playground-sidebar-btn{width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;background:#58a6ff12;border:1px solid #58a6ff33;border-radius:10px;align-items:center;gap:10px;margin-bottom:12px;padding:10px 14px;transition:background .15s,border-color .15s;display:flex}.playground-sidebar-btn:hover{color:var(--text-primary);background:#58a6ff24;border-color:#58a6ff66}.playground-sidebar-btn.active{border-color:var(--color-accent,#58a6ff);color:var(--text-primary);background:#58a6ff2e}.playground-sidebar-icon{color:var(--color-accent,#58a6ff);flex-shrink:0;font-size:16px}.playground-sidebar-label{flex:1;font-size:13px;font-weight:600}.playground-sidebar-sub{color:var(--text-muted);font-size:10px}.playground-lang-select{background:var(--bg-tertiary,#2a2a3a);color:var(--text-primary);cursor:pointer;border:1px solid #58a6ff4d;border-radius:6px;outline:none;padding:4px 8px;font-size:12px;font-weight:500;transition:border-color .15s}.playground-lang-select:hover,.playground-lang-select:focus{border-color:var(--color-accent,#58a6ff)}.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-stars .star-rating{justify-content:center;gap:4px;margin-bottom:8px;font-size:36px}.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;min-width:0;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-lang-cards{scrollbar-width:none;-ms-overflow-style:none;flex-wrap:nowrap;gap:8px;min-width:0;max-width:100%;padding:0 8px 14px;display:flex;overflow:auto hidden}.track-lang-cards::-webkit-scrollbar{display:none}.track-lang-cards-wrapper{align-items:center;gap:0;min-width:0;display:flex}.track-lang-cards-wrapper .track-lang-cards{flex:1;min-width:0}.track-cards-arrow{background:var(--bg-secondary);border:1px solid var(--border);width:22px;height:48px;color:var(--text-muted);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-family:inherit;font-size:18px;transition:all .15s;display:flex}.track-cards-arrow:hover{color:var(--text-primary);border-color:var(--accent);background:#58a6ff14}.track-cards-arrow.left{margin-right:2px}.track-cards-arrow.right{margin-left:2px}.track-lang-card{border:1px solid var(--border);background:var(--bg-secondary);min-width:72px;color:var(--text-secondary);cursor:pointer;border-radius:10px;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;padding:10px 8px 8px;font-family:inherit;transition:all .15s;display:flex;position:relative}.track-lang-card:hover{border-color:var(--lang-color,var(--accent));background:#58a6ff0d}.track-lang-card.active{border-color:var(--lang-color,var(--accent));background:#58a6ff14;box-shadow:0 1px 10px #58a6ff26}.track-lang-card-icon{justify-content:center;align-items:center;height:28px;font-size:24px;line-height:1;display:flex}.track-lang-card-name{white-space:nowrap;font-size:11px;font-weight:600}.track-lang-card-container{flex-direction:column;flex-shrink:0;align-items:center;gap:4px;display:flex}.track-lang-about-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;padding:2px 10px;font-family:inherit;font-size:10px;transition:all .15s}.track-lang-about-btn:hover{color:var(--lang-color,var(--accent));border-color:var(--lang-color,var(--accent));background:#58a6ff14}.track-lang-card.explore{border-style:dashed;border-color:var(--text-muted);opacity:.7}.track-lang-card.explore:hover{opacity:1;border-color:var(--lang-color,var(--accent))}.track-lang-card-subscribe{color:var(--accent);white-space:nowrap;font-size:9px;font-weight:600}.track-lang-info-panel{border:1px solid var(--lang-color,var(--border));background:var(--bg-secondary);border-radius:10px;margin:0 8px 12px;padding:12px;animation:.2s ease-out trackInfoSlideIn}@keyframes trackInfoSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.track-lang-info-header{align-items:center;gap:10px;margin-bottom:10px;display:flex}.track-lang-info-icon{flex-shrink:0;font-size:28px}.track-lang-info-header>div{flex:1;min-width:0}.track-lang-info-name{color:var(--text-primary);font-size:14px;font-weight:700;display:block}.track-lang-info-tagline{color:var(--text-secondary);font-size:11px;font-style:italic;display:block}.track-lang-info-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:4px;font-family:inherit;font-size:14px;transition:color .15s}.track-lang-info-close:hover{color:var(--text-primary)}.track-lang-info-desc{color:var(--text-secondary);margin-bottom:10px;font-size:12px;line-height:1.5}.track-lang-info-section{margin-bottom:8px}.track-lang-info-section:last-child{margin-bottom:0}.track-lang-info-section strong{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:10px;font-weight:700;display:block}.track-lang-info-section p{color:var(--text-secondary);font-size:12px;line-height:1.4}.profile-section-desc{color:var(--text-muted);margin-bottom:8px;font-size:12px}.profile-section-empty{color:var(--text-muted);margin-top:8px;font-size:.8rem;font-style:italic}.profile-lang-sub-list{flex-direction:column;gap:6px;display:flex}.profile-lang-sub-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.profile-lang-sub-name{color:var(--text-primary);text-transform:capitalize;font-size:13px;font-weight:500}.profile-lang-unsub-btn{color:#ff6464;cursor:pointer;background:0 0;border:1px solid #ff64644d;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:11px;font-weight:500;transition:all .15s}.profile-lang-unsub-btn:hover{background:#ff64641a;border-color:#ff6464}.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:1px;font-size:14px;display:inline-flex}.track-exercise .star-rating{flex-shrink:0;margin-left:auto;font-size:10px}.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-editor.focused{border-color:var(--accent);box-shadow:0 0 0 2px #58a6ff33}.onboarding-exercise-tap-hint{color:var(--accent);text-align:center;margin-top:12px;font-size:13px;animation:1.5s ease-in-out infinite pulse-hint}@keyframes pulse-hint{0%,to{opacity:.6}50%{opacity:1}}.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);height:100dvh;font-family:Inter,sans-serif;display:flex;overflow:hidden}.profile-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:16px;width:220px;padding:20px 16px;display:flex;overflow-y:auto}.profile-sidebar-nav{flex-direction:column;gap:2px;display:flex}.profile-sidebar-item{text-align:left;width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-left:3px solid #0000;border-radius:0 6px 6px 0;padding:10px 14px;font-family:inherit;font-size:.9rem;transition:background .15s,color .15s,border-color .15s;display:block}.profile-sidebar-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.profile-sidebar-item.active{background:var(--bg-tertiary);color:var(--accent);border-left-color:var(--accent);font-weight:600}.profile-content{flex:1;max-width:720px;padding:24px 32px;overflow-y:auto}.profile-section-title{margin-bottom:20px;font-size:1.4rem;font-weight:600}.profile-back{border:1px solid var(--border);color:var(--text-primary);cursor:pointer;background:0 0;border-radius:6px;align-self:flex-start;padding:6px 12px;font-family:inherit;font-size:.9rem}.profile-back:hover{background:var(--bg-tertiary)}.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-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}.profile-field{align-items:center;gap:10px;display:flex}.profile-field-input{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);border-radius:6px;outline:none;flex:1;padding:8px 12px;font-family:inherit;font-size:.9rem}.profile-field-input:focus{border-color:var(--accent)}.profile-field-save{background:var(--accent);color:var(--bg-primary);cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:8px 16px;font-family:inherit;font-size:.85rem;font-weight:600}.profile-field-save:disabled{opacity:.5;cursor:not-allowed}.profile-field-msg{color:var(--accent);margin-top:6px;font-size:.8rem;display:block}.profile-field-msg.error{color:#e65555}.profile-field-hint{color:var(--text-muted);margin-top:4px;font-size:.75rem;display:block}.profile-info-row{color:var(--text-secondary);margin-bottom:6px;font-size:.85rem}.profile-danger-zone{background:var(--bg-secondary);border:2px solid #e65555;border-radius:12px;margin-bottom:20px;padding:20px}.profile-danger-zone h3{color:#e65555;margin-bottom:8px;font-size:1rem}.profile-danger-zone p{color:var(--text-secondary);margin-bottom:12px;font-size:.85rem}.profile-danger-btn{color:#e65555;cursor:pointer;background:0 0;border:1px solid #e65555;border-radius:6px;padding:8px 16px;font-family:inherit;font-size:.85rem}.profile-danger-btn:hover,.profile-danger-btn.destructive{color:#fff;background:#e65555}.profile-danger-btn.destructive:disabled{opacity:.5;cursor:not-allowed}.profile-danger-confirm{margin-top:8px}.profile-danger-actions{gap:8px;margin-top:8px;display:flex}.profile-plan-current{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:20px;padding:20px;display:flex}.profile-plan-badge{border-radius:8px;padding:6px 18px;font-size:1.1rem;font-weight:700}.profile-plan-badge.free{background:var(--bg-tertiary);color:var(--text-secondary)}.profile-plan-badge.pro{background:var(--accent);color:var(--bg-primary)}.profile-plan-badge.beta{color:#fff;background:linear-gradient(135deg,#58a6ff,#388bfd)}.profile-plan-badge.admin{color:#fff;background:linear-gradient(135deg,#e65555,#c44040)}.profile-plan-expires,.profile-plan-info{color:var(--text-secondary);font-size:.85rem}.profile-plan-compare{grid-template-columns:1fr 1fr;gap:16px;margin-top:12px;display:grid}.profile-plan-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:10px;padding:20px}.profile-plan-card.highlight{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.profile-plan-card h4{margin-bottom:8px;font-size:1rem}.profile-plan-price{color:var(--accent);margin-bottom:12px;font-size:1.3rem;font-weight:700}.profile-plan-features{color:var(--text-secondary);padding:0;font-size:.8rem;line-height:1.8;list-style:none}.profile-upgrade-options{flex-direction:column;gap:10px;display:flex}.profile-upgrade-btn{background:var(--accent);color:var(--bg-primary);cursor:pointer;border:none;border-radius:8px;padding:12px 20px;font-family:inherit;font-size:.95rem;font-weight:600;transition:opacity .15s}.profile-upgrade-btn:hover{opacity:.9}.profile-upgrade-btn:disabled{opacity:.5;cursor:not-allowed}.profile-upgrade-btn.annual{background:linear-gradient(135deg, var(--accent), #48c78e)}.profile-track-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.profile-track-confirm{color:#e65555;align-items:center;gap:6px;font-size:.75rem;display:flex}.profile-track-reset-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;padding:2px 8px;font-family:inherit;font-size:.7rem}.profile-track-reset-btn:hover{color:#e65555;border-color:#e65555}.profile-track-reset-btn.confirm{color:#e65555;border-color:#e65555;font-weight:600}.contract-page{background:var(--bg-primary);color:var(--text-primary);max-width:640px;min-height:100dvh;margin:0 auto;padding:32px 24px 48px;font-family:Inter,sans-serif;overflow-y:auto}.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-signed-banner{color:var(--accent);text-align:center;background:#58a6ff1a;border:1px solid #58a6ff4d;border-radius:8px;margin-bottom:8px;padding:14px 18px;font-size:.85rem}.contract-signature-readonly .contract-signed-info{flex-direction:column;gap:8px;display:flex}.contract-signature-readonly .contract-signed-info p{color:var(--text-secondary);font-size:.85rem}.contract-signature-readonly .contract-signed-info strong{color:var(--text-primary)}.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;flex-direction:column;align-items:center;gap:10px;margin-top:8px;display:flex}.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)}.profile-link-logout{color:var(--error);border-color:var(--error)}.profile-link-logout:hover{color:var(--error);background:#f851491a}.beta-gate-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100dvh;padding:20px;display:flex}.beta-gate-card{background:var(--bg-secondary);border:1px solid var(--border);text-align:center;border-radius:16px;width:100%;max-width:420px;padding:40px 32px}.beta-gate-ghost{margin-bottom:12px;font-size:3.5rem}.beta-gate-card h1{color:var(--text-primary);margin-bottom:8px;font-size:1.6rem}.beta-gate-subtitle{color:var(--text-secondary);margin-bottom:24px;font-size:.95rem}.beta-gate-input-group{margin-bottom:16px}.beta-gate-input{border:1px solid var(--border);background:var(--bg-tertiary);width:100%;color:var(--text-primary);text-align:center;letter-spacing:2px;border-radius:8px;padding:12px 16px;font-family:monospace;font-size:1.1rem}.beta-gate-input:focus{border-color:var(--accent);outline:none}.beta-gate-error{color:var(--error);margin-top:8px;font-size:.85rem;display:block}.beta-gate-btn{cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:8px;padding:12px;font-size:1rem;font-weight:600;transition:background .2s;display:block}.beta-gate-btn:disabled{opacity:.5;cursor:not-allowed}.beta-gate-btn-submit{background:var(--accent);color:var(--bg-primary)}.beta-gate-btn-submit:hover:not(:disabled){background:var(--accent-hover)}.beta-gate-btn-nocode{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.beta-gate-btn-nocode:hover{background:var(--bg-tertiary)}.beta-gate-btn-back{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.beta-gate-btn-back:hover{background:var(--border)}.beta-gate-notify{border:1px solid var(--border);background:var(--bg-tertiary);border-radius:8px;margin:20px 0;padding:16px}.beta-gate-notify p{color:var(--text-secondary);margin-bottom:8px;font-size:.95rem}.beta-gate-notify p:last-child{margin-bottom:0}.contract-verify{text-align:center;max-width:420px;margin:0 auto;padding:40px 24px}.contract-verify-icon{margin-bottom:12px;font-size:3rem}.contract-verify h2{color:var(--text-primary);margin-bottom:8px}.contract-verify>p{color:var(--text-secondary);margin-bottom:20px;font-size:.95rem}.contract-verify-code-display{background:var(--bg-tertiary);border:2px solid var(--accent);border-radius:12px;margin-bottom:20px;padding:16px}.contract-verify-code-label{color:var(--text-secondary);margin-bottom:4px;font-size:.85rem;display:block}.contract-verify-code-value{color:var(--accent);letter-spacing:6px;font-family:monospace;font-size:2rem;font-weight:700;display:block}.contract-verify-code-timer{color:var(--text-muted);margin-top:6px;font-size:.75rem;display:block}.contract-verify-hidden{color:var(--text-muted);margin-bottom:16px;font-size:.85rem;font-style:italic}.contract-verify-input-group{margin-bottom:16px}.contract-verify-input{border:1px solid var(--border);background:var(--bg-tertiary);width:100%;max-width:200px;color:var(--text-primary);text-align:center;letter-spacing:6px;border-radius:8px;padding:12px 16px;font-family:monospace;font-size:1.5rem}.contract-verify-input:focus{border-color:var(--accent);outline:none}.contract-verify-error{color:var(--error);margin-top:8px;font-size:.85rem;display:block}.contract-verify-actions{justify-content:center;gap:12px;display:flex}.contract-verify-actions .contract-btn{flex:1;max-width:180px}.contract-verify-hint{color:var(--text-muted);text-align:center;margin-top:16px;font-size:.8rem}.mobile-topbar{background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;height:48px;padding:0 12px;display:flex}.mobile-topbar-btn{color:var(--text-primary);cursor:pointer;background:0 0;border:none;padding:6px 10px;font-size:22px;line-height:1}.mobile-topbar-title{color:var(--text-primary);letter-spacing:-.3px;font-size:15px;font-weight:600}.mobile-professor-icon{font-size:20px}.mobile-overlay{z-index:199;background:#00000080;position:fixed;inset:0}.mobile-drawer{z-index:200;width:85vw;max-width:320px;transition:transform .25s;position:fixed;top:0;bottom:0;overflow-y:auto;transform:translate(-100%)}.mobile-drawer--right{left:auto;right:0;transform:translate(100%)}.mobile-drawer--open{transform:translate(0)}.app-layout--mobile{flex-direction:column;width:100vw;max-width:100vw;position:fixed;inset:0;overflow:hidden}.app-layout--mobile .mobile-editor{flex:1;min-height:0;overflow:auto}.app-layout--mobile .app-professor-divider{display:none}@media (width<=767px){input,select,textarea{font-size:16px!important}html,body,#root{-webkit-text-size-adjust:100%;max-width:100vw;overflow-x:clip}body{touch-action:pan-x pan-y}.login-card{border-radius:12px;max-width:100%;margin:0 16px;padding:28px 20px}.login-title{font-size:22px}.login-subtitle{font-size:13px}.login-mascot{width:56px;height:56px}.contract-page,.contract-card{padding:16px}.contract-actions{flex-direction:column;gap:8px}.contract-actions button{width:100%}.profile-page{flex-direction:column;height:auto;min-height:100dvh;overflow:visible}.profile-sidebar{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;gap:4px;width:100%;padding:8px;overflow-x:auto}.profile-sidebar-item{white-space:nowrap;padding:6px 14px;font-size:13px}.profile-content{padding:16px;overflow-y:visible}.profile-card{text-align:center;flex-direction:column;align-items:center;gap:12px}.profile-stats{grid-template-columns:repeat(2,1fr);gap:8px}.profile-avatar-grid{grid-template-columns:repeat(4,1fr);gap:8px}.profile-badge-grid{grid-template-columns:repeat(2,1fr)}.code-editor-header{flex-wrap:wrap;gap:4px;min-height:32px;padding:4px 8px}.code-editor-lang{font-size:10px}.code-editor-progress-bar{width:60px}.mode-selector{flex-wrap:wrap;gap:4px;padding:6px 8px}.mode-selector-btn{padding:4px 8px;font-size:11px}.track-list{font-size:13px}.track-lang-scroll{gap:4px}.track-lang-btn{padding:4px 8px;font-size:12px}.professor-panel{height:100%}.professor-chat-input{font-size:14px}.tutorial-tooltip{flex-direction:column;align-items:center;max-width:90vw}.tutorial-professor-right{flex-direction:column;align-items:center}.tutorial-professor-aside{width:100px}.tutorial-professor-aside img{width:100px;max-height:120px}.tutorial-card{width:min(300px,88vw);font-size:14px}.tutorial-actions{flex-direction:column;gap:6px}.tutorial-actions button{width:100%}.onboarding-page{padding:16px}.onboarding-card{max-width:100%;padding:20px}.terminal-panel-body,.inline-feedback{font-size:12px}.completion-modal,.paywall-overlay .paywall-card,.upgrade-modal{width:90vw;max-width:400px;padding:20px}.review-queue{padding:8px}.track-explore-popup{width:90vw;max-width:320px}}.level-select-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.level-select-modal{background:var(--bg-secondary,#1e1e2e);border:1px solid var(--border,#333);border-radius:12px;width:100%;max-width:480px;max-height:90vh;padding:2rem;overflow-y:auto}.level-select-title{color:var(--text-primary,#e0e0e0);margin:0 0 .5rem;font-size:1.3rem}.level-select-subtitle{color:var(--text-secondary,#999);margin:0 0 1.5rem;font-size:.85rem;line-height:1.4}.level-select-options{flex-direction:column;gap:.75rem;display:flex}.level-select-card{background:var(--bg-primary,#121220);border:1px solid var(--border,#333);cursor:pointer;text-align:left;color:var(--text-primary,#e0e0e0);border-radius:8px;flex-direction:column;gap:.25rem;padding:1rem;transition:border-color .15s,background .15s;display:flex}.level-select-card:hover:not(:disabled){border-color:var(--accent,#7c3aed);background:#7c3aed14}.level-select-card:disabled{opacity:.5;cursor:wait}.level-select-card-title{font-size:1rem;font-weight:600}.level-select-card-desc{color:var(--text-secondary,#999);font-size:.8rem}.level-select-card-skip{color:var(--accent,#7c3aed);margin-top:.25rem;font-size:.75rem}.level-select-footer{justify-content:center;margin-top:1.5rem;display:flex}.level-select-close{color:var(--text-secondary,#999);cursor:pointer;background:0 0;border:none;padding:.5rem 1rem;font-size:.85rem}.level-select-close:hover{color:var(--text-primary,#e0e0e0)}.track-reset-btn{border:1px solid var(--border,#333);width:100%;color:var(--text-secondary,#999);cursor:pointer;text-align:center;background:0 0;border-radius:4px;margin-bottom:.5rem;padding:.4rem .75rem;font-size:.7rem;transition:color .15s,border-color .15s;display:block}.track-reset-btn:hover{color:#ef4444;border-color:#ef4444}.briefing-professor-area{flex-direction:column;gap:0;height:100%;display:flex;overflow-y:auto}.code-editor-test-btn{background:var(--accent-green,#4caf50)!important}.code-editor-test-btn:hover:not(:disabled){background:#388e3c!important}.code-editor-test-btn:disabled{opacity:.6}.briefing-panel{background:var(--bg-primary);flex-direction:column;height:100%;display:flex}.briefing-panel-header{border-bottom:1px solid var(--border);background:var(--bg-secondary);padding:10px 14px}.briefing-panel-label{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:700}.briefing-panel-body{flex:1;padding:16px;overflow-y:auto}.briefing-panel-description{color:var(--text-primary);margin:0 0 16px;font-size:14px;line-height:1.6}.briefing-panel-hints{margin-top:12px}.briefing-panel-hints-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:11px;font-weight:600;display:block}.briefing-panel-hint{color:var(--text-secondary);padding:6px 0;font-size:13px;line-height:1.4}.briefing-panel-hint-number{color:var(--accent);margin-right:6px;font-weight:600}.briefing-panel-hint-btn{color:var(--accent);border:1px solid var(--accent);cursor:pointer;background:0 0;border-radius:6px;margin-top:12px;padding:6px 14px;font-family:inherit;font-size:12px;transition:all .2s}.briefing-panel-hint-btn:hover{background:#58a6ff1a}.briefing-panel-checklist{flex-direction:column;gap:6px;margin-top:16px;display:flex}.briefing-panel-checklist-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:4px;font-size:11px}.briefing-panel-check-item{color:var(--text-primary);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.briefing-panel-check-item input[type=checkbox]{accent-color:var(--accent)}.briefing-panel-confirm-area{flex-direction:column;gap:8px;margin-top:16px;display:flex}.briefing-panel-run-hint{color:var(--text-muted);margin:0;font-size:12px;font-style:italic}.briefing-panel-confirm-btn{background:var(--accent);color:#000;cursor:pointer;border:none;border-radius:8px;padding:10px 16px;font-size:13px;font-weight:600;transition:filter .15s}.briefing-panel-confirm-btn:hover:not(:disabled){filter:brightness(1.1)}.briefing-panel-confirm-btn:disabled{background:var(--bg-tertiary,#2a2a3a);color:var(--text-muted);cursor:not-allowed}.briefing-panel-confirmed{color:#3fb950;background:#3fb95026;border-radius:6px;margin-top:10px;padding:8px 12px;font-size:13px;font-weight:500}.test-results-panel{background:var(--bg-secondary);border-top:1px solid var(--border);max-height:300px;overflow-y:auto}.test-results-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 14px;display:flex}.test-results-title{color:var(--text-primary);font-size:12px;font-weight:600}.test-results-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:700}.test-results-badge-passed{color:var(--success);background:#3fb95033}.test-results-badge-failed{color:var(--error);background:#f8514933}.test-results-badge-running{color:var(--accent);background:#58a6ff33}.test-results-list{padding:6px}.test-result-item{border-radius:6px;margin-bottom:4px;padding:8px 10px}.test-result-pass{background:#3fb9500f}.test-result-fail{background:#f851490f}.test-result-row{align-items:center;gap:8px;display:flex}.test-result-icon{text-align:center;width:20px;font-size:11px;font-weight:700}.test-result-pass .test-result-icon{color:var(--success)}.test-result-fail .test-result-icon{color:var(--error)}.test-result-label{color:var(--text-primary);font-size:12px;font-weight:600}.test-result-details{margin-top:8px;padding-left:28px}.test-result-field{margin-bottom:4px}.test-result-field-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:2px;font-size:10px;display:block}.test-result-field code{color:var(--text-secondary);background:var(--bg-tertiary);white-space:pre-wrap;word-break:break-all;border-radius:3px;padding:2px 6px;font-family:Cascadia Code,Fira Code,monospace;font-size:12px}.placement-page{background:var(--bg-primary);min-height:100dvh;color:var(--text-primary);flex-direction:column;align-items:center;padding:2rem 1rem;display:flex}.placement-page-header{text-align:center;margin-bottom:2rem}.placement-page-header h1{color:var(--text-primary);font-size:1.5rem;font-weight:600}.placement-page-content{width:100%;max-width:700px}.placement-page-error{text-align:center;padding:3rem 1rem}.placement-page-error h2{margin-bottom:.5rem}.placement-page-error p{color:var(--text-secondary);margin-bottom:1.5rem}.placement-question{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem}.placement-question-header{align-items:center;gap:1rem;margin-bottom:1rem;font-size:.85rem;display:flex}.placement-question-number{color:var(--text-secondary);font-weight:500}.placement-question-level{color:var(--accent-color);font-weight:600}.placement-question-timer{color:var(--text-primary);margin-left:auto;font-family:Cascadia Code,Fira Code,monospace;font-size:1rem;font-weight:600}.placement-question-timer.warning{color:#ff6b6b;animation:1s ease-in-out infinite timer-pulse}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.5}}.placement-question-body{margin-bottom:1rem}.placement-question-title{margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.placement-question-desc{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.placement-question-editor{border:1px solid var(--border-color);border-radius:8px;margin-bottom:1rem;overflow:hidden}.placement-question-actions{gap:.75rem;display:flex}.placement-btn{cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:500;transition:background .2s,opacity .2s}.placement-btn:disabled{opacity:.5;cursor:not-allowed}.placement-btn-primary{background:var(--accent-color);color:#fff}.placement-btn-primary:hover:not(:disabled){filter:brightness(1.1)}.placement-btn-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.placement-btn-secondary:hover:not(:disabled){background:var(--border-color)}.placement-result{background:var(--bg-secondary);border:1px solid var(--border-color);text-align:center;border-radius:12px;padding:2rem}.placement-result-icon{margin-bottom:1rem;font-size:3rem}.placement-result-title{margin-bottom:1.5rem;font-size:1.4rem;font-weight:600}.placement-result-level{justify-content:center;align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:1.1rem;display:flex}.placement-result-level-label{color:var(--text-secondary)}.placement-result-level-value{color:var(--accent-color);font-size:1.3rem;font-weight:700}.placement-result-stats{justify-content:center;gap:2rem;margin-bottom:1.5rem;display:flex}.placement-result-stat{flex-direction:column;align-items:center;gap:.25rem;display:flex}.placement-result-stat-value{color:var(--text-primary);font-size:1.5rem;font-weight:700}.placement-result-stat-label{color:var(--text-secondary);font-size:.75rem}.placement-result-skip-info{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.85rem;line-height:1.5}.placement-result-start-btn{padding:.75rem 2rem;font-size:1rem}.level-select-test-link{color:var(--accent-color);cursor:pointer;opacity:.8;background:0 0;border:none;padding:.5rem;font-size:.85rem;text-decoration:underline;transition:opacity .2s}.level-select-test-link:hover:not(:disabled){opacity:1}.level-select-test-link:disabled{opacity:.4;cursor:not-allowed}@media (width<=767px){html{-webkit-text-size-adjust:100%;overflow-x:hidden}body{overflow-x:hidden}}
