:root{
  --ink:#0B1B2B; --ink2:#102639; --ink3:#0E2133;
  --line:#1E3A52; --line-faint:#122A40;
  --paper:#E8F0F7; --dim:#8FA9BE; --dim2:#5E7B93;
  --amber:#FFB454; --cyan:#4FC3F7; --green:#6FCF97; --red:#F2727D;
  --r:10px;
  --display:'Space Grotesk',system-ui,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,Menlo,Consolas,monospace;
  --body:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  background:var(--ink);
  background-image:linear-gradient(var(--line-faint) 1px,transparent 1px),linear-gradient(90deg,var(--line-faint) 1px,transparent 1px);
  background-size:28px 28px;
  color:var(--paper);font-family:var(--body);font-size:15px;line-height:1.55;
  min-height:100vh;
}
a{color:var(--cyan);text-decoration:none}
a:hover{text-decoration:underline}
code{font-family:var(--mono);font-size:.86em;background:var(--ink);border:1px solid var(--line);border-radius:5px;padding:1px 5px;color:var(--amber);white-space:nowrap}
strong{color:var(--paper)}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
button:focus-visible,a:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;border-radius:6px}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}

.wrap{max-width:880px;margin:0 auto;padding:0 14px 90px}
header.top{padding:18px 0 10px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.brand{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:.3px}
.brand small{display:block;font-family:var(--mono);font-weight:400;font-size:10.5px;color:var(--dim);letter-spacing:1.4px;text-transform:uppercase;margin-top:2px}
.scorechip{font-family:var(--mono);font-size:12px;color:var(--dim);border:1px solid var(--line);border-radius:999px;padding:5px 12px;background:var(--ink2);white-space:nowrap}
.scorechip b{color:var(--amber);font-size:14px}

nav.tabs{position:sticky;top:0;z-index:50;background:rgba(11,27,43,.92);backdrop-filter:blur(6px);margin:0 -14px;padding:0 14px;border-bottom:1px solid var(--line);display:flex;gap:2px;overflow-x:auto;scrollbar-width:none}
nav.tabs::-webkit-scrollbar{display:none}
nav.tabs button{font-family:var(--display);font-weight:500;font-size:13.5px;color:var(--dim);padding:12px 13px 10px;border-bottom:2px solid transparent;white-space:nowrap;flex-shrink:0}
nav.tabs button.on{color:var(--paper);border-bottom-color:var(--cyan)}
nav.tabs button:hover{color:var(--paper)}

main{padding-top:18px}
.view{display:none}.view.on{display:block}
h2.vt{font-family:var(--display);font-weight:700;font-size:21px;margin-bottom:4px}
p.vs{color:var(--dim);font-size:13.5px;margin-bottom:18px}

.panel{background:var(--ink2);border:1px solid var(--line);border-radius:var(--r);padding:16px;margin-bottom:14px}
.panel h3{font-family:var(--display);font-size:15px;font-weight:700;margin-bottom:10px}
.label{font-family:var(--mono);font-size:10.5px;letter-spacing:1.6px;text-transform:uppercase;color:var(--dim2);margin-bottom:8px}

.factgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(125px,1fr));gap:8px}
.fact{background:var(--ink3);border:1px solid var(--line);border-radius:8px;padding:10px 12px}
.fact b{font-family:var(--mono);font-size:16px;color:var(--paper);display:block}
.fact span{font-size:11.5px;color:var(--dim)}

.gaugewrap{display:flex;flex-wrap:wrap;gap:18px;align-items:center}
.gauge{flex-shrink:0}
.gstats{flex:1;min-width:200px;display:grid;gap:8px}
.gstat{display:flex;justify-content:space-between;font-size:13px;color:var(--dim);border-bottom:1px dashed var(--line);padding-bottom:6px}
.gstat b{color:var(--paper);font-family:var(--mono)}

.btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:500;font-size:13.5px;border:1px solid var(--line);background:var(--ink3);color:var(--paper);padding:9px 16px;border-radius:8px;transition:border-color .15s}
.btn:hover{border-color:var(--cyan)}
.btn.primary{background:var(--amber);color:#1C1206;border-color:var(--amber);font-weight:700}
.btn.primary:hover{filter:brightness(1.07)}
.btn.ghost{background:transparent}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btnrow{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}

.chips{display:flex;gap:7px;overflow-x:auto;padding-bottom:8px;margin-bottom:12px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex-shrink:0;font-size:12.5px;font-family:var(--mono);border:1px solid var(--line);background:var(--ink2);color:var(--dim);border-radius:999px;padding:6px 13px}
.chip.on{border-color:var(--cyan);color:var(--cyan);background:rgba(79,195,247,.08)}
.chip .n{opacity:.7}

.dombar{height:5px;background:var(--ink);border-radius:3px;overflow:hidden;margin-top:6px}
.dombar i{display:block;height:100%;background:var(--cyan)}

/* layout */
.day{margin-bottom:16px}
.dayhead{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.dayhead h3{font-family:var(--display);font-size:16px}
.dayhead span{font-family:var(--mono);font-size:11.5px;color:var(--dim)}
.block{background:var(--ink2);border:1px solid var(--line);border-radius:var(--r);padding:13px 15px;margin-bottom:9px}
.block .bt{display:flex;justify-content:space-between;gap:10px;margin-bottom:8px}
.block .bt b{font-family:var(--display);font-size:13.5px}
.block .bt span{font-family:var(--mono);font-size:10.5px;color:var(--amber);white-space:nowrap;letter-spacing:.5px}
.task{display:flex;gap:10px;align-items:flex-start;padding:6px 0;border-top:1px dashed var(--line-faint);font-size:13.5px;color:var(--dim);cursor:pointer}
.task input{margin-top:3px;accent-color:var(--amber);width:15px;height:15px;flex-shrink:0;cursor:pointer}
.task.done{color:var(--dim2);text-decoration:line-through}
.task .tk{flex:1}

/* domains */
.dom{border:1px solid var(--line);border-radius:var(--r);background:var(--ink2);margin-bottom:10px;overflow:hidden}
.dom>button{width:100%;text-align:left;padding:14px 16px;display:flex;align-items:center;gap:12px}
.dom .dn{font-family:var(--mono);font-size:11px;color:var(--dim2);flex-shrink:0}
.dom .dt{flex:1;font-family:var(--display);font-weight:700;font-size:14.5px}
.dom .dw{font-family:var(--mono);font-size:13px;color:var(--amber);flex-shrink:0}
.dom .arr{color:var(--dim2);transition:transform .2s;flex-shrink:0}
.dom.open .arr{transform:rotate(90deg)}
.dombody{display:none;padding:0 16px 16px;border-top:1px solid var(--line-faint)}
.dom.open .dombody{display:block}
.sec{margin-top:14px}
.sec h4{font-family:var(--display);font-size:13px;color:var(--cyan);margin-bottom:7px;letter-spacing:.2px}
.sec ul{list-style:none}
.sec li{position:relative;padding:5px 0 5px 16px;font-size:13.5px;color:var(--dim);border-top:1px dashed var(--line-faint)}
.sec li::before{content:'';position:absolute;left:0;top:13px;width:7px;height:1px;background:var(--dim2)}
.sec li strong{color:var(--paper)}
.trap{margin-top:14px;border:1px solid rgba(242,114,125,.4);background:rgba(242,114,125,.06);border-radius:8px;padding:11px 13px}
.trap h4{font-family:var(--mono);font-size:10.5px;letter-spacing:1.5px;color:var(--red);margin-bottom:7px}
.trap ul{list-style:none}
.trap li{padding:4px 0;font-size:13px;color:var(--dim)}
.trap li b{color:var(--red)}

/* flashcards */
.fcstage{perspective:1200px;margin-bottom:12px}
.fcard{position:relative;min-height:230px;cursor:pointer;transform-style:preserve-3d;transition:transform .45s}
.fcard.flip{transform:rotateY(180deg)}
.fface{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border:1px solid var(--line);border-radius:var(--r);background:var(--ink2);padding:20px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:10px}
.fface.back{transform:rotateY(180deg);border-color:var(--amber);background:var(--ink3)}
.fface .ftag{position:absolute;top:12px;left:14px;font-family:var(--mono);font-size:10px;letter-spacing:1.4px;color:var(--dim2);text-transform:uppercase}
.fface .fhint{position:absolute;bottom:11px;font-family:var(--mono);font-size:10px;color:var(--dim2);letter-spacing:1px}
.fface .ftxt{font-size:15.5px;line-height:1.5}
.fface.back .ftxt{font-size:14.5px;color:var(--paper)}
.fcontrols{display:flex;gap:8px}
.fcontrols .btn{flex:1;justify-content:center}
.fmeta{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11.5px;color:var(--dim2);margin-bottom:10px}

/* questions */
.qcard{background:var(--ink2);border:1px solid var(--line);border-radius:var(--r);padding:16px;margin-bottom:12px}
.qtop{display:flex;justify-content:space-between;gap:10px;font-family:var(--mono);font-size:10.5px;color:var(--dim2);letter-spacing:.8px;text-transform:uppercase;margin-bottom:10px}
.qsit{background:var(--ink);border:1px solid var(--line-faint);border-left:2px solid var(--cyan);border-radius:6px;padding:11px 13px;font-size:13.5px;color:var(--dim);margin-bottom:12px}
.qtext{font-family:var(--display);font-weight:700;font-size:15px;margin-bottom:13px}
.opt{display:flex;gap:11px;align-items:flex-start;width:100%;text-align:left;border:1px solid var(--line);background:var(--ink3);border-radius:8px;padding:11px 13px;margin-bottom:8px;font-size:13.5px;color:var(--paper);transition:border-color .12s}
.opt:hover{border-color:var(--dim2)}
.opt .ol{font-family:var(--mono);font-weight:600;font-size:12px;color:var(--dim2);border:1px solid var(--line);border-radius:5px;padding:1px 7px;flex-shrink:0;margin-top:1px}
.opt.sel{border-color:var(--cyan)}
.opt.ok{border-color:var(--green);background:rgba(111,207,151,.08)}
.opt.ok .ol{color:var(--green);border-color:var(--green)}
.opt.bad{border-color:var(--red);background:rgba(242,114,125,.07)}
.opt.bad .ol{color:var(--red);border-color:var(--red)}
.opt:disabled{cursor:default;opacity:1}
.opt:disabled:not(.ok):not(.bad){opacity:.5}
.expl{border:1px solid rgba(111,207,151,.35);background:rgba(111,207,151,.05);border-radius:8px;padding:12px 14px;font-size:13.5px;color:var(--dim);margin-top:4px}
.expl b.vh{color:var(--green);font-family:var(--mono);font-size:11px;letter-spacing:1.2px;display:block;margin-bottom:5px}
.qnav{display:flex;gap:8px;align-items:center;justify-content:space-between;margin-top:12px}
.qnav .mid{font-family:var(--mono);font-size:12px;color:var(--dim)}
.statrow{display:flex;gap:14px;font-family:var(--mono);font-size:11.5px;color:var(--dim);margin-bottom:12px;flex-wrap:wrap}
.statrow b{color:var(--paper)}
.statrow .g{color:var(--green)}.statrow .r{color:var(--red)}

/* exam */
.simbar{position:sticky;top:43px;z-index:40;background:var(--ink2);border:1px solid var(--line);border-radius:9px;padding:9px 14px;display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;font-family:var(--mono);font-size:12.5px}
.simbar .timer{font-size:17px;font-weight:600;color:var(--amber)}
.simbar .timer.low{color:var(--red)}
.dots{display:none;flex-wrap:wrap;gap:5px;margin-bottom:12px}
.dots.show{display:flex}
.dots button{width:26px;height:26px;border-radius:6px;border:1px solid var(--line);font-family:var(--mono);font-size:10px;color:var(--dim2);background:var(--ink2)}
.dots button.a{border-color:var(--cyan);color:var(--cyan)}
.dots button.cur{border-color:var(--amber);color:var(--amber)}
.passfail{font-family:var(--display);font-weight:700;font-size:15px;padding:8px 16px;border-radius:8px;display:inline-block;margin:6px 0 2px}
.passfail.p{background:rgba(111,207,151,.12);color:var(--green);border:1px solid rgba(111,207,151,.4)}
.passfail.f{background:rgba(242,114,125,.1);color:var(--red);border:1px solid rgba(242,114,125,.4)}
.scbar{margin-bottom:9px}
.scbar .sl{display:flex;justify-content:space-between;font-size:12px;color:var(--dim);margin-bottom:4px;font-family:var(--mono)}
.scbar .tr{height:7px;background:var(--ink);border-radius:4px;overflow:hidden}
.scbar .tr i{display:block;height:100%}
.note{border:1px solid rgba(255,180,84,.4);background:rgba(255,180,84,.06);border-radius:8px;padding:11px 14px;font-size:13px;color:var(--dim);margin-bottom:14px}
.note b{color:var(--amber)}
.linklist{list-style:none}
.linklist li{padding:7px 0;border-top:1px dashed var(--line-faint);font-size:13.5px}
.linklist li span{color:var(--dim2);font-family:var(--mono);font-size:11px;display:block}
hr.sep{border:none;border-top:1px solid var(--line);margin:16px 0}
.muted{color:var(--dim2);font-size:12.5px}

/* ====== Server-app extensions (dashboard, drill auto-next, tables) ====== */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:560px){.grid2{grid-template-columns:1fr}}
.card{background:var(--ink2);border:1px solid var(--line);border-radius:var(--r);padding:16px}
.card h3{font-family:var(--display);font-size:14px;letter-spacing:.4px;margin-bottom:8px}
.kpi{font-family:var(--mono);font-size:26px;color:var(--amber)}
.kpi small{font-size:11px;color:var(--dim2);display:block;letter-spacing:.8px;text-transform:uppercase}
.bigbtn{display:block;width:100%;text-align:left;background:var(--ink2);border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;color:var(--paper);cursor:pointer;font-family:var(--display);font-size:15px}
.bigbtn:hover{border-color:var(--amber)}
.bigbtn .sub{display:block;font-family:var(--body);font-size:12.5px;color:var(--dim);margin-top:3px}
.feedback{border-radius:var(--r);padding:12px 14px;margin-top:12px;font-size:14px;border:1px solid}
.feedback.ok{background:rgba(111,207,151,.10);border-color:var(--green)}
.feedback.bad{background:rgba(242,114,125,.10);border-color:var(--red)}
.feedback .verdict{font-family:var(--mono);font-size:12px;letter-spacing:1px;text-transform:uppercase;display:block;margin-bottom:6px}
.autonext{height:3px;background:var(--line);border-radius:2px;margin-top:10px;overflow:hidden}
.autonext>div{height:100%;background:var(--amber);width:100%;transform-origin:left;animation:an 2.6s linear forwards}
@keyframes an{from{transform:scaleX(1)}to{transform:scaleX(0)}}
.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th,.tbl td{border-bottom:1px solid var(--line-faint);padding:8px 6px;text-align:left;vertical-align:top}
.tbl th{font-family:var(--mono);font-size:10.5px;letter-spacing:.8px;text-transform:uppercase;color:var(--dim2)}
.bar{height:8px;background:var(--line-faint);border-radius:4px;overflow:hidden}
.bar>div{height:100%;background:var(--cyan)}
.pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10.5px;letter-spacing:.6px;padding:3px 8px;border:1px solid var(--line);border-radius:99px;color:var(--dim);transition:border-color .15s,color .15s}
.pill:hover{border-color:var(--accent,#888);color:var(--fg,#ddd)}
.pill-switch{font-size:9.5px;padding:1px 6px;border-radius:99px;background:var(--line);color:var(--dim)}
.pill:hover .pill-switch{background:var(--accent,#555);color:#fff}
.toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin:10px 0}
select,input[type=number],input[type=text]{background:var(--ink3);color:var(--paper);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-family:var(--mono);font-size:13px}
.toast{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);background:var(--ink3);border:1px solid var(--amber);color:var(--paper);padding:10px 16px;border-radius:10px;font-size:13.5px;z-index:50}
.switch{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--dim);cursor:pointer;user-select:none}
.switch input{accent-color:var(--amber)}
.badge{display:inline-block;min-width:17px;text-align:center;background:var(--amber);color:var(--ink);border-radius:99px;font-family:var(--mono);font-size:10px;padding:1px 5px;margin-left:6px;vertical-align:1px}
/* Option states used by the views (equivalent to the inherited sel/ok/bad) */
.opt.picked{border-color:var(--cyan)}
.opt.picked .ol{color:var(--cyan);border-color:var(--cyan)}
.opt.right{border-color:var(--green);background:rgba(111,207,151,.08)}
.opt.right .ol{color:var(--green);border-color:var(--green)}
.opt.wrong{border-color:var(--red);background:rgba(242,114,125,.07)}
.opt.wrong .ol{color:var(--red);border-color:var(--red)}
.opt:disabled:not(.right):not(.wrong){opacity:.5}
.opts{margin-top:6px}
.qfoot{margin-top:2px}
/* Exam question map */
.qmap{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:6px}
.qm{font-family:var(--mono);font-size:12px;padding:7px 0;border:1px solid var(--line);border-radius:7px;background:var(--ink3);color:var(--dim)}
.qm.done{color:var(--paper);border-color:var(--dim2)}
.qm.cur{border-color:var(--amber);color:var(--amber)}
#examTimer.low{border-color:var(--red);color:var(--red)}

/* Reports tables */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;color:var(--muted);font-weight:600;padding:6px 8px;border-bottom:1px solid var(--line)}
.tbl td{padding:6px 8px;border-bottom:1px solid var(--line)}
.tbl tr:hover td{background:rgba(255,180,84,.05)}

