/* =====================================================================
   RankForge2 PWA — styles.css
   ---------------------------------------------------------------------
   The Mission Control design tokens load first from css/tokens.css
   (= docs/design-system/tokens.css). The :root / [data-theme="light"]
   blocks below hold the THEME values + backward-compat ALIASES that map
   the old v1 token names (--c-primary, --n-0, --fs-*, …) onto the Mission
   Control tokens (--cy, --bg, --fs-*, …) so legacy rules keep working;
   new rules reference the MC tokens directly. Every component rule
   references tokens via var(). No raw hex / font-size / spacing / radius /
   shadow literal appears outside these token blocks (exceptions: @media
   breakpoint conditions where CSS forbids var(); border-widths, fixed
   dimensions, blur + motion offsets; unitless line-height/opacity/z-index).
   ===================================================================== */

/* ---------------------------------------------------------------------
   1. Design tokens — DARK (default)
   --------------------------------------------------------------------- */
:root {
  /* Tell the UA this surface is dark so native controls/scrollbars match. */
  color-scheme: dark;

  /* 2a. Accent palette — aliased onto the Mission Control instrument set
     (defined in tokens.css, loaded first). ONE mapping serves both themes:
     every var(--cy)/(--amber)/(--green)… is itself theme-aware in tokens.css,
     so the [data-theme="light"] flip flows through automatically. */
  --c-primary: var(--cy);
  --c-primary-70: var(--dv-3);
  --c-primary-30: var(--dv-1);
  --c-primary-15: var(--cysoft);
  --c-secondary: var(--violet);
  --c-secondary-70: var(--violet);
  --c-secondary-30: var(--violet);
  --c-secondary-15: color-mix(in srgb, var(--violet) 12%, transparent);
  --c-tertiary: var(--amber);
  --c-tertiary-70: var(--amber);
  --c-tertiary-30: var(--amber);
  --c-tertiary-15: var(--ambersoft);
  --success: var(--green);
  --danger: var(--red);

  /* 2b. Neutral ramp → flight-deck surfaces + ink (theme-aware via tokens.css) */
  --n-0: var(--bg);
  --n-10: var(--panel);
  --n-20: var(--panel2);
  --n-30: var(--raised);
  --n-40: var(--line2);
  --n-50: var(--tx4);
  --n-55: var(--tx4);
  --n-70: var(--tx3);
  --n-90: var(--tx2);
  --n-95: var(--tx);
  --n-99: var(--tx);

  /* 2c. Painted atmosphere */
  --bg-paint-1: color-mix(in srgb, var(--violet) 10%, transparent);
  --bg-paint-2: var(--cysoft);
  --border-hairline: var(--line);
  --border-hairline-strong: var(--line2);
  --border-hairline-soft: var(--line);
  --border-hairline-emphasis: var(--line2);
  --surface-topbar: color-mix(in srgb, var(--panel) 82%, transparent);
  --surface-raised: var(--panel);
  --surface-card-top: var(--panel);
  --surface-card-bot: var(--panel);
  --on-primary: var(--cyink);

  /* 2d. Effect tokens — cyan instrument glow + telemetry washes */
  --focus-ring: var(--cyline);
  --focus-ring-soft: var(--cysoft);
  --ring-primary-soft: var(--cyline);
  --ring-primary-nav: var(--cyline);
  --accent-primary-soft: var(--cyline);
  --accent-primary-medium: var(--cyline);
  --accent-primary-strong: var(--cyline);
  --accent-primary-work: var(--cyline);
  --accent-secondary-soft: color-mix(in srgb, var(--violet) 25%, transparent);
  --accent-secondary-medium: color-mix(in srgb, var(--violet) 30%, transparent);
  --accent-secondary-chip: color-mix(in srgb, var(--violet) 35%, transparent);
  --accent-tertiary-soft: var(--amberline);
  --accent-tertiary-chip: var(--amberline);
  --accent-tertiary-sacred: var(--amberline);
  --accent-tertiary-mock: var(--amberline);
  --wash-primary: var(--cysoft);
  --wash-secondary: color-mix(in srgb, var(--violet) 8%, transparent);
  --wash-tertiary: var(--ambersoft);
  --wash-primary-chip: var(--cysoft);
  --wash-secondary-chip: color-mix(in srgb, var(--violet) 10%, transparent);
  --wash-tertiary-chip: var(--ambersoft);
  --glow-primary: var(--glow);
  --glow-primary-strong: var(--glow);
  --glow-primary-soft: var(--cysoft);
  --glow-primary-text: var(--cyline);
  --glow-success-text: var(--greensoft);
  --glow-success: color-mix(in srgb, var(--green) 50%, transparent);
  --glow-danger: color-mix(in srgb, var(--red) 50%, transparent);
  --accent-success-break: var(--green);
  --wash-success-break: var(--greensoft);

  /* Danger / success washes (used by alert chips) */
  --wash-danger: color-mix(in srgb, var(--red) 12%, transparent);
  --wash-success: var(--greensoft);

  /* 2e. Shadow presets → unified flight-deck elevation */
  --shadow-card: var(--shadow);
  --shadow-hover: var(--shadow);

  /* 3. Typography — Mission Control families (Space Grotesk display/UI) */
  --font-display: "Space Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-ui: "Space Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;


  /* line-heights (unitless) */
  --lh-1: 1;
  --lh-12: 1.2;
  --lh-125: 1.25;
  --lh-14: 1.4;
  --lh-15: 1.5;

  /* letter-spacing */
  --tr-eyebrow: 0.14em;
  --tr-chip: 0.08em;

  /* 4a. Spacing scale (multiples of 4) */
  --sp-4: 4px;
  --sp-8: 8px;
  --sp-12: 12px;
  --sp-14: 14px;
  --sp-16: 16px;
  --sp-20: 20px;
  --sp-24: 24px;
  --sp-28: 28px;
  --sp-32: 32px;
  --sp-40: 40px;
  --sp-44: 44px;
  --sp-56: 56px;
  --sp-80: 80px;

  /* border-width tokens */
  --bw-1: 1px;
  --bw-2: 2px;
  --bw-3: 3px;
  --bw-6: 6px;

  /* 5. Radii */
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --radius-pill: 999px;

  /* 6. Motion */
  --ease: cubic-bezier(0.32, 0.72, 0, 1);
  --dur-color: 160ms;
  --dur-theme: 180ms;
  --dur-transform: 220ms;
  --dur-progress: 300ms;

  /* layout widths (mobile-first app frame) */
  --w-content: 480px;
  /* responsive layout — tablet/desktop adapt automatically via @media.
     CSS forbids custom properties inside @media conditions, so the
     breakpoint pixel values are repeated literally in the queries below;
     these tokens hold the layout sizes the queries reference. */
  --w-content-wide: 1180px;
  --w-sidebar: 212px;
  --h-topbar: 56px;

  /* modal scrim (single token, reused dark + light) */
  --scrim: rgba(0, 0, 0, 0.5);
}

/* ---------------------------------------------------------------------
   1b. Design tokens — LIGHT theme. The v1 token names above alias the
   Mission Control set (var(--cy)/(--bg)/…), and tokens.css already supplies
   the full AA-correct [data-theme="light"] flip for those, so the aliases
   re-derive automatically. Only the UA hint needs restating here.
   --------------------------------------------------------------------- */
[data-theme="light"] {
  color-scheme: light;
}

/* ---------------------------------------------------------------------
   2. Reset + base
   --------------------------------------------------------------------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  height: 100%;
}

body {
  font-family: var(--font-ui);
  font-size: var(--fs-b1);
  line-height: var(--lh-15);
  font-feature-settings: "ss01", "ss02", "cv11";
  color: var(--n-90);
  background-color: var(--n-0);
  background-image:
    radial-gradient(120% 80% at 100% 0%, var(--bg-paint-1), transparent 60%),
    radial-gradient(120% 80% at 0% 100%, var(--bg-paint-2), transparent 60%);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  transition: background-color var(--dur-theme) var(--ease),
    color var(--dur-theme) var(--ease);
  overflow-x: hidden;
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  color: var(--n-99);
  margin: 0;
  line-height: var(--lh-125);
}

p { margin: 0; }

a {
  color: var(--c-primary);
  text-decoration: none;
}

button {
  font-family: inherit;
  cursor: pointer;
}

input,
select,
textarea {
  font-family: inherit;
  font-size: var(--fs-b2);
  color: var(--n-95);
}

:focus-visible {
  outline: none;
  box-shadow: 0 0 0 var(--bw-3) var(--focus-ring);
  border-radius: var(--radius-sm);
}

.visually-hidden {
  position: absolute;
  width: var(--bw-1);
  height: var(--bw-1);
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.hidden,
[hidden] { display: none !important; }

/* ---------------------------------------------------------------------
   3. App frame (mobile-first column, centered on wider screens)
   --------------------------------------------------------------------- */
.topbar {
  position: sticky;
  top: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  padding-top: calc(var(--sp-3) + env(safe-area-inset-top));
  background-color: color-mix(in srgb, var(--panel) 82%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
  transition: background-color var(--motion-transition) ease,
    border-color var(--motion-transition) ease;
}

.app-frame {
  max-width: var(--w-content);
  margin: 0 auto;
}

.view {
  max-width: var(--w-content);
  margin: 0 auto;
  /* Bottom clearance = tab-bar height + the device safe-area inset + breathing
     room, so the last item never hides behind the fixed bar and every page can
     scroll to a clean empty bottom. */
  padding: var(--sp-5) var(--sp-4)
    calc(var(--sp-7) + var(--sp-5) + env(safe-area-inset-bottom));
  min-height: 60vh;
}

/* ---- brand ---- */
.brand {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  min-width: 0;
}
.brand-mark {
  display: block;
  height: 26px;
  width: auto;
  flex: 0 0 auto;
}
/* legacy brand dot — kept for any non-topbar caller (e.g. login hero) */
.brand-dot {
  width: var(--sp-3);
  height: var(--sp-3);
  border-radius: var(--r-pill);
  background-color: var(--cy);
  box-shadow: var(--glow);
  flex: 0 0 auto;
}
.brand-name {
  font-family: var(--font-display);
  font-size: var(--fs-b2);
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--tx);
  white-space: nowrap;
}
.brand-name .brand-name-2 { color: var(--tx3); }
.brand-sub {
  font-size: var(--fs-m2);
  font-family: var(--font-mono);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--tx4);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.topbar-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex: 0 0 auto;
}

/* ---- T-minus countdown chip (mission clock) ---- */
.tminus {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  border: 1px solid var(--amberline);
  border-radius: var(--r-md);
  padding: var(--sp-2) var(--sp-3);
  background-color: var(--ambersoft);
  white-space: nowrap;
}
.tminus-days {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: var(--fs-d2);
  line-height: 1;
  color: var(--amber);
}
.tminus-days .tminus-pre {
  font-weight: 500;
  font-size: var(--fs-l2a);
  color: var(--tx4);
  vertical-align: 3px;
  margin-right: 1px;
}
.tminus-days .tminus-d { font-size: var(--fs-b3); }
.tminus-until { border-left: 1px solid var(--amberline); padding-left: var(--sp-3); }
.tminus-until-label {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-m4);
  line-height: 1.3;
  letter-spacing: 0.14em;
  color: var(--tx4);
}
.tminus-until-target {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: var(--fs-l4);
  line-height: 1.3;
  color: var(--tx2);
  margin-top: 1px;
}
@media (min-width: 768px) {
  .tminus-until-target::after { content: " lift-off"; }
}

/* ---- mobile account avatar (opens the More / account menu) ---- */
.topbar-avatar {
  appearance: none;
  width: 32px;
  height: 32px;
  flex: 0 0 auto;
  border-radius: var(--r-md);
  background-color: var(--cysoft);
  border: 1px solid var(--cyline);
  color: var(--cy);
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-b3);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: border-color var(--motion-transition) ease;
}
.topbar-avatar:hover { border-color: var(--cy); }

/* ---- theme toggle ---- */
/* On phones the top bar is reserved for brand + mission clock + avatar (theme
   switching moves into the More / account menu). It returns at >=768px. */
