/* ============================================================
   RACE PREPRR — Starting Line Design System
   ============================================================ */

/* ===== Google Fonts are loaded in base.html ===== */

/* ===== TOKENS ===== */
:root {
  --bg-0: #0a0b0c;
  --bg-1: #121315;
  --bg-2: #1b1d20;
  --bg-3: #24272d;
  --line: #2a2d33;
  --text-hi: #f4f5f7;
  --text-md: #b7bcc8;
  --text-lo: #6b7280;
  --accent: oklch(88% 0.22 135);
  --accent-ink: #0a0b0c;
  --accent-soft: oklch(88% 0.22 135 / 0.12);
  --warn: oklch(78% 0.18 60);
  --warn-soft: oklch(78% 0.18 60 / 0.12);
  --info: oklch(82% 0.14 220);
  --swim-color: oklch(82% 0.14 220);
  --bike-color: oklch(86% 0.18 145);
  --run-color: oklch(80% 0.18 40);
  --danger: oklch(68% 0.2 28);
  --danger-soft: oklch(68% 0.2 28 / 0.12);

  /* Legacy compat */
  --colour-bg: var(--bg-0);
  --colour-surface: var(--bg-1);
  --colour-text: var(--text-hi);
  --colour-muted: var(--text-md);
  --colour-link: var(--accent);
  --colour-accent: var(--accent);
  --colour-outline: var(--line);
  --colour-success: var(--accent);
  --colour-warning: var(--warn);
}

/* ===== BASE RESET ===== */
*, *::before, *::after { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--bg-0);
  color: var(--text-hi);
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
img, svg { display: block; max-width: 100%; }
button { cursor: pointer; }
input, select, textarea, button { font-family: inherit; font-size: inherit; }

/* ===== APP SHELL ===== */
.app-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* ===== HEADER / NAV ===== */
.app-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--bg-0);
  border-bottom: 1px solid var(--line);
}
.app-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 28px;
  gap: 16px;
}

/* Brand / Logo */
.app-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  flex-shrink: 0;
}
.app-brand-mark {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: var(--accent);
  color: var(--accent-ink);
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900; font-size: 22px;
  display: grid; place-items: center;
  transform: skewX(-8deg);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.05), 0 4px 12px rgba(0,0,0,0.4);
  flex-shrink: 0;
}
.app-brand-mark span { transform: skewX(8deg); display: block; }
.app-brand-word {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 20px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--text-hi);
  line-height: 1;
}
.app-brand-sub {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 0.2em;
  color: var(--text-lo); text-transform: uppercase;
  margin-top: 2px;
}

/* Nav links */
.app-nav {
  display: flex;
  align-items: center;
  gap: 2px;
}
.app-nav__link {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 600; font-size: 14px;
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 8px 12px; border-radius: 6px;
  color: var(--text-md); text-decoration: none;
  transition: all .15s;
}
.app-nav__link:hover { color: var(--text-hi); background: var(--bg-2); text-decoration: none; }
.app-nav__link--active,
.app-nav__link.active { color: var(--accent-ink); background: var(--accent); }
.app-nav__link--active:hover,
.app-nav__link.active:hover { color: var(--accent-ink); filter: brightness(1.08); }

/* Sign out button in nav */
.app-nav__signout-form { margin: 0; }
.app-nav__signout {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 8px 12px; border-radius: 6px;
  border: 1px solid var(--line);
  background: transparent; color: var(--text-md);
  cursor: pointer; transition: all .15s;
}
.app-nav__signout:hover { color: var(--text-hi); border-color: var(--text-md); }

/* Sign in/up CTA buttons in nav */
.app-nav__cta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 8px 14px; border: 1px solid var(--line); border-radius: 6px;
  background: transparent; color: var(--text-md); text-decoration: none;
  transition: all .15s;
}
.app-nav__cta:hover { text-decoration: none; color: var(--text-hi); }
.app-nav__cta--primary {
  background: var(--accent); color: var(--accent-ink);
  border-color: var(--accent); font-weight: 700;
}
.app-nav__cta--primary:hover { filter: brightness(1.08); color: var(--accent-ink); }

/* ===== MAIN ===== */
.app-container {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
}
.app-main {
  flex: 1;
  padding: 28px;
}

/* ===== FOOTER ===== */
.app-footer {
  border-top: 1px solid var(--line);
  padding: 24px 28px;
  background: var(--bg-0);
}
.app-footer__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-lo);
}
.app-footer__copy { display: flex; flex-direction: column; gap: 4px; }
.app-footer__eyebrow { font-weight: 600; color: var(--text-hi); }
.app-footer__nav { display: flex; gap: 16px; flex-wrap: wrap; }
.app-footer__link { color: var(--text-lo); text-decoration: none; transition: color .15s; }
.app-footer__link:hover { color: var(--accent); text-decoration: none; }
.app-footer__kofi {
  display: inline-block;
  background: var(--accent); color: var(--accent-ink);
  padding: 8px 14px; border-radius: 999px;
  font-weight: 700; letter-spacing: 0.1em;
  text-decoration: none; font-size: 11px;
}

/* Ko-fi widget override */
.app-footer__support .kofi-button,
.app-footer__support a[href*="ko-fi"] {
  background: var(--accent) !important;
  color: var(--accent-ink) !important;
  border-radius: 999px !important;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 11px !important;
  letter-spacing: 0.1em !important;
}

/* ===== TYPOGRAPHY ===== */
.kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent);
}
.kicker--mute { color: var(--text-lo); }

.display {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900;
  font-size: clamp(48px, 8vw, 110px);
  line-height: 0.88; letter-spacing: -0.01em;
  text-transform: uppercase; margin: 8px 0 20px;
}
.display .accent { color: var(--accent); }
.display--sm { font-size: clamp(36px, 5vw, 72px); }

h1.section-title, h2.section-title, h3.section-title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 28px;
  letter-spacing: 0.02em; text-transform: uppercase; margin: 0;
}
.section-head {
  display: flex; align-items: baseline; justify-content: space-between;
  margin: 36px 0 16px;
}
.section-head small {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-lo);
}

/* Legacy heading styles */
h1 { font-family: 'Big Shoulders Display', system-ui; font-weight: 800; font-size: 36px; text-transform: uppercase; letter-spacing: 0.02em; margin: 0 0 12px; }
h2 { font-family: 'Big Shoulders Display', system-ui; font-weight: 800; font-size: 26px; text-transform: uppercase; letter-spacing: 0.02em; margin: 0 0 10px; }
h3 { font-family: 'Big Shoulders Display', system-ui; font-weight: 700; font-size: 20px; text-transform: uppercase; letter-spacing: 0.04em; margin: 0 0 8px; }
h4, h5, h6 { font-family: 'Big Shoulders Display', system-ui; font-weight: 700; font-size: 16px; text-transform: uppercase; letter-spacing: 0.05em; margin: 0 0 6px; }
p { margin: 0 0 1em; }
.muted { color: var(--text-md); }
strong { font-weight: 600; color: var(--text-hi); }

.stripe {
  display: inline-block;
  height: 6px; width: 72px;
  background: var(--accent);
  margin: 4px 0 20px;
}

/* ===== CARD ===== */
.card {
  position: relative; overflow: hidden;
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 22px;
}
.card--hero {
  padding: 36px;
  border-radius: 18px;
}
.card--hero::before {
  content: "";
  position: absolute; inset: auto -20% -60% -20%; height: 300px;
  background: radial-gradient(ellipse at center, var(--accent), transparent 60%);
  opacity: 0.07; pointer-events: none;
}
/* Legacy alias */
.card.hero { padding: 36px; border-radius: 18px; }
.card.hero::before {
  content: "";
  position: absolute; inset: auto -20% -60% -20%; height: 300px;
  background: radial-gradient(ellipse at center, var(--accent), transparent 60%);
  opacity: 0.07; pointer-events: none;
}

/* ===== BUTTONS ===== */
.btn, .button {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 700; font-size: 15px;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 12px 20px; border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--bg-2); color: var(--text-hi);
  display: inline-flex; align-items: center; gap: 8px;
  text-decoration: none; cursor: pointer;
  transition: all .15s;
}
.btn:hover, .button:hover {
  border-color: var(--accent); color: var(--accent);
  text-decoration: none;
}
.btn.primary, .button.primary, .btn--primary {
  background: var(--accent); color: var(--accent-ink);
  border-color: var(--accent);
}
.btn.primary:hover, .button.primary:hover, .btn--primary:hover {
  filter: brightness(1.08); color: var(--accent-ink); border-color: var(--accent);
}
.btn.secondary, .button.secondary {
  background: transparent; border-color: var(--line); color: var(--text-md);
}
.btn.secondary:hover, .button.secondary:hover {
  border-color: var(--accent); color: var(--accent);
}
.btn.danger, .button.danger {
  background: transparent; border-color: var(--danger-soft); color: var(--danger);
}
.btn.danger:hover, .button.danger:hover {
  background: var(--danger-soft);
}
.btn.sm, .btn--sm { padding: 8px 14px; font-size: 13px; }
.button-group { display: flex; gap: 8px; flex-wrap: wrap; }

