@font-face{font-family:"Geist";src:url(/assets/geist.woff2) format("woff2");font-weight:100 900;font-style:normal;font-display:swap}
:root{
  --ground:#FBFAF6;--white:#FFFFFF;
  --ink:#1A1813;--ink-soft:#343026;--ink-mut:#6F6A5D;--ink-faint:#9D978A;
  --brand:#F7C948;--brand-deep:#F0B429;--brand-tint:#FFF6D6;
  --line:#ECE7DA;--line-soft:#F1ECE0;
  --ok:#15803D;--ok-bg:#EAF5EE;--warn:#B45309;--bad:#DC2626;--bad-bg:#FBEAEA;
  --glass:rgba(255,255,255,0.60);--glass-strong:rgba(255,255,255,0.80);--glass-brd:rgba(255,255,255,0.72);
  --r-card:16px;--r-ctl:11px;--shadow-soft:0 1px 2px rgba(26,24,19,.04),0 8px 24px rgba(26,24,19,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{min-height:100%}
body{
  font-family:"Geist",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);line-height:1.5;font-size:15px;letter-spacing:-0.005em;
  background:
    radial-gradient(900px 620px at 4% -12%,rgba(247,201,72,.16),transparent 60%),
    radial-gradient(820px 600px at 116% 2%,rgba(250,219,95,.10),transparent 58%),
    linear-gradient(180deg,#FCFBF7 0%,#F6F1E7 100%);
  background-attachment:fixed;
}
.tnum{font-variant-numeric:tabular-nums}.muted{color:var(--ink-mut)}.faint{color:var(--ink-faint)}
h1,h2,h3,h4{letter-spacing:-0.025em;text-wrap:balance;font-weight:600;color:var(--ink)}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit}
[hidden]{display:none !important}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 15px;border-radius:11px;font-weight:600;font-size:13.5px;transition:transform .08s,box-shadow .15s,background .15s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--brand);color:var(--ink);box-shadow:0 1px 2px rgba(26,24,19,.08),0 6px 16px rgba(240,180,41,.28)}
.btn-primary:hover{background:var(--brand-deep)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.btn-ghost:hover{border-color:#dcd5c4}
.btn svg{width:15px;height:15px}
.btn-sm{padding:6px 10px;font-size:12px;border-radius:9px}

/* ---------- login ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{width:100%;max-width:400px;background:var(--glass-strong);backdrop-filter:blur(24px) saturate(185%);-webkit-backdrop-filter:blur(24px) saturate(185%);border:1px solid var(--glass-brd);border-radius:20px;box-shadow:0 1px 2px rgba(26,24,19,.05),0 24px 60px rgba(26,24,19,.14);padding:30px 28px}
.login-logo{display:flex;justify-content:center;margin-bottom:18px}
.login-logo img{height:56px}
.login-card h1{font-size:22px;text-align:center;margin-bottom:5px}
.login-card .lead{text-align:center;color:var(--ink-mut);font-size:13.5px;margin-bottom:22px}
.login-card label{display:block;font-size:12px;font-weight:600;color:var(--ink-soft);margin-bottom:6px}
.input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:var(--r-ctl);background:#fff;font:inherit;font-size:14px;color:var(--ink);box-shadow:var(--shadow-soft);outline:none}
.input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-tint)}
.login-card .btn-primary{width:100%;margin-top:14px;padding:11px}
.code-input{letter-spacing:.5em;text-align:center;font-size:20px;font-weight:600}
.msg{font-size:12.5px;margin-top:10px;padding:9px 11px;border-radius:9px}
.msg-err{background:var(--bad-bg);color:var(--bad)}
.msg-ok{background:var(--ok-bg);color:var(--ok)}
.msg-dev{background:var(--brand-tint);color:var(--warn);text-align:center}
.linklike{background:none;border:none;color:var(--brand-deep);font-weight:600;font-size:12.5px;margin-top:14px;display:block;width:100%;text-align:center}

/* ---------- app shell ---------- */
.app{min-height:100vh;display:flex;flex-direction:column}
.appbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:16px;padding:11px 18px;background:#fff;border-bottom:1px solid var(--line)}
.logo{height:44px;display:block}
.nav{display:none;gap:3px;margin-left:6px}
.nav button{padding:8px 13px;border-radius:9px;font-size:13.5px;font-weight:500;color:var(--ink-mut);display:flex;gap:7px;align-items:center}
.nav button.on{background:var(--ground);color:var(--ink)}
.nav button:hover{color:var(--ink)}
.nav svg{width:16px;height:16px}
.spring{flex:1}
.classchip{display:flex;align-items:center;gap:7px;padding:6px 11px;background:var(--ground);border:1px solid var(--line);border-radius:9px;font-size:12.5px;font-weight:500;white-space:nowrap}
.classchip svg{width:13px;height:13px;color:var(--ink-faint)}
.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-deep));display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;color:var(--ink);flex:none;cursor:pointer}
.appbody{flex:1;padding:22px 18px 96px}
.wrap{max-width:1080px;margin:0 auto}
.screen{display:none}.screen.on{display:block;animation:fade .26s ease}
@keyframes fade{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.screen.on{animation:none}}
.bottomnav{position:fixed;left:0;right:0;bottom:0;z-index:30;display:flex;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--line);padding:7px 8px 9px}
.bottomnav button{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10.5px;font-weight:500;color:var(--ink-faint);padding:4px}
.bottomnav button.on{color:var(--ink)}.bottomnav button.on svg{color:var(--brand-deep)}
.bottomnav svg{width:20px;height:20px}