.theme-toggle {
  display: none;
  background-color: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 3px;
  gap: 2px;
}
@media (min-width: 768px) {
  .theme-toggle { display: inline-flex; }
}
/* Compact mission clock on narrow screens so it never collides with the brand. */
@media (max-width: 599px) {
  .tminus { gap: var(--sp-2); padding: var(--sp-1) 9px; border-radius: var(--r-sm); }
  .tminus-days { font-size: var(--fs-d4); }
  .tminus-days .tminus-pre { font-size: var(--fs-m4); vertical-align: 2px; }
  .tminus-days .tminus-d { font-size: var(--fs-l4); }
  .tminus-until { padding-left: var(--sp-2); }
  .tminus-until-label { font-size: var(--fs-m6); letter-spacing: 0.1em; }
  .tminus-until-target { font-size: var(--fs-m3); }
}
.theme-toggle button {
  appearance: none;
  border: none;
  background: transparent;
  color: var(--tx3);
  width: 28px;
  height: 28px;
  border-radius: var(--r-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color var(--motion-transition) ease,
    color var(--motion-transition) ease;
}
.theme-toggle button[aria-pressed="true"] {
  background-color: var(--cysoft);
  color: var(--cy);
}
.theme-toggle svg {
  width: 16px;
  height: 16px;
}

/* ---- icon button (menu) ---- */
.icon-btn {
  appearance: none;
  border: var(--bw-1) solid var(--border-hairline-strong);
  background-color: var(--surface-raised);
  color: var(--n-90);
  width: var(--sp-40);
  height: var(--sp-40);
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color var(--dur-color) var(--ease);
}
.icon-btn:hover { background-color: var(--n-20); }
.icon-btn svg { width: var(--sp-20); height: var(--sp-20); }

/* ---------------------------------------------------------------------
   4. Cards, eyebrows, chips, buttons
   --------------------------------------------------------------------- */
.card {
  background-image: linear-gradient(var(--surface-card-top), var(--surface-card-bot));
  border: var(--bw-1) solid var(--border-hairline);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-card);
  padding: var(--sp-24) var(--sp-20);
  margin-bottom: var(--sp-16);
}
.card.tight { padding: var(--sp-16); }

.section-title {
  font-size: var(--fs-l2);
  letter-spacing: var(--tr-eyebrow);
  text-transform: uppercase;
  color: var(--n-70);
  font-weight: 600;
  margin: var(--sp-24) 0 var(--sp-12);
}

.screen-title {
  font-size: var(--fs-d1);
  line-height: var(--lh-12);
  margin-bottom: var(--sp-8);
}

.muted { color: var(--n-70); }
.small { font-size: var(--fs-b3); }
.tiny { font-size: var(--fs-l1); }
.strong { color: var(--n-99); font-weight: 600; }

/* chips */
.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-4) var(--sp-12);
  border-radius: var(--radius-pill);
  background-color: var(--n-20);
  border: var(--bw-1) solid var(--border-hairline-strong);
  color: var(--n-90);
  font-size: var(--fs-l3);
  letter-spacing: var(--tr-chip);
  text-transform: uppercase;
  font-weight: 600;
  white-space: nowrap;
}
.chip.primary {
  background-color: var(--wash-primary-chip);
  border-color: var(--accent-primary-medium);
  color: var(--c-primary);
}
.chip.secondary {
  background-color: var(--wash-secondary-chip);
  border-color: var(--accent-secondary-chip);
  color: var(--c-secondary);
}
.chip.tertiary {
  background-color: var(--wash-tertiary-chip);
  border-color: var(--accent-tertiary-chip);
  color: var(--c-tertiary);
}
.chip.success {
  background-color: var(--wash-success);
  border-color: var(--accent-success-break);
  color: var(--success);
}
.chip.danger {
  background-color: var(--wash-danger);
  border-color: var(--glow-danger);
  color: var(--danger);
}

/* buttons */
.btn {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-8);
  min-height: var(--sp-44);
  padding: var(--sp-12) var(--sp-20);
  border-radius: var(--radius-pill);
  border: var(--bw-1) solid transparent;
  background-color: var(--c-primary);
  color: var(--on-primary);
  font-size: var(--fs-b2);
  font-weight: 600;
  box-shadow: 0 var(--sp-8) var(--sp-24) var(--glow-primary);
  transition: transform var(--dur-transform) var(--ease),
    box-shadow var(--dur-color) var(--ease),
    background-color var(--dur-color) var(--ease);
}
.btn:hover { background-color: var(--c-primary-70); box-shadow: 0 var(--sp-8) var(--sp-28) var(--glow-primary-strong); }
.btn:active { transform: translateY(calc(-1 * var(--bw-1))); }
.btn:disabled { opacity: 0.5; box-shadow: none; cursor: not-allowed; }
.btn.block { width: 100%; }

.btn.outlined {
  background-color: transparent;
  border-color: var(--border-hairline-strong);
  color: var(--n-90);
  box-shadow: none;
}
.btn.outlined:hover { background-color: var(--n-20); }
.btn.ghost {
  background-color: transparent;
  color: var(--n-90);
  box-shadow: none;
}
.btn.ghost:hover { background-color: var(--n-20); }
.btn.secondary {
  background-color: var(--n-20);
  color: var(--n-95);
  box-shadow: none;
  border-color: var(--border-hairline-strong);
}
.btn.good {
  background-color: var(--success);
  color: var(--n-0);
  box-shadow: 0 var(--sp-8) var(--sp-24) var(--glow-success);
}
.btn.bad {
  background-color: var(--danger);
  color: var(--n-0);
  box-shadow: 0 var(--sp-8) var(--sp-24) var(--glow-danger);
}
.btn.small { min-height: var(--sp-32); padding: var(--sp-8) var(--sp-16); font-size: var(--fs-b3); box-shadow: none; }

.btn-row {
  display: flex;
  gap: var(--sp-12);
  flex-wrap: wrap;
}

/* ---------------------------------------------------------------------
   5. Forms
   --------------------------------------------------------------------- */
.field {
  margin-bottom: var(--sp-16);
  display: flex;
  flex-direction: column;
  gap: var(--sp-8);
}
.field > label {
  font-size: var(--fs-l1);
  letter-spacing: var(--tr-chip);
  text-transform: uppercase;
  color: var(--n-70);
  font-weight: 600;
}
.field .hint { font-size: var(--fs-b3); color: var(--n-70); }

.control,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="date"],
select,
textarea {
  width: 100%;
  background-color: var(--surface-raised);
  border: var(--bw-1) solid var(--border-hairline-strong);
  border-radius: var(--radius-md);
  padding: var(--sp-12) var(--sp-14);
  color: var(--n-95);
  transition: border-color var(--dur-color) var(--ease),
    box-shadow var(--dur-color) var(--ease);
}
textarea { min-height: var(--sp-80); resize: vertical; line-height: var(--lh-15); }
.control:focus,
input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--accent-primary-medium);
  box-shadow: 0 0 0 var(--bw-3) var(--focus-ring-soft);
}

.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-12);
}

/* toggle / checkbox row */
.toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-12);
  padding: var(--sp-12) var(--sp-14);
  background-color: var(--surface-raised);
  border: var(--bw-1) solid var(--border-hairline-strong);
  border-radius: var(--radius-md);
  margin-bottom: var(--sp-12);
}
.toggle-row .label-text { font-size: var(--fs-b2); color: var(--n-95); }
.toggle-row input[type="checkbox"] {
  width: var(--sp-20);
  height: var(--sp-20);
  accent-color: var(--c-primary);
  flex: 0 0 auto;
}

.check-line {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-12);
  margin-bottom: var(--sp-12);
}
.check-line input[type="checkbox"] {
  margin-top: var(--sp-4);
  width: var(--sp-20);
  height: var(--sp-20);
  accent-color: var(--c-primary);
  flex: 0 0 auto;
}
.check-line label { font-size: var(--fs-b2); color: var(--n-90); }

.form-error {
  color: var(--danger);
  font-size: var(--fs-b3);
  margin-top: var(--sp-8);
  min-height: var(--sp-20);
}

/* segmented (mood/energy) */
.segmented {
  display: flex;
  gap: var(--sp-8);
}
.segmented button {
  flex: 1;
  appearance: none;
  border: var(--bw-1) solid var(--border-hairline-strong);
  background-color: var(--surface-raised);
  color: var(--n-90);
  min-height: var(--sp-44);
  border-radius: var(--radius-md);
  font-size: var(--fs-b1);
  font-weight: 600;
  transition: background-color var(--dur-color) var(--ease),
    border-color var(--dur-color) var(--ease);
}
.segmented button[aria-pressed="true"] {
  background-color: var(--c-primary-15);
  border-color: var(--accent-primary-medium);
  color: var(--c-primary);
}

/* ---------------------------------------------------------------------
   6. Auth / centered screens
   --------------------------------------------------------------------- */
.auth-wrap {
  min-height: 70vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.auth-card { margin-top: var(--sp-16); }
.auth-hero {
  text-align: center;
  margin-bottom: var(--sp-24);
}
/* Centre the RANK·FORGE lockup in the auth hero (it is left-aligned in chrome). */
.auth-hero .brand { justify-content: center; margin-bottom: var(--sp-16); }
.auth-tagline {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-d1);
  line-height: var(--lh-125);
  letter-spacing: -0.01em;
  color: var(--n-99);
  max-width: 22ch;
  margin: 0 auto var(--sp-8);
}
.auth-sub {
  font-family: var(--font-mono);
  font-size: var(--fs-b3);
  line-height: var(--lh-15);
  color: var(--n-70);
}

/* ---------------------------------------------------------------------
   7. Today screen
   --------------------------------------------------------------------- */
.today-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-12);
  flex-wrap: wrap;
  margin-bottom: var(--sp-12);
}
.capacity-line {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  color: var(--n-70);
  font-size: var(--fs-b3);
  margin-bottom: var(--sp-16);
}

.banner {
  display: flex;
  gap: var(--sp-12);
  align-items: flex-start;
  padding: var(--sp-16);
  border-radius: var(--radius-lg);
  margin-bottom: var(--sp-16);
}
.banner.blackout {
  background-color: var(--wash-tertiary);
  border: var(--bw-1) solid var(--accent-tertiary-sacred);
}
.banner.info {
  background-color: var(--wash-primary);
  border: var(--bw-1) solid var(--accent-primary-soft);
}
.banner .banner-icon {
  width: var(--sp-24);
  height: var(--sp-24);
  flex: 0 0 auto;
  color: var(--c-tertiary);
}
.banner.info .banner-icon { color: var(--c-primary); }
.banner-title { font-weight: 600; color: var(--n-99); font-size: var(--fs-b2); }
.banner-body { font-size: var(--fs-b3); color: var(--n-90); }

/* task item */
.task {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-12);
  padding: var(--sp-16);
  background-image: linear-gradient(var(--surface-card-top), var(--surface-card-bot));
  border: var(--bw-1) solid var(--border-hairline);
  border-left: var(--bw-3) solid var(--accent-primary-medium);
  border-radius: var(--radius-md);
  margin-bottom: var(--sp-12);
  transition: border-color var(--dur-color) var(--ease), opacity var(--dur-color) var(--ease);
}
.task.rwa { border-left-color: var(--accent-tertiary-mock); }
.task.done { opacity: 0.6; border-left-color: var(--accent-success-break); }
.task-main { flex: 1; min-width: 0; }
.task-title {
  font-family: var(--font-display);
  font-size: var(--fs-d4);
  color: var(--n-99);
  line-height: var(--lh-14);
}
.task.done .task-title { text-decoration: line-through; }
.task-detail { font-size: var(--fs-b3); color: var(--n-70); margin-top: var(--sp-4); }
.task-meta {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  flex-wrap: wrap;
  margin-top: var(--sp-8);
}
.task-check {
  appearance: none;
  flex: 0 0 auto;
  width: var(--sp-28);
  height: var(--sp-28);
  border-radius: var(--radius-pill);
  border: var(--bw-2) solid var(--border-hairline-strong);
  background-color: transparent;
  color: var(--success);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color var(--dur-color) var(--ease), border-color var(--dur-color) var(--ease);
}
.task-check.done {
  background-color: var(--success);
  border-color: var(--success);
  color: var(--n-0);
}
.task-check svg { width: var(--sp-16); height: var(--sp-16); }

.milestone {
  display: flex;
  gap: var(--sp-12);
  align-items: flex-start;
  padding: var(--sp-12) 0;
  border-bottom: var(--bw-1) solid var(--border-hairline-soft);
}
.milestone:last-child { border-bottom: none; }
.milestone-title { font-size: var(--fs-b2); color: var(--n-95); font-weight: 600; }
.milestone-desc { font-size: var(--fs-b3); color: var(--n-70); margin-top: var(--sp-4); }
.milestone-dot {
  width: var(--sp-8);
  height: var(--sp-8);
  border-radius: var(--radius-pill);
  background-color: var(--c-primary);
  margin-top: var(--sp-8);
  flex: 0 0 auto;
}
.milestone.rwa .milestone-dot { background-color: var(--c-tertiary); box-shadow: 0 0 var(--sp-8) var(--accent-tertiary-mock); }

/* =====================================================================
   8. Roadmap — Mission Control reskin (Phase 2).
   Shared MC header / section labels live here (reused by Cards, Odds, Coach).
   ===================================================================== */

