*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#eef2f7;color:#111827}button,input{font:inherit}.login{min-height:100vh;display:grid;place-items:center}.login section{width:min(360px,92vw);display:grid;gap:12px}.login h1{margin:0 0 8px;font-size:32px}.login input{height:44px;padding:0 12px;border:1px solid #b8c0cc;border-radius:4px}.login button,.actions button,.modal-actions button{height:42px;display:inline-flex;gap:8px;align-items:center;justify-content:center;border:1px solid #8390a3;background:#fff;border-radius:4px;cursor:pointer}button:disabled{opacity:.65;cursor:wait}.error{color:#b91c1c}.exam{height:100vh;display:grid;grid-template-rows:58px 1fr 62px;-webkit-user-select:none;user-select:none;overflow:hidden}.topbar{display:grid;grid-template-columns:1fr auto auto;gap:24px;align-items:center;padding:0 18px;background:#e9eef5;border-bottom:1px solid #bcc7d6;font-size:18px}.candidate{display:inline-flex;align-items:center;gap:10px;font-weight:700}.candidate i{width:38px;height:44px;display:inline-block;border:1px solid #8b99aa;background:linear-gradient(#f8fafc 0 45%,#cbd5e1 46%)}.timer{font-size:18px}.timer.warn{color:#b91c1c}.workspace{display:grid;grid-template-columns:minmax(0,3fr) 320px;min-height:0}.question{background:#fff;padding:16px 22px;border-right:1px solid #c8d1dd;overflow:auto}.tabs{display:flex;gap:6px;border-bottom:1px solid #b9c4d2;margin:-16px -22px 16px;padding:8px 12px 0;background:#f8fafc}.tabs button{padding:8px 16px;border:1px solid #9eb1ca;border-bottom:0;background:#dbeafe;border-radius:4px 4px 0 0;cursor:pointer;display:inline-flex;align-items:center;gap:8px;min-width:118px;justify-content:center}.tabs button.active{background:#2563eb;border-color:#1d4ed8;color:#fff;font-weight:700}.tabs button span{font-size:11px;padding:2px 6px;border-radius:999px;background:#0f172a1f}.tabs button.active span{background:#fff3}.marks{color:#0f766e;font-weight:700}.stem{font-size:18px;line-height:1.5}.question-image{display:block;max-width:min(520px,100%);max-height:280px;margin:14px 0;border:1px solid #cbd5e1;background:#fff}.option{display:block;margin:12px 0;padding:12px;border:1px solid #c8d1dd;border-radius:4px;cursor:pointer}.option:has(input:checked){border-color:#2563eb;background:#eff6ff}.palette{padding:14px;background:#f8fafc;overflow:auto;border-left:1px solid #d3dce8}.palette h3{margin:0 0 12px;font-size:18px}.section-name{margin:-4px 0 12px;text-transform:uppercase;font-size:12px;color:#475569;font-weight:700}.grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.grid button{aspect-ratio:1;border:1px solid #9ca3af;background:#e5e7eb;border-radius:3px;cursor:pointer;font-weight:700}.grid button.current{outline:3px solid #0f172a;outline-offset:2px}.grid button.not_answered{background:#dc2626;color:#fff;border-color:#991b1b}.grid button.answered{background:#16a34a;color:#fff;border-color:#166534}.grid button.marked{background:#7c3aed;color:#fff;border-color:#5b21b6}.grid button.answered_marked{background:linear-gradient(135deg,#7c3aed 0 64%,#16a34a 65%);color:#fff;border-color:#5b21b6}.legend{display:grid;gap:8px;margin-top:18px;font-size:13px}.legend span{display:flex;gap:8px;align-items:center}.legend i{width:18px;height:18px;display:inline-block;border-radius:3px;border:1px solid #8d98a8}.nv{background:#e5e7eb}.na{background:#dc2626}.ans{background:#16a34a}.mark{background:#7c3aed}.ansmark{background:linear-gradient(135deg,#7c3aed 0 64%,#16a34a 65%)}.actions{display:flex;gap:10px;align-items:center;padding:10px 16px;border-top:1px solid #bcc7d6;background:#eef2f7}.actions .primary{background:#2563eb;border-color:#1d4ed8;color:#fff;margin-left:auto}.actions .submit,.modal-actions .submit{background:#16a34a;border-color:#15803d;color:#fff}.modal{position:fixed;inset:0;display:grid;place-items:center;background:#0f172a75;padding:24px;z-index:20}.modal-panel{width:min(920px,96vw);background:#fff;border-radius:6px;border:1px solid #94a3b8;box-shadow:0 20px 60px #0f172a4d;padding:20px}.modal-panel h2{margin:0 0 14px}.modal-panel table{width:100%;border-collapse:collapse;font-size:14px}.modal-panel th,.modal-panel td{border:1px solid #cbd5e1;padding:9px;text-align:center}.modal-panel th{background:#e2e8f0}.modal-panel td:first-child,.modal-panel th:first-child{text-align:left;font-weight:700}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.result{min-height:100vh;display:grid;place-items:start center;background:#f8fafc;padding:28px 0}.result section{width:min(760px,94vw);border:1px solid #cbd5e1;background:#fff;padding:28px;border-radius:6px}.result-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start}.result h1{margin:0 0 6px}.result-head p{margin:0;color:#475569}.result button{height:40px;padding:0 14px;border:1px solid #8390a3;background:#fff;border-radius:4px;cursor:pointer;white-space:nowrap}.score{font-size:44px;font-weight:800;margin:10px 0 18px;color:#0f766e}.result-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}.result-grid strong{border:1px solid #cbd5e1;border-radius:4px;padding:12px;text-align:center;background:#f8fafc}.bars{display:grid;gap:10px;margin-bottom:24px}.bar-row{display:grid;grid-template-columns:110px 1fr 80px;gap:12px;align-items:center}.bar-row div{height:12px;background:#e2e8f0;border-radius:999px;overflow:hidden}.bar-row i{display:block;height:100%;background:#0f766e}.chapter-list{display:grid;gap:8px}.chapter-list p{display:flex;justify-content:space-between;gap:16px;margin:0;padding:10px 12px;border:1px solid #e2e8f0;border-radius:4px;background:#f8fafc}.chapter-list p>span:last-child{white-space:nowrap;color:#475569}@media(max-width:800px){.workspace{grid-template-columns:1fr}.palette{display:none}.topbar{grid-template-columns:1fr;height:auto;padding:8px 12px;gap:4px}}