/* ===== CHIPS / PILLS ===== */
.chip, .pill {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 999px;
  background: var(--bg-2); color: var(--text-md);
  border: 1px solid var(--line);
  white-space: nowrap;
}
.chip.accent, .pill--success { background: var(--accent-soft); color: var(--accent); border-color: transparent; }
.chip.warn, .pill--warning { background: var(--warn-soft); color: var(--warn); border-color: transparent; }
.chip.info { background: oklch(82% 0.14 220 / 0.12); color: var(--info); border-color: transparent; }
.chip.danger, .pill--danger { background: var(--danger-soft); color: var(--danger); border-color: transparent; }

/* ===== SPORT SPORT SPORT PILLS ===== */
.sport-pill-swim {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 2px 8px; border-radius: 4px;
  background: oklch(82% 0.14 220 / .15); color: var(--swim-color);
}
.sport-pill-bike {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 2px 8px; border-radius: 4px;
  background: oklch(86% 0.18 145 / .15); color: var(--bike-color);
}
.sport-pill-run {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 2px 8px; border-radius: 4px;
  background: oklch(80% 0.18 40 / .15); color: var(--run-color);
}

/* ===== FORMS ===== */
.field { display: flex; flex-direction: column; gap: 6px; }
label, .field label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-lo);
}
input[type="text"], input[type="email"], input[type="password"],
input[type="date"], input[type="time"], input[type="number"],
input[type="url"], input[type="search"], textarea, select,
.input, .select, .textarea {
  background: var(--bg-0);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px 14px;
  color: var(--text-hi);
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  width: 100%;
  transition: border-color .15s;
}
input:focus, textarea:focus, select:focus,
.input:focus, .select:focus, .textarea:focus {
  outline: none;
  border-color: var(--accent);
}
textarea { min-height: 96px; resize: vertical; font-family: 'Inter', system-ui; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-full { grid-column: 1 / -1; }
.row-actions { display: flex; gap: 8px; justify-content: flex-end; flex-wrap: wrap; margin-top: 16px; }

/* ===== TOGGLE ===== */
.toggle {
  position: relative; width: 46px; height: 26px;
  border-radius: 999px; background: var(--bg-2);
  border: 1px solid var(--line); cursor: pointer; padding: 0;
}
.toggle::after {
  content: ""; position: absolute; top: 2px; left: 2px;
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--text-lo); transition: all .18s;
}
.toggle.on { background: var(--accent); border-color: var(--accent); }
.toggle.on::after { transform: translateX(20px); background: var(--accent-ink); }

/* ===== LAYOUT UTILITIES ===== */
.stack { display: flex; flex-direction: column; gap: 16px; }
.stack-tight { display: flex; flex-direction: column; gap: 6px; }
.row { display: flex; align-items: center; gap: 16px; }
.row-header {
  display: flex; align-items: baseline;
  justify-content: space-between; gap: 12px;
  flex-wrap: wrap;
}
.wrap { flex-wrap: wrap; }
.space-between { justify-content: space-between; }
.grid { display: grid; gap: 14px; }
.cols-2 { grid-template-columns: repeat(2, 1fr); }
.cols-3 { grid-template-columns: repeat(3, 1fr); }
.cols-4 { grid-template-columns: repeat(4, 1fr); }

/* ===== STAT BOX ===== */
.stat-box {
  background: var(--bg-1); border: 1px solid var(--line);
  border-radius: 12px; padding: 16px 20px;
  text-align: center; min-width: 90px;
}
.stat-box b {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900; font-size: 38px; line-height: 1;
  display: block;
}
.stat-box b.accent { color: var(--accent); }
.stat-box small {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-lo);
}

/* ===== COUNTDOWN ===== */
.countdown {
  background: var(--bg-2); border-radius: 14px;
  padding: 18px 22px; border: 1px solid var(--line);
}
.countdown-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-lo);
}
.countdown-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-top: 10px;
}
.countdown-cell {
  background: var(--bg-0); border-radius: 8px;
  padding: 10px 6px; text-align: center;
}
.countdown-num {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 40px; line-height: 1;
  color: var(--text-hi); font-variant-numeric: tabular-nums;
}
.countdown-cell:first-child .countdown-num { color: var(--accent); }
.countdown-u {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--text-lo); margin-top: 4px;
}
.tick {
  display: inline-block; width: 6px; height: 6px;
  border-radius: 50%; background: var(--accent); margin-left: 6px;
  animation: blink 1s infinite;
}
@keyframes blink { 0%,49% { opacity: 1; } 50%,100% { opacity: 0.2; } }

/* ===== READINESS RING ===== */
.ring { position: relative; width: 120px; height: 120px; }
.ring svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.ring-inner {
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900; font-size: 30px;
}
.ring-inner small {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.15em; color: var(--text-lo);
  display: block; text-align: center; font-weight: 500; margin-top: 2px;
}
.ring.xs { width: 52px; height: 52px; }
.ring.xs .ring-inner { font-size: 14px; }

/* ===== LEG CARDS ===== */
.legs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.leg {
  position: relative; overflow: hidden;
  background: var(--bg-1); border: 1px solid var(--line);
  border-radius: 14px; padding: 20px;
}
.leg-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-md);
}
.leg-tag::before {
  content: ""; display: block; width: 8px; height: 8px;
  border-radius: 50%; background: var(--accent);
}
.leg.swim .leg-tag::before { background: var(--swim-color); }
.leg.bike .leg-tag::before { background: var(--bike-color); }
.leg.run .leg-tag::before { background: var(--run-color); }
.leg h4 {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 26px;
  letter-spacing: 0.02em; text-transform: uppercase; margin: 10px 0 4px;
}
.leg-dist {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 42px; line-height: 1;
  color: var(--text-hi); font-variant-numeric: tabular-nums;
}
.leg-dist u {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; color: var(--text-lo);
  letter-spacing: 0.15em; text-decoration: none; margin-left: 4px;
}
.leg-foot {
  display: flex; gap: 14px; margin-top: 14px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.08em; color: var(--text-md);
}
.leg-foot span b { color: var(--text-hi); display: block; }
.leg-bar { height: 4px; background: var(--bg-2); border-radius: 2px; margin-top: 14px; overflow: hidden; }
.leg-bar i { display: block; height: 100%; background: var(--accent); border-radius: 2px; }

/* ===== QUICK ACTIONS ===== */
.qa { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.qa-tile {
  background: var(--bg-1); border: 1px solid var(--line);
  border-radius: 12px; padding: 18px;
  display: flex; flex-direction: column; gap: 8px;
  cursor: pointer; text-decoration: none; color: var(--text-hi);
  transition: all .15s;
}
.qa-tile:hover { border-color: var(--accent); transform: translateY(-2px); text-decoration: none; color: var(--text-hi); }
.qa-tile svg, .qa-tile img { width: 22px; height: 22px; color: var(--accent); }
.qa-tile h5 {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 18px;
  letter-spacing: 0.04em; text-transform: uppercase; margin: 0;
}
.qa-tile p { margin: 0; font-size: 12px; color: var(--text-md); }
.qa-tile .arrow {
  margin-top: 4px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--text-lo); letter-spacing: 0.15em; text-transform: uppercase;
}

/* ===== SETUP CARD ===== */
.setup-card {
  background: var(--bg-1); border: 1px solid var(--line);
  border-radius: 14px; overflow: hidden;
}
.setup-row {
  display: grid; grid-template-columns: 60px 1fr auto; gap: 16px;
  align-items: center; padding: 16px 20px;
  border-bottom: 1px solid var(--line);
}
.setup-row:last-child { border-bottom: 0; }
.setup-num {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900; font-size: 38px; color: var(--text-lo);
  line-height: 1; font-variant-numeric: tabular-nums;
}
.setup-row.done .setup-num { color: var(--accent); }
.setup-title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 700; font-size: 18px;
  letter-spacing: 0.03em; text-transform: uppercase; margin: 0 0 4px;
}
.setup-desc { margin: 0; color: var(--text-md); font-size: 13px; }
.setup-status {
  display: inline-block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  padding: 3px 8px; border-radius: 4px; margin-top: 6px;
}
.setup-status.done { background: var(--accent); color: var(--accent-ink); }
.setup-status.wip { background: transparent; color: var(--accent); border: 1px solid var(--accent); }
.setup-status.pending { background: transparent; color: var(--text-md); border: 1px solid var(--line); }

/* ===== PLAN SHELL ===== */
.plan-shell-wrap { padding: 0; }
.plan-shell {
  display: grid;
  grid-template-columns: 190px 1fr;
  gap: 24px;
  align-items: start;
}