/* Exam: mark-for-review */
.qm.marked{box-shadow:0 0 0 2px var(--amber, #FFB454) inset}
.statrow .y b{color:var(--amber, #FFB454)}
/* Print: clean report output for Save-as-PDF */
@media print{
  #nav, header, .toolbar, .btn, .btnrow, #rpLogsPanel .row, select, input{display:none !important}
  body{background:#fff;color:#000}
  .panel,.card{border-color:#ccc;box-shadow:none;background:#fff}
  .view{display:block !important}
  .view:not(.on){display:none !important}
}

/* Recommended-next card (dashboard): the single highest-impact action, one click */
.reco{display:block;width:100%;text-align:left;background:linear-gradient(180deg,rgba(255,180,84,.10),var(--ink2));border:1px solid var(--amber);border-radius:var(--r);padding:16px;margin-bottom:14px;transition:filter .15s,transform .05s}
.reco:hover{filter:brightness(1.06)}
.reco:active{transform:translateY(1px)}
.reco-k{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:1.6px;text-transform:uppercase;color:var(--amber);margin-bottom:6px}
.reco-t{display:block;font-family:var(--display);font-weight:700;font-size:17px;color:var(--paper)}
.reco-d{display:block;font-size:13px;color:var(--dim);margin:4px 0 12px;line-height:1.5}
.reco-cta{display:inline-block;font-family:var(--display);font-weight:700;font-size:13.5px;background:var(--amber);color:#1C1206;padding:8px 14px;border-radius:8px}

/* Exam-readiness panel: conic-gradient ring + level + focus gaps */
.rdy{display:flex;gap:16px;align-items:center}
.rdy-ring{position:relative;width:92px;height:92px;flex-shrink:0;border-radius:50%;background:conic-gradient(var(--col) calc(var(--p)*1%),var(--ink3) 0);display:grid;place-items:center}
.rdy-ring::before{content:'';position:absolute;width:70px;height:70px;border-radius:50%;background:var(--ink2)}
.rdy-ring b{position:relative;font-family:var(--mono);font-size:22px;color:var(--paper)}
.rdy-ring b i{font-size:12px;color:var(--dim);font-style:normal}
.rdy-body{flex:1;min-width:0}
.rdy-lvl{font-family:var(--display);font-weight:700;font-size:16px;margin:2px 0}

/* Command palette + shortcut-help overlay */
.cmdk-backdrop{position:fixed;inset:0;z-index:200;background:rgba(7,18,30,.66);backdrop-filter:blur(3px);display:flex;align-items:flex-start;justify-content:center;padding:12vh 14px 0;animation:cmdk-in .12s ease-out}
@keyframes cmdk-in{from{opacity:0}to{opacity:1}}
.cmdk{width:100%;max-width:540px;background:var(--ink2);border:1px solid var(--line);border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.5);overflow:hidden}
.cmdk-input{width:100%;border:none;background:transparent;color:var(--paper);font-family:var(--display);font-size:16px;padding:16px 18px;border-bottom:1px solid var(--line);outline:none}
.cmdk-list{max-height:46vh;overflow-y:auto;padding:6px}
.cmdk-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;font-size:14px;cursor:pointer}
.cmdk-item.on{background:rgba(79,195,247,.12);color:var(--paper)}
.cmdk-hint{font-family:var(--mono);font-size:11px;color:var(--dim2)}
.cmdk-empty{padding:14px;color:var(--dim);font-size:13px}
.cmdk-foot{display:flex;gap:14px;padding:9px 16px;border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;color:var(--dim2)}
.cmdk.help{padding:18px}
.cmdk.help h3{font-family:var(--display);font-size:16px;margin-bottom:12px}
.cmdk-keys{width:100%;border-collapse:collapse}
.cmdk-keys td{padding:7px 8px;border-bottom:1px solid var(--line-faint);font-size:13.5px;color:var(--dim)}
.cmdk-keys td:first-child{width:140px}
.cmdk-keys kbd{font-family:var(--mono);font-size:11.5px;background:var(--ink3);border:1px solid var(--line);border-radius:5px;padding:2px 7px;color:var(--paper)}
.cmdk.help .cmdk-foot{margin-top:12px;padding:9px 0 0}
.cmdk-open{cursor:pointer;font-family:var(--mono)}

/* Drill confidence check */
.confbar{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-bottom:10px;background:var(--ink3);border:1px solid var(--line);border-radius:8px;padding:8px 10px}
.confbar-l{font-size:12.5px;color:var(--dim);margin-right:2px}
.confb{font-family:var(--display);font-size:12.5px;border:1px solid var(--line);background:var(--ink2);color:var(--dim);padding:5px 11px;border-radius:7px;transition:border-color .12s,color .12s}
.confb:hover{border-color:var(--cyan)}
.confb.on{border-color:var(--cyan);color:var(--cyan);background:rgba(79,195,247,.10)}

/* Spaced-repetition: next-review hint after answering in Review */
.srs-next{font-size:12px;color:var(--dim);margin-top:8px;font-family:var(--mono)}

/* Structured feedback: a small label before the explanation */
.why-label{font-family:var(--mono);font-size:10px;letter-spacing:1.4px;text-transform:uppercase;color:var(--dim2);margin:8px 0 3px}

/* Progress-over-time sparkline */
.spark{display:block;margin:8px 0;background:var(--ink3);border:1px solid var(--line);border-radius:8px}
.spark-line{fill:none;stroke:var(--cyan);stroke-width:2;vector-effect:non-scaling-stroke}
.spark-dot{fill:var(--amber)}
.spark-pass{stroke:var(--green);stroke-width:1;stroke-dasharray:3 3;opacity:.5;vector-effect:non-scaling-stroke}

/* Profile selection ("Who is studying?") — responsive cards instead of unstyled buttons */
.profile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:10px;margin-top:2px}
.pcard{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:var(--ink3);border:1px solid var(--line);border-radius:12px;padding:12px 14px;color:var(--paper);cursor:pointer;transition:border-color .15s,background .15s,transform .05s}
.pcard:hover{border-color:var(--cyan);background:var(--ink2)}
.pcard:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}
.pcard:active{transform:translateY(1px)}
.pcard-av{flex-shrink:0;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:18px;color:#0B1B2B;background:var(--cyan)}
.pcard-av.admin{background:var(--amber)}
.pcard-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;overflow:hidden}
.pcard-name{font-family:var(--display);font-weight:700;font-size:15px;color:var(--paper);display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pcard-lock{font-size:11px;flex-shrink:0}
.pcard-role{font-size:11.5px;color:var(--dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pcard-go{flex-shrink:0;font-size:18px;color:var(--dim2);transition:color .15s,transform .15s}
.pcard:hover .pcard-go{color:var(--cyan);transform:translateX(2px)}

/* Public sign-in screen: hide branding, tabs and pills so nothing hints at the product */
body.anon header.top{display:none}
body.anon nav.tabs{display:none}