/* Big uppercase display title + mono sub-line, mirroring the Today cockpit. */
.mc-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-5);
  margin-bottom: var(--sp-4);
}
.mc-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-d1);
  line-height: 1;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--tx);
}
.mc-sub {
  font-family: var(--font-mono);
  font-size: var(--fs-l2);
  line-height: 1.5;
  color: var(--tx3);
  margin-top: 7px;
  max-width: 620px;
}
.mc-pill {
  flex: 0 0 auto;
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: var(--fs-l4);
  color: var(--tx3);
  border: 1px solid var(--line);
  padding: 7px 11px;
  border-radius: var(--r-pill);
  white-space: nowrap;
}
.mc-label {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-l4);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--tx3);
  margin: var(--sp-5) 0 var(--sp-3);
}
.mc-labelrow { display: flex; align-items: center; gap: 9px; margin: var(--sp-5) 0 var(--sp-3); }
.mc-labelrow .mc-label { margin: 0; }
.mc-rule { flex: 1; height: 1px; background-color: var(--line); }
.mc-caption { font-family: var(--font-mono); font-size: var(--fs-m2); text-transform: uppercase; color: var(--tx4); white-space: nowrap; }
.mc-note { font-family: var(--font-mono); font-size: var(--fs-l2a); line-height: 1.5; color: var(--tx4); margin: 0 0 var(--sp-4); }

/* 3-phase spine — current + past phases light cyan, future stays on the track. */
.rm-spine { display: flex; align-items: flex-start; gap: 0; margin: var(--sp-5) 0 var(--sp-4); }
.rm-phase { flex: 1; text-align: center; }
.rm-phase-bar { height: 6px; background-color: var(--line); }
.rm-phase-bar.first { border-radius: 3px 0 0 3px; }
.rm-phase-bar.last { border-radius: 0 3px 3px 0; }
.rm-phase-bar.is-lit { background-color: var(--cy); box-shadow: var(--glow); }
.rm-phase-name { font-family: var(--font-mono); font-weight: 600; font-size: var(--fs-l4); color: var(--tx3); margin-top: 9px; }
.rm-phase-name.is-now { color: var(--cy); }
.rm-phase-sub { font-family: var(--font-mono); font-size: var(--fs-m2); line-height: 1.3; color: var(--tx4); margin-top: 3px; }

/* workstream status cards */
.rm-ws-grid { display: grid; grid-template-columns: 1fr; gap: 10px; margin-bottom: var(--sp-3); }
.rm-ws {
  appearance: none;
  width: 100%;
  text-align: left;
  cursor: pointer;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 15px 16px;
  background-color: var(--panel);
  transition: border-color var(--motion-transition) ease;
}
.rm-ws:hover { border-color: var(--cyline); }
.rm-ws-top { display: flex; align-items: baseline; justify-content: space-between; gap: var(--sp-3); }
.rm-ws-name { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-b3); line-height: 1.2; color: var(--tx); }
.rm-ws-status { font-family: var(--font-mono); font-weight: 600; font-size: var(--fs-l4); white-space: nowrap; flex: 0 0 auto; }
.rm-ws-desc { font-family: var(--font-mono); font-size: var(--fs-l2a); line-height: 1.45; color: var(--tx3); margin: 7px 0 10px; }
.rm-ws-bar { height: 4px; border-radius: 2px; background-color: var(--line); overflow: hidden; }
.rm-ws-fill { height: 4px; border-radius: 2px; background-color: var(--cy); transition: width var(--motion-transition) ease; }
.rm-ws-status.t-cy, .rm-phase-name.t-cy { color: var(--cy); }
.rm-ws-status.t-amber { color: var(--amber); }
.rm-ws-status.t-green { color: var(--green); }
.rm-ws-status.t-violet { color: var(--violet); }
.rm-ws-status.t-mute { color: var(--tx4); }
.rm-ws-fill.t-cy { background-color: var(--cy); }
.rm-ws-fill.t-amber { background-color: var(--amber); }
.rm-ws-fill.t-green { background-color: var(--green); }
.rm-ws-fill.t-violet { background-color: var(--violet); }
.rm-ws-fill.t-mute { background-color: var(--line2); }

/* milestone list — active (next not-done) highlighted, the rest upcoming */
.rm-ms-list { display: flex; flex-direction: column; gap: 8px; }
.rm-ms {
  appearance: none;
  width: 100%;
  text-align: left;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 13px;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 13px 15px;
  background-color: var(--panel);
  transition: border-color var(--motion-transition) ease;
}
.rm-ms:hover { border-color: var(--cyline); }
.rm-ms.is-active { border-color: var(--cyline); background-color: var(--cysoft); }
.rm-ms-node {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  border-radius: 50%;
  border: 2px solid var(--line2);
  display: flex;
  align-items: center;
  justify-content: center;
}
.rm-ms-node.active { border-color: var(--cy); background-color: var(--cysoft); }
.rm-ms-node.done { border-color: var(--green); background-color: var(--green); color: var(--cyink); }
.rm-ms-check svg { width: 11px; height: 11px; display: block; }
.rm-ms-title { flex: 1; font-family: var(--font-display); font-weight: 600; font-size: var(--fs-b3); line-height: 1.2; color: var(--tx); }
.rm-ms-title.is-muted { color: var(--tx2); }
.rm-ms-date { font-family: var(--font-mono); font-weight: 500; font-size: var(--fs-l4); color: var(--tx4); white-space: nowrap; flex: 0 0 auto; }
.rm-ms-date.now { color: var(--cy); }

@media (min-width: 768px) {
  .rm-ws-grid { grid-template-columns: 1fr 1fr; }
}

/* Milestone nodes — the tappable cards inside the workstream bottom-sheet
   (openWorkstreamSheet). The legacy proportional/collapsible timeline builders
   were retired in the Mission Control reskin; only these node styles survive. */
.vt-item {
  position: relative;
  display: block;
  width: 100%;
  text-align: left;
  appearance: none;
  background: transparent;
  border: none;
  padding: var(--sp-8) 0;
  cursor: pointer;
}
.vt-node {
  position: absolute;
  top: var(--sp-16);
  left: calc(-1 * var(--sp-16));
  transform: translateX(-50%);
  width: var(--sp-12);
  height: var(--sp-12);
  border-radius: var(--radius-pill);
  border: var(--bw-2) solid var(--surface-raised);
}
.vt-card {
  background-color: var(--surface-raised);
  border: var(--bw-1) solid var(--border-hairline);
  border-radius: var(--radius-md);
  padding: var(--sp-12) var(--sp-14);
  transition: border-color var(--dur-color) var(--ease);
}
.vt-item:hover .vt-card { border-color: var(--border-hairline-strong); }
.vt-item.is-done .vt-card { opacity: 0.6; }
.vt-date {
  font-size: var(--fs-l3);
  letter-spacing: var(--tr-chip);
  text-transform: uppercase;
  color: var(--n-70);
  margin-bottom: var(--sp-4);
}
.vt-title { font-weight: 600; color: var(--n-95); font-size: var(--fs-b2); }
.vt-meta { display: flex; flex-wrap: wrap; gap: var(--sp-8); margin-top: var(--sp-8); }
/* Workstream-sheet milestone node — cyan fill so it reads on the hairline. */
.vt-node { background-color: var(--c-primary); box-shadow: 0 0 var(--sp-8) var(--glow-primary-soft); }
.vt-item.is-done .vt-node { background-color: var(--success); box-shadow: 0 0 var(--sp-8) var(--glow-success); }

/* ---------------------------------------------------------------------
   Today v2 — guided focus card, day progress, chore/study lanes,
   flashcard breakdown, and the reusable bottom-sheet popup.
   --------------------------------------------------------------------- */
.day-progress { margin: var(--sp-8) 0 var(--sp-16); }
.day-progress-track {
  height: var(--bw-6);
  border-radius: var(--radius-pill);
  background-color: var(--n-30);
  overflow: hidden;
}
.day-progress-fill {
  height: 100%;
  border-radius: var(--radius-pill);
  background-image: linear-gradient(90deg, var(--c-primary), var(--c-secondary));
  transition: width var(--dur-progress) var(--ease);
}
.day-progress-label { margin-top: var(--sp-8); font-size: var(--fs-b3); color: var(--n-70); }

.focus-card {
  background-image: linear-gradient(var(--surface-card-top), var(--surface-card-bot));
  border: var(--bw-1) solid var(--accent-primary-soft);
  border-radius: var(--radius-lg);
  padding: var(--sp-20) var(--sp-20) var(--sp-16);
  box-shadow: var(--shadow-hover);
  margin-bottom: var(--sp-16);
}
.focus-card.admin { border-color: var(--border-hairline-strong); }
.focus-card.rest { text-align: center; border-color: var(--accent-success-break); }
.focus-rest-icon { width: var(--sp-48); height: var(--sp-48); color: var(--success); margin: 0 auto var(--sp-8); }
.focus-eyebrow {
  font-size: var(--fs-l3);
  letter-spacing: var(--tr-chip);
  text-transform: uppercase;
  color: var(--c-primary-70);
  margin-bottom: var(--sp-8);
}
.focus-meta { display: flex; align-items: center; gap: var(--sp-8); margin-bottom: var(--sp-8); }
.focus-title { font-family: var(--font-display); font-size: var(--fs-d1); color: var(--n-99); margin: 0; }
.focus-sub { font-size: var(--fs-b2); color: var(--n-90); margin-top: var(--sp-8); }
.focus-actions { display: flex; gap: var(--sp-8); margin-top: var(--sp-16); }
.focus-actions .btn { flex: 1; }
.focus-next { margin-top: var(--sp-12); font-size: var(--fs-b3); color: var(--n-70); }

.admin-nudge {
  margin: calc(-1 * var(--sp-8)) 0 var(--sp-16);
  padding: var(--sp-8) var(--sp-12);
  border-left: var(--bw-3) solid var(--border-hairline-strong);
  background-color: var(--wash-tertiary);
  border-radius: var(--radius-sm);
  font-size: var(--fs-b3);
  color: var(--n-90);
}

.lane { margin-top: var(--sp-12); }
.lane-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: var(--sp-8); }
.lane-name {
  font-size: var(--fs-l3);
  letter-spacing: var(--tr-chip);
  text-transform: uppercase;
  color: var(--n-90);
  font-weight: 600;
}
.lane-study { border-left: var(--bw-3) solid var(--c-primary); padding-left: var(--sp-12); }
.lane-admin { border-left: var(--bw-3) solid var(--border-hairline-strong); padding-left: var(--sp-12); }
.lane-admin .task { opacity: 0.82; }

.day-full {
  margin-top: var(--sp-16);
  border: var(--bw-1) solid var(--border-hairline);
  border-radius: var(--radius-md);
  padding: 0 var(--sp-14);
}
.day-full[open] { padding-bottom: var(--sp-12); }
.day-full-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-12);
  padding: var(--sp-12) 0;
  cursor: pointer;
  font-weight: 600;
  color: var(--n-90);
  list-style: none;
}
.day-full-summary::-webkit-details-marker { display: none; }
.day-full-summary::after { content: "⌄"; color: var(--n-70); }
.day-full[open] .day-full-summary::after { content: "⌃"; }

.fc-due { margin: var(--sp-16) 0; }
/* Cards menu — recall-first deck picker (review-all + subject chips). */
.fc-review-all {
  appearance: none;
  width: 100%;
  cursor: pointer;
  border: 1px solid var(--cyline);
  background-color: var(--cysoft);
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-b4);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--cy);
  padding: 13px 0;
  border-radius: var(--r-md);
  margin: var(--sp-4) 0;
  transition: border-color var(--motion-transition) ease;
}
.fc-review-all:hover { border-color: var(--cy); }
.fc-chips { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin: var(--sp-4) 0; }
.fc-chip {
  appearance: none;
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  cursor: pointer;
  border: 1px solid var(--line);
  background-color: var(--panel);
  border-radius: var(--r-pill);
  padding: 8px 12px;
  transition: border-color var(--motion-transition) ease;
}
.fc-chip:hover { border-color: var(--cyline); }
.fc-chip-name { font-family: var(--font-mono); font-weight: 500; font-size: var(--fs-l4); color: var(--tx3); }
.fc-chip-count { font-family: var(--font-mono); font-weight: 600; font-size: var(--fs-l4); color: var(--cy); }

.sheet-backdrop {
  position: fixed;
  inset: 0;
  z-index: 70;
  background-color: var(--scrim);
  backdrop-filter: blur(2px);
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.sheet {
  width: 100%;
  max-height: 85vh;
  overflow-y: auto;
  background-image: linear-gradient(var(--surface-card-top), var(--surface-card-bot));
  border: var(--bw-1) solid var(--border-hairline);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  padding: var(--sp-16) var(--sp-16) calc(var(--sp-20) + env(safe-area-inset-bottom));
  box-shadow: var(--shadow-hover);
}
.sheet-head { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-12); margin-bottom: var(--sp-12); }
.sheet-title { font-family: var(--font-display); font-size: var(--fs-d2); color: var(--n-99); }
.sheet-meta { display: flex; gap: var(--sp-8); align-items: center; margin-bottom: var(--sp-8); }
.sheet-detail { font-size: var(--fs-b2); color: var(--n-90); }
.sheet-actions { display: flex; flex-direction: column; gap: var(--sp-8); margin-top: var(--sp-16); }

