:root{--bg:#f5f6fb;--ink:#102038;--muted:#5d6a7b;--brand:#006d77;--brand-2:#83c5be;--accent:#ee6c4d;--card:#ffffff;--border:#dce3ef;--ok:#2a9d8f;--bad:#d1495b}*{box-sizing:border-box}body{margin:0;font-family:Avenir Next,Segoe UI,sans-serif;color:var(--ink);background:radial-gradient(circle at 10% 10%,#d5f5f6,transparent 40%),radial-gradient(circle at 80% 0,#ffd8c9,transparent 35%),var(--bg)}.app-shell{min-height:100vh;padding:24px}.page{max-width:1200px;margin:0 auto}.login-wrap{min-height:calc(100vh - 48px);display:flex;align-items:center;justify-content:center}.login-card{width:min(460px,100%);background:#ffffff;border:1px solid var(--border);border-radius:20px;padding:24px;box-shadow:0 18px 40px rgba(15,23,42,.18)}.login-hint,.login-note{color:var(--muted);margin:6px 0 14px}.login-form{display:grid;grid-gap:12px;gap:12px}.login-form label{display:grid;grid-gap:6px;gap:6px;font-weight:600}.login-form input{border:1px solid var(--border);border-radius:10px;padding:10px 12px;font:inherit}.login-error{color:#b91c1c;font-weight:600;margin-top:10px}.hero{background:linear-gradient(120deg,#0b3c5d,#006d77 58%,#138a8d);color:white;border-radius:24px;padding:28px;box-shadow:0 20px 40px rgba(8,30,61,.2)}.eyebrow{text-transform:uppercase;letter-spacing:.09em;font-size:12px;opacity:.85}.hero h1{margin:8px 0;font-size:36px}.hero p{opacity:.95;max-width:760px}.grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:16px;gap:16px}.folder-list,.grid{margin-top:20px;display:grid}.folder-list{grid-gap:14px;gap:14px}.folder{background:#ffffff;border:1px solid var(--border);border-radius:20px;overflow:hidden;box-shadow:0 8px 20px rgba(0,0,0,.05)}.folder-head{list-style:none;cursor:pointer;padding:22px 20px;display:flex;align-items:center;justify-content:space-between;min-height:88px;background:#f8fafc;transition:background .2s ease}.folder-head::-webkit-details-marker{display:none}.folder:hover .folder-head{background:#f0f7ff}.folder[open] .folder-head{border-bottom:1px solid var(--border)}.folder-left{gap:12px}.folder-icon,.folder-left{display:inline-flex;align-items:center;font-size:20px}.folder-icon{width:36px;height:36px;justify-content:center;border-radius:10px;background:#e0f2fe}.folder-count{font-size:14px;color:var(--muted)}.folder-grid{margin-top:0;padding:14px}.card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:0 8px 20px rgba(0,0,0,.05)}.card-clickable{cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.card-clickable:hover{transform:translateY(-3px);border-color:#9dc9ff;box-shadow:0 14px 28px rgba(7,41,80,.16)}.card-clickable:focus-visible{outline:3px solid #5aa9ff;outline-offset:2px}.card-top{display:flex;justify-content:space-between;align-items:center}.pill{background:#e8f4f4;border:1px solid #b9e1dc;color:#065f64}.pill,.status-pill{border-radius:999px;padding:4px 10px;font-size:12px}.status-pill{display:inline-flex;align-items:center;font-weight:700;border:1px solid #cbd5e1;background:#f1f5f9;color:#334155}.status-pill.in_progress{background:#e0f2fe;border-color:#93c5fd;color:#1d4ed8}.status-pill.paused{background:#fff7ed;border-color:#fdba74;color:#c2410c}.btn{background:var(--brand);color:white;border:none;border-radius:12px;padding:10px 14px;font-weight:600;cursor:pointer}.btn:hover{filter:brightness(1.05)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-secondary{background:#39495f}.btn-danger{background:var(--bad)}.btn.tiny{padding:7px 10px;font-size:12px}.actions-row{display:flex;gap:10px;flex-wrap:wrap}.exam-layout{display:grid;grid-template-columns:320px 1fr;grid-gap:16px;gap:16px;max-width:1400px;margin:0 auto}.exam-layout.paused{filter:blur(2px);opacity:.85;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.left-panel,.question-panel{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:18px}.left-panel{position:-webkit-sticky;position:sticky;top:16px;height:calc(100vh - 48px);overflow:auto}.timer{margin:10px 0;font-size:34px;font-weight:800;color:#0d3b66;background:#ecf6ff;border:1px solid #c9e3ff;border-radius:14px;text-align:center;padding:10px}.meta-row{display:flex;justify-content:space-between;color:var(--muted);font-size:14px}.palette{margin:14px 0;display:grid;grid-template-columns:repeat(5,1fr);grid-gap:8px;gap:8px}.palette-btn{position:relative;border:1px solid var(--border);background:#fff;border-radius:10px;padding:8px 0;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center}.palette-btn.active{outline:2px solid #5aa9ff}.palette-btn.answered,.palette-btn.correct{background:#def7ec;border-color:#98d8b9}.palette-btn.wrong{background:#fee2e2;border-color:#fca5a5;color:#991b1b}.palette-btn.marked{border-color:#f59e0b}.q-flag{position:absolute;top:1px;right:5px;font-size:12px;line-height:1;color:#dc2626}.question-head{display:flex;justify-content:space-between;align-items:center}.question-box{background:#f8fafc;border:1px solid var(--border);border-radius:14px;padding:16px;line-height:1.6;overflow-wrap:anywhere;word-break:break-word}.answers{display:flex;flex-direction:column;gap:10px;margin-top:14px}.answer{display:grid;grid-template-columns:20px 28px 1fr;align-items:start;grid-column-gap:10px;column-gap:10px;border:1px solid var(--border);border-radius:14px;padding:12px;cursor:pointer;background:white}.answer.checked{border-color:#5aa9ff;background:#eff7ff}.answer input{margin:6px 0 0}.option-badge{min-width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-weight:800;background:#edf2f7}.answer>span:last-child>p:first-child{margin-top:0}.answer>span:last-child>p:last-child{margin-bottom:0}.question-actions{margin-top:16px;display:flex;gap:10px;flex-wrap:wrap}.history-table-wrap{margin-top:16px;background:white;border:1px solid var(--border);border-radius:14px;overflow:hidden}.history-table{width:100%;border-collapse:collapse}.history-table td,.history-table th{border-bottom:1px solid var(--border);padding:12px;text-align:left}.history-table th{background:#f8fafc}.review-list{display:grid;grid-gap:14px;gap:14px;margin-top:16px}.review-card{background:white;border:1px solid var(--border);border-left:6px solid #94a3b8;border-radius:14px;padding:16px}.review-card.correct{border-left-color:var(--ok)}.review-card.wrong{border-left-color:var(--bad)}.review-answers .answer.review{cursor:default;grid-template-columns:28px 1fr}.answer.review.is-correct{background:#def7ec;border-color:#98d8b9}.answer.review.is-selected{background:#fff4f2;border-color:#ffcabf}.answer.practice-correct{background:#def7ec;border-color:#98d8b9}.answer.practice-wrong{background:#fff4f2;border-color:#ffcabf}.explain-box,.review-html{overflow-wrap:anywhere;word-break:break-word}.explain-box img,.question-box img,.review-html img{max-width:100%;height:auto}.explain-box{margin-top:14px;background:#f9fafb;border:1px dashed #cfd8e3;border-radius:12px;padding:12px}.explain-box.practice-ok{background:#ecfdf5;border-color:#10b981}.explain-box.practice-bad{background:#fef2f2;border-color:#ef4444}.error,.loading{position:fixed;right:16px;z-index:100;border-radius:12px;padding:10px 12px;color:white;font-weight:600}.loading{top:16px;background:#2b6cb0}.error{top:64px;background:#c53030}.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.5);display:flex;align-items:center;justify-content:center;z-index:300;padding:16px}.modal-card{width:min(480px,100%);background:#ffffff;border:1px solid var(--border);border-radius:16px;box-shadow:0 24px 50px rgba(15,23,42,.25);padding:20px}.modal-card h3,.modal-card p{margin:0 0 8px}.modal-card p{color:var(--muted)}@media (max-width:1024px){.exam-layout{grid-template-columns:1fr}.left-panel{position:static;height:auto}.hero h1{font-size:28px}}@media (max-width:768px){.app-shell{padding:12px}.page{max-width:100%}.hero{border-radius:16px;padding:18px}.hero h1{font-size:24px}.hero p{font-size:14px}.card{border-radius:14px;padding:14px}.actions-row{display:grid;grid-template-columns:1fr}.btn{width:100%;justify-content:center}.btn.tiny{width:auto}.left-panel,.question-panel{border-radius:14px;padding:14px}.timer{font-size:28px;padding:8px}.palette{grid-template-columns:repeat(6,1fr);gap:6px}.question-box{padding:12px}.answer{padding:10px;column-gap:8px}.question-actions{display:grid;grid-template-columns:1fr 1fr}.history-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.history-table{min-width:640px}.review-card{border-radius:12px;padding:12px}.explain-box{padding:10px}.error,.loading{right:12px;left:12px;width:auto;text-align:center}}@media (max-width:480px){.app-shell{padding:10px}.hero{border-radius:12px;padding:14px}.hero h1{font-size:21px}.eyebrow{font-size:11px}.login-card{border-radius:14px;padding:16px}.palette{grid-template-columns:repeat(5,1fr)}.option-badge{min-width:24px;height:24px;font-size:12px}.answer{grid-template-columns:18px 24px 1fr}.review-answers .answer.review{grid-template-columns:24px 1fr}.modal-card{border-radius:12px;padding:14px}}