/* ===== SIDEBAR / PLAN NAV ===== */
.plan-nav {
  position: sticky; top: 84px;
  align-self: start;
  padding: 18px;
  border-radius: 14px;
}
.plan-nav__header { margin-bottom: 16px; }
.plan-nav__eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-lo);
  display: block; margin-bottom: 4px;
}
.plan-nav__title-row { display: flex; align-items: baseline; gap: 8px; }
.plan-nav__title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 30px; letter-spacing: 0;
  text-transform: uppercase; line-height: 0.9; margin: 0 0 10px;
  max-width: 120px;
  word-break: break-word;
}
.plan-nav__section-count {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  background: rgba(255,255,255,0.05); color: var(--text-md);
  padding: 3px 8px; border-radius: 999px;
}
.plan-nav__links {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 14px;
}
.plan-nav__link {
  display: flex; flex-direction: column; align-items: center; gap: 5px;
  padding: 12px 8px;
  background: var(--bg-2); border: 1px solid transparent; border-radius: 10px;
  color: var(--text-md); cursor: pointer; text-decoration: none;
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 700; font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase;
  transition: all .15s;
}
.plan-nav__link:hover { border-color: var(--line); color: var(--text-hi); text-decoration: none; }
.plan-nav__link.active,
.plan-nav__link[aria-current="page"] {
  background: var(--accent); color: var(--accent-ink); border-color: var(--accent);
}
.plan-nav__link-icon { width: 20px; height: 20px; display: flex; align-items: center; justify-content: center; }
.plan-nav__link-icon svg, .plan-nav__link-icon img { width: 18px; height: 18px; }
.plan-nav__link-label { font-size: 12px; }
.plan-nav__back-link {
  display: block; width: 100%; padding: 10px; text-align: center;
  background: transparent; border: 1px dashed var(--line); border-radius: 8px;
  color: var(--text-md); text-decoration: none;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  cursor: pointer; transition: all .15s;
}
.plan-nav__back-link:hover { border-color: var(--accent); color: var(--accent); text-decoration: none; }
.plan-content { min-width: 0; }

/* ===== HERO SECTION (plan home) ===== */
.hero-meta {
  display: flex; gap: 22px; flex-wrap: wrap;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-md);
}
.hero-meta b {
  display: block; color: var(--text-hi); font-weight: 600;
  font-family: 'Big Shoulders Display', system-ui; font-size: 20px;
  letter-spacing: 0.04em; margin-top: 2px;
}

/* ===== READINESS ROW ===== */
.readiness-row { display: flex; gap: 20px; align-items: center; flex-wrap: wrap; }
.readiness-stage { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.readiness-stage small {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-md);
}

/* ===== SECTION STATUS GRID ===== */
.section-status-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px;
}
.section-status-cell {
  padding: 10px; background: var(--bg-2); border-radius: 6px;
}
.section-status-cell .cell-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-lo);
  display: block; margin-bottom: 4px;
}
.section-status-cell .cell-val {
  color: var(--accent);
  font-family: 'Big Shoulders Display', system-ui;
  font-size: 14px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
}
.section-status-cell .cell-val.muted { color: var(--text-md); }

/* ===== COURSE MAP ===== */
.course-grid { display: grid; grid-template-columns: 1fr 320px; gap: 18px; }
.map {
  background: var(--bg-1); border: 1px solid var(--line);
  border-radius: 14px; overflow: hidden; position: relative;
  min-height: 360px;
}
.course-hero__eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent);
}
.course-hero__title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900; font-size: clamp(36px, 5vw, 64px);
  text-transform: uppercase; line-height: 0.9; margin: 8px 0 16px;
}
.course-hero__intro { color: var(--text-md); font-size: 14px; max-width: 60ch; }
.course-hero__stats { display: flex; gap: 12px; flex-wrap: wrap; }
.course-hero__stat-value {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900; font-size: 42px; line-height: 1; color: var(--accent);
}
.course-hero__stat-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-lo);
  display: block;
}

/* Course workspace */
.course-workspace {
  display: grid; grid-template-columns: 1fr 320px;
  gap: 18px; margin-top: 18px; align-items: start;
}
.course-map-shell { padding: 0; overflow: hidden; }
.course-map-shell__header { padding: 18px 20px; border-bottom: 1px solid var(--line); }
.course-map-shell__title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 20px; letter-spacing: 0.03em; text-transform: uppercase; margin: 0;
}
.course-map-shell__hint { color: var(--text-md); font-size: 12px; margin: 6px 0 0; }
.course-builder__eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-lo);
  display: block;
}
#course-map {
  height: 520px; width: 100%;
  background: var(--bg-2);
}

/* Map overlay controls */
.course-map-stage { position: relative; }
.course-map-overlay {
  position: absolute; top: 12px; left: 12px; right: 12px;
  display: flex; justify-content: space-between; align-items: flex-start;
  pointer-events: none; z-index: 1000;
}
.course-map-overlay__primary { pointer-events: auto; display: flex; gap: 8px; max-width: calc(100% - 160px); }
.course-map-overlay__trailing { pointer-events: auto; display: flex; gap: 8px; align-items: flex-start; }
.course-map-float {
  background: rgba(8,9,11,0.75); backdrop-filter: blur(8px);
  border: 1px solid var(--line); border-radius: 10px; padding: 6px 10px;
  display: flex; align-items: center; gap: 8px;
}
.course-map-mini-chip {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-md);
}
.course-map-segment-switcher {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.course-map-route-option {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 62px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(8,9,11,0.82);
  backdrop-filter: blur(8px);
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-md);
  cursor: pointer;
  transition: all .15s;
}
.course-map-route-option:hover { border-color: var(--accent); color: var(--accent); }
.course-map-route-option.is-active {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--accent-ink);
}
.course-map-route-option[data-sport-type="swim"].is-active {
  background: var(--swim-color);
  border-color: var(--swim-color);
  color: var(--bg-0);
}
.course-map-route-option[data-sport-type="bike"].is-active {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--accent-ink);
}
.course-map-route-option[data-sport-type="run"].is-active {
  background: var(--run-color);
  border-color: var(--run-color);
  color: var(--bg-0);
}
.course-map-overlay-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(8,9,11,0.82);
  backdrop-filter: blur(8px);
  color: var(--text-hi);
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  transition: all .15s;
}
.course-map-overlay-button:hover,
.course-map-overlay-button.is-active,
.course-map-overlay-button[aria-pressed="true"] {
  border-color: var(--accent);
  color: var(--accent);
}
.course-map-layers {
  position: relative;
}
.course-map-layers-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 220px;
  padding: 10px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: rgba(8,9,11,0.92);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 36px rgba(0,0,0,0.35);
}
.course-map-layer-toggle {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--bg-1);
  color: var(--text-md);
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: all .15s;
}
.course-map-layer-toggle:hover,
.course-map-layer-toggle[aria-pressed="true"] {
  border-color: var(--accent);
  color: var(--accent);
}
.course-map-layer-toggle__state {
  color: inherit;
}

/* Elevation */
.course-map-elevation-panel {
  background: rgba(8,9,11,0.8); backdrop-filter: blur(8px);
  border-top: 1px solid var(--line); padding: 12px 16px;
}
.course-elevation-svg { width: 100%; }

/* Legs panel */
.course-legs-panel { padding: 0; overflow: hidden; }
.course-legs-panel__header { padding: 18px 18px 0; }
.course-legs-panel__title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 20px; letter-spacing: 0.03em; text-transform: uppercase; margin: 0;
}
.course-legs-panel__hint { color: var(--text-md); font-size: 12px; margin: 6px 0 12px; }
.course-legs-panel--empty .course-legs-panel__empty {
  padding: 24px; text-align: center;
}
.course-legs-panel__empty-title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 22px; text-transform: uppercase; margin-bottom: 8px;
}
.course-legs-list { padding: 0 18px 18px; display: flex; flex-direction: column; gap: 8px; }
.course-leg {
  background: var(--bg-2); border: 1px solid transparent;
  border-radius: 10px; overflow: hidden; cursor: pointer;
  transition: border-color .15s;
}
.course-leg[open] { border-color: var(--accent); background: rgba(255,255,255,0.01); }
.course-leg-summary {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; list-style: none; cursor: pointer;
  gap: 10px;
}
.course-leg-summary::-webkit-details-marker { display: none; }
.course-leg-summary__main { display: flex; align-items: center; gap: 8px; }
.course-leg-sport-pill {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 2px 8px; border-radius: 4px;
  background: var(--bg-3); color: var(--text-md);
}
.course-leg[data-sport="swim"] .course-leg-sport-pill { background: oklch(82% 0.14 220 / .15); color: var(--swim-color); }
.course-leg[data-sport="bike"] .course-leg-sport-pill { background: oklch(86% 0.18 145 / .15); color: var(--bike-color); }
.course-leg[data-sport="run"] .course-leg-sport-pill { background: oklch(80% 0.18 40 / .15); color: var(--run-color); }
.course-leg-title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 700; font-size: 16px; text-transform: uppercase; letter-spacing: 0.04em;
}
.course-leg-meta {
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.1em; text-transform: uppercase;
}
.course-leg-body { padding: 0 14px 14px; }
.course-leg-intelligence {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px;
  margin-bottom: 12px;
}
.course-leg-intelligence__item {
  background: var(--bg-3); border-radius: 8px; padding: 10px;
}
.course-leg-intelligence__label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-lo);
  display: block; margin-bottom: 4px;
}

/* Add a leg */
.course-add-leg {
  padding: 16px 18px; border-top: 1px solid var(--line);
}
.course-add-leg-title {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-lo);
  display: block; margin-bottom: 10px;
}
.course-leg-type-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
}
.course-leg-type-card {
  background: var(--bg-2); border: 1px solid var(--line); border-radius: 10px;
  padding: 14px; cursor: pointer; text-align: center;
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 700; font-size: 14px; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--text-md); transition: all .15s;
}
.course-leg-type-card:hover { border-color: var(--accent); color: var(--accent); }
.course-leg-type-card.is-active { background: var(--accent-soft); border-color: var(--accent); color: var(--accent); }