@media (min-width: 768px) {
  .sheet-backdrop { align-items: center; }
  .sheet { max-width: 520px; border-radius: var(--radius-lg); }
}

/* =====================================================================
   TODAY — Mission Control cockpit. All values map to Mission Control tokens.
   ===================================================================== */
@keyframes rfSweep { from { transform: rotate(0); } to { transform: rotate(360deg); } }
@keyframes rfPop { 0% { transform: scale(.6); opacity: 0; } 60% { transform: scale(1.15); } 100% { transform: scale(1); opacity: 1; } }
@keyframes rfPulse { 0%, 100% { opacity: 1; } 50% { opacity: .45; } }

.tdy-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-5);
}
.tdy-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-d1);
  line-height: 1;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--tx);
}
.tdy-date {
  font-family: var(--font-mono);
  font-size: var(--fs-l2);
  color: var(--tx3);
  margin-top: 7px;
}

/* presence reticle gauge */
.gauge {
  position: relative;
  width: 74px;
  height: 74px;
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
.gauge-ring { position: absolute; inset: 0; border-radius: 50%; border: 1px solid var(--cyline); }
.gauge-sweep {
  position: absolute;
  inset: 6px;
  border-radius: 50%;
  border: 1px dashed var(--cyline);
  border-top-color: var(--cy);
  animation: rfSweep 14s linear infinite;
}
.gauge-core {
  position: absolute;
  inset: 16px;
  border-radius: 50%;
  border: 2px solid var(--cy);
  box-shadow: inset 0 0 10px var(--cysoft);
}
.gauge-readout { text-align: center; position: relative; }
.gauge-pct { font-family: var(--font-mono); font-weight: 600; font-size: var(--fs-b2); line-height: 1; color: var(--cy); }
.gauge-label {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: var(--fs-m7);
  line-height: 1;
  letter-spacing: 0.12em;
  color: var(--tx4);
  margin-top: 2px;
}

/* journey spine */
.spine-row { margin: 18px 0 4px; display: flex; align-items: center; gap: var(--sp-3); }
.spine-end {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: var(--fs-m2);
  color: var(--tx4);
  white-space: nowrap;
}
.spine-end.target { color: var(--amber); }
.spine-track { flex: 1; position: relative; height: 5px; border-radius: 3px; background-color: var(--line); }
.spine-fill {
  position: absolute;
  left: 0;
  top: 0;
  height: 5px;
  border-radius: 3px;
  background-color: var(--cy);
  box-shadow: var(--glow);
  transition: width var(--motion-transition) ease;
}
.spine-dot {
  position: absolute;
  top: -3px;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background-color: var(--cy);
  box-shadow: var(--glow);
  transform: translateX(-50%);
  border: 2px solid var(--bg);
}
.spine-caption {
  font-family: var(--font-mono);
  font-size: var(--fs-l4);
  color: var(--tx4);
  text-transform: uppercase;
  margin-bottom: var(--sp-3);
}

/* momentum + check-in chips */
.tdy-chips { display: flex; gap: var(--sp-3); margin-bottom: var(--sp-5); }
.momentum {
  flex: 1;
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-4);
  background-color: var(--panel);
}
.momentum-num { font-family: var(--font-mono); font-weight: 700; font-size: var(--fs-d-b); line-height: 1; color: var(--cy); }
.momentum-num span { font-size: var(--fs-l2a); color: var(--tx4); margin-left: 2px; }
.momentum-label {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-m1);
  letter-spacing: 0.12em;
  color: var(--tx3);
}
.momentum-sub { font-family: var(--font-mono); font-size: var(--fs-m1); line-height: 1.35; color: var(--tx4); margin-top: 4px; }
.checkin-chip {
  appearance: none;
  flex: 1;
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  border: 1px solid var(--amberline);
  border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-4);
  background-color: var(--ambersoft);
  cursor: pointer;
  text-align: left;
  transition: border-color var(--motion-transition) ease;
}
.checkin-chip:hover { border-color: var(--amber); }
.checkin-chip .checkin-ico { color: var(--amber); display: inline-flex; }
.checkin-chip .checkin-ico svg { width: 16px; height: 16px; }
.checkin-title { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-l2); color: var(--tx); }
.checkin-sub { font-family: var(--font-mono); font-size: var(--fs-m1); line-height: 1.35; color: var(--tx4); margin-top: 4px; }
.checkin-arrow { color: var(--amber); margin-left: auto; flex: 0 0 auto; }
.checkin-arrow svg { width: 12px; height: 12px; }

/* NEXT BURN card */
.burn {
  border: 1px solid var(--cyline);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  background-image: linear-gradient(135deg, var(--cysoft), transparent 62%);
  margin-bottom: var(--sp-3);
}
.burn-head { display: flex; align-items: center; gap: 9px; margin-bottom: var(--sp-3); }
.burn-eyebrow {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-l4);
  letter-spacing: 0.14em;
  color: var(--cy);
}
.burn-rule { flex: 1; height: 1px; background-color: var(--cyline); }
.burn-count { font-family: var(--font-mono); font-weight: 500; font-size: var(--fs-m2); color: var(--tx4); }
.burn-meta { display: flex; align-items: center; gap: 9px; margin-bottom: var(--sp-3); }
.burn-tag {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-m1);
  text-transform: uppercase;
  color: var(--tx2);
  border: 1px solid var(--line2);
  padding: 4px 8px;
  border-radius: var(--r-sm);
}
.burn-mins { font-family: var(--font-mono); font-size: var(--fs-l2a); text-transform: uppercase; color: var(--tx3); }
.burn-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-d-c);
  line-height: 1.08;
  letter-spacing: -0.01em;
  color: var(--tx);
  margin-bottom: 9px;
}
.burn-desc {
  font-family: var(--font-mono);
  font-size: var(--fs-b2a);
  line-height: 1.55;
  color: var(--tx3);
  margin-bottom: var(--sp-5);
  max-width: 560px;
}
.burn-actions { display: flex; gap: var(--sp-3); align-items: center; flex-wrap: wrap; }
.btn-initiate {
  appearance: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-b2a);
  color: var(--cyink);
  background-color: var(--cy);
  padding: 13px 26px;
  border-radius: var(--r-sm);
  box-shadow: 0 8px 20px -8px var(--cyline);
  transition: transform var(--motion-transition) ease, box-shadow var(--motion-transition) ease;
}
.btn-initiate:hover { box-shadow: 0 10px 24px -8px var(--cy); }
.btn-initiate:active { transform: translateY(1px); }
.btn-mark {
  appearance: none;
  border: 1px solid var(--line2);
  cursor: pointer;
  background: transparent;
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-l1);
  text-transform: uppercase;
  color: var(--tx2);
  padding: 13px 18px;
  border-radius: var(--r-sm);
  transition: border-color var(--motion-transition) ease, color var(--motion-transition) ease;
}
.btn-mark:hover { border-color: var(--tx3); color: var(--tx); }
.btn-mark:active { transform: translateY(1px); }
.btn-mark:disabled { opacity: 0.5; cursor: not-allowed; }
.burn-then {
  font-family: var(--font-mono);
  font-size: var(--fs-l4);
  text-transform: uppercase;
  color: var(--tx4);
  margin-top: 15px;
}

/* NEXT BURN — logged / done state */
.burn-done {
  border: 1px solid var(--green);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  background-image: linear-gradient(135deg, var(--greensoft), transparent 62%);
  margin-bottom: var(--sp-3);
}
.burn-done-top { display: flex; align-items: center; gap: var(--sp-3); }
.burn-done-ring {
  width: 42px;
  height: 42px;
  flex: 0 0 auto;
  border-radius: 50%;
  border: 2px solid var(--green);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--green);
  animation: rfPop var(--motion-ignite) ease-out;
}
.burn-done-ring svg { width: 20px; height: 20px; }
.burn-done-eyebrow {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-l4);
  letter-spacing: 0.14em;
  color: var(--green);
  margin-bottom: 7px;
}
.burn-done-title { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-d2); line-height: 1.1; color: var(--tx); }
.burn-done-body {
  font-family: var(--font-mono);
  font-size: var(--fs-b4);
  line-height: 1.5;
  color: var(--tx3);
  margin: var(--sp-3) 0 var(--sp-4);
}

/* amber low-pressure admin nudge */
.admin-banner {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  border: 1px solid var(--amberline);
  background-color: var(--ambersoft);
  border-radius: var(--r-sm);
  padding: var(--sp-3) var(--sp-4);
  margin-bottom: var(--sp-5);
}
.admin-banner .admin-ico { color: var(--amber); display: inline-flex; flex: 0 0 auto; }
.admin-banner .admin-ico svg { width: 14px; height: 14px; }
.admin-banner-text { font-family: var(--font-mono); font-size: var(--fs-l2); line-height: 1.4; color: var(--amber); }

/* cards due deck grid */
.cards-due-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--sp-3);
}
.cards-due-label {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-l4);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--tx3);
}
.cards-due-count { font-family: var(--font-mono); font-size: var(--fs-l4); text-transform: uppercase; color: var(--tx4); }
.review-all {
  appearance: none;
  width: 100%;
  border: 1px solid var(--cyline);
  cursor: pointer;
  background-color: var(--cysoft);
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-b4);
  text-transform: uppercase;
  color: var(--cy);
  padding: 13px 0;
  border-radius: var(--r-md);
  margin-bottom: var(--sp-3);
  transition: border-color var(--motion-transition) ease;
}
.review-all:hover { border-color: var(--cy); }
.deck-grid { display: grid; grid-template-columns: 1fr; gap: 9px; }
.deck-row {
  appearance: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 11px 13px;
  background-color: var(--panel);
  cursor: pointer;
  transition: border-color var(--motion-transition) ease;
}
.deck-row:hover { border-color: var(--cyline); }
.deck-row .deck-left { display: flex; align-items: center; gap: var(--sp-2); min-width: 0; }
.deck-tag {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-m4);
  text-transform: uppercase;
  color: var(--tx4);
  border: 1px solid var(--line2);
  padding: 3px 5px;
  border-radius: var(--r-sm);
  flex: 0 0 auto;
}
.deck-name {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-b4);
  color: var(--tx2);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.deck-count { font-family: var(--font-mono); font-weight: 600; font-size: var(--fs-l1); color: var(--cy); flex: 0 0 auto; }

/* jump back in */
.jump-head { display: flex; align-items: center; gap: 9px; margin: var(--sp-5) 0 var(--sp-3); }
.jump-label {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-l4);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--tx3);
}
.jump-rule { flex: 1; height: 1px; background-color: var(--line); }
.jump-caption { font-family: var(--font-mono); font-size: var(--fs-m2); text-transform: uppercase; color: var(--tx4); }
.jump-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-3); }
.jump-card {
  appearance: none;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 13px 14px;
  background-color: var(--panel);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  text-align: left;
  transition: border-color var(--motion-transition) ease;
}
.jump-card:hover { border-color: var(--cyline); }
.jump-card.accent { border-color: var(--cyline); background-color: var(--cysoft); }
.jump-card.accent:hover { border-color: var(--cy); }
.jump-card-top { display: flex; align-items: center; justify-content: space-between; }
.jump-card-id { display: flex; align-items: center; gap: var(--sp-2); }
.jump-card-id .jump-ico { color: var(--cy); display: inline-flex; }
.jump-card-id .jump-ico svg { width: 14px; height: 14px; }
.jump-card-name { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-l1); color: var(--tx); }
.jump-card-arrow { color: var(--tx4); display: inline-flex; }
.jump-card.accent .jump-card-arrow { color: var(--cy); }
.jump-card-arrow svg { width: 13px; height: 13px; }
.jump-card-big {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-b2);
  line-height: 1.1;
  color: var(--tx);
}
.jump-card-big.mono { font-family: var(--font-mono); color: var(--cy); }
.jump-card-sub { font-family: var(--font-mono); font-size: var(--fs-m1); line-height: 1.35; color: var(--tx4); margin-top: 4px; }

