:root{--c-bg: #f5f7fb;--c-bg-alt: #fff;--c-border: #e4e7ee;--c-border-strong: #cdd2dc;--c-text: #0f172a;--c-text-dim: #64748b;--c-primary: #1e40af;--c-primary-dark: #1e3a8a;--c-primary-light: #dbeafe;--c-success: #16a34a;--c-success-light: #dcfce7;--c-danger: #dc2626;--c-danger-light: #fee2e2;--c-warn: #b45309;--c-warn-light: #fef3c7;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow: 0 4px 20px rgba(15, 23, 42, .08);--radius: 10px}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--c-text);background:var(--c-bg);font-size:15px;line-height:1.45}a{color:var(--c-primary);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3{margin:0 0 8px}.auth-shell{min-height:100%;display:grid;place-items:center;padding:32px 16px;background:linear-gradient(135deg,#1e3a8a,#0ea5e9)}.auth-card{background:#fff;border-radius:14px;padding:32px;width:100%;max-width:420px;box-shadow:var(--shadow)}.auth-card h1{font-size:22px;margin-bottom:4px}.auth-card p.sub{color:var(--c-text-dim);margin:0 0 24px;font-size:14px}.auth-switch{text-align:center;margin-top:20px;color:var(--c-text-dim);font-size:13px}label.field{display:block;margin-bottom:14px}label.field span{display:block;font-size:13px;font-weight:600;color:var(--c-text);margin-bottom:6px}input,select,textarea{width:100%;font:inherit;padding:10px 12px;border-radius:var(--radius);border:1px solid var(--c-border-strong);background:#fff;color:var(--c-text);transition:border-color .15s,box-shadow .15s}textarea{resize:vertical}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px #1e40af26}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:var(--radius);border:1px solid transparent;background:var(--c-primary);color:#fff;font:inherit;font-weight:600;cursor:pointer;transition:background .15s,transform .05s}.btn:hover{background:var(--c-primary-dark)}.btn:active{transform:translateY(1px)}.btn:disabled{background:#94a3b8;cursor:not-allowed}.btn.secondary{background:#fff;color:var(--c-text);border-color:var(--c-border-strong)}.btn.secondary:hover{background:#f1f5f9}.btn.danger{background:var(--c-danger)}.btn.danger:hover{background:#b91c1c}.btn.success{background:var(--c-success)}.btn.success:hover{background:#15803d}.btn.ghost{background:transparent;color:var(--c-primary);border-color:transparent;padding:4px 8px}.btn.full{width:100%}.alert{padding:10px 12px;border-radius:var(--radius);font-size:14px;margin-bottom:14px}.alert.error{background:var(--c-danger-light);color:var(--c-danger)}.alert.info{background:var(--c-primary-light);color:var(--c-primary-dark)}.alert.warn{background:var(--c-warn-light);color:var(--c-warn)}.alert.success{background:var(--c-success-light);color:var(--c-success)}.admin-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.admin-side{background:#0f172a;color:#e2e8f0;padding:20px 16px;display:flex;flex-direction:column}.admin-side .brand{font-weight:700;font-size:17px;color:#fff;padding:4px 8px 20px}.admin-side nav a{display:block;padding:10px 12px;color:#cbd5e1;border-radius:8px;margin-bottom:4px;font-weight:500}.admin-side nav a:hover{background:#1e293b;color:#fff;text-decoration:none}.admin-side nav a.active{background:var(--c-primary);color:#fff}.admin-side .bottom{margin-top:auto;padding-top:16px;border-top:1px solid #1e293b;font-size:13px;color:#94a3b8}.admin-main{padding:24px 32px;overflow:auto}.admin-main h2{font-size:24px}.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}.card{background:var(--c-bg-alt);border:1px solid var(--c-border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);margin-bottom:16px}.proctor-settings{border:1px solid var(--c-border);border-radius:var(--radius);padding:14px 16px;margin-bottom:16px;background:#f8fafc}.proctor-settings-title{font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--c-text-dim);margin-bottom:12px}.proctor-toggle{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px solid var(--c-border);cursor:pointer;-webkit-user-select:none;user-select:none}.proctor-toggle:last-child{border-bottom:none}.proctor-toggle input[type=checkbox]{display:none}.proctor-toggle-info{flex:1}.proctor-toggle-info span{display:block;font-weight:500}.proctor-toggle-info small{display:block;font-size:12px;color:var(--c-text-dim);margin-top:2px}.toggle-slider{flex-shrink:0;width:44px;height:24px;background:#cbd5e1;border-radius:999px;position:relative;transition:background .2s}.toggle-slider:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:left .2s;box-shadow:0 1px 3px #0003}.proctor-toggle input:checked~.toggle-slider{background:var(--c-primary)}.proctor-toggle input:checked~.toggle-slider:after{left:23px}.btn-clear-answer{margin-top:6px;padding:4px 12px;border-radius:6px;border:1px solid var(--c-danger);background:var(--c-danger-light);color:var(--c-danger);font-size:12px;cursor:pointer;transition:background .15s}.btn-clear-answer:hover{background:#fecaca}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px}.stat{background:#fff;padding:16px;border-radius:var(--radius);border:1px solid var(--c-border)}.stat .label{font-size:13px;color:var(--c-text-dim)}.stat .value{font-size:28px;font-weight:700;margin-top:4px}table.tbl{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--c-border)}table.tbl th,table.tbl td{padding:10px 12px;border-bottom:1px solid var(--c-border);text-align:left;vertical-align:middle}table.tbl tr:last-child td{border-bottom:none}table.tbl th{background:#f8fafc;font-weight:600;font-size:13px;color:var(--c-text-dim)}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:600}.badge.draft{background:#e2e8f0;color:#475569}.badge.active{background:var(--c-success-light);color:var(--c-success)}.badge.archived{background:var(--c-warn-light);color:var(--c-warn)}.badge.submitted{background:var(--c-success-light);color:var(--c-success)}.badge.in_progress{background:var(--c-primary-light);color:var(--c-primary-dark)}.badge.expired{background:var(--c-warn-light);color:var(--c-warn)}.badge.cancelled{background:var(--c-danger-light);color:var(--c-danger)}.row-actions button{margin-right:6px}.student-shell{min-height:100vh;background:var(--c-bg)}.student-top{background:#fff;border-bottom:1px solid var(--c-border);padding:12px 20px;display:flex;align-items:center;justify-content:space-between}.student-top .brand{font-weight:700;color:var(--c-primary)}.student-container{max-width:960px;margin:24px auto;padding:0 20px}.exam-card{background:#fff;border:1px solid var(--c-border);border-radius:12px;padding:20px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.exam-card h3{margin:0 0 6px}.exam-card .meta{color:var(--c-text-dim);font-size:13px;margin-bottom:12px}.exam-info-card{background:#fff;border:1px solid var(--c-border);border-radius:14px;padding:24px;margin-bottom:20px;box-shadow:var(--shadow-sm);transition:box-shadow .15s}.exam-info-card:hover{box-shadow:var(--shadow)}.exam-stat-chip{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;border:1px solid var(--c-border);background:#f8fafc;min-width:0}.exam-stat-icon{font-size:20px;flex-shrink:0}.exam-stat-label{font-size:11px;color:var(--c-text-dim);font-weight:500;margin-bottom:2px}.exam-stat-value{font-size:14px;font-weight:700}.exam-start-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;font-size:16px;font-weight:700;border-radius:12px;border:none;background:linear-gradient(135deg,#1e40af,#1d4ed8);color:#fff;cursor:pointer;box-shadow:0 4px 14px #1e40af59;transition:transform .12s,box-shadow .12s,opacity .12s;letter-spacing:.01em}.exam-start-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #1e40af73}.exam-start-btn:active:not(:disabled){transform:translateY(0)}.exam-start-btn:disabled{opacity:.6;cursor:not-allowed}.start-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.result-card{background:#fff;border:1px solid var(--c-border);border-radius:12px;padding:20px;margin-bottom:16px;box-shadow:var(--shadow-sm);transition:box-shadow .15s}.result-card:hover{box-shadow:var(--shadow)}.result-card-body{display:flex;align-items:center;gap:20px}.result-card-title{font-size:17px;font-weight:700;margin-bottom:4px}.result-card-meta{font-size:13px;color:var(--c-text-dim)}.result-pending{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-text-dim);font-style:italic}.pending-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--c-warn);animation:pendingPulse 1.4s ease-in-out infinite}@keyframes pendingPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.score-banner{border:1px solid var(--c-border);border-radius:16px;padding:24px 28px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;gap:20px}.score-banner-left{flex:1}.exam-run{min-height:100vh;background:#0f172a;color:#e2e8f0;display:flex;flex-direction:column}.exam-header{background:#111c33;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #1e293b;gap:12px;flex-wrap:wrap}.exam-header .title{font-weight:700}.exam-header .name{color:#94a3b8;font-size:13px}.exam-timer{font-variant-numeric:tabular-nums;font-weight:700;font-size:22px;padding:4px 12px;border-radius:8px;background:#1e293b}.exam-timer.warn{background:#713f12;color:#fcd34d}.exam-timer.crit{background:#7f1d1d;color:#fca5a5;animation:pulse 1s infinite}@keyframes pulse{50%{opacity:.55}}.exam-body{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:16px 24px;flex:1;max-width:1400px;margin:0 auto;width:100%}.exam-body.kazus-collapsed{grid-template-columns:1fr}@media (max-width: 1000px){.exam-body{grid-template-columns:1fr}}.exam-pane{background:#fff;color:var(--c-text);border-radius:12px;padding:18px 22px;overflow:auto;max-height:calc(100vh - 140px)}.exam-pane h3{font-size:18px;margin:0}.kazus-content{white-space:pre-wrap;font-size:15px;line-height:1.6}.kazus-panel-title,.questions-panel-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px}.kazus-toggle-btn{flex-shrink:0;padding:5px 14px;border-radius:8px;border:1px solid var(--c-border);background:#f1f5f9;color:var(--c-text-dim);font-size:13px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.kazus-toggle-btn:hover{background:#e2e8f0;color:var(--c-text)}.kazus-toggle-btn.open{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.kazus-toggle-btn.open:hover{opacity:.88}.answers .qblock{border:1px solid var(--c-border);border-radius:10px;padding:12px 14px;margin-bottom:14px}.answers .qtitle{font-weight:600;margin-bottom:8px}.answers textarea{min-height:220px;font-family:inherit;overflow-y:hidden;line-height:1.6}.answer-status{font-size:12px;color:var(--c-text-dim);margin-top:4px;text-align:right}.answer-status.saved{color:var(--c-success)}.answer-status.dirty{color:var(--c-warn)}.mc-option{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:8px;border:1px solid var(--c-border);margin-bottom:6px;cursor:pointer;background:#fff}.mc-option:hover{background:#f1f5f9}.mc-option.selected{background:var(--c-primary-light);border-color:var(--c-primary)}.mc-option input{margin-top:3px}.exam-footer{background:#111c33;border-top:1px solid #1e293b;padding:12px 24px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.exam-violations{color:#fcd34d;font-size:13px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172ad9;display:grid;place-items:center;z-index:9999;padding:16px}.overlay-card{background:#fff;color:var(--c-text);border-radius:12px;padding:28px;max-width:480px;width:100%;text-align:center}.overlay-card.alert{border-top:6px solid var(--c-danger)}.kbd{display:inline-block;padding:2px 6px;font-family:monospace;background:#f1f5f9;border:1px solid var(--c-border-strong);border-radius:4px;font-size:12px}.student-creds{background:#f0fdf4;border-radius:8px;padding:14px 16px;margin:12px 0;border:1px solid #bbf7d0;font-family:monospace;font-size:14px}.mini-code{font-family:monospace;background:#f1f5f9;padding:2px 8px;border-radius:4px;font-size:13px}.split-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.options-editor .opt-row{display:grid;grid-template-columns:auto 1fr auto;gap:8px;margin-bottom:6px;align-items:center}.help{font-size:12px;color:var(--c-text-dim);margin-top:6px}details.foldable{margin-bottom:12px;background:#fff;border:1px solid var(--c-border);border-radius:8px;padding:10px 14px}details.foldable summary{cursor:pointer;font-weight:600}.kazus-panel-title,.questions-panel-title{position:sticky;top:0;background:#fff;padding-bottom:8px;border-bottom:1px solid var(--c-border);margin-bottom:10px}.loading{padding:40px;text-align:center;color:var(--c-text-dim)}.consent-shell{min-height:100vh;padding:24px 16px;background:linear-gradient(135deg,#0f172a,#1e3a8a);display:flex;justify-content:center;align-items:flex-start;overflow-y:auto}.consent-card{background:#fff;max-width:780px;width:100%;border-radius:16px;padding:32px 36px;box-shadow:0 20px 60px #02061766;margin:12px 0 24px}.consent-hdr{border-bottom:1px solid var(--c-border);padding-bottom:16px;margin-bottom:18px}.consent-eyebrow{color:var(--c-primary);font-weight:700;font-size:12px;letter-spacing:.08em;text-transform:uppercase}.consent-hdr h1{font-size:26px;margin:4px 0 6px}.consent-sub{color:var(--c-text-dim);font-size:14px}.consent-section{margin-bottom:18px}.consent-section h3{font-size:16px;margin:0 0 10px;color:var(--c-primary-dark)}.consent-item{display:grid;grid-template-columns:44px 1fr;gap:10px;padding:12px 14px;background:#f8fafc;border:1px solid #e4e7ee;border-radius:10px;margin-bottom:8px;font-size:14px;line-height:1.5}.consent-icon{font-size:22px;display:flex;align-items:flex-start;justify-content:center}.consent-fineprint{font-size:13px;color:var(--c-text-dim);margin:0;padding:10px 14px;background:#f8fafc;border-radius:8px}.consent-webcam{margin:18px 0;padding:14px 16px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:12px}.consent-webcam-status{margin-bottom:10px;font-size:14px}.consent-webcam-preview{width:240px;height:180px;border-radius:8px;overflow:hidden;background:#0f172a;margin-bottom:10px;display:flex;align-items:center;justify-content:center}.consent-webcam-preview video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.consent-webcam-preview .placeholder{color:#64748b;font-size:13px}.consent-agree{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;background:#fef9c3;border:1px solid #fde68a;border-radius:10px;margin:18px 0;font-size:14px;cursor:pointer}.consent-agree input{margin-top:4px}.consent-actions{display:flex;justify-content:space-between;gap:10px;padding-top:12px;border-top:1px solid var(--c-border)}.exam-header-right{display:flex;align-items:center;gap:14px}.exam-recdot{display:flex;align-items:center;gap:6px;background:#1e293b;border:1px solid #334155;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;color:#fca5a5}.exam-recdot .dot{width:8px;height:8px;border-radius:50%;background:#ef4444;animation:recpulse 1.5s infinite}.exam-recdot video{margin-left:6px;width:60px;height:40px;border-radius:4px;object-fit:cover;transform:scaleX(-1);background:#0f172a}@keyframes recpulse{50%{opacity:.4}}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-top:10px}.photo-card{background:#0f172a;border-radius:8px;overflow:hidden;border:1px solid #e4e7ee;display:flex;flex-direction:column}.photo-card img{width:100%;aspect-ratio:4 / 3;object-fit:cover;display:block;cursor:zoom-in}.photo-card .cap{background:#fff;color:var(--c-text-dim);font-size:11px;text-align:center;padding:4px 0}.photo-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:grid;place-items:center;z-index:9999;padding:24px}.photo-lightbox img{max-width:100%;max-height:90vh;border-radius:8px}.keylog-viewer{max-height:360px;overflow:auto;background:#0f172a;color:#e2e8f0;padding:10px 12px;border-radius:8px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px;line-height:1.55}.keylog-viewer .kl-row{display:grid;grid-template-columns:92px 1fr;gap:10px}.keylog-viewer .kl-ts{color:#64748b}.keylog-viewer .kl-key{color:#38bdf8}.keylog-viewer .kl-special{color:#fbbf24}.keylog-viewer .kl-mod{color:#f472b6}.mobile-block{min-height:100vh;background:#0f172a;color:#e2e8f0;display:grid;place-items:center;padding:24px;text-align:center}.mobile-block .card{background:#1e293b;border:1px solid #334155;color:#f8fafc;max-width:420px}