/* POI drawer */
.course-poi-drawer {
  position: absolute;
  left: 16px;
  bottom: 16px;
  z-index: 1100;
  width: min(320px, calc(100% - 32px));
  max-height: calc(100% - 92px);
  overflow-y: auto;
  background: rgba(8,9,11,0.92);
  backdrop-filter: blur(12px);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 18px;
  box-shadow: 0 22px 48px rgba(0,0,0,0.4);
}
.course-poi-drawer__header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 12px; }
.course-poi-drawer__title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 20px; text-transform: uppercase; margin: 0;
}
.course-poi-drawer__summary {
  max-width: 24ch;
}
.course-poi-type-fieldset { border: 0; padding: 0; margin: 0; }
.course-poi-type-fieldset legend {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-lo);
  margin-bottom: 6px;
}
.course-poi-type-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.course-poi-type-option {
  padding: 6px 8px; border-radius: 6px;
  border: 1px solid var(--line); background: var(--bg-2);
  color: var(--text-md); cursor: pointer;
  font-family: 'Big Shoulders Display', system-ui;
  font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em;
  transition: all .15s;
}
.course-poi-type-option:hover { border-color: var(--accent); color: var(--accent); }
.course-poi-type-option.is-active { background: var(--accent-soft); border-color: var(--accent); color: var(--accent); }
.course-poi-drawer__actions { justify-content: flex-start; }

/* Course intelligence */
.course-intelligence__header { margin-bottom: 18px; }
.course-intelligence__title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 22px; text-transform: uppercase; margin: 0;
}
.course-intelligence__intro { color: var(--text-md); font-size: 13px; margin: 6px 0 0; }
.course-intelligence__stats {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px;
}
.course-intelligence__stat {
  background: var(--bg-2); border-radius: 10px; padding: 14px;
}
.course-intelligence__stat-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-lo);
  display: block; margin-bottom: 6px;
}
.course-intelligence__stat-value {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900; font-size: 24px; color: var(--text-hi);
}

/* ===== CHECKLIST ===== */
.tabs {
  display: flex; gap: 4px; padding: 4px;
  background: var(--bg-1); border: 1px solid var(--line); border-radius: 10px;
  width: fit-content; margin-bottom: 16px;
}
.tabs button {
  font-family: 'Big Shoulders Display', system-ui; font-weight: 700;
  font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 8px 14px; border-radius: 6px; border: 0;
  background: transparent; color: var(--text-md); cursor: pointer;
}
.tabs button.active { background: var(--accent); color: var(--accent-ink); }
.check-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.check-col {
  background: var(--bg-1); border: 1px solid var(--line);
  border-radius: 14px; padding: 18px;
}
.check-col h4 {
  font-family: 'Big Shoulders Display', system-ui; font-weight: 800;
  font-size: 20px; letter-spacing: 0.03em; text-transform: uppercase;
  margin: 0 0 4px; display: flex; justify-content: space-between; align-items: baseline;
}
.check-col h4 small {
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.15em; color: var(--text-lo); font-weight: 500;
}
.check-col-sub { color: var(--text-md); font-size: 12px; margin: 0 0 12px; }
.check-item {
  display: grid; grid-template-columns: auto 1fr auto auto; gap: 12px;
  align-items: center; padding: 10px; border-radius: 8px;
  cursor: pointer; transition: background .1s;
}
.check-item__reorder {
  display: flex;
  flex-direction: column;
  gap: 2px;
  align-self: center;
}
.check-item__reorder-btn {
  width: 28px;
  min-height: 26px;
  padding: 0 2px;
  margin: 0;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--bg-2);
  color: var(--text-md);
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  line-height: 1;
  cursor: pointer;
}
.check-item__reorder-btn:hover:not(:disabled) {
  border-color: var(--accent);
  color: var(--accent);
}
.check-item__reorder-btn:disabled {
  opacity: 0.28;
  cursor: not-allowed;
}
.check-item:hover { background: var(--bg-2); }
.check-item__body { min-width: 0; }
.check-box {
  width: 22px; height: 22px; border-radius: 6px;
  border: 1.5px solid var(--line); cursor: pointer;
  display: grid; place-items: center;
  background: transparent; color: var(--accent-ink); font-weight: 700;
  flex-shrink: 0;
}
.check-item.checked .check-box { background: var(--accent); border-color: var(--accent); }
.check-item.checked .check-name { text-decoration: line-through; color: var(--text-lo); }
.check-name { font-weight: 600; font-size: 14px; }
.check-meta {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  color: var(--text-lo); letter-spacing: 0.08em; text-transform: uppercase;
}
.check-tag {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--bg-2); color: var(--text-md);
  padding: 2px 6px; border-radius: 4px;
}

.check-item__actions {
  margin-top: 6px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: opacity .15s ease, max-height .15s ease;
}
.check-item:hover .check-item__actions,
.check-item:focus-within .check-item__actions {
  opacity: 1;
  max-height: 24px;
}
.check-item__actions button {
  background: transparent;
  border: 0;
  color: var(--text-lo);
  cursor: pointer;
  padding: 0;
}
.check-item__actions button:hover {
  color: var(--accent);
}
.check-item__actions button.check-item__actions--danger:hover {
  color: var(--warn);
}

.checklist-page {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.checklist-hero {
  overflow: visible;
}
.checklist-hero__intro {
  color: var(--text-md);
  max-width: 60ch;
  margin: 0 0 16px;
  font-size: 15px;
  position: relative;
  z-index: 1;
}
.checklist-hero__actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  position: relative;
  z-index: 2;
}
.checklist-hero__control {
  position: relative;
  margin: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  overflow: visible;
}
.checklist-hero__control > summary {
  list-style: none;
  cursor: pointer;
  /* Keep .btn padding, inline-flex, and colours — do not reset to plain text. */
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.checklist-hero__control > summary::after {
  content: none;
}
.checklist-hero__control > summary::-webkit-details-marker {
  display: none;
}
.checklist-hero__panel {
  position: absolute;
  top: calc(100% + 12px);
  left: 0;
  width: min(460px, calc(100vw - 96px));
  padding: 18px;
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: 0 22px 48px rgba(0, 0, 0, 0.35);
}
.checklist-hero__panel-top {
  display: flex;
  justify-content: flex-end;
  margin: -6px -6px 10px 0;
}
.checklist-hero__panel-close {
  margin: 0;
  padding: 2px 8px;
  border: 0;
  background: transparent;
  font: inherit;
  font-size: 1.35rem;
  line-height: 1;
  color: var(--text-md);
  cursor: pointer;
  border-radius: 6px;
}
.checklist-hero__panel-close:hover {
  color: var(--text-hi);
  background: var(--bg-2);
}
.checklist-hero__panel--narrow {
  width: min(320px, calc(100vw - 96px));
}
.checklist-hero__form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.checklist-hero__form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.checklist-hero__form-span-2 {
  grid-column: 1 / -1;
}
.checklist-hero__panel-actions {
  display: flex;
  justify-content: flex-start;
}
.checklist-stage-shell {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.checklist-empty {
  background: var(--bg-1);
  border: 1px dashed var(--line);
  border-radius: 14px;
  padding: 28px 24px;
}
.checklist-empty p {
  margin: 0;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-lo);
}

/* ===== NUTRITION ===== */
.nutri-hero {
  background: linear-gradient(140deg, var(--bg-1), var(--bg-2));
  border: 1px solid var(--line); border-radius: 18px;
  padding: 32px; position: relative; overflow: hidden;
}
.nutri-hero::after {
  content: ""; position: absolute; right: -80px; top: -80px;
  width: 300px; height: 300px;
  background: radial-gradient(circle, var(--accent), transparent 60%);
  opacity: 0.08;
}
.nutri-big {
  background: var(--bg-1); border: 1px solid var(--line);
  border-radius: 12px; padding: 16px;
}
.nutri-big small {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-lo); display: block;
}
.nutri-big b {
  font-family: 'Big Shoulders Display', system-ui; font-weight: 900;
  font-size: 50px; line-height: 1; display: block; font-variant-numeric: tabular-nums;
}
.nutri-big b.accent { color: var(--accent); }
.nutri-big u { font-family: 'JetBrains Mono', monospace; font-size: 13px; text-decoration: none; color: var(--text-md); margin-left: 4px; }
.nutri-big-sub {
  font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-md); letter-spacing: 0.1em; margin-top: 6px;
}
.nutri-bar { height: 4px; background: var(--bg-2); border-radius: 2px; margin-top: 8px; overflow: hidden; }
.nutri-bar-fill { height: 100%; background: var(--accent); border-radius: 2px; }

.timeline {
  background: var(--bg-1); border: 1px solid var(--line);
  border-radius: 14px; padding: 20px;
}
.timeline-row {
  display: grid; grid-template-columns: 90px 1fr auto; gap: 16px;
  align-items: center; padding: 12px 0; border-bottom: 1px solid var(--line);
}
.timeline-row:last-child { border-bottom: 0; }
.timeline-time {
  font-family: 'JetBrains Mono', monospace; font-weight: 600;
  color: var(--accent); font-size: 13px; letter-spacing: 0.08em;
}
.timeline-name { font-weight: 600; font-size: 14px; }
.timeline-meta { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-md); margin-top: 2px; }
.timeline-carbs {
  font-family: 'Big Shoulders Display', system-ui; font-weight: 800; font-size: 20px;
}