@media (min-width: 768px) {
  .deck-grid { grid-template-columns: 1fr 1fr; }
  .jump-grid { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1024px) {
  .deck-grid { grid-template-columns: 1fr 1fr 1fr; }
  .jump-grid { grid-template-columns: 1fr 1fr 1fr; }
}

/* Progress — KPI dials, consistency heat-map, badges */
.kpi-dials { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-12); margin-bottom: var(--sp-16); }
.kpi-dial {
  background-color: var(--surface-raised);
  border: var(--bw-1) solid var(--border-hairline);
  border-radius: var(--radius-lg);
  padding: var(--sp-16);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-4);
  text-align: center;
}
.kpi-dial .donut { width: var(--sp-80); height: var(--sp-80); }
.kpi-dial-label { font-weight: 600; color: var(--n-99); font-size: var(--fs-b1); }
.kpi-dial-sub { font-size: var(--fs-b3); color: var(--n-70); }
.kpi-big { font-family: var(--font-display); font-size: var(--fs-d1); color: var(--c-primary); margin: var(--sp-4) 0; }
.kpi-row { display: flex; gap: var(--sp-24); margin: var(--sp-8) 0 var(--sp-12); }
.kpi-stat-num { font-family: var(--font-display); font-size: var(--fs-d2); color: var(--n-99); }
.kpi-stat-label { font-size: var(--fs-b3); color: var(--n-70); }
.heatmap { display: grid; grid-template-columns: repeat(14, 1fr); gap: var(--sp-4); }
.heat-cell { aspect-ratio: 1; border-radius: var(--radius-sm); background-color: var(--n-20); }
.heat-cell.on { background-color: var(--c-primary); box-shadow: 0 0 var(--sp-4) var(--glow-primary-soft); }
.badge-next { display: flex; align-items: center; gap: var(--sp-16); margin: var(--sp-8) 0 var(--sp-16); }
.badge-next .donut { width: var(--sp-56); height: var(--sp-56); flex: 0 0 auto; }
.badge-next-name { font-weight: 600; color: var(--n-99); }
.badge-shelf { display: flex; flex-wrap: wrap; gap: var(--sp-8); }
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-8);
  padding: var(--sp-8) var(--sp-12);
  border-radius: var(--radius-pill);
  border: var(--bw-1) solid var(--border-hairline);
  background-color: var(--surface-raised);
  font-size: var(--fs-b3);
  color: var(--n-70);
  opacity: 0.55;
}
.badge.earned { opacity: 1; color: var(--n-95); border-color: var(--accent-primary-soft); background-color: var(--wash-primary); }
.badge-dot { width: var(--sp-8); height: var(--sp-8); border-radius: var(--radius-pill); background-color: var(--n-40); flex: 0 0 auto; }
.badge.earned .badge-dot { background-color: var(--c-primary); box-shadow: 0 0 var(--sp-8) var(--glow-primary-soft); }
.effort-chips { display: flex; flex-wrap: wrap; gap: var(--sp-8); margin: var(--sp-16) 0; }
.eff-chip { font-size: var(--fs-b3); color: var(--n-55); padding: var(--sp-4) var(--sp-12); border-radius: var(--radius-pill); border: var(--bw-1) solid var(--border-hairline); }

/* ---------------------------------------------------------------------
   9. Calendar
   --------------------------------------------------------------------- */
.cal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-12);
  margin-bottom: var(--sp-16);
}
.cal-month { font-family: var(--font-display); font-size: var(--fs-d2); color: var(--n-99); }
.cal-dow {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: var(--sp-4);
  margin-bottom: var(--sp-8);
}
.cal-dow span {
  text-align: center;
  font-size: var(--fs-l3);
  letter-spacing: var(--tr-chip);
  text-transform: uppercase;
  color: var(--n-70);
}
.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: var(--sp-4);
}
.day-cell {
  position: relative;
  aspect-ratio: 1;
  border-radius: var(--radius-sm);
  border: var(--bw-1) solid var(--border-hairline-soft);
  background-color: var(--surface-raised);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding: var(--sp-4);
  font-size: var(--fs-b3);
  color: var(--n-90);
}
.day-cell.empty { background: transparent; border-color: transparent; }
.day-cell.past { opacity: 0.55; }
.day-cell.today {
  border-color: var(--ring-primary-soft);
  box-shadow: 0 0 var(--sp-12) var(--glow-primary), inset 0 0 0 var(--bw-1) var(--ring-primary-nav);
  color: var(--c-primary);
}
.day-cell.blackout { background-color: var(--wash-tertiary); border-color: var(--accent-tertiary-sacred); }
.day-num { font-variant-numeric: tabular-nums; line-height: var(--lh-1); margin-bottom: var(--sp-4); }
/* Count of scheduled items, centred in the cell's empty middle. */
.day-count {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  min-width: var(--sp-20);
  padding: var(--bw-2) var(--sp-4);
  border-radius: var(--radius-pill);
  background-color: var(--c-primary-15);
  color: var(--c-primary);
  font-size: var(--fs-l1);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  text-align: center;
}
.day-cell.past .day-count { background-color: var(--n-20); color: var(--n-70); }
.day-marks { display: flex; gap: var(--bw-2); flex-wrap: wrap; justify-content: center; }
.dot {
  width: var(--sp-4);
  height: var(--sp-4);
  border-radius: var(--radius-pill);
}
.dot.deadline { background-color: var(--c-secondary); }
.dot.festival { background-color: var(--c-tertiary); }
.dot.rwa { background-color: var(--danger); }
.cal-legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-8) var(--sp-12);
  margin-top: var(--sp-16);
  font-family: var(--font-mono);
  font-size: var(--fs-l2);
  color: var(--n-70);
}
.cal-legend span { display: inline-flex; align-items: center; gap: var(--sp-4); }

/* ---------------------------------------------------------------------
   10. Flashcards
   --------------------------------------------------------------------- */
/* Recall-first focused card: thin session progress + a single card panel. */
.fc-track { height: 5px; border-radius: 3px; background-color: var(--line); overflow: hidden; margin: var(--sp-4) 0 var(--sp-4); }
.fc-fill { height: 5px; border-radius: 3px; background-color: var(--cy); box-shadow: var(--glow); transition: width var(--motion-transition) ease; }
.fc-card {
  max-width: 680px;
  margin: var(--sp-3) auto 0;
  border: 1px solid var(--line2);
  border-radius: var(--r-xl);
  background-color: var(--panel);
  box-shadow: var(--shadow);
  overflow: hidden;
}
.fc-card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 13px 18px;
  border-bottom: 1px solid var(--line);
}
.fc-card-deck { font-family: var(--font-mono); font-weight: 600; font-size: var(--fs-m1); letter-spacing: 0.1em; text-transform: uppercase; color: var(--tx4); }
.fc-card-count { font-family: var(--font-mono); font-weight: 500; font-size: var(--fs-m2); color: var(--tx4); }
.fc-card-body { padding: 40px 32px; text-align: center; }
.fc-q-eyebrow { font-family: var(--font-mono); font-size: var(--fs-l4); letter-spacing: 0.12em; text-transform: uppercase; color: var(--cy); margin-bottom: 18px; }
.fc-a-eyebrow { font-family: var(--font-mono); font-size: var(--fs-l4); letter-spacing: 0.12em; text-transform: uppercase; color: var(--green); margin-bottom: 14px; }
.fc-front { font-family: var(--font-display); font-weight: 500; font-size: var(--fs-d-a); line-height: 1.3; color: var(--tx); max-width: 480px; margin: 0 auto; }
.fc-divider { height: 1px; background-color: var(--line); margin: 30px auto; max-width: 200px; }
.fc-back { font-family: var(--font-mono); font-size: var(--fs-b1); line-height: 1.6; color: var(--tx2); max-width: 500px; margin: 0 auto; }
.fc-prov { font-family: var(--font-mono); font-size: var(--fs-m1); line-height: 1.4; color: var(--tx4); margin-top: 14px; }
.fc-actions { padding: 0 32px 30px; }
.fc-show {
  appearance: none;
  width: 100%;
  cursor: pointer;
  border: none;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-b3);
  color: var(--cyink);
  background-color: var(--cy);
  padding: 15px 0;
  border-radius: var(--r-md);
  box-shadow: 0 8px 20px -8px var(--cyline);
  transition: box-shadow var(--motion-transition) ease;
}
.fc-show:hover { box-shadow: 0 10px 24px -8px var(--cy); }
.fc-hint { text-align: center; font-family: var(--font-mono); font-size: var(--fs-m2); letter-spacing: 0.06em; text-transform: uppercase; color: var(--tx4); margin-top: 11px; }
.fc-grades { padding: 0 24px 26px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 9px; }
.fc-grade {
  appearance: none;
  cursor: pointer;
  background: transparent;
  border: 1px solid var(--line2);
  border-radius: var(--r-md);
  padding: 13px 0;
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-l2a);
  color: var(--tx2);
  transition: background-color var(--motion-transition) ease, border-color var(--motion-transition) ease;
}
.fc-grade:disabled { opacity: 0.5; cursor: not-allowed; }
.fc-grade.g-again { border-color: var(--red); color: var(--red); }
.fc-grade.g-hard { border-color: var(--amberline); color: var(--amber); }
.fc-grade.g-good { border-color: var(--cyline); background-color: var(--cysoft); color: var(--cy); }
.fc-grade.g-easy { border-color: var(--green); color: var(--green); }
@media (max-width: 440px) {
  .fc-grades { grid-template-columns: 1fr 1fr; }
  .fc-card-body { padding: 32px 22px; }
  .fc-front { font-size: var(--fs-d-sm); }
}

.empty-state {
  text-align: center;
  padding: var(--sp-40) var(--sp-20);
  color: var(--n-70);
}
.empty-state .es-icon {
  display: block; /* span is inline by default — needed for width/height + margin:auto to apply */
  width: var(--sp-44);
  height: var(--sp-44);
  margin: 0 auto var(--sp-16);
  color: var(--success);
}
.empty-state .es-icon svg { display: block; width: 100%; height: 100%; }

/* ---------------------------------------------------------------------
   11. Odds
   --------------------------------------------------------------------- */
.odds-band {
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 22px 24px;
  margin-bottom: var(--sp-3);
  background-color: var(--panel);
}
.odds-band.reach  { border-left: 3px solid var(--violet); }
.odds-band.match  { border-left: 3px solid var(--cy); }
.odds-band.safety { border-left: 3px solid var(--green); }
.odds-band-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: 16px;
}
.odds-tier {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-l2a);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--tx3);
}
.odds-range {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-d0);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  color: var(--cy);
  margin-bottom: 18px;
}
.odds-band.reach  .odds-range { color: var(--violet); }
.odds-band.match  .odds-range { color: var(--cy); }
.odds-band.safety .odds-range { color: var(--green); }
.odds-rationale { font-family: var(--font-mono); font-size: var(--fs-l1); line-height: 1.6; color: var(--tx3); }
.odds-examples { margin-top: 14px; display: flex; flex-direction: column; gap: 10px; }

/* scholarship card */
.scholar {
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 16px 18px;
  background-color: var(--panel);
}
.scholar .sc-name { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-b1); line-height: 1.2; color: var(--tx); }
.scholar .sc-meta { font-family: var(--font-mono); font-size: var(--fs-l2a); line-height: 1.4; color: var(--tx3); margin-top: 6px; }
.scholar .sc-link { font-family: var(--font-mono); font-weight: 600; font-size: var(--fs-l3); color: var(--cy); display: inline-block; margin-top: 9px; }

.safety-net-card { border-color: var(--greensoft); }

/* likelihood range bar (0–100% axis with a shaded low→high segment) */
.range { margin: 0 0 9px; }
.range-bar {
  position: relative;
  height: 12px;
  border-radius: var(--r-pill);
  background-color: var(--line);
  overflow: hidden;
}
.range-grid { position: absolute; top: 0; bottom: 0; width: 1px; background-color: var(--line2); }
.range-fill {
  position: absolute;
  top: 0;
  bottom: 0;
  border-radius: var(--r-pill);
  background-image: linear-gradient(90deg, var(--cy), var(--cyline));
}
.range-fill.reach  { background-image: none; background-color: var(--violet); }
.range-fill.match  { background-image: linear-gradient(90deg, var(--cy), var(--cyline)); }
.range-fill.safety { background-image: none; background-color: var(--green); }
.range-axis { display: flex; justify-content: space-between; margin-top: var(--sp-1); }
.range-axis .tiny { font-family: var(--font-mono); font-size: var(--fs-m1); color: var(--tx4); }
.odds-mover { margin-top: 14px; }
.odds-mover-sum {
  cursor: pointer;
  list-style: none;
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-l4);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cy);
}
.odds-mover-sum::-webkit-details-marker { display: none; }
.odds-mover-list { margin: var(--sp-2) 0 0; padding-left: var(--sp-4); }
.odds-mover-list li { font-family: var(--font-mono); font-size: var(--fs-l2a); line-height: 1.5; color: var(--tx2); margin-bottom: var(--sp-1); }