/* headings + toolbar */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px}
.page-head h1{font-size:23px}
.page-head .sub{color:var(--ink-mut);font-size:13.5px;margin-top:3px}
.toolbar{display:flex;gap:9px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.search{flex:1;min-width:160px;display:flex;align-items:center;gap:8px;padding:9px 12px;background:#fff;border:1px solid var(--line);border-radius:11px;box-shadow:var(--shadow-soft)}
.search svg{width:15px;height:15px;color:var(--ink-faint)}
.search input{border:none;outline:none;font:inherit;font-size:13.5px;flex:1;background:none;min-width:0}
.fpill{padding:8px 12px;border-radius:10px;font-size:12.5px;font-weight:500;background:#fff;border:1px solid var(--line);color:var(--ink-soft);display:flex;gap:6px;align-items:center;box-shadow:var(--shadow-soft);white-space:nowrap}
.fpill svg{width:12px;height:12px;color:var(--ink-faint)}

/* inbox */
.inbox{background:var(--glass);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--glass-brd);border-radius:var(--r-card);box-shadow:var(--shadow-soft);overflow:hidden}
.row{display:flex;align-items:center;gap:13px;padding:14px 15px;border-bottom:1px solid var(--line-soft);transition:background .12s;cursor:pointer;flex-wrap:wrap}
.row:last-child{border-bottom:none}.row:hover{background:rgba(255,255,255,.5)}
.subject-ic{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex:none;font-weight:700;font-size:14px;background:#EAF0FB;color:#2f5fbf}
.row-main{flex:1;min-width:170px}
.row-title{font-weight:600;font-size:14px;margin-bottom:3px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.row-meta{color:var(--ink-mut);font-size:12px;display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.dot{width:3px;height:3px;border-radius:50%;background:var(--ink-faint);display:inline-block}
.tag{font-size:10px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;padding:2px 6px;border-radius:5px}
.tag-hw{background:var(--brand-tint);color:var(--warn)}.tag-omr{background:#F0EAFB;color:#6b46c1}.tag-up{background:#EAF0FB;color:#2f5fbf}
.pill{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.pill-ready{background:var(--ok-bg);color:var(--ok)}.pill-draft{background:#F1ECE0;color:var(--ink-mut)}
.pill::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}
.row-marks{font-weight:600;font-size:13px;color:var(--ink-soft);white-space:nowrap}
.row-actions{display:flex;gap:6px;flex:none}
.empty{padding:44px 20px;text-align:center;color:var(--ink-mut)}
.empty svg{width:34px;height:34px;color:var(--ink-faint);margin-bottom:8px}

/* wizard */
.wiz-head{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.backbtn{width:34px;height:34px;border-radius:10px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-soft);flex:none}
.backbtn svg{width:15px;height:15px}
.wiz-head h1{font-size:20px}
.mode-toggle{display:inline-flex;background:#fff;border:1px solid var(--line);border-radius:11px;padding:4px;gap:4px;box-shadow:var(--shadow-soft)}
.mode-toggle button{padding:6px 13px;border-radius:8px;font-size:12.5px;font-weight:600;color:var(--ink-mut)}
.mode-toggle button.on{background:var(--ink);color:#fff}
.wiz-grid{display:grid;grid-template-columns:1fr;gap:14px;align-items:start}
.cards{display:flex;flex-direction:column;gap:13px;min-width:0}
.card{background:var(--glass);backdrop-filter:blur(18px) saturate(180%);-webkit-backdrop-filter:blur(18px) saturate(180%);border:1px solid var(--glass-brd);border-radius:var(--r-card);box-shadow:var(--shadow-soft);padding:16px 17px}
.card-eyebrow{font-size:10.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--brand-deep);margin-bottom:3px}
.card h3{font-size:15.5px;margin-bottom:13px}
.field{margin-bottom:13px}.field:last-child{margin-bottom:0}
.field label{display:block;font-size:12px;font-weight:600;color:var(--ink-soft);margin-bottom:6px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.sel{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:var(--r-ctl);background:#fff;font:inherit;font-size:13.5px;color:var(--ink);box-shadow:var(--shadow-soft);appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239d978a' stroke-width='3'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 11px center}
#w-book{gap:8px;background-image:none}
#w-book svg{width:16px;height:16px;flex:none;color:var(--ink-faint)}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{padding:7px 12px;border-radius:9px;font-size:12.5px;font-weight:500;background:#fff;border:1px solid var(--line);color:var(--ink-soft);box-shadow:var(--shadow-soft)}
.chip.on{background:var(--brand-tint);border-color:var(--brand);color:var(--ink);font-weight:600}
.chip.on::after{content:"✓";margin-left:6px;color:var(--brand-deep);font-weight:700}
.chip[disabled]{opacity:.45;cursor:not-allowed}
.autofix{font-size:12px;color:var(--ok);display:flex;gap:6px;align-items:flex-start;margin-top:8px}
.autofix svg{width:13px;height:13px;flex:none;margin-top:2px}
.tree{border:1px solid var(--line);border-radius:var(--r-ctl);background:#fff;overflow:hidden;max-height:240px;overflow-y:auto}
.tree-ch{display:flex;align-items:center;gap:9px;padding:9px 12px;font-size:13px;border-bottom:1px solid var(--line-soft);cursor:pointer}
.tree-ch:last-child{border-bottom:none}
.tree-ch input{width:15px;height:15px;accent-color:var(--brand-deep);flex:none}
.tree-ch .cnt{margin-left:auto;font-size:11px;color:var(--ink-faint);white-space:nowrap}
.tree-ch.sel{background:var(--brand-tint)}
.blueprint{width:100%;border-collapse:collapse;font-size:12.5px}
.blueprint th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-faint);font-weight:700;padding:6px 8px;border-bottom:1px solid var(--line)}
.blueprint td{padding:8px;border-bottom:1px solid var(--line-soft)}
.blueprint tr:last-child td{border-bottom:none}
.blueprint .sec{font-weight:700;color:var(--brand-deep)}
.blueprint tfoot td{font-weight:700;border-top:1px solid var(--line);border-bottom:none}
.diffbars{display:flex;flex-direction:column;gap:8px}
.diffrow{display:grid;grid-template-columns:104px 1fr 58px;gap:9px;align-items:center;font-size:12px}
.diffrow input{width:52px;padding:5px 7px;border:1px solid var(--line);border-radius:7px;font:inherit;font-size:12px;text-align:right}
.bar{height:8px;border-radius:4px;background:var(--line);overflow:hidden}
.bar span{display:block;height:100%;border-radius:4px;background:linear-gradient(90deg,var(--brand),var(--brand-deep))}
.difftotal{font-size:11.5px;margin-top:8px;font-weight:600}
.difftotal.bad{color:var(--bad)}.difftotal.ok{color:var(--ok)}
.radio-row{display:flex;gap:9px;flex-wrap:wrap}
.radio-card{flex:1;min-width:120px;padding:11px 12px;border:1.5px solid var(--line);border-radius:var(--r-ctl);background:#fff;font-size:12.5px;box-shadow:var(--shadow-soft);cursor:pointer}
.radio-card.on{border-color:var(--brand);background:var(--brand-tint)}
.radio-card b{display:block;font-size:13px;margin-bottom:3px}
.radio-card span{color:var(--ink-mut);font-size:11.5px}

.summary{display:none;position:sticky;top:78px;background:var(--glass-strong);backdrop-filter:blur(20px) saturate(185%);-webkit-backdrop-filter:blur(20px) saturate(185%);border:1px solid var(--glass-brd);border-radius:var(--r-card);box-shadow:0 1px 2px rgba(26,24,19,.05),0 14px 40px rgba(26,24,19,.10);padding:17px}
.summary h4{font-size:10.5px;text-transform:uppercase;letter-spacing:.09em;color:var(--ink-faint);font-weight:700;margin-bottom:12px}
.stat{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0;border-bottom:1px solid var(--line-soft)}
.stat .k{font-size:12.5px;color:var(--ink-mut)}
.stat .v{font-size:18px;font-weight:700;letter-spacing:-0.02em}
.stat .v small{font-size:11px;font-weight:500;color:var(--ink-faint)}
.sheet-note{display:flex;gap:8px;align-items:center;margin:12px 0;padding:9px 11px;background:#F0EAFB;border-radius:10px;font-size:12px;color:#6b46c1;font-weight:500}
.sheet-note svg{width:15px;height:15px;flex:none}
.summary .btn-primary{width:100%}
.summary .hint{font-size:11px;color:var(--ink-faint);text-align:center;margin-top:8px;line-height:1.4}
.msummary{position:fixed;left:0;right:0;bottom:0;z-index:31;padding:11px 16px;background:var(--glass-strong);backdrop-filter:blur(20px) saturate(185%);-webkit-backdrop-filter:blur(20px) saturate(185%);border-top:1px solid var(--glass-brd);display:flex;align-items:center;gap:12px;box-shadow:0 -8px 24px rgba(26,24,19,.08)}
.msummary .mstat{font-size:12px;color:var(--ink-mut);line-height:1.3}
.msummary .mstat b{color:var(--ink);font-size:15px;font-weight:700;letter-spacing:-0.02em}
.msummary .btn-primary{margin-left:auto}

/* report */
.rep-grid{display:grid;grid-template-columns:1fr;gap:14px;align-items:start}
.preview-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);box-shadow:var(--shadow-soft);padding:18px}
.qcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);box-shadow:var(--shadow-soft);padding:16px 17px;margin-bottom:12px}
.q{font-size:14.5px;font-weight:600;margin-bottom:4px}
.qmeta{display:flex;gap:7px;align-items:center;margin-bottom:12px;flex-wrap:wrap}
.badge{font-size:10.5px;font-weight:600;padding:3px 8px;border-radius:6px;background:#F1ECE0;color:var(--ink-soft)}
.badge-diff{background:var(--brand-tint);color:var(--warn)}
.opts{display:flex;flex-direction:column;gap:5px;margin:8px 0 12px;font-size:13px}
.opt{padding:6px 10px;border:1px solid var(--line);border-radius:8px}
.opt.correct{border-color:var(--ok);background:var(--ok-bg);font-weight:600}
.steps{border-left:2px solid var(--line);padding-left:15px;display:flex;flex-direction:column;gap:12px;margin:6px 0 4px}
.step{position:relative;padding-right:56px}
.step::before{content:"";position:absolute;left:-20px;top:4px;width:9px;height:9px;border-radius:50%;background:var(--brand);border:2px solid #fff;box-shadow:0 0 0 1px var(--brand)}
.step .sd{font-size:13px;margin-bottom:3px}
.step .salu{font-size:11px;color:#2f5fbf;margin-top:3px;display:flex;gap:5px;align-items:center}
.step .salu svg{width:11px;height:11px;flex:none}
.stepmark{position:absolute;right:0;top:2px;font-size:11px;font-weight:700;color:var(--ok);background:var(--ok-bg);padding:2px 8px;border-radius:20px}
.ans-final{margin-top:10px;padding:8px 11px;background:var(--ok-bg);border-radius:9px;font-size:13px;color:var(--ink-soft)}
.ans-final b{color:var(--ok)}
.wtable{width:100%;font-size:12px;border-collapse:collapse}
.wtable td{padding:5px 0}
.bar2{height:6px;border-radius:3px;background:var(--line)}.bar2 span{display:block;height:100%;border-radius:3px;background:var(--brand-deep)}
.note-strip{display:flex;gap:9px;padding:11px 13px;background:var(--brand-tint);border:1px solid var(--brand);border-radius:12px;font-size:12px;color:var(--ink-soft);margin-bottom:16px}
.note-strip svg{width:15px;height:15px;color:var(--warn);flex:none;margin-top:1px}
.report-side{display:flex;flex-direction:column;gap:12px}
.report-side h4{font-size:10.5px;text-transform:uppercase;letter-spacing:.09em;color:var(--ink-faint);margin-bottom:11px}

/* modal + admin */
.modal-backdrop{position:fixed;inset:0;z-index:70;background:rgba(26,24,19,.34);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);display:flex;align-items:flex-start;justify-content:center;padding:34px 18px;overflow-y:auto}
.modal{width:100%;max-width:560px;background:var(--glass-strong);backdrop-filter:blur(26px) saturate(185%);-webkit-backdrop-filter:blur(26px) saturate(185%);border:1px solid var(--glass-brd);border-radius:18px;box-shadow:0 30px 80px rgba(26,24,19,.28);padding:22px}
.modal h3{font-size:18px;margin-bottom:14px}
.modal .field{margin-bottom:12px}
.modal .field label{display:block;font-size:12px;font-weight:600;color:var(--ink-soft);margin-bottom:6px}
.modal-actions{display:flex;justify-content:flex-end;gap:9px;margin-top:18px}
.seg2{display:flex;background:#fff;border:1px solid var(--line);border-radius:11px;padding:4px;gap:4px;box-shadow:var(--shadow-soft);margin-bottom:14px}
.seg2 button{flex:1;padding:8px;border-radius:8px;font-size:13px;font-weight:600;color:var(--ink-mut)}
.seg2 button.on{background:var(--ink);color:#fff}
.assign-card{border:1px solid var(--line);border-radius:var(--r-ctl);background:#fff;padding:13px;margin-bottom:10px;box-shadow:var(--shadow-soft)}
.subj-row{display:grid;grid-template-columns:1fr 1fr 30px;gap:8px;margin-bottom:8px;align-items:center}
.subj-rm{width:30px;height:34px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--bad);font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}
.subj-rm:hover{border-color:var(--bad);background:var(--bad-bg)}

/* calendar */
.cal-controls{display:grid;grid-template-columns:1fr;gap:11px}
.cal-controls .field{margin:0}
.cov-bar{background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--r-card);box-shadow:var(--shadow-soft);padding:14px 16px;margin-bottom:14px}
.cov-label{font-size:13px;color:var(--ink-mut);margin-bottom:8px}
.cov-label b{color:var(--ink)}
.cov-bar .bar{height:9px}
.tree-ch.done{color:var(--ink-mut);background:#FAFBF9}
.tree-ch.done input{accent-color:var(--ok)}
.cal-foot{position:sticky;bottom:0;padding:12px 0;display:flex;justify-content:flex-end}
.cal-foot .btn-primary{box-shadow:0 1px 2px rgba(26,24,19,.08),0 6px 20px rgba(240,180,41,.35)}
@media (min-width:680px){ .cal-controls{grid-template-columns:180px 1fr 1fr} }

/* loading overlay */
.overlay{position:fixed;inset:0;z-index:60;background:rgba(251,250,246,.86);backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;padding:24px}
.spinner{width:42px;height:42px;border-radius:50%;border:3px solid var(--brand-tint);border-top-color:var(--brand-deep);animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.overlay .ttl{font-size:17px;font-weight:600}
.overlay .sub{font-size:13px;color:var(--ink-mut);max-width:340px}

/* evaluate + reports */
.dropzone{border:1.5px dashed #d8d0bd;border-radius:var(--r-ctl);padding:26px 18px;text-align:center;color:var(--ink-mut);font-size:13.5px;cursor:pointer;transition:border-color .15s,background .15s}
.dropzone:hover,.dropzone.over{border-color:var(--brand);background:var(--brand-tint)}
.dropzone svg{width:30px;height:30px;color:var(--ink-faint);margin-bottom:8px}
.dropzone b{color:var(--brand-deep)}
.dz-note{font-size:11.5px;color:var(--ink-faint);margin-top:5px}
.sheet-img{width:100%;border:1px solid var(--line);border-radius:10px;display:block;margin-bottom:10px;box-shadow:var(--shadow-soft)}
.vchip{font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap}
.kvtags{display:flex;flex-wrap:wrap;gap:6px}
.kvtag{font-size:11.5px;font-weight:500;padding:4px 10px;border-radius:8px;background:#fff;border:1px solid var(--line);color:var(--ink-soft);box-shadow:var(--shadow-soft)}
.qcard.vb-correct{border-left:3px solid var(--ok)}
.qcard.vb-wrong{border-left:3px solid var(--bad)}
.qcard.vb-partial{border-left:3px solid var(--warn)}
.qcard.vb-unattempted,.qcard.vb-duplicate{border-left:3px solid var(--ink-faint)}
.qcomment{font-size:12.5px;color:var(--ink-mut);margin:8px 0 2px;padding:8px 11px;background:var(--ground);border-radius:9px}
.bigscore{font-size:36px;font-weight:700;letter-spacing:-0.03em;line-height:1}
.bigscore small{font-size:16px;font-weight:500;color:var(--ink-faint)}
.bigband{font-size:13px;color:var(--ink-mut);margin-top:4px;font-weight:600}
.gaps{display:flex;flex-wrap:wrap;gap:6px}
.gapchip{font-size:11.5px;font-weight:500;padding:4px 10px;border-radius:8px;background:var(--brand-tint);color:var(--warn)}
.stbl td,.stbl th{text-align:left;padding:7px 6px;border-bottom:1px solid var(--line-soft);font-size:12.5px}
.stbl th{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-faint);font-weight:700}
.stbl .pill{font-size:10.5px;padding:2px 8px}

@media (min-width:680px){
  .nav{display:flex}.bottomnav{display:none}.appbody{padding-bottom:28px}
  .page-head h1{font-size:26px}
  .wiz-grid{grid-template-columns:1fr 250px}
  .summary{display:block}.msummary{display:none}
  .rep-grid{grid-template-columns:1fr 290px}
}
@media (min-width:1000px){
  .wiz-grid{grid-template-columns:1fr 270px}
}