/* ===== FAQ ACCORDION ===== */
.faq-list { display: flex; flex-direction: column; gap: 8px; }
.faq-item {
  background: var(--bg-1); border: 1px solid var(--line);
  border-radius: 12px; overflow: hidden;
}
details.faq-item summary,
.faq-q {
  width: 100%; text-align: left; background: transparent; color: var(--text-hi);
  border: 0; padding: 18px 22px; cursor: pointer;
  font-family: 'Big Shoulders Display', system-ui; font-weight: 700;
  font-size: 18px; letter-spacing: 0.03em; text-transform: uppercase;
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  list-style: none;
}
details.faq-item summary::-webkit-details-marker { display: none; }
.faq-q .caret { font-family: 'JetBrains Mono', monospace; font-weight: 500; color: var(--accent); font-size: 20px; transition: transform .2s; }
.faq-item.open .faq-q .caret { transform: rotate(45deg); }
details.faq-item[open] summary::after { content: "−"; font-family: 'JetBrains Mono', monospace; color: var(--accent); font-size: 20px; }
details.faq-item summary::after { content: "+"; font-family: 'JetBrains Mono', monospace; color: var(--accent); font-size: 20px; }
.faq-a { display: none; color: var(--text-md); font-size: 14px; line-height: 1.6; padding: 0 22px; }
.faq-item.open .faq-a { display: block; padding: 0 22px 20px; }
details.faq-item p { color: var(--text-md); font-size: 14px; line-height: 1.6; padding: 0 22px 16px; margin: 0; }

/* Legacy details/summary for help page */
details { background: var(--bg-1); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; margin-bottom: 8px; }
details summary {
  padding: 16px 20px; cursor: pointer;
  font-family: 'Big Shoulders Display', system-ui; font-weight: 700;
  font-size: 16px; text-transform: uppercase; letter-spacing: 0.04em;
  color: var(--text-hi); list-style: none; display: flex; justify-content: space-between; align-items: center;
}
details summary::-webkit-details-marker { display: none; }
details summary::after { content: "+"; font-family: 'JetBrains Mono', monospace; color: var(--accent); font-size: 18px; }
details[open] summary::after { content: "−"; }
details p { padding: 0 20px 16px; color: var(--text-md); font-size: 14px; line-height: 1.6; margin: 0; }

/* ===== ABOUT GRID ===== */
.about-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.about-card { background: var(--bg-1); border: 1px solid var(--line); border-radius: 12px; padding: 22px; }
.about-card h4 {
  font-family: 'Big Shoulders Display', system-ui; font-weight: 800;
  font-size: 20px; letter-spacing: 0.03em; text-transform: uppercase; margin: 0 0 8px;
}
.about-card p { color: var(--text-md); font-size: 13px; margin: 0; line-height: 1.55; }

/* ===== CONTACT / KV ===== */
.kv { display: grid; grid-template-columns: 160px 1fr; gap: 0; }
.kv dt {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-lo);
  padding: 12px 0; border-bottom: 1px solid var(--line); margin: 0;
}
.kv dd {
  font-size: 14px; color: var(--text-hi); padding: 12px 0;
  border-bottom: 1px solid var(--line); margin: 0;
}
.kv dt:last-of-type, .kv dd:last-of-type { border-bottom: 0; }

/* ===== PROFILE ===== */
.profile-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 10px; }

/* Benchmark tiles (HTMX swap); matches .bench-tile look */
.profile-metric-card { min-width: 0; }
.profile-metric-card__display {
  width: 100%;
  margin: 0;
  padding: 14px;
  text-align: left;
  cursor: pointer;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--bg-2);
  color: inherit;
  font: inherit;
  transition: border-color .15s, background .15s;
  display: block;
  box-sizing: border-box;
}
.profile-metric-card__display:hover { border-color: var(--accent); }
.profile-metric-card__display:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.profile-metric-card__label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-lo);
  display: block;
}
.profile-metric-card__value {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800;
  font-size: 24px;
  letter-spacing: 0.02em;
  display: block;
  margin-top: 6px;
  color: var(--text-hi);
}
.profile-metric-card__value .muted { color: var(--text-lo); }

.profile-metric-card__form {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px;
  box-sizing: border-box;
}
.profile-metric-card--error .profile-metric-card__form { border-color: var(--danger); }
.profile-metric-card__edit-title { display: block; margin-bottom: 6px; }
.profile-metric-card__input { width: 100%; box-sizing: border-box; }
.profile-metric-card__error {
  margin: 8px 0 0;
  font-size: 12px;
  color: var(--danger);
}
.profile-metric-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.bench-tile {
  background: var(--bg-2); border: 1px solid var(--line); border-radius: 10px;
  padding: 14px; cursor: pointer; transition: all .15s;
}
.bench-tile:hover { border-color: var(--accent); }
.bench-tile small {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-lo); display: block;
}
.bench-tile b {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 24px; letter-spacing: 0.02em; display: block; margin-top: 6px;
}
.bench-tile b.empty { color: var(--text-lo); }
.race-row {
  display: grid; grid-template-columns: auto 1fr auto; gap: 14px;
  align-items: center; padding: 14px;
  background: var(--bg-2); border: 1px solid var(--line); border-radius: 10px;
}
.race-row-sport { display: flex; gap: 6px; }
.race-row h5 {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 18px; letter-spacing: 0.03em; text-transform: uppercase; margin: 0;
}
.race-row-meta {
  font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-lo); letter-spacing: 0.1em;
}
.race-row-cd {
  font-family: 'JetBrains Mono', monospace; font-weight: 700; font-size: 13px; color: var(--accent);
}

/* ===== OPTIONS ===== */
.opt-row {
  display: grid; grid-template-columns: 1fr auto; gap: 20px;
  align-items: center; padding: 18px 0; border-bottom: 1px solid var(--line);
}
.opt-row:last-child { border-bottom: 0; }
.opt-row h5 {
  font-family: 'Big Shoulders Display', system-ui; font-weight: 700;
  font-size: 18px; letter-spacing: 0.04em; text-transform: uppercase; margin: 0 0 4px;
}
.opt-row p { margin: 0; color: var(--text-md); font-size: 13px; }
.theme-picker { display: flex; gap: 6px; }
.theme-swatch {
  padding: 8px 12px; border: 1px solid var(--line); background: var(--bg-2);
  border-radius: 8px; cursor: pointer;
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-md);
  transition: all .15s;
}
.theme-swatch.active { border-color: var(--accent); color: var(--accent); }

/* ===== PUBLIC LANDING ===== */
.public-hero {
  position: relative; padding: 72px 40px 56px;
  border-radius: 24px; border: 1px solid var(--line);
  background: radial-gradient(1200px 500px at 80% -20%, oklch(88% 0.22 135 / 0.18), transparent 50%), var(--bg-1);
  overflow: hidden; margin-bottom: 0;
}
.public-hero::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px);
  background-size: 40px 40px; pointer-events: none;
}
.public-hero-grid {
  position: relative; display: grid;
  grid-template-columns: 1.3fr 1fr; gap: 40px; align-items: center;
}
.public-hero h1 {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900; font-size: clamp(56px, 8vw, 130px);
  line-height: 0.86; letter-spacing: -0.015em; text-transform: uppercase;
  margin: 16px 0 18px;
}
.public-hero h1 .accent { color: var(--accent); }
.public-hero p { color: var(--text-md); font-size: 16px; max-width: 54ch; line-height: 1.55; margin: 0 0 20px; }
.public-hero ul { list-style: none; padding: 0; margin: 0 0 24px; }
.public-hero ul li { padding: 7px 0 7px 24px; position: relative; color: var(--text-md); font-size: 14px; }
.public-hero ul li::before { content: "✓"; position: absolute; left: 0; color: var(--accent); font-weight: 800; }
.cta-row { display: flex; gap: 10px; margin-bottom: 24px; flex-wrap: wrap; }
.signals { display: flex; gap: 28px; flex-wrap: wrap; }
.signals > div {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-md);
}
.signals b {
  display: block; color: var(--text-hi);
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 26px; letter-spacing: 0.02em; margin-top: 2px;
}

/* Snapshot (public hero right col) */
.snapshot {
  background: rgba(8,9,11,0.6); backdrop-filter: blur(8px);
  border: 1px solid var(--line); border-radius: 18px; padding: 20px;
}
.snapshot-label {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.25em; text-transform: uppercase; color: var(--text-lo);
}
.snapshot h4 {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 22px; letter-spacing: 0.02em; text-transform: uppercase;
  margin: 6px 0 14px;
}
.snapshot-kv {
  display: grid; grid-template-columns: 1fr auto; gap: 8px 12px;
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  color: var(--text-md); letter-spacing: 0.06em;
}
.snapshot-kv b { color: var(--text-hi); font-weight: 500; font-family: 'Inter', system-ui; font-size: 12px; }