/* calendar day drill-down */
.day-cell:not(.empty) { cursor: pointer; }
.day-cell:not(.empty):hover { border-color: var(--border-hairline-strong); }
.day-task { display: flex; align-items: center; gap: var(--sp-8); padding: var(--sp-8) 0; border-bottom: var(--bw-1) solid var(--border-hairline-soft); }
.day-task:last-child { border-bottom: none; }
.day-task-title { flex: 1; min-width: 0; font-size: var(--fs-b2); color: var(--n-90); }
.day-task.done .day-task-title { opacity: 0.6; text-decoration: line-through; }
.day-milestone {
  display: block;
  width: 100%;
  text-align: left;
  appearance: none;
  background-color: var(--wash-tertiary);
  border: var(--bw-1) solid var(--accent-tertiary-soft);
  border-radius: var(--radius-md);
  padding: var(--sp-8) var(--sp-12);
  margin-bottom: var(--sp-8);
  color: var(--n-90);
  font-size: var(--fs-b3);
  cursor: pointer;
}

/* ---------------------------------------------------------------------
   12. Progress
   --------------------------------------------------------------------- */
.stat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-12);
  margin-bottom: var(--sp-16);
}
.scores-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-12); }
/* Keep the scores card at two columns even on desktop (only two stats). */
.scores-card .scores-grid { grid-template-columns: 1fr 1fr; }
.stat {
  padding: var(--sp-16);
  border-radius: var(--radius-lg);
  background-color: var(--surface-raised);
  border: var(--bw-1) solid var(--border-hairline);
  text-align: center;
}
.stat .stat-num {
  font-family: var(--font-display);
  font-size: var(--fs-d1);
  color: var(--c-primary);
  font-variant-numeric: tabular-nums;
  line-height: var(--lh-1);
}
.stat .stat-label {
  font-size: var(--fs-l3);
  letter-spacing: var(--tr-chip);
  text-transform: uppercase;
  color: var(--n-70);
  margin-top: var(--sp-8);
}
.progress-track {
  width: 100%;
  height: var(--bw-6);
  border-radius: var(--radius-pill);
  background-color: var(--n-30);
  overflow: hidden;
  margin: var(--sp-8) 0;
}
.progress-fill {
  height: 100%;
  border-radius: var(--radius-pill);
  background-image: linear-gradient(90deg, var(--c-primary), var(--c-secondary));
  transition: width var(--dur-progress) var(--ease);
}

/* plan-completion donut + bar */
.completion-row {
  display: flex;
  align-items: center;
  gap: var(--sp-20);
  margin-top: var(--sp-8);
}
.completion-bar { flex: 1 1 auto; min-width: 0; }
.donut { width: var(--sp-80); height: var(--sp-80); flex: 0 0 auto; }
.donut-track { stroke: var(--n-30); }
.donut-value {
  stroke: var(--c-primary);
  transition: stroke-dashoffset var(--dur-progress) var(--ease);
}
.donut-text {
  fill: var(--n-99);
  font-family: var(--font-display);
  font-size: var(--fs-d2);
  font-weight: 600;
}

/* ---------------------------------------------------------------------
   13. Coach chat
   --------------------------------------------------------------------- */
.coach-screen {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

/* Header mode selector — the "Mode ▾" pill (prototype top-right). */
.coach-mode { display: flex; align-items: center; gap: var(--sp-2); flex: 0 0 auto; }
.coach-mode-label { font-family: var(--font-mono); font-weight: 600; font-size: var(--fs-m2); letter-spacing: 0.12em; text-transform: uppercase; color: var(--tx4); }
.coach-mode select {
  width: auto;
  font-family: var(--font-mono);
  font-size: var(--fs-l2a);
  color: var(--tx2);
  background-color: var(--panel);
  border: 1px solid var(--line2);
  border-radius: var(--r-md);
  padding: 8px 10px;
}

.ai-banner {
  display: flex;
  gap: var(--sp-3);
  align-items: flex-start;
  padding: var(--sp-3);
  border-radius: var(--r-md);
  background-color: var(--cysoft);
  border: 1px solid var(--cyline);
  font-family: var(--font-mono);
  font-size: var(--fs-l2);
  line-height: 1.5;
  color: var(--tx2);
}
.ai-banner .ai-icon { color: var(--cy); width: 18px; height: 18px; flex: 0 0 auto; }

.crisis-card {
  padding: var(--sp-3);
  border-radius: var(--r-md);
  border: 1px solid var(--red);
  background-color: var(--panel);
  font-family: var(--font-mono);
  font-size: var(--fs-l2);
  line-height: 1.5;
  color: var(--tx2);
}
.crisis-card .crisis-title { color: var(--red); font-weight: 600; margin-bottom: var(--sp-1); }
.crisis-card a { color: var(--red); font-weight: 600; }

.chat-log {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: var(--sp-2) 0;
  min-height: 30vh;
}
.bubble {
  max-width: 86%;
  padding: 12px 15px;
  font-family: var(--font-mono);
  font-size: var(--fs-b3);
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
  border: 1px solid var(--line2);
  background-color: var(--panel2);
}
.bubble.user { align-self: flex-end; max-width: 78%; color: var(--tx); border-radius: 12px 12px 4px 12px; }
.bubble.coach { align-self: flex-start; color: var(--tx2); border-radius: 12px 12px 12px 4px; }
.bubble.coach:last-child { border-color: var(--cyline); background-image: linear-gradient(160deg, var(--cysoft), transparent); }
.bubble.offline { border-color: var(--amberline); }
.bubble-tag {
  font-family: var(--font-mono);
  font-size: var(--fs-m2);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--amber);
  margin-bottom: var(--sp-1);
  display: flex;
  align-items: center;
  gap: var(--sp-1);
}
.bubble-tag svg { width: 12px; height: 12px; }
.bubble-cta { margin-top: 10px; }
.bubble-disclaimer {
  font-family: var(--font-mono);
  font-size: var(--fs-m1);
  color: var(--tx4);
  margin-top: var(--sp-2);
  border-top: 1px dashed var(--line);
  padding-top: var(--sp-2);
}
.chat-input-row { display: flex; gap: var(--sp-2); align-items: flex-end; }
.chat-input-row textarea {
  flex: 1;
  min-height: 46px;
  max-height: 30vh;
  font-family: var(--font-mono);
  font-size: var(--fs-b4);
  color: var(--tx);
  background-color: var(--panel);
  border: 1px solid var(--line2);
  border-radius: var(--r-md);
}
.typing { font-family: var(--font-mono); font-size: var(--fs-l2a); color: var(--tx4); font-style: italic; align-self: flex-start; }

/* Square cyan send button. */
.chat-send {
  appearance: none;
  flex: 0 0 auto;
  width: 46px;
  height: 46px;
  border: none;
  border-radius: var(--r-md);
  background-color: var(--cy);
  color: var(--cyink);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 20px -8px var(--cyline);
  transition: box-shadow var(--motion-transition) ease;
}
.chat-send:hover { box-shadow: 0 10px 24px -8px var(--cy); }
.chat-send:disabled { opacity: 0.5; cursor: default; box-shadow: none; }
.chat-send svg { width: 18px; height: 18px; }

/* Pinned composer: stays put above the tab bar while the thread scrolls. */
.coach-composer {
  position: fixed;
  left: 0;
  right: 0;
  bottom: calc(var(--sp-56) + env(safe-area-inset-bottom));
  z-index: 35;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-4);
  background-color: var(--panel);
  border-top: 1px solid var(--line);
}
.chat-disclaimer {
  font-family: var(--font-mono);
  font-size: var(--fs-m1);
  line-height: 1.4;
  color: var(--tx4);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 6px;
}
.chat-disclaimer-warn { color: var(--amber); display: inline-flex; flex: 0 0 auto; }
.chat-disclaimer-warn svg { width: 12px; height: 12px; display: block; }
/* Room so the last bubble is never hidden behind the pinned composer. */
.chat-spacer { height: calc(var(--sp-80) + var(--sp-56)); flex: 0 0 auto; }

/* ---------------------------------------------------------------------
   14. Profile
   --------------------------------------------------------------------- */
.kv {
  display: flex;
  justify-content: space-between;
  gap: var(--sp-12);
  padding: var(--sp-12) 0;
  border-bottom: var(--bw-1) solid var(--border-hairline-soft);
}
.kv:last-child { border-bottom: none; }
.kv .k { color: var(--n-70); font-size: var(--fs-b3); }
.kv .v { color: var(--n-95); font-size: var(--fs-b2); text-align: right; }

.consent-status {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  padding: var(--sp-12) var(--sp-14);
  border-radius: var(--radius-md);
  margin-bottom: var(--sp-12);
  font-size: var(--fs-b2);
}
.consent-status.granted { background-color: var(--wash-success); border: var(--bw-1) solid var(--accent-success-break); color: var(--success); }
.consent-status.pending { background-color: var(--wash-tertiary); border: var(--bw-1) solid var(--accent-tertiary-sacred); color: var(--c-tertiary); }

/* ---------------------------------------------------------------------
   15. Bottom tab bar + drawer
   --------------------------------------------------------------------- */
.tabbar {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 40;
  display: flex;
  justify-content: space-around;
  background-color: var(--panel);
  border-top: 1px solid var(--line);
  padding-bottom: env(safe-area-inset-bottom);
}
.tabbar .tab {
  appearance: none;
  border: none;
  background: transparent;
  color: var(--tx4);
  flex: 1;
  min-height: 56px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-1);
  font-family: var(--font-mono);
  font-size: var(--fs-m4);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: color var(--motion-transition) ease;
}
.tabbar .tab svg { width: 22px; height: 22px; }
.tabbar .tab[aria-current="page"] { color: var(--cy); font-weight: 600; }
.tabbar .tab[aria-current="page"] svg { filter: drop-shadow(0 0 6px var(--cy)); }

.scrim {
  position: fixed;
  inset: 0;
  z-index: 49;
  background-color: var(--scrim);
  backdrop-filter: blur(2px);
}
.drawer {
  position: fixed;
  z-index: 50;
  right: 0;
  top: 0;
  bottom: 0;
  width: 78%;
  max-width: 320px;
  background-color: var(--panel);
  border-left: 1px solid var(--line2);
  box-shadow: var(--shadow);
  padding: var(--sp-5) var(--sp-4);
  padding-top: calc(var(--sp-5) + env(safe-area-inset-top));
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
  overflow-y: auto;
}
.drawer-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-3);
}
.drawer-item {
  appearance: none;
  border: 1px solid transparent;
  background: transparent;
  text-align: left;
  width: 100%;
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3);
  border-radius: var(--r-sm);
  color: var(--tx3);
  font-family: var(--font-mono);
  font-size: var(--fs-b4);
  transition: background-color var(--motion-transition) ease,
    color var(--motion-transition) ease;
}
.drawer-item:hover { background-color: var(--panel2); color: var(--tx); }
.drawer-item[aria-current="page"] {
  background-color: var(--cysoft);
  border-color: var(--cyline);
  color: var(--cy);
}
.drawer-item svg { width: 18px; height: 18px; flex: 0 0 auto; }
.drawer-sep { height: 1px; background-color: var(--line); margin: var(--sp-2) 0; }
.drawer-item.danger { color: var(--red); }

/* ---------------------------------------------------------------------
   Desktop left flight-deck sidebar (#sidebar) — shown only at >=1024px.
   --------------------------------------------------------------------- */
