:root{--bg:#0f1117;--surface:#1a1d27;--surface2:#22263a;--border:#2e3250;--accent:#6366f1;--accent-hover:#4f46e5;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--text:#e8eaf6;--text-muted:#8b91b0;--radius:12px;--shadow:0 4px 24px #0006}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);height:100%;color:var(--text);font-family:Inter,system-ui,sans-serif;font-size:15px;line-height:1.6}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.login-page{background:radial-gradient(ellipse at 60% 30%, #1e2040 0%, var(--bg) 70%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:420px;box-shadow:var(--shadow);padding:2.5rem}.login-logo{text-align:center;margin-bottom:2rem}.login-logo .logo-icon{margin-bottom:.5rem;font-size:3rem;display:block}.login-logo h1{color:var(--text);font-size:1.6rem;font-weight:700}.login-logo p{color:var(--text-muted);font-size:.9rem}.login-form{flex-direction:column;gap:1.2rem;display:flex}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:600}.form-group input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:.7rem 1rem;font-size:1rem;transition:border-color .2s}.form-group input:focus{border-color:var(--accent);outline:none}.login-error{color:#fca5a5;background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;padding:.6rem 1rem;font-size:.9rem}.login-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.8rem;font-size:1rem;font-weight:600;transition:background .2s,transform .1s}.login-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.82rem}.app-shell{grid-template-columns:220px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;gap:.3rem;height:100vh;padding:1.5rem 1rem;display:flex;position:sticky;top:0}.sidebar-brand{color:var(--accent);letter-spacing:.02em;padding:.5rem .75rem 1.5rem;font-size:1rem;font-weight:700}.sidebar-link{color:var(--text-muted);border-radius:8px;align-items:center;gap:.6rem;padding:.65rem .75rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.sidebar-link:hover,.sidebar-link.active{background:var(--surface2);color:var(--text);text-decoration:none}.sidebar-link.active{color:var(--accent)}.sidebar-spacer{flex:1}.sidebar-signout{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:.6rem;width:100%;padding:.65rem .75rem;font-size:.9rem;font-weight:500;transition:background .15s,color .15s;display:flex}.sidebar-signout:hover{color:var(--danger);background:#ef44441a}.main-content{padding:2rem 2.5rem;overflow-y:auto}.page-header{margin-bottom:1.5rem}.page-header h1{font-size:1.6rem;font-weight:700}.page-header p{color:var(--text-muted);margin-top:.25rem;font-size:.9rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.card-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem}.stat-card .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.stat-card .value{margin-top:.25rem;font-size:2rem;font-weight:700;line-height:1.2}.stat-card .value.accent{color:var(--accent)}.stat-card .value.success{color:var(--success)}.stat-card .value.warning{color:var(--warning)}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.9rem}thead th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);padding:.6rem 1rem;font-size:.78rem;font-weight:600}tbody td{border-bottom:1px solid var(--border);padding:.75rem 1rem}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--surface2)}.badge{border-radius:99px;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-draft{color:var(--text-muted);background:#8b91b026}.badge-active{color:var(--success);background:#22c55e26}.badge-closed{color:var(--accent);background:#6366f126}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.4rem;padding:.55rem 1rem;font-size:.9rem;font-weight:600;transition:opacity .15s,transform .1s;display:inline-flex}.btn:hover{opacity:.9;transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--accent);color:#fff}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-ghost{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.input,select,textarea{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:8px;width:100%;padding:.65rem .9rem;font-size:.9rem;transition:border-color .2s}.input:focus,select:focus,textarea:focus{border-color:var(--accent);outline:none}select option{background:var(--surface)}.score-bar-container{align-items:center;gap:.75rem;display:flex}.score-bar-track{background:var(--bg);border-radius:99px;flex:1;height:8px;overflow:hidden}.score-bar-fill{background:var(--accent);border-radius:99px;height:100%;transition:width .4s}.score-bar-fill.good{background:var(--success)}.score-bar-fill.average{background:var(--warning)}.score-bar-fill.poor{background:var(--danger)}.q-chip{border:1px solid;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:700;display:inline-flex}.q-chip.correct{border-color:var(--success);color:var(--success);background:#22c55e26}.q-chip.incorrect{border-color:var(--danger);color:var(--danger);background:#ef444426}.q-chip.partial{border-color:var(--warning);color:var(--warning);background:#f59e0b26}.q-chip.unattempted{border-color:var(--border);color:var(--text-muted);background:#8b91b01a}.section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border);margin:1.5rem 0 .75rem;padding-bottom:.4rem;font-size:.8rem;font-weight:600}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 2rem}.empty-state .icon{margin-bottom:.5rem;font-size:3rem;display:block}.empty-state p{font-size:.95rem}.cbt-shell{grid-template-columns:1fr 260px;height:100vh;display:grid;overflow:hidden}.cbt-timer{background:var(--surface2);text-align:center;border-radius:8px;padding:.75rem 1rem}.cbt-timer .time-display{font-variant-numeric:tabular-nums;font-size:1.6rem;font-weight:700}.cbt-timer .time-display.warning{color:var(--warning)}.cbt-timer .time-display.danger{color:var(--danger)}.q-grid{grid-template-columns:repeat(5,1fr);gap:.4rem;display:grid}.q-btn{border:1px solid var(--border);background:var(--bg);width:36px;height:36px;color:var(--text-muted);cursor:pointer;border-radius:6px;font-size:.78rem;font-weight:600;transition:background .15s,color .15s}.q-btn.answered{background:var(--success);border-color:var(--success);color:#fff}.q-btn.review{background:var(--warning);border-color:var(--warning);color:#fff}.q-btn.visited{background:var(--surface2);color:var(--text)}.q-btn.current{outline:2px solid var(--accent);outline-offset:1px}@media (max-width:768px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.main-content{padding:1.25rem}.cbt-shell{grid-template-columns:1fr}.cbt-sidebar{display:none}}.cbt-container{background:var(--bg);flex-direction:column;height:100vh;display:flex;overflow:hidden}.cbt-topbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:1rem;padding:.75rem 1.5rem;display:flex}.cbt-title{white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:1rem;font-weight:700;overflow:hidden}.cbt-timer{font-variant-numeric:tabular-nums;background:var(--surface2);border:1px solid var(--border);letter-spacing:.05em;border-radius:8px;padding:.3rem 1rem;font-size:1.3rem;font-weight:700}.cbt-timer.timer-warning{color:var(--warning);border-color:var(--warning)}.cbt-timer.timer-critical{color:var(--danger);border-color:var(--danger);animation:1s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.cbt-submit-btn{flex-shrink:0}.cbt-section-tabs{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;gap:.25rem;padding:.5rem 1.5rem;display:flex;overflow-x:auto}.section-tab{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:.4rem 1rem;font-size:.85rem;font-weight:500;transition:all .15s}.section-tab:hover,.section-tab.active{background:var(--surface2);color:var(--text)}.section-tab.active{color:var(--accent);border-color:var(--accent)}.cbt-main{flex:1;grid-template-columns:1fr 260px;display:grid;overflow:hidden}.cbt-question-area{flex-direction:column;gap:1rem;padding:1.5rem;display:flex;overflow-y:auto}.cbt-q-header{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.q-serial{color:var(--accent);font-size:1.1rem;font-weight:700}.q-type-tag{color:var(--accent);background:#6366f11a;border:1px solid #6366f14d;border-radius:99px;padding:.1rem .6rem;font-size:.72rem;font-weight:600}.q-tag{background:var(--surface2);color:var(--text-muted);border-radius:99px;padding:.1rem .6rem;font-size:.72rem}.q-img-wrap{background:var(--surface);border:1px solid var(--border);border-radius:10px;justify-content:center;align-items:center;min-height:80px;display:flex;overflow:hidden}.q-img{object-fit:contain;max-width:100%;max-height:420px;display:block}.q-no-img{color:var(--text-muted);text-align:center;padding:1.5rem;font-size:.85rem}.cbt-answer-area{flex:1}.option-list{flex-direction:column;gap:.5rem;display:flex}.option-label{border:1px solid var(--border);background:var(--surface);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:.75rem;padding:.7rem 1rem;transition:all .15s;display:flex}.option-label:hover{border-color:var(--accent);background:var(--surface2)}.option-label.selected{border-color:var(--accent);background:#6366f11a}.option-box{border:2px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:700;transition:all .15s;display:flex}.option-box.selected{border-color:var(--accent);background:var(--accent);color:#fff}.option-chr{color:var(--text-muted);font-size:.9rem}.numeric-input-wrap{flex-direction:column;gap:.75rem;display:flex}.numeric-label{color:var(--text-muted);font-size:.85rem}.big-number-input{background:var(--surface);border:2px solid var(--border);color:var(--text);text-align:center;border-radius:10px;width:100%;max-width:280px;padding:1rem 1.25rem;font-size:1.6rem;font-weight:700;transition:border-color .2s}.big-number-input:focus{border-color:var(--accent);outline:none}.matrix-wrap{flex-direction:column;gap:.75rem;display:flex}.matrix-table{border-collapse:collapse;font-size:.9rem}.matrix-table th,.matrix-table td{border:1px solid var(--border);text-align:center;padding:.5rem .75rem}.matrix-table thead th{background:var(--surface2);font-weight:600}.matrix-row-label{background:var(--surface);font-weight:700}.matrix-cb{cursor:pointer;width:18px;height:18px;accent-color:var(--accent)}.cbt-controls{border-top:1px solid var(--border);flex-wrap:wrap;gap:.5rem;padding-top:1rem;display:flex}.cbt-sidebar{background:var(--surface);border-left:1px solid var(--border);flex-direction:column;gap:.75rem;padding:1rem;display:flex;overflow-y:auto}.cbt-sidebar-header{border-bottom:1px solid var(--border);padding-bottom:.75rem}.nav-legend{color:var(--text-muted);flex-wrap:wrap;gap:.4rem;font-size:.72rem;display:flex}.nav-legend-item{align-items:center;gap:.3rem;display:flex}.nav-section-group{flex-direction:column;gap:.4rem;display:flex}.nav-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.nav-grid{grid-template-columns:repeat(5,1fr);gap:.3rem;display:grid}.nav-btn{aspect-ratio:1;border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text-muted);cursor:pointer;border-radius:5px;justify-content:center;align-items:center;font-size:.7rem;font-weight:600;transition:all .1s;display:flex}.nav-btn.answered{background:var(--success);border-color:var(--success);color:#fff}.nav-btn.answered-marked{background:var(--success);border-color:var(--warning);color:#fff;box-shadow:0 0 0 2px var(--warning)}.nav-btn.marked{background:var(--warning);border-color:var(--warning);color:#fff}.nav-btn.visited{background:var(--surface2);border-color:var(--border);color:var(--text)}.nav-btn.not-visited{background:var(--bg);border-color:var(--border);color:var(--text-muted)}.nav-btn.current{outline:2px solid var(--accent);outline-offset:1px}.modal-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:400px;box-shadow:var(--shadow);padding:2rem}.submit-stat{background:var(--surface2);border-radius:6px;justify-content:space-between;align-items:center;padding:.5rem .75rem;display:flex}.ss-label{color:var(--text-muted);font-size:.88rem}.ss-label.ss-answered{color:var(--success)}.ss-label.ss-marked{color:var(--warning)}.ss-label.ss-notvisited{color:var(--text-muted)}.ss-val{font-size:1.1rem;font-weight:700}.btn-warning{background:var(--warning);color:#fff}@media (max-width:768px){.cbt-main{grid-template-columns:1fr}.cbt-sidebar{display:none}.cbt-section-tabs{padding:.5rem}}