/* Feature grid */
.feature-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.feature, .feature-card {
  background: var(--bg-1); border: 1px solid var(--line);
  border-radius: 14px; padding: 22px;
}
.feature svg, .feature-card svg,
.feature-card__icon { width: 28px; height: 28px; color: var(--accent); margin-bottom: 12px; display: block; }
.feature h4, .feature-card h3 {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 20px; letter-spacing: 0.03em; text-transform: uppercase; margin: 0 0 6px;
}
.feature p, .feature-card p { margin: 0; color: var(--text-md); font-size: 13px; line-height: 1.55; }

/* Step rows (help/landing) */
.steps { display: flex; flex-direction: column; gap: 10px; }
.step-row {
  display: grid; grid-template-columns: 80px 1fr auto; gap: 20px;
  align-items: center; padding: 18px 22px;
  background: var(--bg-2); border: 1px solid var(--line); border-radius: 12px;
}
.step-chip {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: 'JetBrains Mono', monospace; font-weight: 700;
  font-size: 11px; letter-spacing: 0.15em; text-transform: uppercase;
  background: var(--accent-soft); color: var(--accent);
  border: 1px solid var(--accent); padding: 6px 10px; border-radius: 999px;
}
.step-title {
  font-family: 'Big Shoulders Display', system-ui; font-weight: 700;
  font-size: 20px; letter-spacing: 0.03em; text-transform: uppercase; margin: 0 0 4px;
}
.step-desc { color: var(--text-md); font-size: 13px; margin: 0; max-width: 64ch; }

/* Tips grid */
.tips-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.tip {
  display: grid; grid-template-columns: 32px 1fr; gap: 14px;
  padding: 16px; background: var(--bg-2); border-radius: 10px; border: 1px solid var(--line);
}
.tip-num {
  font-family: 'Big Shoulders Display', system-ui; font-weight: 900;
  font-size: 26px; color: var(--accent); line-height: 1;
}
.tip p { margin: 0; font-size: 14px; color: var(--text-md); }

/* ===== PLANS INDEX ===== */
.plans-hero {
  padding: 36px;
}
.plans-hero::before {
  content: ""; position: absolute; inset: auto -20% -60% -20%; height: 300px;
  background: radial-gradient(ellipse at center, var(--accent), transparent 60%);
  opacity: 0.07; pointer-events: none;
}
.plans-hero__eyebrow {
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent);
  display: block; margin-bottom: 4px;
}
.plans-hero__title {
  font-family: 'Big Shoulders Display', system-ui; font-weight: 900;
  font-size: clamp(48px, 7vw, 96px); line-height: 0.88; text-transform: uppercase;
  margin: 8px 0 16px;
}
.plans-hero__intro { color: var(--text-md); font-size: 15px; margin: 0; }
.plans-hero__stats { display: flex; gap: 14px; margin-top: 20px; }
.plans-hero__stat-value {
  font-family: 'Big Shoulders Display', system-ui; font-weight: 900;
  font-size: 48px; color: var(--accent); line-height: 1;
}
.plans-hero__stat-label {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-lo);
}
.plans-page { display: flex; flex-direction: column; gap: 20px; }
.plans-grid { display: grid; grid-template-columns: 360px 1fr; gap: 18px; align-items: start; }
.plans-create-panel__eyebrow {
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent);
  display: block; margin-bottom: 4px;
}
.plans-create-panel__title {
  font-family: 'Big Shoulders Display', system-ui; font-weight: 800;
  font-size: 24px; text-transform: uppercase; letter-spacing: 0.02em; margin: 0 0 6px;
}
.plans-create-panel__intro { color: var(--text-md); font-size: 13px; margin: 0 0 16px; }
.plans-create-form { display: flex; flex-direction: column; gap: 12px; }
.plans-list-panel__header { margin-bottom: 16px; }
.plans-list-panel__eyebrow {
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-lo); display: block;
}
.plans-list-panel__title {
  font-family: 'Big Shoulders Display', system-ui; font-weight: 800;
  font-size: 22px; text-transform: uppercase; letter-spacing: 0.02em; margin: 0;
}
.plans-card-list { display: flex; flex-direction: column; gap: 8px; }
.plans-card {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: 10px; padding: 14px 18px;
  transition: border-color .15s;
}
.plans-card:hover { border-color: var(--accent); }
.plans-card__header { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.plans-card__title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 700; font-size: 18px; text-transform: uppercase; letter-spacing: 0.04em;
  color: var(--text-hi); text-decoration: none;
}
.plans-card__title:hover { color: var(--accent); text-decoration: none; }
.plans-card__meta {
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
}
.plans-card__actions { display: flex; gap: 8px; }
.plans-card__delete-form { margin: 0; }
.plans-empty-state { padding: 32px; text-align: center; }
.plans-empty-state h3 {
  font-family: 'Big Shoulders Display', system-ui; font-size: 24px; margin-bottom: 8px;
}

/* ===== DASHBOARD (home page) ===== */
.dashboard-layout { display: flex; flex-direction: column; gap: 20px; }
.current-plan-hero {
  padding: 36px; border-radius: 18px;
  position: relative; overflow: hidden;
}
.current-plan-hero::before {
  content: ""; position: absolute; inset: auto -20% -60% -20%; height: 300px;
  background: radial-gradient(ellipse at center, var(--accent), transparent 60%);
  opacity: 0.07; pointer-events: none;
}
.hero-sparkline {
  position: absolute; inset: 0; width: 100%; height: 100%;
  pointer-events: none; opacity: 0.08;
}
.hero-sparkline__line { stroke: var(--accent); }
.hero-sparkline__fill { fill: var(--accent); opacity: 0.3; }
.current-plan-hero__inner { position: relative; z-index: 1; }
.current-plan-hero__title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900; font-size: clamp(36px, 5vw, 72px);
  line-height: 0.9; text-transform: uppercase;
  letter-spacing: -0.01em; margin: 8px 0 16px;
}
.race-meta {
  font-family: 'JetBrains Mono', monospace; font-size: 12px;
  letter-spacing: 0.1em; text-transform: uppercase;
}

/* Quick actions */
.quick-actions-column__label { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; }
.quick-actions { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.quick-action-tile {
  background: var(--bg-1); border: 1px solid var(--line);
  border-radius: 12px; padding: 16px;
  display: flex; flex-direction: column; gap: 8px;
  text-decoration: none; color: var(--text-hi);
  transition: all .15s;
}
.quick-action-tile:hover { border-color: var(--accent); transform: translateY(-2px); text-decoration: none; color: var(--text-hi); }
.quick-action-tile.is-disabled { opacity: 0.4; cursor: not-allowed; }
.quick-action-tile.is-disabled:hover { border-color: var(--line); transform: none; }
.quick-action-tile__icon { width: 24px; height: 24px; color: var(--accent); }
.quick-action-tile__label {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 16px; text-transform: uppercase; letter-spacing: 0.04em;
}

/* Dashboard section */
.dashboard-top { display: flex; flex-direction: column; gap: 20px; }
.dashboard-rail-label {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-lo);
}
.dashboard-rail-label-spacer { display: block; height: 20px; }

/* Archives */
.archives-divider { border: none; border-top: 1px solid var(--line); margin: 0; }
.archives-list { list-style: none; padding: 0; margin: 0; }
.archives-row { border-bottom: 1px solid var(--line); }
.archives-row:last-child { border-bottom: 0; }
.archives-row-main {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 0; text-decoration: none; color: var(--text-hi);
  transition: color .15s;
}
.archives-row-main:hover { color: var(--accent); text-decoration: none; }
.archives-row-body { flex: 1; }
.archives-row-title-line { display: flex; align-items: center; gap: 10px; }
.archives-row-title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 700; font-size: 16px; text-transform: uppercase; letter-spacing: 0.04em;
}
.archives-progress-label {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase;
}
.progress-track { width: 100%; height: 4px; border-radius: 2px; appearance: none; background: var(--bg-2); }
.progress-track::-webkit-progress-bar { background: var(--bg-2); border-radius: 2px; }
.progress-track::-webkit-progress-value { background: var(--accent); border-radius: 2px; }
.progress-track::-moz-progress-bar { background: var(--accent); border-radius: 2px; }
.archives-row-actions { display: flex; gap: 12px; padding: 8px 0; }
.archives-inline-action {
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  text-decoration: none; color: var(--text-lo); transition: color .15s;
}
.archives-inline-action:hover { color: var(--accent); text-decoration: none; }

/* Sport icons */
.sport-icons { display: flex; gap: 4px; align-items: center; }
.sport-icon { color: var(--text-md); }
.sport-icon--neutral { color: var(--text-lo); }
.chevron { font-family: 'JetBrains Mono', monospace; font-size: 12px; }

/* Guided setup */
.guided-setup-list { display: flex; flex-direction: column; gap: 0; }
.guided-setup-step {
  display: grid; grid-template-columns: 64px 1fr auto; gap: 16px;
  align-items: center; padding: 16px 0; border-bottom: 1px solid var(--line);
}
.guided-setup-step:last-child { border-bottom: 0; }
.guided-setup-step__meta { font-size: 12px; }

/* Status pills row */
.status-pills { display: flex; gap: 8px; flex-wrap: wrap; list-style: none; padding: 0; margin: 0; }