.sidebar {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: var(--w-sidebar);
  z-index: 20; /* below the sticky topbar (30) */
  flex-direction: column;
  background-color: var(--panel);
  border-right: 1px solid var(--line);
  padding: calc(var(--h-topbar) + var(--sp-4)) var(--sp-3) var(--sp-4);
  /* The nav region (.side-scroll) scrolls on its own when the viewport is
     short; the account foot stays pinned to the bottom of the viewport so it
     is always reachable without scrolling. */
  overflow: hidden;
}
.side-scroll {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.side-group {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-m5);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--tx4);
  padding: var(--sp-1) var(--sp-3) 6px;
}
.side-group.spaced { margin-top: var(--sp-3); }
.side-item {
  appearance: none;
  border: 1px solid transparent;
  background: transparent;
  text-align: left;
  width: 100%;
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3);
  border-radius: var(--r-sm);
  color: var(--tx3);
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: var(--fs-b4);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background-color var(--motion-transition) ease,
    color var(--motion-transition) ease, border-color var(--motion-transition) ease;
}
.side-item:hover { color: var(--tx2); }
.side-item svg { width: 17px; height: 17px; flex: 0 0 auto; }
.side-item[aria-current="page"] {
  background-color: var(--cysoft);
  border-color: var(--cyline);
  color: var(--cy);
  font-weight: 600;
}
.side-foot { flex: 0 0 auto; position: relative; padding-top: var(--sp-3); }
.account-chip {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--sp-2);
  background-color: var(--panel2);
  cursor: pointer;
  transition: border-color var(--motion-transition) ease;
}
.account-chip:hover { border-color: var(--line2); }
.account-avatar {
  width: 32px;
  height: 32px;
  flex: 0 0 auto;
  border-radius: var(--r-sm);
  background-color: var(--cysoft);
  border: 1px solid var(--cyline);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-b3);
  color: var(--cy);
}
.account-id { min-width: 0; flex: 1; text-align: left; }
.account-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-l1);
  line-height: 1.1;
  color: var(--tx);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.account-meta {
  font-family: var(--font-mono);
  font-size: var(--fs-m3);
  line-height: 1.2;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--tx4);
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.account-caret { color: var(--tx4); flex: 0 0 auto; }
.account-caret svg { width: 14px; height: 14px; }
.account-menu {
  position: absolute;
  bottom: calc(100% + var(--sp-2));
  left: 0;
  right: 0;
  border: 1px solid var(--line2);
  border-radius: var(--r-lg);
  background-color: var(--raised);
  box-shadow: var(--shadow);
  padding: 6px;
  z-index: 30;
}
.account-menu-item {
  appearance: none;
  border: none;
  background: transparent;
  text-align: left;
  width: 100%;
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-2) 9px;
  border-radius: var(--r-sm);
  cursor: pointer;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-l1);
  color: var(--tx2);
  transition: background-color var(--motion-transition) ease,
    color var(--motion-transition) ease;
}
.account-menu-item:hover { background-color: var(--panel2); color: var(--tx); }
.account-menu-item svg { width: 15px; height: 15px; color: var(--tx3); flex: 0 0 auto; }
.account-menu-item.danger { color: var(--tx3); }
.account-menu-item.danger:hover { color: var(--tx2); }
.account-menu-sep { height: 1px; background-color: var(--line); margin: var(--sp-1) 9px; }

/* ---------------------------------------------------------------------
   16. Toast + loaders + states
   --------------------------------------------------------------------- */
.toast {
  position: fixed;
  left: 50%;
  bottom: calc(var(--sp-80) + env(safe-area-inset-bottom));
  transform: translateX(-50%);
  z-index: 60;
  max-width: 90%;
  padding: var(--sp-12) var(--sp-16);
  border-radius: var(--radius-pill);
  background-color: var(--n-10);
  border: var(--bw-1) solid var(--border-hairline-strong);
  box-shadow: var(--shadow-hover);
  color: var(--n-95);
  font-size: var(--fs-b3);
}
.toast.error { border-color: var(--glow-danger); color: var(--danger); }
.toast.ok { border-color: var(--accent-success-break); color: var(--success); }

.skeleton {
  background-image: linear-gradient(90deg, var(--n-20), var(--n-30), var(--n-20));
  border-radius: var(--radius-md);
  min-height: var(--sp-56);
  margin-bottom: var(--sp-12);
  opacity: 0.6;
}

.error-box {
  padding: var(--sp-16);
  border-radius: var(--radius-md);
  background-color: var(--wash-danger);
  border: var(--bw-1) solid var(--glow-danger);
  color: var(--n-90);
  font-size: var(--fs-b3);
  display: flex;
  flex-direction: column;
  gap: var(--sp-12);
}
.error-box .eb-title { color: var(--danger); font-weight: 600; }

.spinner {
  width: var(--sp-20);
  height: var(--sp-20);
  border-radius: var(--radius-pill);
  border: var(--bw-2) solid var(--border-hairline-strong);
  border-top-color: var(--c-primary);
  animation: spin 0.8s linear infinite;
}
.center-load {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-12);
  padding: var(--sp-40);
  color: var(--n-70);
}
@keyframes spin { to { transform: rotate(360deg); } }

.offline-pill {
  position: fixed;
  top: calc(var(--sp-56) + env(safe-area-inset-top));
  left: 50%;
  transform: translateX(-50%);
  z-index: 35;
  padding: var(--sp-4) var(--sp-12);
  border-radius: var(--radius-pill);
  background-color: var(--wash-tertiary);
  border: var(--bw-1) solid var(--accent-tertiary-sacred);
  color: var(--c-tertiary);
  font-size: var(--fs-l2);
  font-weight: 600;
}

/* ---------------------------------------------------------------------
   17. Responsive — the app adapts AUTOMATICALLY to the screen it opens on.
        phone (<768px)   : single column, bottom tab-bar  (mobile-first base)
        tablet (768-1023): wider content column, denser grids, bottom tabs
        laptop (>=1024px): left sidebar nav, content uses the width
   --------------------------------------------------------------------- */
@media (min-width: 480px) {
  .ws-grid { grid-template-columns: 1fr 1fr; }
}

/* ---- tablet: keep the bottom tab-bar, just let content breathe ---- */
@media (min-width: 768px) {
  :root { --w-content: 720px; }
  .stat-grid { grid-template-columns: repeat(4, 1fr); }
}

/* ---- laptop / desktop: bottom tab-bar gives way to the #sidebar ---- */
@media (min-width: 1024px) {
  /* content area sits to the right of the sidebar and uses the width */
  .app-frame { max-width: none; margin: 0; }
  .view {
    max-width: var(--w-content-wide);
    margin: 0 0 0 var(--w-sidebar);
    margin-right: auto;
    padding: var(--sp-5) var(--sp-7) var(--sp-7);
    min-height: calc(100dvh - var(--h-topbar));
  }

  /* the mobile bottom tab-bar is hidden; the flight-deck sidebar takes over */
  .tabbar { display: none; }
  .sidebar:not([hidden]) { display: flex; }

  /* the topbar avatar is desktop-redundant (account chip lives in the sidebar) */
  .topbar-avatar { display: none; }

  /* roomier grids now that there is room */
  .ws-grid { grid-template-columns: repeat(3, 1fr); }

  /* The sidebar holds nav on desktop, so the pinned composer sits at the
     very bottom of the content column (offset by the sidebar). */
  .coach-composer {
    bottom: 0;
    left: var(--w-sidebar);
    padding-left: var(--sp-7);
    padding-right: var(--sp-7);
  }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
  }
}

/* ---------------------------------------------------------------------
   18. Spike Tracker screen
   --------------------------------------------------------------------- */

/* Empty-state icon uses primary accent (bolt = energy/initiative) */
.spike-es-icon {
  width: var(--sp-44);
  height: var(--sp-44);
  margin: 0 auto var(--sp-16);
  color: var(--c-primary);
}
.spike-es-icon svg { width: 100%; height: 100%; }

/* Clickable project card in the list */
.spike-proj {
  appearance: none;
  display: block;
  width: 100%;
  text-align: left;
  border: var(--bw-1) solid var(--border-hairline);
  background-image: linear-gradient(var(--surface-card-top), var(--surface-card-bot));
  border-radius: var(--radius-md);
  padding: var(--sp-16) var(--sp-14);
  margin-bottom: var(--sp-12);
  cursor: pointer;
  transition: border-color var(--dur-color) var(--ease),
              background-color var(--dur-color) var(--ease);
}
.spike-proj:hover,
.spike-proj:focus-visible {
  border-color: var(--accent-primary-soft);
  background-image: none;
  background-color: var(--n-20);
  outline: none;
}

/* Row inside the card: title on the left, status chip on the right */
.spike-proj-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-8);
  margin-bottom: var(--sp-8);
}
.spike-proj-title {
  font-weight: 600;
  color: var(--n-95);
  font-size: var(--fs-b2);
  flex: 1;
  min-width: 0;
}

/* Truncated description preview */
.spike-proj-desc {
  font-size: var(--fs-b3);
  color: var(--n-70);
  margin-bottom: var(--sp-8);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Meta row: category chip + hours + target date */
.spike-proj-meta {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  flex-wrap: wrap;
}

/* Hours figure — prominent display font */
.spike-proj-hours {
  font-family: var(--font-display);
  font-size: var(--fs-d4);
  color: var(--c-primary);
  font-weight: 600;
}

/* Detail view: project header block */
.spike-detail-head {
  margin: var(--sp-16) 0;
}

/* Individual log entry row inside the hours card */
.spike-log-row {
  padding: var(--sp-12) 0;
  border-bottom: var(--bw-1) solid var(--border-hairline-soft);
}
.spike-log-row:last-child { border-bottom: none; }

/* Top line of a log row: date + chip side by side */
.spike-log-top {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  margin-bottom: var(--sp-4);
}
.spike-log-date {
  font-size: var(--fs-b3);
  font-weight: 600;
  color: var(--n-95);
}
.spike-log-note {
  font-size: var(--fs-b3);
  color: var(--n-70);
}

/* ---------------------------------------------------------------------
   19. Essay Workspace screen
   --------------------------------------------------------------------- */

/* Empty-state icon uses primary accent (pen = expression/writing) */
.essay-es-icon {
  width: var(--sp-44);
  height: var(--sp-44);
  margin: 0 auto var(--sp-16);
  color: var(--c-primary);
}
.essay-es-icon svg { width: 100%; height: 100%; }

/* Clickable essay card in the list */
.essay-card {
  appearance: none;
  display: block;
  width: 100%;
  text-align: left;
  border: var(--bw-1) solid var(--border-hairline);
  background-image: linear-gradient(var(--surface-card-top), var(--surface-card-bot));
  border-radius: var(--radius-md);
  padding: var(--sp-16) var(--sp-14);
  margin-bottom: var(--sp-12);
  cursor: pointer;
  transition: border-color var(--dur-color) var(--ease),
              background-color var(--dur-color) var(--ease);
}
.essay-card:hover,
.essay-card:focus-visible {
  border-color: var(--accent-primary-soft);
  background-image: none;
  background-color: var(--n-20);
  outline: none;
}

/* Row inside the card: title on the left, status chip on the right */
.essay-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-8);
  margin-bottom: var(--sp-8);
}
.essay-card-title {
  font-weight: 600;
  color: var(--n-95);
  font-size: var(--fs-b2);
  flex: 1;
  min-width: 0;
}

/* Meta row: type chip + word-target + school */
.essay-card-meta {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  flex-wrap: wrap;
}

/* Detail view: essay header block */
.essay-detail-head {
  margin: var(--sp-16) 0;
}

/* Individual draft row inside the drafts card */
.essay-draft-row {
  padding: var(--sp-12) 0;
  border-bottom: var(--bw-1) solid var(--border-hairline-soft);
}
.essay-draft-row:last-child { border-bottom: none; }

/* Top line of a draft row: version label + word-count chip */
.essay-draft-top {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  margin-bottom: var(--sp-8);
}
.essay-draft-version {
  font-size: var(--fs-b3);
  font-weight: 600;
  color: var(--n-95);
}

/* Rubric chips row — wraps on narrow screens */
.essay-rubric {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-6);
}

/* Note row inside the notes card */
.essay-note-row {
  padding: var(--sp-12) 0;
  border-bottom: var(--bw-1) solid var(--border-hairline-soft);
}
.essay-note-row:last-child { border-bottom: none; }

/* Top line of a note row: tag chip + date */
.essay-note-top {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  margin-bottom: var(--sp-6);
}
.essay-note-content {
  font-size: var(--fs-b3);
  color: var(--n-70);
}

/* =====================================================================
   Section 20 — Coach Quality screen
   ===================================================================== */

/* CTA button appended to a coach chat bubble */
.bubble-cta {
  display: block;
  margin-top: var(--sp-8);
}

/* Flagged-turn row */
.quality-turn-row {
  padding: var(--sp-12) 0;
  border-bottom: var(--bw-1) solid var(--border-hairline-soft);
}
.quality-turn-row:last-child { border-bottom: none; }

.quality-turn-top {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-8);
  margin-bottom: var(--sp-6);
}
.quality-turn-user {
  font-size: var(--fs-b3);
  font-weight: 500;
  color: var(--n-95);
}
.quality-flags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-4);
  margin-bottom: var(--sp-4);
}
.quality-coach-snippet {
  font-size: var(--fs-b3);
  color: var(--n-55);
}

/* Golden-set result row */
.quality-golden-row {
  display: flex;
  align-items: baseline;
  gap: var(--sp-8);
  padding: var(--sp-10) 0;
  border-bottom: var(--bw-1) solid var(--border-hairline-soft);
}
.quality-golden-row:last-child { border-bottom: none; }
.quality-golden-label {
  font-size: var(--fs-b3);
  color: var(--n-95);
  flex: 1;
}
.quality-golden-reason {
  font-size: var(--fs-b3);
  color: var(--n-55);
  width: 100%;
  padding-top: var(--sp-2);
}

/* Proposal row */
.quality-proposal-row {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-8);
  padding: var(--sp-10) 0;
  border-bottom: var(--bw-1) solid var(--border-hairline-soft);
  font-size: var(--fs-b3);
  color: var(--n-90);
}
.quality-proposal-row:last-child { border-bottom: none; }
.quality-proposal-icon {
  flex-shrink: 0;
  width: var(--sp-16);
  height: var(--sp-16);
  color: var(--accent-blue);
}

