/* ===========================================================================
   Statistics dashboard — "Clinical Dashboard" (design A).

   Everything is scoped under .statdash and every custom property is prefixed
   --sd- so the Plum Dusk palette here never clobbers the app-wide tokens
   (--paper / --accent / --ink) that drive the Tailwind theme. Fonts reference
   the families already loaded app-wide (Geist / Fraunces / Geist Mono) with
   system fallbacks, so no new font request is added.
   =========================================================================== */

.statdash {
  --sd-paper: #f4f2f4;
  --sd-paper-2: #e8e4ea;
  --sd-paper-inset: #dfd9e2;
  --sd-ink: #1a1620;
  --sd-ink-soft: #423a48;
  --sd-ink-mute: #6c6474;
  --sd-ink-faint: #938c9b;
  --sd-accent: #7a3e86;
  --sd-accent-hover: #683472;
  --sd-good: #3f7d5a;
  --sd-warn: #b0852f;
  --sd-bad: #a8394f;
  --sd-line: rgba(26, 22, 32, 0.10);
  --sd-line-2: rgba(26, 22, 32, 0.16);
  --sd-shadow: 0 1px 2px rgba(26, 22, 32, 0.04), 0 4px 14px rgba(26, 22, 32, 0.05);
  --sd-radius: 12px;
  --sd-radius-sm: 9px;
  --sd-mono: "Geist Mono", ui-monospace, "SFMono-Regular", monospace;
  --sd-ui: "Geist", system-ui, -apple-system, "Inter", sans-serif;
  --sd-display: "Fraunces", "Iowan Old Style", Georgia, serif;

  font-family: var(--sd-ui);
  color: var(--sd-ink);
  background: var(--sd-paper);
  background-image:
    radial-gradient(1200px 600px at 100% -10%, rgba(122, 62, 134, 0.06), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(122, 62, 134, 0.045), transparent 55%);
  -webkit-font-smoothing: antialiased;
  line-height: 1.45;
  letter-spacing: 0.005em;
  min-height: 100%;
}

.statdash * { box-sizing: border-box; }
.statdash a { color: inherit; text-decoration: none; }
.statdash .sd-mono { font-family: var(--sd-mono); font-variant-numeric: tabular-nums; }

.sd-wrap { max-width: 1220px; margin: 0 auto; padding: 22px 22px 64px; }

/* ---- Top bar ---- */
.sd-topbar {
  display: flex; align-items: center; justify-content: space-between; gap: 18px;
  flex-wrap: wrap; margin-bottom: 20px;
}
.sd-brand { display: flex; align-items: center; gap: 12px; }
.sd-glyph {
  width: 38px; height: 38px; border-radius: 10px; flex: 0 0 auto;
  background: linear-gradient(150deg, var(--sd-accent), #9a5aa6);
  display: grid; place-items: center; color: #fff; font-family: var(--sd-display);
  font-weight: 600; font-size: 20px; box-shadow: 0 4px 12px rgba(122, 62, 134, 0.30);
}
.sd-brand__title { font-family: var(--sd-display); font-weight: 600; font-size: 22px; margin: 0; letter-spacing: -0.01em; }
.sd-brand__sub { font-size: 12px; color: var(--sd-ink-mute); margin-top: 1px; font-variant: all-small-caps; letter-spacing: 0.08em; }

.sd-seg {
  display: inline-flex; background: var(--sd-paper-2); border: 1px solid var(--sd-line);
  border-radius: 10px; padding: 3px; gap: 2px; box-shadow: inset 0 1px 2px rgba(26, 22, 32, 0.04);
  margin: 0;
}
.sd-seg button {
  font-family: var(--sd-mono); font-size: 12px; font-weight: 500; color: var(--sd-ink-mute);
  border: 0; background: transparent; padding: 6px 13px; border-radius: 7px; cursor: pointer; transition: 0.16s;
}
.sd-seg button[aria-pressed="true"] { background: var(--sd-paper); color: var(--sd-ink); box-shadow: var(--sd-shadow); font-weight: 600; }
.sd-seg button:hover[aria-pressed="false"] { color: var(--sd-ink); }

.sd-meta-row { display: flex; gap: 10px; align-items: center; color: var(--sd-ink-mute); font-size: 12px; }
.sd-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--sd-good); box-shadow: 0 0 0 3px rgba(63, 125, 90, 0.18); }
.sd-topbar__controls { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }

/* ---- grid ---- */
.sd-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 14px; }
.sd-card {
  background: var(--sd-paper); border: 1px solid var(--sd-line); border-radius: var(--sd-radius);
  box-shadow: var(--sd-shadow); padding: 16px; position: relative;
}
.sd-card--tint { background: linear-gradient(180deg, #faf9fb, var(--sd-paper)); }
.sd-card__h {
  font-size: 11px; font-weight: 600; letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--sd-ink-faint); margin: 0 0 12px; display: flex; align-items: center; gap: 8px;
}
.sd-card__h .sd-ic { width: 15px; height: 15px; color: var(--sd-accent); flex: 0 0 auto; }
.sd-span3 { grid-column: span 3; }
.sd-span4 { grid-column: span 4; }
.sd-span5 { grid-column: span 5; }
.sd-span6 { grid-column: span 6; }
.sd-span7 { grid-column: span 7; }
.sd-span8 { grid-column: span 8; }
.sd-span12 { grid-column: span 12; }

/* ---- KPI ---- */
.sd-kpi__big { font-family: var(--sd-display); font-weight: 600; font-size: 38px; line-height: 1; letter-spacing: -0.02em; display: flex; align-items: baseline; gap: 5px; }
.sd-kpi__big small { font-size: 16px; color: var(--sd-ink-mute); font-family: var(--sd-ui); font-weight: 500; }
.sd-kpi__lbl { font-size: 11px; color: var(--sd-ink-faint); text-transform: uppercase; letter-spacing: 0.09em; font-weight: 600; margin-bottom: 9px; }
.sd-kpi__delta { font-family: var(--sd-mono); font-size: 12px; font-weight: 600; display: inline-flex; align-items: center; gap: 3px; margin-top: 10px; padding: 2px 7px; border-radius: 20px; }
.sd-kpi__delta--up { color: var(--sd-good); background: rgba(63, 125, 90, 0.10); }
.sd-kpi__delta--dn { color: var(--sd-bad); background: rgba(168, 57, 79, 0.10); }
.sd-kpi__delta--flat { color: var(--sd-ink-mute); background: rgba(26, 22, 32, 0.05); }
.sd-band { display: inline-block; font-size: 11px; font-weight: 600; font-family: var(--sd-mono); padding: 3px 9px; border-radius: 6px; background: rgba(122, 62, 134, 0.10); color: var(--sd-accent); margin-top: 10px; letter-spacing: 0.02em; }
.sd-streak { display: flex; gap: 3px; margin-top: 11px; }
.sd-streak i { width: 9px; height: 18px; border-radius: 3px; background: var(--sd-paper-inset); }
.sd-streak i.f { background: var(--sd-accent); }
.sd-streak i.t { background: rgba(122, 62, 134, 0.45); }

/* ---- competency / section list ---- */
.sd-comp { display: flex; flex-direction: column; gap: 2px; }
.sd-comp .sd-row {
  display: grid; grid-template-columns: 150px 1fr 64px 70px 56px; gap: 12px; align-items: center;
  padding: 9px 8px; border-radius: 9px; transition: 0.14s;
}
.sd-comp .sd-row:hover { background: var(--sd-paper-2); }
.sd-comp .sd-row + .sd-row { border-top: 1px solid var(--sd-line); }
.sd-name { font-weight: 600; font-size: 13.5px; display: flex; align-items: center; gap: 8px; min-width: 0; }
.sd-name span.sd-label { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sd-pip { width: 8px; height: 8px; border-radius: 3px; flex: 0 0 auto; }
.sd-pip.s { background: var(--sd-good); }
.sd-pip.m { background: var(--sd-warn); }
.sd-pip.w { background: var(--sd-bad); }
.sd-pip.n { background: var(--sd-ink-faint); }
.sd-bar { height: 8px; border-radius: 6px; background: var(--sd-paper-inset); overflow: hidden; position: relative; }
.sd-bar > span { position: absolute; inset: 0 auto 0 0; border-radius: 6px; }
.sd-bar .sd-ghost { position: absolute; top: -3px; width: 2px; height: 14px; background: var(--sd-ink-faint); border-radius: 2px; opacity: 0.7; }
.sd-scoreval { font-family: var(--sd-mono); font-weight: 600; font-size: 15px; text-align: right; }
.sd-scoreval--dim { color: var(--sd-ink-faint); }
.sd-recent { font-family: var(--sd-mono); font-size: 11px; text-align: right; color: var(--sd-ink-mute); }
.sd-recent b.up { color: var(--sd-good); }
.sd-recent b.dn { color: var(--sd-bad); }
.sd-pctband { font-family: var(--sd-mono); font-size: 10.5px; font-weight: 600; text-align: center; padding: 3px 0; border-radius: 5px; }
.sd-pctband.top { background: rgba(63, 125, 90, 0.12); color: var(--sd-good); }
.sd-pctband.mid { background: rgba(176, 133, 47, 0.13); color: var(--sd-warn); }
.sd-pctband.low { background: rgba(168, 57, 79, 0.12); color: var(--sd-bad); }
.sd-pctband.none { background: rgba(26, 22, 32, 0.05); color: var(--sd-ink-faint); }
.sd-comp-head { display: grid; grid-template-columns: 150px 1fr 64px 70px 56px; gap: 12px; padding: 0 8px 8px; font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--sd-ink-faint); font-weight: 600; }
.sd-comp-head span:nth-child(3), .sd-comp-head span:nth-child(4), .sd-comp-head span:nth-child(5) { text-align: right; }
.sd-comp-head span:nth-child(5) { text-align: center; }
.sd-comp__empty { color: var(--sd-ink-mute); font-size: 13px; padding: 18px 8px; }
.sd-comp__toggle { margin-top: 10px; background: transparent; border: 1px solid var(--sd-line-2); color: var(--sd-accent); font-weight: 600; font-size: 12px; padding: 7px 12px; border-radius: 8px; cursor: pointer; }
.sd-comp__toggle:hover { background: var(--sd-paper-2); }
.sd-comp .sd-row--hidden,
.sd-comp .progress-specialty__row--hidden { display: none; }

/* ---- small-sample confidence guard ---- */
/* Let the name column stack the label and the confidence meta line. */
.sd-comp .sd-row .sd-name { flex-wrap: wrap; row-gap: 1px; }
.sd-conf {
  font-family: var(--sd-mono); font-size: 10px; font-weight: 600;
  color: var(--sd-ink-faint); letter-spacing: 0.02em;
  flex-basis: 100%; padding-left: 16px;
  display: inline-flex; align-items: center; gap: 6px;
}
.sd-conf--low { color: var(--sd-warn); }
.sd-conf__pill {
  font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em;
  padding: 1px 6px; border-radius: 5px;
  background: rgba(176, 133, 47, 0.14); color: var(--sd-warn);
}
/* Hedge thin samples so a 1–2 attempt row never reads as a firm result. */
.sd-comp .sd-row--lowconf .sd-bar > span { opacity: 0.5; }
.sd-comp .sd-row--lowconf .sd-scoreval { color: var(--sd-ink-mute); font-weight: 500; }

/* ---- trends ---- */
.sd-legend { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 6px; font-size: 11.5px; color: var(--sd-ink-soft); }
.sd-legend i { display: inline-flex; align-items: center; gap: 6px; font-style: normal; }
.sd-legend i b { width: 14px; height: 3px; border-radius: 2px; display: inline-block; }
.sd-chartwrap { width: 100%; }
.sd-axhint { font-size: 9.5px; fill: var(--sd-ink-faint); font-family: var(--sd-mono); }
.sd-chart-empty { font-size: 12px; color: var(--sd-ink-mute); padding: 24px 4px; line-height: 1.5; }

/* ---- form breakdown ---- */
.sd-forms { display: flex; flex-direction: column; gap: 11px; }
.sd-formrow { display: grid; grid-template-columns: 110px 1fr 44px; gap: 11px; align-items: center; }
.sd-formrow .sd-fn { font-size: 12.5px; font-weight: 600; color: var(--sd-ink-soft); }
.sd-formrow .sd-fv { font-family: var(--sd-mono); font-weight: 600; font-size: 13px; text-align: right; }

/* ---- pace (aptitude) ---- */
.sd-pace { display: flex; flex-direction: column; gap: 10px; }
.sd-pacerow { display: grid; grid-template-columns: 1fr auto auto; gap: 12px; align-items: center; padding: 8px 0; border-bottom: 1px solid var(--sd-line); }
.sd-pacerow:last-child { border-bottom: 0; }
.sd-pacerow .sd-pn { font-size: 12.5px; font-weight: 600; color: var(--sd-ink-soft); }
.sd-pacerow .sd-pacev { font-family: var(--sd-mono); font-weight: 600; font-size: 14px; }
.sd-pacerow .sd-paceacc { font-family: var(--sd-mono); font-size: 11px; color: var(--sd-ink-mute); }

/* ---- crosstab heatmap ---- */
.sd-heat { display: grid; gap: 4px; font-size: 10.5px; }
.sd-heat .sd-hc { aspect-ratio: 1.5 / 1; border-radius: 6px; display: grid; place-items: center; font-family: var(--sd-mono); font-weight: 600; font-size: 11px; color: var(--sd-ink); }
.sd-heat .sd-hc--empty { color: var(--sd-ink-faint); background: var(--sd-paper-2); }
.sd-heat .sd-hlbl { display: grid; place-items: center; font-weight: 600; color: var(--sd-ink-mute); font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.04em; text-align: center; padding: 2px; }
.sd-heat .sd-rlbl { display: flex; align-items: center; font-weight: 600; font-size: 11px; color: var(--sd-ink-soft); padding-right: 4px; }
.sd-heat__read { font-size: 11.5px; color: var(--sd-ink-mute); margin: 13px 0 0; line-height: 1.5; }
.sd-heat__read b { color: var(--sd-ink-soft); }
.sd-heat__read b.bad { color: var(--sd-bad); }

/* ---- ledger ---- */
.sd-ledger { display: flex; flex-direction: column; gap: 9px; }
.sd-miss { display: flex; gap: 11px; padding: 11px; border-radius: 9px; border: 1px solid var(--sd-line); background: var(--sd-paper-2); }
.sd-miss.good { background: rgba(63, 125, 90, 0.06); border-color: rgba(63, 125, 90, 0.22); }
.sd-miss .sd-mk { width: 26px; height: 26px; border-radius: 7px; flex: 0 0 auto; display: grid; place-items: center; color: #fff; font-weight: 700; font-size: 13px; }
.sd-miss .sd-mk.b { background: var(--sd-bad); }
.sd-miss .sd-mk.g { background: var(--sd-good); }
.sd-miss .sd-mk.p { background: var(--sd-accent); }
.sd-miss .sd-mt { font-size: 13px; font-weight: 600; margin-bottom: 2px; line-height: 1.35; }
.sd-miss .sd-md { font-size: 11.5px; color: var(--sd-ink-mute); }
.sd-miss .sd-md strong { color: var(--sd-ink-soft); }
.sd-miss .sd-tag { font-family: var(--sd-mono); font-size: 10px; font-weight: 600; color: var(--sd-accent); background: rgba(122, 62, 134, 0.10); padding: 1px 6px; border-radius: 5px; margin-left: 5px; white-space: nowrap; }
.sd-ledger__empty { font-size: 12px; color: var(--sd-ink-mute); line-height: 1.5; }

/* ---- coach ---- */
.sd-coach { background: linear-gradient(155deg, #241a2a, #3a2942); color: #efe9f1; border: 1px solid rgba(122, 62, 134, 0.5); box-shadow: 0 10px 30px rgba(36, 26, 42, 0.30); }
.sd-coach .sd-card__h { color: rgba(239, 233, 241, 0.6); }
.sd-coach .sd-card__h .sd-ic { color: #c79ad0; }
.sd-coach__head { font-family: var(--sd-display); font-size: 21px; font-weight: 600; letter-spacing: -0.01em; line-height: 1.25; margin-bottom: 14px; }
.sd-coach__head b { color: #d9a8e4; font-weight: 600; }
.sd-actions { display: flex; flex-direction: column; gap: 10px; }
.sd-act { display: flex; gap: 11px; padding: 11px; border-radius: 9px; background: rgba(255, 255, 255, 0.05); border: 1px solid rgba(255, 255, 255, 0.08); }
.sd-act__n { font-family: var(--sd-mono); font-size: 12px; font-weight: 700; color: #c79ad0; flex: 0 0 auto; width: 18px; }
.sd-act__t { font-size: 12.5px; line-height: 1.45; color: #e7dfea; }
.sd-act__t em { font-style: normal; color: #fff; font-weight: 600; background: rgba(199, 154, 208, 0.18); padding: 0 4px; border-radius: 4px; }
.sd-act__cta { margin-top: 8px; display: inline-flex; align-items: center; gap: 4px; font-size: 11px; font-weight: 600; color: #d9a8e4; background: transparent; border: 0; padding: 0; cursor: pointer; }
.sd-coach__foot { margin-top: 13px; font-size: 11px; color: rgba(239, 233, 241, 0.55); display: flex; align-items: center; gap: 7px; font-family: var(--sd-mono); }
.sd-why { margin-top: 7px; font-size: 11px; }
.sd-why > summary { cursor: pointer; color: rgba(239, 233, 241, 0.6); list-style: none; user-select: none; }
.sd-why > summary::-webkit-details-marker { display: none; }
.sd-why > summary:hover { color: #d9a8e4; }
.sd-why > summary:focus-visible { outline: 1px solid rgba(217, 168, 228, 0.7); outline-offset: 2px; border-radius: 3px; }
.sd-why[open] > summary { color: #d9a8e4; margin-bottom: 5px; }
.sd-why ul { margin: 0; padding-left: 15px; display: flex; flex-direction: column; gap: 3px; }
.sd-why li { color: rgba(231, 223, 234, 0.78); line-height: 1.4; }

/* ---- next / playlist ---- */
.sd-play { display: flex; flex-direction: column; gap: 8px; }
.sd-pl { display: grid; grid-template-columns: 30px 1fr auto; gap: 12px; align-items: center; padding: 11px; border-radius: 10px; border: 1px solid var(--sd-line); background: var(--sd-paper); transition: 0.16s; cursor: pointer; }
.sd-pl:hover { border-color: var(--sd-accent); box-shadow: 0 4px 16px rgba(122, 62, 134, 0.12); transform: translateY(-1px); }
.sd-pl__rk { font-family: var(--sd-display); font-size: 20px; font-weight: 600; color: var(--sd-ink-faint); text-align: center; }
.sd-pl__pt { font-size: 13px; font-weight: 600; line-height: 1.3; }
.sd-pl__pd { font-size: 11px; color: var(--sd-ink-mute); margin-top: 2px; display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.sd-chip { font-family: var(--sd-mono); font-size: 9.5px; font-weight: 600; padding: 1px 6px; border-radius: 5px; text-transform: uppercase; letter-spacing: 0.03em; }
.sd-chip--due { background: rgba(168, 57, 79, 0.12); color: var(--sd-bad); }
.sd-chip--weak { background: rgba(176, 133, 47, 0.14); color: var(--sd-warn); }
.sd-chip--form { background: rgba(122, 62, 134, 0.10); color: var(--sd-accent); }
.sd-chip--rev { background: rgba(63, 125, 90, 0.12); color: var(--sd-good); }
.sd-cta { font-family: var(--sd-ui); font-size: 12px; font-weight: 600; color: #fff; background: var(--sd-accent); border: 0; padding: 7px 14px; border-radius: 8px; cursor: pointer; white-space: nowrap; transition: 0.16s; display: inline-block; }
.sd-cta:hover { background: var(--sd-accent-hover); }
.sd-cta--ghost { background: transparent; color: var(--sd-accent); border: 1px solid var(--sd-line-2); }
.sd-cta--ghost:hover { background: var(--sd-paper-2); }

.sd-splitstat { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.sd-ministat { padding: 12px; border: 1px solid var(--sd-line); border-radius: 9px; background: var(--sd-paper-2); }
.sd-ministat .l { font-size: 10px; color: var(--sd-ink-faint); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600; }
.sd-ministat .v { font-family: var(--sd-mono); font-size: 22px; font-weight: 600; margin-top: 4px; }

/* ---- empty / stub ---- */
.sd-stub { text-align: center; padding: 40px 20px; }
.sd-stub__title { font-family: var(--sd-display); font-size: 20px; font-weight: 600; margin: 0 0 8px; }
.sd-stub__sub { font-size: 13px; color: var(--sd-ink-mute); max-width: 460px; margin: 0 auto 18px; line-height: 1.5; }
.sd-stub__ctas { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }

@media (max-width: 1000px) {
  .sd-span3 { grid-column: span 6; }
  .sd-span4 { grid-column: span 6; }
  .sd-span5 { grid-column: span 12; }
  .sd-span6 { grid-column: span 12; }
  .sd-span7 { grid-column: span 12; }
  .sd-span8 { grid-column: span 12; }
}
@media (max-width: 620px) {
  .sd-wrap { padding: 16px 14px 56px; }
  .sd-span3 { grid-column: span 12; }
  .sd-span4 { grid-column: span 12; }
  .sd-comp .sd-row, .sd-comp-head { grid-template-columns: 1fr 56px 60px; }
  .sd-comp .sd-row .sd-bar, .sd-comp-head span:nth-child(2) { display: none; }
  .sd-comp .sd-row .sd-recent, .sd-comp-head span:nth-child(4) { display: none; }
  .sd-kpi__big { font-size: 32px; }
}