/* ===== PROFILE page ===== */
.profile-command { display: flex; flex-direction: column; gap: 20px; }
.profile-identity { padding: 28px; }
.profile-identity__row { display: flex; align-items: center; gap: 20px; margin-bottom: 20px; }
.profile-identity__avatar {
  width: 80px; height: 80px; border-radius: 16px;
  background: var(--accent); display: grid; place-items: center;
  color: var(--accent-ink); font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900; font-size: 36px; flex-shrink: 0;
}
.profile-identity__name {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 30px; text-transform: uppercase; margin: 0;
}
.profile-identity__status { color: var(--text-md); margin: 4px 0 0; font-size: 14px; }
.profile-identity__name-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

/* ===== ACCOUNT / AUTH ===== */
.auth-shell {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: var(--bg-0);
}
.auth-card {
  background: var(--bg-1); border: 1px solid var(--line);
  border-radius: 18px; padding: 40px; width: 100%; max-width: 440px;
}
.auth-logo { margin-bottom: 28px; }
.auth-kicker {
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent);
  display: block; margin-bottom: 4px;
}
.auth-title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900; font-size: 40px; text-transform: uppercase; margin: 0 0 24px;
}
.auth-form { display: flex; flex-direction: column; gap: 14px; }
.auth-link {
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-lo);
  margin-top: 16px; text-align: center;
}
.auth-link a { color: var(--accent); }
.auth-errors {
  background: var(--danger-soft); border: 1px solid var(--danger);
  border-radius: 8px; padding: 12px 16px;
  font-size: 13px; color: var(--danger);
}

/* ===== MESSAGES / TOASTS ===== */
.messages { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.message {
  padding: 12px 16px; border-radius: 8px;
  border: 1px solid var(--line); background: var(--bg-2);
  font-family: 'JetBrains Mono', monospace; font-size: 12px;
  letter-spacing: 0.06em; text-transform: uppercase;
}
.message--success { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
.message--error { border-color: var(--danger); color: var(--danger); background: var(--danger-soft); }
.message--warning { border-color: var(--warn); color: var(--warn); background: var(--warn-soft); }
.message--info { border-color: var(--info); color: var(--info); }

/* ===== BAGS ===== */
.bag-list { display: flex; flex-direction: column; gap: 12px; }
.bag-card { background: var(--bg-2); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.bag-card__header {
  padding: 14px 18px; border-bottom: 1px solid var(--line);
  display: flex; justify-content: space-between; align-items: center;
}
.bag-card__title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 20px; text-transform: uppercase; letter-spacing: 0.04em; margin: 0;
}
.bag-card__body { padding: 14px 18px; }
.bag-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0; border-bottom: 1px solid var(--line);
}
.bag-item:last-child { border-bottom: 0; }
.bag-item__name { flex: 1; font-size: 14px; font-weight: 600; }
.bag-item__qty {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--text-lo); letter-spacing: 0.1em;
}

/* ===== BRIEF ===== */
.brief-actions { display: flex; gap: 10px; flex-wrap: wrap; }

/* ===== WEATHER ===== */
.weather-panel {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: 12px; padding: 16px;
}

/* ===== IMPORT PAGE ===== */
.import-zone {
  border: 2px dashed var(--line); border-radius: 14px;
  padding: 40px; text-align: center;
  transition: border-color .15s;
}
.import-zone:hover { border-color: var(--accent); }

/* ===== NUTRITION PAGE ===== */
.nutrition-page { display: flex; flex-direction: column; gap: 20px; }
.nutrition-hub { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; }
.nutrition-day-before, .nutrition-race-day { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; align-items: start; }

/* Nutrition rows */
.nutri-row {
  display: grid; grid-template-columns: 90px 1fr auto; gap: 16px;
  align-items: center; padding: 12px;
  background: var(--bg-2); border-radius: 8px; margin-bottom: 8px;
}
.nutri-row-time {
  font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--accent); font-weight: 600;
}
.nutri-row-name { font-weight: 600; font-size: 14px; }
.nutri-row-carbs {
  font-family: 'Big Shoulders Display', system-ui; font-weight: 800; font-size: 20px; color: var(--accent);
}

/* ===== LISTS ===== */
.list { padding-left: 20px; display: flex; flex-direction: column; gap: 8px; }
.list li { color: var(--text-md); font-size: 14px; }
.empty-state {
  padding: 32px; text-align: center;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase;
}

/* ===== MISC ===== */
.link { color: var(--accent); text-decoration: none; transition: opacity .15s; }
.link:hover { text-decoration: underline; }
hr { border: none; border-top: 1px solid var(--line); margin: 20px 0; }

/* ===== PRINT ===== */
@media print {
  .app-header, .app-footer, .plan-nav { display: none !important; }
  .plan-shell { display: block; }
  body { background: white; color: black; }
}

/* ===== RESPONSIVE ===== */
@media (max-width: 1100px) {
  .plan-shell { grid-template-columns: 1fr; }
  .plan-nav { position: static; }
  .course-workspace { grid-template-columns: 1fr; }
  .course-grid { grid-template-columns: 1fr; }
  .legs, .qa, .feature-grid, .about-grid { grid-template-columns: 1fr 1fr; }
  .check-grid { grid-template-columns: 1fr; }
  .profile-grid { grid-template-columns: repeat(3, 1fr); }
  .public-hero-grid { grid-template-columns: 1fr; }
  .plans-grid { grid-template-columns: 1fr; }
  .course-intelligence__stats { grid-template-columns: repeat(3, 1fr); }
  .nutrition-hub { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .app-header-inner { padding: 12px 16px; }
  .app-main { padding: 16px; }
  .app-footer { padding: 20px 16px; }
  .legs { grid-template-columns: 1fr; }
  .qa { grid-template-columns: 1fr 1fr; }
  .feature-grid { grid-template-columns: 1fr 1fr; }
  .profile-grid { grid-template-columns: repeat(2, 1fr); }
  .plan-nav__links { grid-template-columns: repeat(4, 1fr); }
  .plan-nav__title { max-width: none; }
  .section-status-grid { grid-template-columns: repeat(3, 1fr); }
  .step-row { grid-template-columns: 60px 1fr; }
  .step-row .btn { display: none; }
  .countdown-num { font-size: 28px; }
  .form-grid { grid-template-columns: 1fr; }
  .nutrition-day-before, .nutrition-race-day { grid-template-columns: 1fr; }
  #course-map { height: 420px; }
  .course-map-overlay {
    flex-direction: column;
    gap: 8px;
  }
  .course-map-overlay__primary,
  .course-map-overlay__trailing {
    max-width: 100%;
    width: 100%;
    flex-wrap: wrap;
  }
  .course-map-overlay__trailing {
    justify-content: flex-end;
  }
  .course-poi-drawer {
    left: 12px;
    right: 12px;
    bottom: 12px;
    width: auto;
    max-height: 58%;
  }
  .checklist-hero__panel {
    position: static;
    width: 100%;
    margin-top: 12px;
  }
  .checklist-hero__form-grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .app-nav__link { display: none; }
  .app-nav .app-nav__link--emphasis { display: block; }
  .quick-actions { grid-template-columns: 1fr 1fr; }
  .feature-grid, .about-grid { grid-template-columns: 1fr; }
  .tips-grid { grid-template-columns: 1fr; }
  .timeline-row { grid-template-columns: 70px 1fr; }
  .timeline-carbs { display: none; }
}

/* ——— Public race guides (/races/) ——— */

/* Hub: hero */
.race-hub__lead { color: var(--text-md); max-width: 62ch; margin: 0; font-size: 15px; line-height: 1.6; }

/* Hub: card grid */
.race-hub__grid {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 12px;
}

/* Hub: filters */
.race-hub__filters { padding: 18px 20px; }
.race-hub__filters-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.7fr 0.9fr 1.2fr 0.9fr auto;
  gap: 12px;
  align-items: end;
}
.race-hub__filter { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.race-hub__filter-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--text-lo);
}
.race-hub__filters select,
.race-hub__filters input {
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--bg-2);
  color: var(--text-hi);
  font-size: 14px;
}
.race-hub__filter--search input::placeholder { color: var(--text-lo); }
.race-hub__filter-actions { display: flex; gap: 8px; justify-content: flex-end; }

@media (max-width: 960px) {
  .race-hub__filters-grid { grid-template-columns: 1fr 1fr; }
  .race-hub__filter-actions { grid-column: 1 / -1; justify-content: flex-start; }
}
.race-hub__card {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 22px 24px;
  background: var(--bg-1); border: 1px solid var(--line);
  border-radius: 14px; text-decoration: none; color: var(--text-hi);
  transition: border-color .18s, background .18s;
}
.race-hub__card:hover { border-color: var(--accent); background: var(--bg-2); text-decoration: none; }
.race-hub__card-body { flex: 1; min-width: 0; }
.race-hub__card-name {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 22px;
  text-transform: uppercase; letter-spacing: 0.02em;
  line-height: 1.1; margin: 6px 0 10px; color: var(--text-hi);
}
.race-hub__card-meta {
  display: flex; gap: 12px; flex-wrap: wrap;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-lo);
}
.race-hub__card-tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.race-hub__card-arrow {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 700; font-size: 20px; color: var(--accent);
  flex-shrink: 0; opacity: 0; transition: opacity .18s;
}
.race-hub__card:hover .race-hub__card-arrow { opacity: 1; }

