@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Merriweather:wght@700&display=swap";
:root{--indigo:#4338ca;--indigo-dark:#312e81;--indigo-light:#6366f1;--indigo-pale:#eef2ff;--amber:#f59e0b;--amber-light:#fef3c7;--bg:#fafaf7;--surface:#fff;--surface2:#f3f4ff;--border:#e5e7eb;--accent:var(--indigo);--accent-hover:var(--indigo-dark);--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--text:#1f2937;--text-muted:#6b7280;--radius:12px;--shadow:0 4px 24px #4338ca14;--shadow-hover:0 12px 40px #4338ca29;--transition:.22s cubic-bezier(.4, 0, .2, 1)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--indigo-light);border-radius:99px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;font-size:15px;line-height:1.6}h1,h2,h3{font-family:Merriweather,serif}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.login-page{background:var(--bg);grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.login-brand-panel{background:linear-gradient(145deg, var(--indigo-dark) 0%, var(--indigo) 100%);flex-direction:column;justify-content:center;padding:4rem;display:flex;position:relative;overflow:hidden}.login-brand-panel:after{content:"";pointer-events:none;background:radial-gradient(circle at 80% 20%,#f59e0b26 0%,#0000 60%);position:absolute;inset:0}.login-brand-logo{align-items:center;gap:10px;margin-bottom:2.5rem;display:flex}.login-brand-dot{background:var(--amber);border-radius:50%;width:12px;height:12px}.login-brand-name{color:#fff;font-family:Inter,sans-serif;font-size:1.15rem;font-weight:800}.login-brand-panel h2{color:#fff;margin-bottom:1.25rem;font-family:Merriweather,serif;font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.3}.login-brand-panel p{color:#c7d2fe;max-width:360px;margin-bottom:2.5rem;font-size:1rem;line-height:1.7}.login-brand-chips{flex-wrap:wrap;gap:10px;display:flex}.login-brand-chip{color:#e0e7ff;background:#ffffff1a;border:1px solid #ffffff2e;border-radius:99px;padding:6px 16px;font-size:.82rem;font-weight:600}.login-form-panel{background:var(--surface);justify-content:center;align-items:center;padding:2rem;display:flex}.login-card{width:100%;max-width:400px}.login-logo{margin-bottom:2.5rem}.login-logo h1{color:var(--indigo-dark);margin-bottom:4px;font-family:Merriweather,serif;font-size:1.5rem;font-weight:700}.login-logo p{color:var(--text-muted);font-family:Inter,sans-serif;font-size:.9rem}.login-logo .logo-icon{margin-bottom:.75rem;font-size:2.5rem;display:block}.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:.06em;font-size:.82rem;font-weight:700}.form-group input{background:var(--bg);border:1.5px solid var(--border);color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);border-radius:10px;padding:.75rem 1rem;font-family:Inter,sans-serif;font-size:1rem}.form-group input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #4338ca1f}.login-error{color:#dc2626;background:#ef444414;border:1px solid #ef444440;border-radius:8px;padding:.65rem 1rem;font-size:.88rem}.login-btn{background:var(--indigo);color:#fff;cursor:pointer;transition:background var(--transition), transform var(--transition), box-shadow var(--transition);border:none;border-radius:99px;padding:.9rem;font-size:1rem;font-weight:700;box-shadow:0 4px 16px #4338ca47}.login-btn:hover:not(:disabled){background:var(--indigo-dark);transform:translateY(-2px);box-shadow:0 8px 24px #4338ca59}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.82rem}.login-back-link{color:var(--indigo);transition:color var(--transition);align-items:center;gap:6px;margin-bottom:2rem;font-size:.88rem;font-weight:600;text-decoration:none;display:inline-flex}.login-back-link:hover{color:var(--indigo-dark);text-decoration:none}@media (max-width:768px){.login-page{grid-template-columns:1fr}.login-brand-panel{display:none}.login-form-panel{align-items:flex-start;padding:3rem 1.25rem 2rem}}.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(--indigo-dark);letter-spacing:.02em;align-items:center;gap:8px;padding:.5rem .75rem 1.5rem;font-size:1rem;font-weight:800;display:flex}.sidebar-brand-dot{background:var(--amber);border-radius:50%;flex-shrink:0;width:9px;height:9px}.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(--indigo-pale);color:var(--indigo-dark);text-decoration:none}.sidebar-link.active{color:var(--indigo);font-weight:600}.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}}
