:root{color-scheme:light;--paper:#f4f2ec;--surface:#fcfbf7;--surface-2:#eceae2;--ink:#0b0b0c;--muted:#66665f;--line:#14140f24;--accent:#1b33ff;--accent-dark:#0e1fcb;--good:#0e7a39;--bad:#b23030;--shadow:#14140f1f}*{box-sizing:border-box}body{background:var(--paper);min-height:100vh;color:var(--ink);margin:0;font-family:Schibsted Grotesk,Space Grotesk,Segoe UI,system-ui,sans-serif}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.48}[hidden]{display:none!important}.exam-gate{z-index:200;background:var(--paper);place-items:center;padding:20px;display:grid;position:fixed;inset:0}.exam-gate-card{border:1px solid var(--line);background:var(--surface);width:min(100%,420px);box-shadow:0 22px 50px var(--shadow);border-radius:8px;gap:16px;padding:28px;display:grid}.exam-gate-card h1{letter-spacing:-.03em;margin:0;font-size:clamp(30px,6vw,44px)}.gate-error{min-height:20px;color:var(--bad);margin:0;font-weight:800}.exam-shell,.session-shell,.result-shell{width:min(1180px,100% - 32px);margin:0 auto;padding:clamp(24px,5vw,56px) 0 64px}.hero-card,.exam-panel,.category-card,.question-card,.feedback,.result-card,.review-card{border:1px solid var(--line);background:var(--surface);box-shadow:0 22px 50px var(--shadow);border-radius:8px}.hero-card{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:28px;padding:clamp(24px,4vw,42px);display:grid}.hero-card h1,.question-card h1,.result-card h1{letter-spacing:-.03em;margin:8px 0 0;font-size:clamp(34px,6vw,64px);line-height:.98}.hero-card p{max-width:62ch;color:var(--muted);line-height:1.6}.eyebrow{color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:12px;font-weight:700}.hero-progress{border:1px solid var(--line);background:var(--surface-2);border-radius:8px;gap:6px;min-width:180px;padding:18px;display:grid}.hero-progress span,.card-stats dt,.progress-meta,.difficulty{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:12px;font-weight:700}.hero-progress strong{font-size:42px;line-height:1}.mode-layout{grid-template-columns:minmax(0,1fr) 360px;align-items:start;gap:22px;margin-top:24px;display:grid}.section-head{margin:0 0 14px}.section-head h2,.exam-panel h2,.review-card h2{letter-spacing:-.02em;margin:6px 0 0;font-size:24px}.category-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.category-card{gap:18px;padding:22px;display:grid}.category-card h2{margin:8px 0 0;font-size:24px}.category-card p{color:var(--muted);margin:8px 0 0;line-height:1.5}.card-stats{border:1px solid var(--line);background:var(--line);border-radius:6px;grid-template-columns:repeat(3,1fr);gap:1px;margin:0;display:grid;overflow:hidden}.card-stats div{background:var(--surface);padding:12px}.card-stats dt,.card-stats dd{margin:0}.card-stats dd{margin-top:4px;font-weight:800}.subcategory-list{gap:8px;display:grid}.subcategory-button{width:100%;color:var(--text);text-align:left;border:1px solid var(--line);background:var(--surface-2);cursor:pointer;border-radius:6px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:10px 12px;display:grid}.subcategory-button:hover,.subcategory-button:focus-visible{border-color:var(--accent)}.subcategory-button span{overflow-wrap:anywhere;font-weight:700}.subcategory-button strong{color:var(--accent);font-size:13px}.exam-panel{padding:22px;position:sticky;top:86px}form,fieldset{gap:12px;display:grid}fieldset{border:0;margin:0;padding:0}legend{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px;font-size:12px;font-weight:800}.check-row,.field,.answer-field,.pair-row{gap:7px;display:grid}.check-row{grid-template-columns:18px 1fr;align-items:center}.field span{color:var(--muted);font-size:13px;font-weight:700}input,select{border:1px solid var(--line);width:100%;min-height:48px;color:var(--ink);background:#fff;border-radius:6px;padding:12px 14px}input[type=checkbox],input[type=radio]{width:18px;height:18px;min-height:auto;accent-color:var(--accent)}.button{border:1px solid var(--line);background:var(--surface);min-height:48px;color:var(--ink);border-radius:6px;justify-content:center;align-items:center;gap:8px;padding:12px 18px;font-weight:800;text-decoration:none;display:inline-flex}.button.primary{border-color:var(--accent);background:var(--accent);color:#fff}.button.ghost{background:0 0}.button.compact{min-height:38px;padding:8px 12px}.image-toolbar{border:1px solid var(--line);background:var(--surface-2);border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;padding:10px;display:flex}.tool-button{border:1px solid var(--line);min-height:40px;color:var(--ink);background:#fff;border-radius:6px;padding:8px 11px;font-weight:800}.tool-button.active{border-color:var(--accent);background:var(--accent);color:#fff}.color-tool{border:1px solid var(--line);min-height:40px;color:var(--muted);text-transform:uppercase;background:#fff;border-radius:6px;align-items:center;gap:8px;padding:6px 10px;font-size:12px;font-weight:800;display:inline-flex}.color-tool input{width:42px;min-height:28px;padding:0}.session-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.admin-topbar{grid-template-columns:auto minmax(0,1fr) auto;display:grid}.admin-topbar>div{justify-items:end}.admin-add-button{width:48px;min-width:48px;padding:0;font-size:26px;line-height:1}.session-header>div{justify-items:end;gap:4px;display:grid}.progress-wrap{margin-bottom:18px}.progress-meta{justify-content:space-between;margin-bottom:8px;display:flex}.progress-track{background:var(--surface-2);border-radius:999px;height:10px;overflow:hidden}.progress-fill{background:var(--accent);height:100%;transition:width .22s}.question-card{gap:22px;padding:clamp(24px,5vw,48px);scroll-margin-top:84px;display:grid}.question-top{justify-content:space-between;gap:16px;display:flex}.question-image{object-fit:contain;border:1px solid var(--line);background:#fff;border-radius:8px;width:min(100%,360px);max-height:240px}.image-fill-stage,.admin-canvas{border:1px solid var(--line);background:#fff;border-radius:8px;position:relative;overflow:hidden}.image-fill-stage img,.admin-canvas img{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:100%;height:auto;display:block}.admin-canvas{touch-action:none;-webkit-user-select:none;user-select:none}.admin-canvas img{pointer-events:none}.image-line,.admin-line{transform-origin:0;pointer-events:none;min-width:12px;height:4px;position:absolute}.image-area,.admin-area{border:2px solid var(--accent);min-width:20px;min-height:20px;color:var(--ink);text-align:center;pointer-events:none;background:#fff;place-items:center;font-size:clamp(10px,1.8vw,14px);font-weight:800;display:grid;position:absolute}.image-area.field{opacity:1;background:#fff}.admin-area,.admin-line-wrap{pointer-events:auto}.admin-area{cursor:move}.admin-line-wrap{cursor:move;position:absolute}.admin-area.selected{outline:2px solid var(--accent);outline-offset:3px;z-index:8}.admin-line-wrap.selected{z-index:8}.admin-edit-menu{z-index:12;border:1px solid var(--line);background:var(--surface);box-shadow:0 10px 24px var(--shadow);pointer-events:auto;border-radius:6px;gap:6px;padding:5px;display:flex;position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%)}.mini-tool{border:1px solid var(--line);min-height:30px;color:var(--ink);background:#fff;border-radius:5px;padding:5px 9px;font-size:12px;font-weight:800}.mini-tool.danger{color:var(--bad)}.resize-handle{z-index:10;background:var(--accent);width:14px;height:14px;box-shadow:0 2px 8px var(--shadow);pointer-events:auto;border:2px solid #fff;border-radius:999px;position:absolute}.resize-handle.nw{cursor:nwse-resize;top:-8px;left:-8px}.resize-handle.ne{cursor:nesw-resize;top:-8px;right:-8px}.resize-handle.sw{cursor:nesw-resize;bottom:-8px;left:-8px}.resize-handle.se{cursor:nwse-resize;bottom:-8px;right:-8px}.image-area.field{pointer-events:auto}.image-area.mask,.admin-area.mask{color:#0000;background:#fff;border-color:#fff}.image-area.text,.admin-area.text{background:#fcfbf7b8;border-color:#0000}.image-answer-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.drag-bank{border:1px solid var(--line);background:var(--surface-2);border-radius:8px;flex-wrap:wrap;gap:10px;padding:12px;display:flex}.drag-chip{border:1px solid var(--line);min-height:42px;color:var(--ink);cursor:grab;background:#fff;border-radius:6px;padding:9px 12px;font-weight:800}.drag-chip.image-chip,.dropped-answer{place-items:center;gap:4px;display:grid}.answer-box-image,.answer-box-preview{object-fit:contain;max-width:100%;display:block}.answer-box-image{max-height:92px}.dropped-answer{background:#fff;width:100%;height:100%;padding:2px}.dropped-answer .answer-box-image{width:100%;height:100%;max-height:none}.answer-box-editor{gap:8px;display:grid}.answer-box-preview{border:1px solid var(--line);background:#fff;border-radius:6px;max-height:120px}.answer-list{gap:10px;display:grid}.answer-list.two{grid-template-columns:repeat(2,minmax(0,1fr))}.answer-option{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:20px 1fr;align-items:center;gap:12px;min-height:56px;padding:14px;font-weight:700;display:grid}.answer-option-image{object-fit:contain;border:1px solid var(--line);background:#fff;border-radius:6px;width:min(100%,160px);max-height:120px;display:block}.pair-list{gap:12px;display:grid}.pair-row{grid-template-columns:minmax(120px,1fr) minmax(160px,1fr);align-items:center}.pair-row>span{font-weight:800}.feedback{border-left-width:6px;margin-top:16px;padding:18px}.feedback.correct{border-left-color:var(--good)}.feedback.wrong{border-left-color:var(--bad)}.feedback h2{color:var(--good);margin:0 0 8px}.feedback.wrong h2{color:var(--bad)}.feedback p{color:var(--muted);margin:6px 0 0}.session-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;margin-top:16px;display:flex}.result-card{padding:clamp(28px,5vw,52px)}.result-card.passed{border-left:6px solid var(--good)}.result-card.failed{border-left:6px solid var(--bad)}.result-card strong{margin-top:16px;font-size:24px;display:block}.admin-shell{width:min(1320px,100% - 32px);margin:0 auto;padding:clamp(24px,5vw,56px) 0 64px}.admin-layout{grid-template-columns:340px minmax(0,1fr);align-items:start;gap:18px;display:grid}.admin-panel,.admin-workspace,.area-list,.bank-manager,.bank-category{border:1px solid var(--line);background:var(--surface);box-shadow:0 22px 50px var(--shadow);border-radius:8px}.admin-panel,.admin-workspace{padding:20px}.admin-actions{grid-template-columns:1fr;gap:8px;display:grid}.field-note,.admin-status{color:var(--muted);margin:0;line-height:1.45}.admin-status{min-height:22px;font-weight:800}.admin-canvas{cursor:crosshair;min-height:320px}.empty-drop{min-height:320px;color:var(--muted);text-align:center;border:2px dashed var(--line);place-items:center;padding:24px;display:grid}.area-list{gap:10px;margin:14px 0;padding:16px;display:grid}.area-list h2{margin:0;font-size:20px}.list-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.answer-box-item{border-top:1px solid var(--line);grid-template-columns:40px minmax(0,1fr) auto;align-items:center;gap:8px;padding-top:10px;display:grid}.bank-manager{gap:14px;margin-top:18px;padding:20px;display:grid}.admin-question-list{margin-top:0}.admin-list-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.symbol-generator{gap:16px;display:grid}.symbol-generator-layout{grid-template-columns:380px minmax(0,1fr)}.symbol-list,.generated-question-list{gap:12px;display:grid}.symbol-card{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:120px minmax(0,1fr) auto;align-items:start;gap:12px;padding:12px;display:grid}.symbol-preview{border:1px dashed var(--line);background:var(--surface-2);min-height:96px;color:var(--muted);border-radius:6px;place-items:center;font-size:13px;font-weight:800;display:grid}.symbol-preview img{object-fit:contain;max-width:100%;max-height:120px;display:block}.symbol-fields{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.bank-category{box-shadow:none;gap:10px;padding:16px;display:grid}.bank-category header{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.bank-category h3{margin:0;font-size:20px}.bank-category header span,.bank-question span{color:var(--muted);font-size:13px;font-weight:700}.bank-question{border:1px solid var(--line);background:#fff;border-radius:6px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px;display:grid}.bank-question.active{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}.bank-question strong,.bank-question span{display:block}.bank-actions{flex-wrap:wrap;gap:8px;display:flex}.area-item{border-top:1px solid var(--line);grid-template-columns:130px minmax(0,1fr) minmax(0,1fr) auto;align-items:center;gap:8px;padding-top:10px;display:grid}textarea{border:1px solid var(--line);width:100%;color:var(--ink);background:#fff;border-radius:6px;padding:12px 14px;font:13px/1.5 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.review-grid{grid-template-columns:minmax(0,1.3fr) minmax(260px,.7fr);gap:16px;margin-top:16px;display:grid}.review-card{padding:22px}.missed{border-top:1px solid var(--line);gap:5px;padding:14px 0;display:grid}.missed span{color:var(--muted)}.tag{background:var(--surface-2);color:var(--ink);border-radius:999px;margin:8px 8px 0 0;padding:8px 10px;font-weight:800;display:inline-flex}@media (width<=980px){.mode-layout,.review-grid,.admin-layout{grid-template-columns:1fr}.exam-panel{position:static}}@media (width<=680px){.exam-shell,.result-shell{width:min(100% - 20px,1180px);padding-top:18px}body[data-exam-view=session]{overflow:hidden}body[data-exam-view=session] .tool-site-header{display:none}body[data-exam-view=session] .session-shell{width:100%;height:100dvh;min-height:100dvh;padding:8px 10px calc(8px + env(safe-area-inset-bottom));grid-template-rows:auto auto minmax(0,1fr) auto auto;gap:6px;display:grid;overflow:hidden}.hero-card,.category-grid,.answer-list.two,.pair-row,.area-item,.answer-box-item,.symbol-card,.symbol-fields,.bank-question{grid-template-columns:1fr}.hero-progress{min-width:0}.card-stats{grid-template-columns:1fr}body[data-exam-view=session] .session-header{flex-direction:row;align-items:center;gap:8px;margin:0}body[data-exam-view=session] .session-header .button{min-height:34px;padding:6px 10px;font-size:13px}body[data-exam-view=session] .session-header>div{justify-items:end;gap:0;min-width:0;font-size:13px}body[data-exam-view=session] .session-header .eyebrow,body[data-exam-view=session] .question-top .difficulty{letter-spacing:.04em;font-size:10px}body[data-exam-view=session] .progress-wrap{margin:0}body[data-exam-view=session] .progress-meta{margin-bottom:4px;font-size:10px}body[data-exam-view=session] .progress-track{height:6px}body[data-exam-view=session] .question-card{min-height:0;box-shadow:none;grid-template-rows:auto auto minmax(0,auto) minmax(0,1fr);gap:7px;padding:10px;display:grid;overflow:hidden}body[data-exam-view=session] .question-top{align-items:center;gap:8px}body[data-exam-view=session] .question-card h1{margin:0;font-size:clamp(17px,5vw,22px);line-height:1.08}body[data-exam-view=session] .question-image{justify-self:center;width:min(100%,260px);max-height:22dvh}body[data-exam-view=session] .answer-list,body[data-exam-view=session] .pair-list,body[data-exam-view=session] .image-answer-grid{overscroll-behavior:contain;min-height:0;overflow:auto}body[data-exam-view=session] .answer-list{gap:6px}body[data-exam-view=session] .answer-option{border-radius:6px;gap:8px;min-height:40px;padding:8px 10px;font-size:13px;line-height:1.2}body[data-exam-view=session] input,body[data-exam-view=session] select{min-height:40px;padding:9px 10px}body[data-exam-view=session] .answer-field{align-self:start}body[data-exam-view=session] .feedback{max-height:18dvh;box-shadow:none;margin:0;padding:8px 10px;overflow:auto}body[data-exam-view=session] .feedback h2{margin:0 0 3px;font-size:16px}body[data-exam-view=session] .feedback p{margin:2px 0 0;font-size:12px;line-height:1.25}body[data-exam-view=session] .session-actions{grid-template-columns:1fr 1fr;justify-content:stretch;gap:8px;margin:0;display:grid}body[data-exam-view=session] .session-actions .button{min-height:42px;padding:9px 10px}.session-header{flex-direction:column;align-items:stretch}.session-header>div{justify-items:start}.session-actions{justify-content:stretch}.session-actions .button{flex:100%}}