/* Race page: preview banner */
.race-page__preview-banner {
  display: block; margin: 0;
  padding: 12px 16px; border-radius: 10px; border: 1px solid var(--warn);
  background: var(--warn-soft); font-size: 14px; color: var(--text-md);
}

/* Race page: hero meta */
.race-page__hero-meta {
  display: flex; align-items: center; gap: 16px 24px;
  flex-wrap: wrap; margin-top: 12px;
}
.race-page__meta-item {
  display: flex; align-items: center; gap: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-md);
}
.race-page__meta-label {
  font-size: 10px; color: var(--text-lo); letter-spacing: 0.2em;
}
.race-page__format { gap: 6px; }

/* Race page: variant tabs */
.race-page__variants { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 20px; }
.race-page__variant {
  display: inline-block; padding: 8px 16px; border-radius: 999px;
  border: 1px solid var(--line); font-size: 13px;
  font-family: 'Big Shoulders Display', system-ui; font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase;
  text-decoration: none; color: var(--text-md); transition: all .15s;
}
.race-page__variant:hover { border-color: var(--accent); color: var(--text-hi); text-decoration: none; }
.race-page__variant--current {
  border-color: var(--accent); color: var(--accent-ink);
  background: var(--accent); font-weight: 700;
}

/* Race page: article prose — brutalist slabs (admin HTML: linebreaks → <p>) */
.race-page__article {
  overflow: visible; /* .card defaults to hidden; do not clip hard shadows */
  border-radius: 0;
  border-width: 3px;
  border-color: var(--text-hi);
  padding: 0;
  box-shadow: 8px 8px 0 0 var(--accent);
}
.race-page__article::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 36px 36px 0;
  border-color: transparent var(--accent) transparent transparent;
  opacity: 0.85;
  pointer-events: none;
}
.race-page__prose-lead {
  padding: 22px 24px 20px;
  border-bottom: 3px solid var(--accent);
  background:
    linear-gradient(165deg, var(--bg-0) 0%, transparent 42%),
    repeating-linear-gradient(
      -45deg,
      transparent,
      transparent 9px,
      rgba(255, 255, 255, 0.035) 9px,
      rgba(255, 255, 255, 0.035) 10px
    );
}
.race-page__prose-lead p {
  font-family: 'Big Shoulders Display', system-ui;
  font-size: clamp(18px, 2.2vw, 26px);
  font-weight: 800;
  line-height: 1.28;
  color: var(--text-hi);
  letter-spacing: 0.03em;
  margin: 0 0 0.65em;
}
.race-page__prose-lead p:last-child { margin-bottom: 0; }
.race-page__prose-body {
  padding: 20px 22px 22px 28px;
  border-left: 6px solid var(--line);
  background: var(--bg-2);
  box-shadow: inset 0 0 0 1px var(--line);
}
.race-page__prose-body p {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  line-height: 1.85;
  color: var(--text-md);
  margin: 0 0 1em;
}
.race-page__prose-body p:last-child { margin-bottom: 0; }
.race-page__article .race-page__prose-body a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* Race page: overview teasers */
.race-page__teasers { font-size: 14px; }
.race-page__teaser-links { display: flex; gap: 8px; flex-wrap: wrap; }

/* Race page: course table */
.race-page__table { width: 100%; border-collapse: collapse; font-size: 14px; }
.race-page__table th,
.race-page__table td { padding: 10px 12px; text-align: left; border-bottom: 1px solid var(--line); }
.race-page__table th {
  color: var(--text-lo); font-weight: 600; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.08em;
  font-family: 'JetBrains Mono', monospace;
}
.race-page__seg-row--swim td:first-child { border-left: 3px solid var(--swim-color); padding-left: 10px; }
.race-page__seg-row--bike td:first-child { border-left: 3px solid var(--bike-color); padding-left: 10px; }
.race-page__seg-row--run  td:first-child { border-left: 3px solid var(--run-color);  padding-left: 10px; }
.race-page__seg-num { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--text-md); }
.race-page__totals-row { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 14px; }

/* Race page: variant-specific section grids */
.race-page__variant-grid {
  display: grid; gap: 12px;
}
.race-page__variant-grid--2 { grid-template-columns: repeat(2, 1fr); }
.race-page__variant-grid--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 640px) {
  .race-page__variant-grid--2,
  .race-page__variant-grid--3 { grid-template-columns: 1fr; }
}

.race-page__plan-card {
  display: flex; flex-direction: column;
  position: relative; overflow: hidden;
}
.race-page__plan-card-num {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900; font-size: 56px; line-height: 1;
  color: var(--bg-3); position: absolute; top: 12px; right: 16px;
  user-select: none; pointer-events: none;
}
.race-page__plan-card-title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800; font-size: 22px; text-transform: uppercase;
  letter-spacing: 0.03em; margin: 0 0 10px; color: var(--text-hi);
}
.race-page__plan-card-body {
  font-size: 14px; line-height: 1.65; color: var(--text-md); margin: 0;
}
.race-page__plan-card--seg { gap: 4px; }
.race-page__plan-card-stat {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900; font-size: 36px; line-height: 1;
  color: var(--text-hi); margin-top: 8px;
}
.race-page__plan-card-gain {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--text-lo); margin-top: 4px;
}
.race-page__plan-card--swim { border-top: 2px solid var(--swim-color); }
.race-page__plan-card--bike { border-top: 2px solid var(--bike-color); }
.race-page__plan-card--run  { border-top: 2px solid var(--run-color); }

/* Race page: compact context bar (non-overview variants) */
.race-page__context-bar { padding: 20px 24px; }
.race-page__context-stats { display: flex; gap: 24px; flex-wrap: wrap; align-items: flex-end; }
.race-page__context-stat { display: flex; flex-direction: column; gap: 6px; }
.race-page__context-dist {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 900; font-size: 32px; line-height: 1; color: var(--text-hi);
}
.race-page__context-unit {
  font-size: 16px; font-weight: 600; color: var(--text-lo); margin-left: 2px;
}

/* Race page: elevation SVG chart */
.race-page__elev-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.race-page__elevation-title {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 700; font-size: 18px; text-transform: uppercase;
  letter-spacing: 0.04em; margin: 0;
}
.race-page__elev-chart {
  border-radius: 6px; overflow: hidden;
  background: var(--bg-0);
  min-height: 80px;
}

/* Race page: conditions — brutalist grid cells */
.race-page__conditions {
  overflow: visible;
  border-radius: 0;
  border: 3px solid var(--text-hi);
  padding: 0 0 22px;
  box-shadow: 8px 8px 0 0 var(--accent);
  background: var(--bg-0);
}
.race-page__cond-grid {
  display: grid;
  /* auto-fit (not auto-fill) collapses empty tracks so wide viewports do not show a blank column */
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 2px;
  margin: 22px 22px 18px;
  border: 2px solid var(--line);
  background: var(--line);
}
.race-page__cond-item {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 16px 18px;
  background: var(--bg-1);
}
.race-page__cond-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent);
}
.race-page__cond-value {
  font-family: 'Big Shoulders Display', system-ui;
  font-size: clamp(17px, 2vw, 22px);
  font-weight: 800;
  line-height: 1.2;
  color: var(--text-hi);
  letter-spacing: 0.03em;
}
.race-page__cond-prose {
  padding: 18px 22px 0;
  border-top: 3px solid var(--line);
}
.race-page__conditions .race-page__cond-prose:first-child {
  border-top: none;
  padding-top: 22px;
}
.race-page__cond-prose .race-page__cond-label {
  display: block;
  margin-bottom: 10px;
  color: var(--text-lo);
}
.race-page__cond-prose .prose {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  line-height: 1.8;
  color: var(--text-md);
}
.race-page__cond-prose .prose p { margin: 0 0 0.85em; }
.race-page__cond-prose .prose p:last-child { margin-bottom: 0; }

/* Race page: FAQ — stacked concrete panels */
.race-page__faq-card {
  overflow: visible;
  border-radius: 0;
  border-width: 3px;
  border-color: var(--line);
  padding: 0;
  box-shadow: 8px 8px 0 0 var(--accent);
  background: var(--bg-0);
}
.race-page__faq { margin: 0; }
.race-page__faq dt {
  font-family: 'Big Shoulders Display', system-ui;
  font-weight: 800;
  font-size: clamp(16px, 1.8vw, 20px);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0;
  padding: 14px 20px 10px;
  color: var(--accent-ink);
  background: var(--accent);
  border-bottom: 3px solid var(--bg-0);
}
.race-page__faq dt:not(:first-child) {
  margin-top: 3px;
  border-top: 3px solid var(--bg-0);
}
.race-page__faq dd {
  margin: 0;
  padding: 14px 20px 20px 24px;
  color: var(--text-md);
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  line-height: 1.8;
  border-left: 5px solid var(--line);
  background: var(--bg-1);
  box-shadow: inset 0 -1px 0 var(--line);
}
.race-page__faq dd p { margin: 0 0 0.75em; }
.race-page__faq dd p:last-child { margin-bottom: 0; }

/* Race page: CTA */
.race-page__cta p { color: var(--text-md); max-width: 52ch; margin: 0 0 20px; }