/* =====================================================================
   19. Refinement layer (Phase 4) — gamification badge tiles, scroll-reveal,
   and playful micro-interactions. Every motion rule is gated behind the
   JS-added <body class="motion-ok"> hook (set only when the OS is NOT in
   prefers-reduced-motion), so the default render is fully visible + static
   and content is NEVER hidden if JS fails or reduced motion is on.
   Colour / shadow / radius values reference tokens; the only raw literals
   are motion offsets (translate ±2px) and durations (allowed inline).
   ===================================================================== */

/* ---- Gamification: custom badge icon tiles (replaces the text chips) ---- */
.badge-shelf {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(var(--sp-80), 1fr));
  gap: var(--sp-8);
}
.badge-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-8);
  padding: var(--sp-12) var(--sp-8);
  border-radius: var(--radius-md);
  border: var(--bw-1) solid var(--border-hairline);
  background-color: var(--surface-raised);
  text-align: center;
  opacity: 0.6; /* locked: slightly dimmed */
}
.badge-ico { width: var(--sp-28); height: var(--sp-28); color: var(--tx4); } /* locked: faint tx4 outline */
.badge-ico svg { width: 100%; height: 100%; display: block; }
.badge-tile .badge-name {
  font-size: var(--fs-l1);
  line-height: var(--lh-12);
  color: var(--n-70);
}
/* earned — cyan telemetry tone: accent + soft glow */
.badge-tile.earned {
  opacity: 1;
  border-color: var(--cyline);
  background-color: var(--cysoft);
  box-shadow: var(--glow);
}
.badge-tile.earned .badge-ico { color: var(--cy); }
.badge-tile.earned .badge-name { color: var(--n-95); }
/* earned — green "real win" tone: milestone + memory-vault recall */
.badge-tile.earned.tone-green {
  border-color: var(--accent-success-break);
  background-color: var(--greensoft);
  box-shadow: 0 0 var(--sp-8) var(--glow-success); /* --glow-success is a colour, not a shadow */
}
.badge-tile.earned.tone-green .badge-ico { color: var(--green); }

/* Real flame icon beside the streak count (replaces the 🔥 emoji) */
.kpi-stat-num { display: inline-flex; align-items: center; gap: var(--sp-4); }
.kpi-stat-ico { width: var(--sp-20); height: var(--sp-20); color: var(--c-tertiary); flex: 0 0 auto; }
.kpi-stat-ico svg { width: 100%; height: 100%; display: block; }

/* ---- Scroll-reveal — animation-driven so it never collides with the
   hover-lift transition. Only active under .motion-ok. ---- */
@keyframes rfReveal {
  from { opacity: 0; transform: translateY(var(--sp-14)); }
  to   { opacity: 1; transform: translateY(0); }
}
.motion-ok .reveal { opacity: 1; } /* rest state = fully visible */
.motion-ok .reveal:not(.is-visible) { opacity: 0; transform: translateY(var(--sp-14)); }
.motion-ok .reveal.is-visible {
  animation: rfReveal 0.45s var(--ease) backwards;
  animation-delay: calc(var(--reveal-i, 0) * 55ms); /* small staggered cascade, capped in JS */
}

/* ---- Playful micro-interactions (all .motion-ok gated) ---- */
/* card hover lift — fine pointers only */
@media (hover: hover) and (pointer: fine) {
  .motion-ok .card {
    transition: transform 0.2s var(--ease), border-color 0.2s var(--ease),
      box-shadow 0.2s var(--ease);
  }
  .motion-ok .card:hover { transform: translateY(-2px); border-color: var(--cyline); }
}
/* buttons compress on press (Initiate / Mark-done keep their own ignite pop) */
.motion-ok .btn:active { transform: scale(0.97); }
/* Today presence gauge: gentle idle float, layered over its radar sweep */
@keyframes rfFloat { 0%, 100% { transform: translateY(-2px); } 50% { transform: translateY(2px); } }
.motion-ok .gauge { animation: rfFloat 4s ease-in-out infinite; }
/* nav active item: a subtle, alive accent */
@keyframes rfNavPulse { 0%, 100% { opacity: 0.62; } 50% { opacity: 1; } }
.motion-ok .tabbar .tab[aria-current="page"] svg {
  animation: rfNavPulse var(--motion-pulse) ease-in-out infinite;
}
.motion-ok .side-item[aria-current="page"] { box-shadow: var(--glow); }

/* =====================================================================
   Tutor UI — .tutor-* components
   All values reference design tokens only; no raw hex / px literals.
   ===================================================================== */

/* ── Layout helpers ─────────────────────────────────────────────────── */
.tutor-domain-section {
  padding-bottom: var(--sp-16);
}
.tutor-concept-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  margin-top: var(--sp-8);
}
.tutor-back-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-8);
}
.tutor-nav-row {
  display: flex;
  gap: var(--sp-8);
  margin-top: var(--sp-16);
}

/* ── Concept picker row ─────────────────────────────────────────────── */
.tutor-concept-row {
  display: flex;
  align-items: center;
  gap: var(--sp-12);
  width: 100%;
  padding: var(--sp-12) var(--sp-16);
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  cursor: pointer;
  text-align: left;
  color: var(--tx);
  transition: background var(--motion-fast);
}
.tutor-concept-row:hover,
.tutor-concept-row:focus-visible {
  background: var(--panel2);
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}
.tutor-concept-name {
  flex: 1;
  font-size: var(--fs-base);
  color: var(--tx);
}
.tutor-concept-pct {
  font-size: var(--fs-sm);
  color: var(--tx3);
  font-variant-numeric: tabular-nums;
}

/* ── Mastery dot ────────────────────────────────────────────────────── */
.tutor-mastery-dot {
  width: var(--sp-8);
  height: var(--sp-8);
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--line2);
}
.tutor-mastery-dot.mastered { background: var(--green); }
.tutor-mastery-dot.strong   { background: var(--cy); }
.tutor-mastery-dot.partial  { background: var(--amber); }
.tutor-mastery-dot.weak     { background: var(--red); }
.tutor-mastery-dot.unset    { background: var(--line2); }

/* ── Lesson body ────────────────────────────────────────────────────── */
.tutor-lesson-chunk {
  margin-bottom: var(--sp-16);
}
.tutor-lesson-heading {
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--tx);
  margin-bottom: var(--sp-8);
}
.tutor-lesson-body {
  font-size: var(--fs-base);
  color: var(--tx2);
  line-height: var(--lh-16);
}
.tutor-lesson-source {
  font-size: var(--fs-xs);
  color: var(--tx4);
  margin-bottom: var(--sp-4);
}
.tutor-source-link {
  display: inline-block;
  font-size: var(--fs-sm);
  color: var(--cy);
  margin-bottom: var(--sp-16);
  text-decoration: underline;
}
.tutor-source-link:hover { color: var(--cyink); }
.tutor-practice-cta {
  margin-top: var(--sp-24);
  display: flex;
  align-items: center;
  gap: var(--sp-8);
}

/* ── KaTeX math containers ──────────────────────────────────────────── */
.tutor-math {
  display: inline;
}
.tutor-math-display {
  display: block;
  overflow-x: auto;
  padding: var(--sp-8) 0;
  text-align: center;
}

/* ── Practice MCQ ───────────────────────────────────────────────────── */
.tutor-practice-counter {
  font-size: var(--fs-sm);
  color: var(--tx3);
  font-variant-numeric: tabular-nums;
}
.tutor-stem {
  font-size: var(--fs-base);
  color: var(--tx);
  line-height: var(--lh-16);
  margin-bottom: var(--sp-16);
  padding: var(--sp-16);
  background: var(--panel);
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
}
.tutor-choice-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-8);
}
.tutor-choice-btn {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-12);
  width: 100%;
  padding: var(--sp-12) var(--sp-16);
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  cursor: pointer;
  color: var(--tx);
  text-align: left;
  transition: background var(--motion-fast), border-color var(--motion-fast);
}
.tutor-choice-btn:hover:not(.picked):not(.correct):not(.wrong):not(.dim) {
  background: var(--panel2);
}
.tutor-choice-btn:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}
.tutor-choice-btn.correct {
  background: var(--greensoft);
  border-color: var(--green);
}
.tutor-choice-btn.wrong {
  background: var(--wash-danger);
  border-color: var(--red);
}
.tutor-choice-btn.dim {
  opacity: 0.5;
}
.tutor-choice-letter {
  flex-shrink: 0;
  width: var(--sp-24);
  height: var(--sp-24);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid var(--line2);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--tx2);
}
.tutor-choice-btn.correct .tutor-choice-letter {
  background: var(--green);
  border-color: var(--green);
  color: var(--bg);
}
.tutor-choice-btn.wrong .tutor-choice-letter {
  background: var(--red);
  border-color: var(--red);
  color: var(--bg);
}
.tutor-choice-text {
  flex: 1;
  font-size: var(--fs-base);
  color: var(--tx);
  line-height: var(--lh-16);
}

/* ── Step feedback ──────────────────────────────────────────────────── */
.tutor-step-feedback {
  margin-top: var(--sp-16);
  padding: var(--sp-16);
  background: var(--panel);
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
}
.tutor-fb-verdict {
  font-size: var(--fs-md);
  font-weight: 600;
  margin-bottom: var(--sp-8);
}
.tutor-fb-verdict.ok  { color: var(--green); }
.tutor-fb-verdict.err { color: var(--red); }
.tutor-fb-text {
  font-size: var(--fs-base);
  color: var(--tx2);
  line-height: var(--lh-16);
}

/* ── Official link card ─────────────────────────────────────────────── */
.tutor-official-link-card {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  padding: var(--sp-8) var(--sp-12);
  background: var(--wash-primary);
  border: 1px solid var(--cyline);
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
  color: var(--cy);
  margin-bottom: var(--sp-12);
  text-decoration: none;
}
.tutor-official-link-card:hover { background: var(--cysoft); }

/* ── Locked / consent gate card ─────────────────────────────────────── */
.tutor-locked-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-16);
  padding: var(--sp-32);
  background: var(--panel);
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  text-align: center;
  margin: var(--sp-40) auto;
  max-width: 360px;
}
.tutor-locked-icon {
  color: var(--amber);
  width: var(--sp-40);
  height: var(--sp-40);
}
.tutor-locked-title {
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--tx);
}

/* ── Mastery map ────────────────────────────────────────────────────── */
.tutor-dial-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-16);
  margin-bottom: var(--sp-16);
}
.tutor-proj-section {
  padding: var(--sp-16);
  background: var(--panel);
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  margin-bottom: var(--sp-24);
}
.tutor-proj-label {
  font-size: var(--fs-sm);
  color: var(--tx3);
  margin-bottom: var(--sp-8);
}
.tutor-mastery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: var(--sp-8);
  margin-top: var(--sp-12);
  margin-bottom: var(--sp-16);
}
.tutor-mastery-cell {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--sp-4);
  padding: var(--sp-12);
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  cursor: pointer;
  text-align: left;
  transition: background var(--motion-fast);
}
.tutor-mastery-cell:hover,
.tutor-mastery-cell:focus-visible {
  background: var(--panel2);
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}
.tutor-mastery-cell.mastered { border-color: var(--green); }
.tutor-mastery-cell.strong   { border-color: var(--cy); }
.tutor-mastery-cell.partial  { border-color: var(--amber); }
.tutor-mastery-cell.weak     { border-color: var(--red); }
.tutor-cell-label {
  font-size: var(--fs-sm);
  color: var(--tx);
  line-height: var(--lh-14);
}
.tutor-improve-row {
  font-size: var(--fs-sm);
  color: var(--tx3);
  padding-left: var(--sp-16);
  position: relative;
  margin-bottom: var(--sp-4);
}
.tutor-improve-row::before {
  content: "·";
  position: absolute;
  left: var(--sp-4);
  color: var(--tx4);
}

/* ── btn-primary — primary action button (alias of .btn for surfaces that ──
   reference it by the primary name used throughout tutor + quiz code)     */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-5);
  font-size: var(--fs-b1);
  font-weight: 600;
  line-height: var(--lh-24);
  border-radius: var(--radius-pill);
  border: none;
  cursor: pointer;
  background: var(--cy);
  color: var(--bg);
  transition:
    background var(--motion-fast),
    box-shadow var(--motion-fast);
}
.btn-primary:hover,
.btn-primary:focus-visible {
  background: var(--cy-hi, var(--cy));
  box-shadow: 0 0 0 3px var(--focus-ring);
  outline: none;
}
.btn-primary:active { opacity: 0.85; }
@media (prefers-reduced-motion: reduce) {
  .btn-primary { transition: none; }
}

/* The quiz surface reuses the .tutor-* MCQ styles (choice buttons, stem,
   step-feedback, nav row) — no bespoke .quiz-* rules needed. */
