.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:100;transition:width var(--transition-base);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:1.25rem;cursor:pointer;border-bottom:1px solid var(--border-color);transition:all var(--transition-fast)}.sidebar-brand:hover{background:var(--bg-input)}.sidebar-logo{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-md);font-size:1.4rem;font-weight:800;color:#fff;flex-shrink:0;font-family:serif}.sidebar-title{font-size:1rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap}.sidebar-nav{flex:1;padding:.75rem;display:flex;flex-direction:column;gap:.25rem;overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.65rem .85rem;border-radius:var(--radius-sm);color:var(--text-secondary);font-weight:500;font-size:.9rem;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none;border:none;background:none;cursor:pointer;width:100%;text-align:left}.sidebar-link:hover{color:var(--text-primary);background:var(--bg-input)}.sidebar-link.active{color:var(--text-accent);background:#4a7cf71a}.sidebar-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--gradient-primary);border-radius:0 3px 3px 0}.sidebar-link.collapsed{justify-content:center;padding:.65rem}.sidebar-link-icon{font-size:1.15rem;flex-shrink:0;width:24px;text-align:center}.sidebar-link-label{overflow:hidden;text-overflow:ellipsis}.sidebar-footer{padding:.75rem;border-top:1px solid var(--border-color)}.sidebar-user{display:flex;align-items:center;gap:.75rem;padding:.5rem .85rem;margin-bottom:.5rem;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.sidebar-user:hover{background:var(--bg-input)}.sidebar-user.active{background:#4a7cf71a}.sidebar-user.collapsed{justify-content:center;padding:.5rem}.sidebar-user-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem;flex-shrink:0}.sidebar-user-info{display:flex;flex-direction:column;min-width:0}.sidebar-user-name{font-weight:600;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-level{font-size:.75rem;color:var(--text-muted)}.fab-container{position:fixed;z-index:1000;display:flex;flex-direction:column;align-items:center;gap:.5rem}.fab-button{width:52px;height:52px;border-radius:50%;background:var(--gradient-primary);color:#fff;font-size:1.5rem;font-weight:800;font-family:serif;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg),0 0 24px #4a7cf74d;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;cursor:grab}.fab-button:hover{transform:scale(1.08);box-shadow:var(--shadow-lg),0 0 32px #4a7cf780}.fab-button.dragging{cursor:grabbing;transform:scale(1.12);box-shadow:var(--shadow-lg),0 0 40px #4a7cf799}.fab-actions{display:flex;flex-direction:column;gap:.4rem;animation:fadeIn .2s ease-out}.fab-action{width:40px;height:40px;border-radius:50%;background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:1.1rem;box-shadow:var(--shadow-md);transition:all var(--transition-fast);cursor:pointer}.fab-action:hover{transform:scale(1.1);background:var(--bg-card-hover)}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%;position:relative;overflow:hidden}.auth-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 20% 50%,rgba(74,124,247,.12) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(99,102,241,.1) 0%,transparent 50%),radial-gradient(ellipse at 60% 80%,rgba(6,182,212,.08) 0%,transparent 50%),var(--bg-primary);z-index:0}.auth-card{position:relative;z-index:1;width:100%;max-width:420px;padding:2.5rem;text-align:center}.auth-logo{width:60px;height:60px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-lg);font-size:2rem;font-weight:800;color:#fff;font-family:serif;box-shadow:0 4px 20px #4a7cf74d}.auth-card h1{font-size:1.5rem;font-weight:700;margin-bottom:.3rem}.auth-subtitle{color:var(--text-secondary);font-size:.9rem;margin-bottom:1.5rem}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--red-500);padding:.6rem 1rem;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:1rem}.auth-form{display:flex;flex-direction:column;gap:1rem;text-align:left}.auth-field label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.3rem;color:var(--text-secondary)}.auth-field .optional{font-weight:400;color:var(--text-muted)}.auth-field input{width:100%}.auth-submit{width:100%;padding:.75rem;font-size:.95rem;margin-top:.5rem}.auth-submit .spinner{width:18px;height:18px;border-width:2px}.auth-footer{margin-top:1.5rem;font-size:.85rem;color:var(--text-secondary)}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-base)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-icon{font-size:1.75rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-input);border-radius:var(--radius-md)}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700}.stat-label{font-size:.8rem;color:var(--text-muted);font-weight:500}.dashboard-xp{margin-bottom:1.5rem}.xp-header{display:flex;justify-content:space-between;margin-bottom:.75rem}.xp-level{font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.xp-text{font-size:.85rem;color:var(--text-secondary)}.xp-bar{height:10px;background:var(--bg-input);border-radius:var(--radius-full);overflow:hidden}.xp-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width .5s ease-out;min-width:4px}.dashboard-recent h2{font-size:1.1rem;margin-bottom:1rem}.empty-state{color:var(--text-muted);text-align:center;padding:2rem}.recent-list{display:flex;flex-direction:column;gap:.5rem}.recent-item{display:flex;align-items:center;gap:.75rem;padding:.6rem 0;border-bottom:1px solid var(--border-color)}.recent-item:last-child{border-bottom:none}.recent-title{flex:1;font-size:.9rem}.recent-time{font-size:.8rem;color:var(--text-muted)}.problems-filters{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.problems-search{flex:1;min-width:200px}.problems-filter{min-width:150px}.problems-list{display:flex;flex-direction:column;gap:.5rem}.problem-row{display:flex;align-items:center;gap:1rem;padding:.85rem 1.25rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);animation:fadeIn .3s ease-out both}.problem-row:hover{background:var(--bg-card-hover);border-color:var(--border-focus);transform:translate(4px)}.problem-id{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);width:40px}.problem-title{flex:1;font-weight:500}.problem-topic{padding:.2rem .6rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.problem-status{width:30px;text-align:center}.status-unseen{color:var(--text-muted)}.editor-layout{display:flex;height:calc(100vh + -0px);overflow:hidden;margin:-2rem}.editor-problem{width:380px;min-width:250px;max-width:60%;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.editor-problem-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:.75rem}.editor-problem-header h2{font-size:1rem;font-weight:600;flex:1}.editor-problem-content{flex:1;overflow-y:auto;padding:1.25rem}.editor-problem-content h3{font-size:.95rem;font-weight:600;margin-top:1.5rem;margin-bottom:.5rem;color:var(--text-accent)}.editor-problem-content h3:first-child{margin-top:0}.editor-problem-content p{color:var(--text-secondary);margin-bottom:.75rem;line-height:1.7}.editor-problem-content pre{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:.75rem 1rem;margin-bottom:1rem;overflow-x:auto;font-family:var(--font-mono);font-size:.85rem;line-height:1.5}.editor-problem-content code{font-family:var(--font-mono);font-size:.85rem;background:var(--bg-input);padding:.15rem .35rem;border-radius:3px}.drag-handle-h{width:5px;cursor:col-resize;background:transparent;transition:background var(--transition-fast);flex-shrink:0;position:relative}.drag-handle-h:hover,.drag-handle-h.dragging{background:var(--blue-500)}.drag-handle-h:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:3px;height:40px;border-radius:2px;background:var(--text-muted);opacity:0;transition:opacity var(--transition-fast)}.drag-handle-h:hover:after{opacity:.5}.editor-right{flex:1;display:flex;flex-direction:column;min-width:300px;overflow:hidden}.editor-toolbar{display:flex;align-items:center;padding:.5rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);gap:.5rem}.editor-toolbar .file-name{font-family:var(--font-mono);font-size:.85rem;color:var(--text-secondary);flex:1}.editor-toolbar .btn{font-size:.8rem;padding:.4rem .9rem}.editor-monaco{flex:1;min-height:200px;overflow:hidden}.drag-handle-v{height:5px;cursor:row-resize;background:transparent;transition:background var(--transition-fast);flex-shrink:0;position:relative}.drag-handle-v:hover,.drag-handle-v.dragging{background:var(--blue-500)}.editor-output{height:200px;min-height:60px;max-height:70%;background:var(--bg-primary);border-top:1px solid var(--border-color);display:flex;flex-direction:column}.editor-output-tabs{display:flex;padding:0 .5rem;border-bottom:1px solid var(--border-color)}.editor-output-tab{padding:.5rem 1rem;font-size:.8rem;font-weight:600;color:var(--text-muted);border-bottom:2px solid transparent;transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:.05em}.editor-output-tab:hover{color:var(--text-secondary)}.editor-output-tab.active{color:var(--text-accent);border-bottom-color:var(--blue-500)}.editor-output-content{flex:1;overflow-y:auto;padding:.75rem 1rem;font-family:var(--font-mono);font-size:.85rem;line-height:1.6;white-space:pre-wrap;word-break:break-all}.output-success{color:var(--emerald-500)}.output-error{color:var(--red-500)}.output-info{color:var(--text-secondary)}.submit-result{padding:1rem;border-radius:var(--radius-md);margin-bottom:.5rem}.submit-result.pass{background:#10b9811a;border:1px solid rgba(16,185,129,.3)}.submit-result.fail{background:#ef44441a;border:1px solid rgba(239,68,68,.3)}.editor-notes-textarea{width:100%;height:100%;min-height:100px;background:transparent;border:none;color:var(--text-primary);font-family:var(--font-sans);font-size:.9rem;line-height:1.6;resize:none;outline:none;padding:0}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}.course-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;padding:2rem 1.5rem}.course-icon{font-size:2.5rem;margin-bottom:.25rem}.course-card h3{font-size:1.05rem;font-weight:600;text-transform:capitalize}.course-meta{font-size:.85rem;color:var(--text-muted)}/**
 * Copyright (c) 2014 The xterm.js authors. All rights reserved.
 * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)
 * https://github.com/chjj/term.js
 * @license MIT
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 *
 * Originally forked from (with the author's permission):
 *   Fabrice Bellard's javascript vt100 for jslinux:
 *   http://bellard.org/jslinux/
 *   Copyright (c) 2011 Fabrice Bellard
 *   The original design remains. The terminal itself
 *   has been extended to include xterm CSI codes, among
 *   other features.
 */.xterm{cursor:text;position:relative;user-select:none;-ms-user-select:none;-webkit-user-select:none}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{position:absolute;top:0;z-index:5}.xterm .xterm-helper-textarea{padding:0;border:0;margin:0;position:absolute;opacity:0;left:-9999em;top:0;width:0;height:0;z-index:-5;white-space:nowrap;overflow:hidden;resize:none}.xterm .composition-view{background:#000;color:#fff;display:none;position:absolute;white-space:nowrap;z-index:1}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{background-color:#000;overflow-y:scroll;cursor:default;position:absolute;right:0;left:0;top:0;bottom:0}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{position:absolute;left:0;top:0}.xterm-char-measure-element{display:inline-block;visibility:hidden;position:absolute;top:0;left:-9999em;line-height:normal}.xterm.enable-mouse-events{cursor:default}.xterm.xterm-cursor-pointer,.xterm .xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility:not(.debug),.xterm .xterm-message{position:absolute;left:0;top:0;bottom:0;right:0;z-index:10;color:transparent;pointer-events:none}.xterm .xterm-accessibility-tree:not(.debug) *::selection{color:transparent}.xterm .xterm-accessibility-tree{font-family:monospace;-webkit-user-select:text;user-select:text;white-space:pre}.xterm .xterm-accessibility-tree>div{transform-origin:left;width:fit-content}.xterm .live-region{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{text-decoration:double underline}.xterm-underline-3{text-decoration:wavy underline}.xterm-underline-4{text-decoration:dotted underline}.xterm-underline-5{text-decoration:dashed underline}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:overline underline}.xterm-overline.xterm-underline-2{text-decoration:overline double underline}.xterm-overline.xterm-underline-3{text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{z-index:6;position:absolute}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{z-index:8;position:absolute;top:0;right:0;pointer-events:none}.xterm-decoration-top{z-index:2;position:relative}.xterm .xterm-scrollable-element>.scrollbar{cursor:default}.xterm .xterm-scrollable-element>.scrollbar>.scra{cursor:pointer;font-size:11px!important}.xterm .xterm-scrollable-element>.visible{opacity:1;background:#0000;transition:opacity .1s linear;z-index:11}.xterm .xterm-scrollable-element>.invisible{opacity:0;pointer-events:none}.xterm .xterm-scrollable-element>.invisible.fade{transition:opacity .8s linear}.xterm .xterm-scrollable-element>.shadow{position:absolute;display:none}.xterm .xterm-scrollable-element>.shadow.top{display:block;top:0;left:3px;height:3px;width:100%;box-shadow:var(--vscode-scrollbar-shadow, #000) 0 6px 6px -6px inset}.xterm .xterm-scrollable-element>.shadow.left{display:block;top:3px;left:0;height:100%;width:3px;box-shadow:var(--vscode-scrollbar-shadow, #000) 6px 0 6px -6px inset}.xterm .xterm-scrollable-element>.shadow.top-left-corner{display:block;top:0;left:0;height:3px;width:3px}.xterm .xterm-scrollable-element>.shadow.top.left{box-shadow:var(--vscode-scrollbar-shadow, #000) 6px 0 6px -6px inset}.reader-layout{display:flex;height:calc(100vh + -0px);overflow:hidden;margin:-2rem}.reader-sidebar{width:240px;min-width:200px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.reader-sidebar-header{padding:1rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:.5rem}.reader-sidebar-header h3{font-size:.95rem;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reader-file-list{flex:1;overflow-y:auto;padding:.5rem}.reader-file-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.85rem;text-align:left;transition:all var(--transition-fast)}.reader-file-item:hover{background:var(--bg-input);color:var(--text-primary)}.reader-file-item.active{background:var(--bg-input-focus);color:var(--text-accent);font-weight:600}.reader-file-icon{font-size:1rem;flex-shrink:0}.reader-file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reader-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:300px}.reader-toolbar{display:flex;align-items:center;padding:.5rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);gap:.5rem}.reader-filename{flex:1;font-family:var(--font-mono);font-size:.85rem;color:var(--text-secondary)}.reader-modified{color:var(--amber-500);font-style:italic}.reader-toolbar .btn{font-size:.8rem;padding:.4rem .9rem}.reader-editor{flex:1;min-height:200px;overflow:hidden}.reader-drag-divider{height:6px;background:var(--bg-secondary);border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);cursor:row-resize;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--transition-fast)}.reader-drag-divider:hover{background:var(--bg-input-focus)}.reader-drag-handle{width:40px;height:3px;background:var(--text-muted);border-radius:2px;opacity:.5}.reader-drag-divider:hover .reader-drag-handle{opacity:1;background:var(--text-accent)}.reader-terminal-panel{display:flex;flex-direction:column;background:#0f0f1a;flex-shrink:0;overflow:hidden}.reader-terminal-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.35rem .75rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.reader-terminal-label{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.reader-autosync-badge{display:inline-block;margin-left:.5rem;padding:.1rem .4rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--emerald-500);background:#10b9811a;border:1px solid rgba(16,185,129,.2);border-radius:var(--radius-full)}.reader-terminal-actions{display:flex;gap:.5rem}.btn-sm{font-size:.75rem!important;padding:.25rem .6rem!important}.reader-terminal-xterm{flex:1;padding:.5rem;overflow:hidden}.reader-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.ghci-page{display:flex;flex-direction:column;gap:1rem;max-width:100%}.ghci-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.ghci-header-left{display:flex;align-items:center;gap:1rem}.ghci-header-left h1{font-size:1.5rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ghci-status{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:600;padding:.3rem .75rem;border-radius:var(--radius-full)}.ghci-status-dot{width:8px;height:8px;border-radius:50%;animation:pulse 2s ease-in-out infinite}.ghci-status.connected{background:#10b98126;color:var(--emerald-500)}.ghci-status.connected .ghci-status-dot{background:var(--emerald-500)}.ghci-status.connecting{background:#f59e0b26;color:var(--amber-500)}.ghci-status.connecting .ghci-status-dot{background:var(--amber-500)}.ghci-status.disconnected{background:#ef444426;color:var(--red-500)}.ghci-status.disconnected .ghci-status-dot{background:var(--red-500);animation:none}.ghci-terminal-container{padding:.75rem;min-height:500px;display:flex}.ghci-terminal{flex:1;min-height:480px}.ghci-terminal .xterm{height:100%}.ghci-info{display:flex;gap:1.5rem;font-size:.8rem;color:var(--text-muted);padding:.5rem 0}.ghci-info span{display:inline-flex;align-items:center;gap:.3rem}.exam-running{display:flex;flex-direction:column;height:100vh;overflow:hidden;margin:-2rem}.exam-topbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.exam-topbar-left{display:flex;align-items:center;gap:.75rem}.exam-type-badge{background:var(--text-accent);color:#fff;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.7rem;font-weight:700;letter-spacing:.05em}.exam-progress{color:var(--text-secondary);font-size:.85rem}.exam-timer{font-family:var(--font-mono);font-size:1.1rem;font-weight:700;color:var(--text-primary)}.exam-timer.low-time{color:var(--red-500);animation:pulse 1s infinite}.exam-topbar-right{display:flex;align-items:center;gap:.5rem}.exam-questions-nav{display:flex;gap:.25rem;padding:.5rem 1rem;background:var(--bg-primary);border-bottom:1px solid var(--border-color);flex-wrap:wrap;flex-shrink:0}.exam-q-btn{width:32px;height:32px;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast)}.exam-q-btn.active{background:var(--text-accent);color:#fff;border-color:var(--text-accent)}.exam-q-btn.answered:not(.active){background:#10b98126;border-color:var(--emerald-500);color:var(--emerald-500)}.exam-workspace{flex:1;display:flex;flex-direction:column;overflow:hidden}.exam-description{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);flex-shrink:0}.exam-description h3{font-size:1rem;margin-bottom:.25rem;display:inline;margin-right:.5rem}.exam-description p{color:var(--text-secondary);font-size:.85rem;margin-top:.25rem}.exam-editor{flex:1;min-height:150px;overflow:hidden}.exam-drag-divider{height:6px;background:var(--bg-secondary);border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);cursor:row-resize;display:flex;align-items:center;justify-content:center;flex-shrink:0}.exam-drag-divider:hover{background:var(--bg-input-focus)}.exam-drag-handle{width:40px;height:3px;background:var(--text-muted);border-radius:2px;opacity:.5}.exam-drag-divider:hover .exam-drag-handle{opacity:1;background:var(--text-accent)}.exam-terminal-panel{display:flex;flex-direction:column;background:#0f0f1a;flex-shrink:0;overflow:hidden}.exam-terminal-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.35rem .75rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.exam-terminal-label{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.exam-autosync-badge{display:inline-block;margin-left:.5rem;padding:.1rem .4rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--emerald-500);background:#10b9811a;border:1px solid rgba(16,185,129,.2);border-radius:var(--radius-full)}.exam-terminal-actions{display:flex;gap:.5rem}.exam-terminal-xterm{flex:1;padding:.5rem;overflow:hidden}.exam-setup{max-width:480px;margin:0 auto;padding:2rem}.exam-setup h3{margin-bottom:1.5rem}.exam-setup-fields{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.exam-field label{display:block;font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:.4rem}.exam-field select,.exam-field input{width:100%;padding:.6rem .8rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem}.exam-results{max-width:600px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.exam-score{text-align:center;padding:2rem}.exam-score-value{font-size:3rem;font-weight:800;color:var(--text-accent)}.exam-score-detail{color:var(--text-secondary);margin-top:.5rem}.exam-results-list{padding:1.5rem}.exam-results-list h3{margin-bottom:1rem}.exam-result-item{display:flex;align-items:center;gap:.75rem;padding:.6rem 0;border-bottom:1px solid var(--border-color)}.exam-result-item:last-child{border-bottom:none}.exam-result-num{font-weight:700;color:var(--text-muted);width:2rem}.exam-result-title{flex:1;font-size:.9rem}.profile-grid{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;max-width:1000px;margin:0 auto}@media(max-width:768px){.profile-grid{grid-template-columns:1fr}}.profile-card{position:relative}.profile-card-inner{display:flex;flex-direction:column;align-items:center;text-align:center}.profile-edit-btn{position:absolute;top:1rem;right:1rem;width:32px;height:32px;border-radius:var(--radius-full);background:var(--bg-input);display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:all var(--transition-fast)}.profile-edit-btn:hover{background:var(--bg-input-focus);transform:scale(1.1)}.profile-avatar{width:80px;height:80px;border-radius:var(--radius-full);background:var(--gradient-cool);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:2rem;margin-bottom:.75rem;box-shadow:0 4px 15px #6366f14d}.profile-name{font-size:1.25rem;font-weight:700;margin-bottom:.15rem}.profile-meta{font-size:.8rem;color:var(--text-muted);margin-bottom:1rem}.profile-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;width:100%;margin-bottom:1.25rem}.profile-stat-box{display:flex;flex-direction:column;align-items:center;padding:.6rem .5rem;background:var(--bg-input);border-radius:var(--radius-sm);border:1px solid var(--border-color)}.profile-stat-value{font-weight:800;font-size:1.15rem}.profile-stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.profile-about{width:100%;text-align:left}.profile-section-label{display:block;font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.3rem;margin-top:.75rem}.profile-bio{font-size:.9rem;color:var(--text-secondary);line-height:1.5}.profile-location{font-size:.9rem;color:var(--text-secondary)}.profile-edit-form{width:100%;text-align:left}.profile-field{margin-bottom:.75rem}.profile-field label{display:block;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.3rem}.profile-field input,.profile-field textarea{width:100%}.profile-form-actions{display:flex;gap:.5rem;margin-top:.75rem}.profile-message{padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:.75rem}.profile-message.success{background:#10b9811a;color:var(--emerald-500);border:1px solid rgba(16,185,129,.2)}.profile-message.error{background:#ef44441a;color:var(--red-500);border:1px solid rgba(239,68,68,.2)}.profile-right{display:flex;flex-direction:column;gap:1.5rem}.profile-xp-card{padding:1.25rem 1.5rem}.profile-xp-card:hover{transform:none}.profile-xp-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.75rem}.profile-xp-title{font-weight:700;font-size:1rem}.profile-xp-numbers{font-family:var(--font-mono);font-size:.85rem;color:var(--text-muted)}.profile-xp-bar{height:10px;background:var(--bg-input);border-radius:var(--radius-full);overflow:hidden}.profile-xp-fill{height:100%;background:var(--gradient-warm);border-radius:var(--radius-full);transition:width .6s cubic-bezier(.4,0,.2,1);min-width:4px}.profile-achievements-card{padding:1.25rem 1.5rem}.profile-achievements-card:hover{transform:none}.profile-achievements-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem}.profile-achievements-header h3{font-size:1rem;font-weight:700}.profile-achievements-count{font-size:.85rem;color:var(--text-muted)}.profile-achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.profile-achievement{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1rem .5rem;border-radius:var(--radius-md);text-align:center;transition:all var(--transition-fast);border:1px solid var(--border-color)}.profile-achievement.unlocked{background:#f59e0b14;border-color:#f59e0b33}.profile-achievement.locked{opacity:.4;filter:grayscale(.8)}.profile-achievement.locked:hover{opacity:.6}.profile-achievement-icon{font-size:1.5rem}.profile-achievement-name{font-size:.75rem;font-weight:600;color:var(--text-secondary);line-height:1.2}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}.admin-stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;text-align:center;transition:all var(--transition-base)}.admin-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.admin-stat-value{display:block;font-size:2rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-stat-label{font-size:.8rem;color:var(--text-muted);font-weight:500}.admin-tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.admin-tab{padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;color:var(--text-muted);border-bottom:2px solid transparent;transition:all var(--transition-fast)}.admin-tab:hover{color:var(--text-secondary)}.admin-tab.active{color:var(--text-accent);border-bottom-color:var(--blue-500)}.admin-table{overflow-x:auto}.admin-table table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-table th,.admin-table td{padding:.6rem .85rem;text-align:left;border-bottom:1px solid var(--border-color)}.admin-table th{font-weight:600;color:var(--text-secondary);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}.admin-table tr:hover td{background:var(--bg-input)}.admin-cell-title{font-weight:600;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-toolbar{display:flex;justify-content:flex-end;margin-bottom:1rem}.admin-row-actions{display:flex;gap:.35rem;white-space:nowrap}.btn-sm{padding:.3rem .55rem;font-size:.8rem;min-width:32px}.admin-form-card{margin-bottom:1.25rem}.admin-form-card h3{margin-bottom:1rem;font-size:1.1rem;font-weight:700}.admin-form{display:flex;flex-direction:column;gap:1rem}.admin-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.admin-field{display:flex;flex-direction:column;gap:.35rem}.admin-field label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.admin-field textarea{resize:vertical;min-height:60px}.admin-field textarea.code-textarea{font-family:var(--font-mono);font-size:.85rem;line-height:1.5;-moz-tab-size:2;tab-size:2;white-space:pre}.admin-form-actions{display:flex;gap:.75rem;padding-top:.5rem}.admin-color-input{display:flex;align-items:center;gap:.5rem}.admin-color-input input[type=color]{width:36px;height:36px;padding:2px;border-radius:var(--radius-sm);cursor:pointer}.admin-color-value{font-family:var(--font-mono);font-size:.85rem;color:var(--text-secondary)}.admin-color-preview{display:inline-block;width:14px;height:14px;border-radius:3px;vertical-align:middle;margin-right:.35rem;border:1px solid var(--border-color)}.admin-color-hex{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted)}.admin-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--red-500);padding:.6rem 1rem;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:.75rem}.admin-empty{text-align:center;padding:3rem;color:var(--text-muted)}.admin-table .problem-topic{display:inline-block;padding:.15rem .5rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.admin-table code{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);background:var(--bg-input);padding:.1rem .35rem;border-radius:3px}:root{color-scheme:light;--bg-primary: #f0f4fa;--bg-secondary: #ffffff;--bg-tertiary: #e8eef8;--bg-card: rgba(255, 255, 255, .95);--bg-card-hover: rgba(255, 255, 255, 1);--bg-input: rgba(74, 124, 247, .04);--bg-input-focus: rgba(74, 124, 247, .08);--text-primary: #1a2233;--text-secondary: #5a6578;--text-muted: #8d95a3;--text-accent: #4a7cf7;--border-color: rgba(74, 124, 247, .1);--border-focus: rgba(74, 124, 247, .4);--blue-400: #5b8df8;--blue-500: #4a7cf7;--blue-600: #3a6ae5;--blue-700: #2a58d3;--indigo-500: #6366f1;--indigo-600: #4f46e5;--cyan-500: #06b6d4;--emerald-500: #10b981;--amber-500: #f59e0b;--rose-500: #f43f5e;--red-500: #ef4444;--gradient-primary: linear-gradient(135deg, #4a7cf7 0%, #6366f1 100%);--gradient-warm: linear-gradient(135deg, #f59e0b 0%, #ef4444 100%);--gradient-cool: linear-gradient(135deg, #4a7cf7 0%, #06b6d4 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #06b6d4 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px rgba(74, 124, 247, .1);--font-sans: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--sidebar-width: 240px;--sidebar-collapsed: 64px;--header-height: 0px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{color-scheme:dark;--bg-primary: #0c1220;--bg-secondary: #151e30;--bg-tertiary: #1a2540;--bg-card: rgba(21, 30, 48, .9);--bg-card-hover: rgba(21, 30, 48, 1);--bg-input: rgba(255, 255, 255, .05);--bg-input-focus: rgba(255, 255, 255, .08);--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #64748b;--text-accent: #5b8df8;--border-color: rgba(255, 255, 255, .08);--border-focus: rgba(91, 141, 248, .5);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(91, 141, 248, .15)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}#root{min-height:100vh;display:flex}a{color:var(--text-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--blue-400)}button{font-family:var(--font-sans);cursor:pointer;border:none;outline:none;background:none;font-size:inherit}input,textarea,select{font-family:var(--font-sans);font-size:inherit;color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:.6rem .9rem;outline:none;transition:all var(--transition-fast)}input:focus,textarea:focus,select:focus{background:var(--bg-input-focus);border-color:var(--border-focus);box-shadow:0 0 0 3px #4a7cf71a}select option{background:var(--bg-secondary);color:var(--text-primary)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}.glass{background:var(--bg-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;transition:all var(--transition-base)}.card:hover{background:var(--bg-card-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1.2rem;border-radius:var(--radius-sm);font-weight:600;font-size:.875rem;letter-spacing:.01em;transition:all var(--transition-fast);white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 2px 8px #4a7cf74d}.btn-primary:hover{box-shadow:0 4px 16px #4a7cf780;filter:brightness(1.1)}.btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-input-focus);border-color:var(--border-focus)}.btn-danger{background:var(--red-500);color:#fff}.btn-danger:hover{background:#dc2626}.btn-success{background:var(--emerald-500);color:#fff}.btn-success:hover{background:#059669}.btn-ghost{color:var(--text-secondary);background:transparent}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-input)}.btn-icon{padding:.5rem;border-radius:var(--radius-sm);width:36px;height:36px}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;letter-spacing:.02em}.badge-easy{background:#10b98126;color:var(--emerald-500)}.badge-medium{background:#f59e0b26;color:var(--amber-500)}.badge-hard{background:#ef444426;color:var(--red-500)}.badge-pass{background:#10b98126;color:var(--emerald-500)}.badge-fail{background:#ef444426;color:var(--red-500)}.badge-error{background:#ef444426;color:var(--rose-500)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn .4s ease-out}.animate-slide-left{animation:slideInLeft .3s ease-out}.animate-pulse{animation:pulse 2s ease-in-out infinite}.spinner{width:24px;height:24px;border:3px solid var(--border-color);border-top-color:var(--blue-500);border-radius:50%;animation:spin .8s linear infinite}.loading-page{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%}.app-layout{display:flex;min-height:100vh;width:100%}.main-content{flex:1;margin-left:var(--sidebar-width);padding:2rem;min-height:100vh;transition:margin-left var(--transition-base);max-width:calc(100% - var(--sidebar-width))}.main-content.collapsed{margin-left:var(--sidebar-collapsed);max-width:calc(100% - var(--sidebar-collapsed))}.page{max-width:1200px;margin:0 auto;animation:fadeIn .4s ease-out}.page-header{margin-bottom:2rem}.page-header h1{font-size:1.75rem;font-weight:700;margin-bottom:.5rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-header p{color:var(--text-secondary)}
