/*
 * Singing Carrots — Canonical Components (new era)
 * ─────────────────────────────────────────────────
 * Components prefixed with `.btn`, `.card`, `.badge`, `.field`, etc.
 * All use tokens from colors_and_type.css — no hard-coded colors/radii.
 *
 * Legacy Bootstrap-era components live in /legacy.css — never mix the two
 * in the same page except inside a Legacy preview card.
 */

@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&display=swap");

/* ─────────────────────────────────────────────────────────────────────
   BASE - scoped under .sc-canon to avoid bleeding into shared chrome.
   Migrated pages opt in by adding class="sc-canon" to their canonical
   content wrapper (e.g. <main class="sc-canon">). Legacy header/footer
   stays outside this scope so its existing styling is untouched.
   ───────────────────────────────────────────────────────────────────── */
.sc-canon, .sc-canon *, .sc-canon *::before, .sc-canon *::after { box-sizing: border-box; }
.sc-canon {
  font-family: var(--sc-font-body);
  color: var(--sc-ink-2);
  line-height: var(--sc-lh-body);
  -webkit-font-smoothing: antialiased;
}
/* Exclude .btn so button-variant text colors (white on gradient, etc.) win.
   Specificity note: .sc-canon a is 0,1,1 - higher than .btn--primary at 0,1,0.
   :not(.btn) keeps the link rule from matching anchors used as buttons. */
.sc-canon a:not(.btn) { color: var(--sc-carrot); text-decoration: none; }
.sc-canon a:not(.btn):hover { text-decoration: underline; }

.content-bounds { max-width: 1200px; margin: 0 auto; padding: 0 var(--sc-s-5); }
.page-section { padding: var(--sc-s-8) 0; }
.page-section--alt { background: var(--sc-bg-soft); }

/* ─────────────────────────────────────────────────────────────────────
   HEADER (canonical)
   ───────────────────────────────────────────────────────────────────── */
.sc-header {
  border-bottom: 1px solid var(--sc-rule-soft);
  background: var(--sc-bg);
  position: sticky; top: 0; z-index: 50;
}
.sc-header-inner {
  max-width: 1200px; margin: 0 auto;
  padding: var(--sc-s-3) var(--sc-s-5);
  display: flex; align-items: center; gap: var(--sc-s-6);
}
.sc-logo img { height: 38px; display: block; }
.sc-nav { display: flex; align-items: center; gap: 2px; flex: 1; }
.sc-nav-item {
  padding: 8px 12px;
  font: var(--sc-w-medium) var(--sc-sm)/1 var(--sc-font-body);
  color: var(--sc-ink-2);
  border-radius: var(--sc-r-sm);
  cursor: pointer;
  background: none; border: 0;
  display: inline-flex; align-items: center; gap: 6px;
  transition: background .15s ease, color .15s ease;
}
.sc-nav-item:hover { background: var(--sc-bg-soft); color: var(--sc-ink); }
.sc-nav-item.active { color: var(--sc-carrot); font-weight: var(--sc-w-semibold); }
.sc-nav-item .fa { font-size: 11px; opacity: 0.5; }

.sc-nav-item--ai { color: var(--sc-ai); }
.sc-nav-item--ai.active { color: var(--sc-ai); }
.sc-nav-ai-dot {
  width: 6px; height: 6px; border-radius: var(--sc-r-pill);
  background: var(--sc-grad-ai);
  box-shadow: 0 0 0 3px rgba(107,78,255,.2);
}
.sc-nav-right { display: flex; align-items: center; gap: 8px; margin-left: auto; }

/* ─────────────────────────────────────────────────────────────────────
   BUTTONS (canonical — one system)
   All: Poppins, 8px radius, 13/28 padding. Variants swap fill only.
   Two tiers:
     · Gradient (marketing moments): --primary, --ai, --pro
     · Flat (in-product everyday):   --success, --success-outline, --secondary, --ghost
   ───────────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px; padding: 13px 28px;
  border-radius: var(--sc-r-sm); border: 1.5px solid transparent;
  font: var(--sc-w-semibold) 15px/1 var(--sc-font-display);
  cursor: pointer; text-decoration: none;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease, border-color .15s ease, opacity .15s ease;
  white-space: nowrap;
}
.btn:hover { text-decoration: none; }
.btn:active { transform: scale(0.98); }

.btn--sm { padding: 9px 18px; font-size: 13px; }
.btn--lg { padding: 16px 32px; font-size: 16px; }
.btn--wide { min-width: 220px; }
.btn--block { display: flex; width: 100%; }

/* Primary: brand gradient (the main CTA on every page) */
.btn--primary {
  background: var(--sc-grad-brand); color: #fff;
  box-shadow: var(--sc-shadow-brand);
}
.btn--primary:hover { filter: brightness(1.06); color: #fff; }

/* Secondary: outlined carrot — paired with primary */
.btn--secondary {
  background: transparent; color: var(--sc-carrot);
  border-color: var(--sc-carrot);
}
.btn--secondary:hover { background: var(--sc-carrot-tint); color: var(--sc-carrot); }

/* Ghost: quiet dark-text option — for "I already have an account" */
.btn--ghost {
  background: transparent; color: var(--sc-ink);
  border-color: var(--sc-rule);
}
.btn--ghost:hover { background: var(--sc-bg-soft); border-color: var(--sc-ink-3); }

/* AI: violet gradient — for AI-feature CTAs only */
.btn--ai {
  background: var(--sc-grad-ai); color: #fff;
  box-shadow: var(--sc-shadow-ai);
}
.btn--ai:hover { filter: brightness(1.08); color: #fff; }

/* Pro: gold gradient — for upsell/pricing CTAs only */
.btn--pro {
  background: var(--sc-grad-brand); color: #fff;
  box-shadow: var(--sc-shadow-brand);
  font-weight: var(--sc-w-bold);
}
.btn--pro:hover { filter: brightness(1.06); color: #fff; }

/* Gradient variants: anchor the gradient to the border box so it starts
   exactly at x=0 of the visible button. Without this, the default
   background-origin (padding-box) shifts the gradient inward by 1.5px
   while background-clip (border-box) paints all the way to the edge —
   the visible left/right slivers are the gradient extrapolated past
   0%/100% (clamped to the endpoint colors), reading as a hard color
   seam. Must come AFTER each variant's `background:` shorthand so it
   isn't reset. */
.btn--primary,
.btn--ai,
.btn--pro {
  background-origin: border-box;
  background-clip: border-box;
}

/* Success: solid green — the in-app workhorse for primary actions inside cards (Start, Save, Confirm) */
.btn--success { background: var(--sc-success); color: #fff; }
.btn--success:hover { background: #218838; color: #fff; }

/* Success outline: paired with .btn--success for secondary in-app actions (Start Guided / Start DIY pattern) */
.btn--success-outline {
  background: transparent; color: var(--sc-success);
  border-color: var(--sc-success);
}
.btn--success-outline:hover { background: rgba(40,167,69,0.08); color: var(--sc-success); }

/* Icon-only */
.btn--icon {
  padding: 0; width: 40px; height: 40px; border-radius: var(--sc-r-pill);
  min-width: 0;
}

/* ─────────────────────────────────────────────────────────────────────
   CARDS (canonical)
   ───────────────────────────────────────────────────────────────────── */
.card {
  background: var(--sc-bg);
  border: 1px solid var(--sc-rule-soft);
  border-radius: var(--sc-r-md);
  padding: var(--sc-s-5);
  box-shadow: var(--sc-shadow-1);
  transition: transform .2s ease, box-shadow .2s ease;
}
.card--hoverable:hover { transform: translateY(-2px); box-shadow: var(--sc-shadow-2); }
.card--flush { padding: 0; }
.card--pad-lg { padding: var(--sc-s-6); }

/* Highlighted card — gradient border but kept 12px so it harmonises */
.card--highlight {
  border: 2px solid transparent;
  background:
    linear-gradient(#fff, #fff) padding-box,
    var(--sc-grad-brand) border-box;
  box-shadow: var(--sc-shadow-2);
}

/* AI-accented card — violet top stripe */
.card--ai {
  border: 1px solid rgba(107,78,255,.12);
  position: relative; overflow: hidden;
}
.card--ai::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--sc-grad-ai);
}

/* Beige callout — the "practice note" inline block */
.card--beige {
  background: var(--sc-beige);
  border: 1px solid transparent;
  box-shadow: none;
}

/* Warning card — soft gold surface for caution/running-low/trial-ending states.
   Caution, not danger: use this when the user still has time/options to act
   (low quota, payment retry, streak about to break). For hard error/failure
   states, reach for danger styling instead. */
.card--warning {
  background: var(--sc-gold-tint);
  border-color: var(--sc-gold);
  box-shadow: none;
}

/* ─────────────────────────────────────────────────────────────────────
   BADGES (canonical — one pill system, colored variants)
   ───────────────────────────────────────────────────────────────────── */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  border-radius: var(--sc-r-pill);
  font: var(--sc-w-semibold) 11px/1.2 var(--sc-font-display);
  letter-spacing: 0.04em; text-transform: uppercase;
  white-space: nowrap;
}
.badge--brand    { background: var(--sc-carrot); color: #fff; }
.badge--pro      { background: var(--sc-grad-brand); color: #fff; }
.badge--success  { background: var(--sc-success); color: #fff; }
.badge--ai       { background: var(--sc-ai-tint); color: var(--sc-ai); }
.badge--ai .dot  { width: 6px; height: 6px; border-radius: 50%; background: var(--sc-ai); box-shadow: 0 0 0 3px rgba(107,78,255,.2); }
.badge--neutral  { background: var(--sc-rule); color: var(--sc-ink-3); }
.badge--outline  { background: transparent; color: var(--sc-carrot); border: 1px solid var(--sc-carrot); }
.badge--lg       { padding: 6px 14px; font-size: 12px; }

/* ─────────────────────────────────────────────────────────────────────
   FORMS (canonical)
   ───────────────────────────────────────────────────────────────────── */
.field-label {
  display: block;
  font: var(--sc-w-semibold) 12px/1 var(--sc-font-display);
  color: var(--sc-ink);
  margin-bottom: 6px; letter-spacing: 0.02em;
}
.field {
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid var(--sc-rule);
  border-radius: var(--sc-r-sm);
  font: var(--sc-w-regular) 14px/1.4 var(--sc-font-body);
  color: var(--sc-ink);
  background: var(--sc-bg);
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.field:hover:not(:focus) { border-color: var(--sc-ink-3); }
.field:focus { border-color: var(--sc-carrot); box-shadow: 0 0 0 3px rgba(255,145,38,0.15); }
.field::placeholder { color: var(--sc-muted); }

/* Native select — add a chevron so it reads as "same rectangle + chevron" */
select.field {
  appearance: none; -webkit-appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--sc-ink-3) 50%), linear-gradient(135deg, var(--sc-ink-3) 50%, transparent 50%);
  background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50%;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 36px;
}

.field-help {
  font: var(--sc-w-regular) 11px/1.4 var(--sc-font-mono);
  color: var(--sc-muted); margin-top: 4px;
}
.field-error { color: var(--sc-danger); font-size: 12px; margin-top: 4px; }

/* Search input — keeps the 4px rectangle with leading icon slot */
.field-search {
  position: relative;
}
.field-search > .fa, .field-search > .icon {
  position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
  color: var(--sc-muted); pointer-events: none;
}
.field-search .field { padding-left: 40px; }

/* Checkbox row — custom-drawn so the tick is guaranteed white on carrot (native accent-color draws a dark tick on some platforms, which reads poorly on orange) */
.field-check {
  display: inline-flex; align-items: center; gap: 10px;
  font: var(--sc-w-regular) 13px/1.3 var(--sc-font-body);
  color: var(--sc-ink-2);
  cursor: pointer;
  user-select: none;
}
.field-check input[type="checkbox"] {
  appearance: none; -webkit-appearance: none;
  width: 18px; height: 18px;
  border: 1.5px solid var(--sc-rule);
  border-radius: 4px;
  background: #fff;
  display: inline-grid; place-content: center;
  cursor: pointer;
  transition: background .15s, border-color .15s, box-shadow .15s;
  flex-shrink: 0;
}
.field-check input[type="checkbox"]:hover { border-color: var(--sc-ink-3); }
.field-check input[type="checkbox"]:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(255,145,38,0.25); }
.field-check input[type="checkbox"]:checked {
  background: var(--sc-carrot);
  border-color: var(--sc-carrot);
}
.field-check input[type="checkbox"]:checked::after {
  content: '';
  width: 10px; height: 10px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14' fill='none' stroke='%23fff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='2.5,7 6,10.5 11.5,4'/></svg>") center/contain no-repeat;
}

/* ─────────────────────────────────────────────────────────────────────
   AI SURFACES
   ───────────────────────────────────────────────────────────────────── */
/* Halo avatar — the signature "AI identity" motif */
.ai-halo {
  position: relative; width: 88px; height: 88px;
  flex-shrink: 0;
}
.ai-halo .ring {
  position: absolute; inset: -5%; border-radius: 50%;
  background: conic-gradient(from 90deg, var(--sc-ai), var(--sc-ai-magenta), var(--sc-ai));
  filter: blur(4px); opacity: .14; animation: halo-rotate 6s linear infinite;
}
.ai-halo .inner {
  position: absolute; inset: 0; border-radius: 50%;
  background: #fff; display: flex; align-items: center; justify-content: center;
  overflow: hidden; box-shadow: var(--sc-shadow-1);
}
.ai-halo .inner img { width: 78%; height: 78%; object-fit: contain; }
@keyframes halo-rotate { to { transform: rotate(360deg); } }

/* AI chat bubble — violet-tinted */
.ai-bubble {
  background: var(--sc-ai-tint);
  color: var(--sc-ink-2);
  padding: 12px 16px;
  border-radius: var(--sc-r-md);
  border-top-left-radius: var(--sc-r-sm);
  font: var(--sc-w-regular) 14px/1.5 var(--sc-font-body);
  max-width: 420px;
}
.user-bubble {
  background: var(--sc-carrot-tint);
  color: var(--sc-ink);
  padding: 12px 16px;
  border-radius: var(--sc-r-md);
  border-top-right-radius: var(--sc-r-sm);
  font: var(--sc-w-regular) 14px/1.5 var(--sc-font-body);
  max-width: 340px;
  align-self: flex-end;
}

/* Typing dots */
.typing-dots { display: inline-flex; gap: 4px; padding: 3px 0; }
.typing-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--sc-muted); animation: sc-bounce 1.2s infinite ease-in-out; }
.typing-dot:nth-child(2) { animation-delay: 0.15s; }
.typing-dot:nth-child(3) { animation-delay: 0.3s; }
@keyframes sc-bounce { 0%, 60%, 100% { transform: translateY(0); opacity: .4; } 30% { transform: translateY(-4px); opacity: 1; } }

/* ─────────────────────────────────────────────────────────────────────
   PITCH / NOTE COMPONENTS
   ───────────────────────────────────────────────────────────────────── */
.pitch-meter {
  height: 10px; background: var(--sc-rule-soft);
  border-radius: var(--sc-r-pill); overflow: hidden;
}
.pitch-meter__fill {
  height: 100%; background: var(--sc-grad-brand);
  border-radius: var(--sc-r-pill);
  transition: width .3s ease;
}

.note-ladder {
  display: flex; gap: 6px; align-items: center;
  background: var(--sc-beige);
  padding: 12px 16px;
  border-radius: var(--sc-r-md);
}
.note-chip {
  font: var(--sc-w-bold) 14px/1 var(--sc-font-display);
  padding: 6px 10px;
  border-radius: var(--sc-r-sm);
  color: var(--sc-ink-3);
}
.note-chip--hit     { background: var(--sc-success); color: #fff; }
.note-chip--current { background: var(--sc-carrot); color: #fff; box-shadow: var(--sc-shadow-brand); }
.note-chip--miss    { color: var(--sc-muted); }

/* ─────────────────────────────────────────────────────────────────────
   HERO (canonical)
   ───────────────────────────────────────────────────────────────────── */
.hero {
  padding: var(--sc-s-9) var(--sc-s-5) var(--sc-s-8);
  background: var(--sc-wash-brand), var(--sc-bg);
  border-bottom: 1px solid var(--sc-rule-soft);
}
.hero--ai {
  background: var(--sc-wash-ai), var(--sc-bg);
  text-align: center;
}
.hero__eyebrow {
  font: var(--sc-w-bold) 11px/1 var(--sc-font-display);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--sc-carrot); margin-bottom: 14px;
}
.hero__title {
  font: var(--sc-w-black) var(--sc-h1)/1.05 var(--sc-font-display);
  letter-spacing: -0.025em; color: var(--sc-ink);
  max-width: 820px; margin: 0 0 18px;
}
.hero__sub {
  font: var(--sc-w-regular) 19px/1.5 var(--sc-font-display);
  color: var(--sc-ink-3);
  max-width: 640px; margin: 0 0 26px;
}
.hero--ai .hero__title,
.hero--ai .hero__sub { margin-left: auto; margin-right: auto; }
.hero__foot { font-size: 13px; color: var(--sc-muted); margin-top: 12px; }

/* Hero stat strip */
.hero-stats {
  display: flex; gap: 48px; margin-top: 40px;
  padding-top: 28px;
  border-top: 1px solid var(--sc-rule-soft);
}
.hero-stats__n {
  font: var(--sc-w-black) 42px/1 var(--sc-font-display);
  letter-spacing: -0.02em;
  background: var(--sc-grad-brand);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.hero-stats__l {
  font: var(--sc-w-medium) 12px/1.3 var(--sc-font-display);
  color: var(--sc-ink-3); margin-top: 4px;
}

/* ─────────────────────────────────────────────────────────────────────
   FOOTER (unchanged vocabulary; kept because it already looks right)
   ───────────────────────────────────────────────────────────────────── */
.page-footer { background: var(--sc-bg-footer); color: #fff; padding: var(--sc-s-8) 0 var(--sc-s-6); }
.page-footer-inner { max-width: 1200px; margin: 0 auto; padding: 0 var(--sc-s-5); display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.page-footer-links { list-style: none; padding: 0; margin: 0; }
.page-footer-links li { padding: 6px 0; }
.page-footer-links--header { font-weight: var(--sc-w-bold); color: #fff; margin-bottom: 4px; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; opacity: 0.7; }
.page-footer-links a { color: rgba(255,255,255,0.8); font-size: 14px; }
.page-footer-links a:hover { color: #fff; }
.page-footer-bottom { max-width: 1200px; margin: 24px auto 0; padding: 20px 20px 0; border-top: 1px solid rgba(255,255,255,0.3); color: rgba(255,255,255,0.6); font-size: 13px; text-align: center; }

/* ─────────────────────────────────────────────────────────────────────
   LEADERBOARD TABLE
   ───────────────────────────────────────────────────────────────────── */
.lb-table { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--sc-rule-soft); border-radius: var(--sc-r-md); overflow: hidden; }
.lb-table th { background: var(--sc-bg-soft); text-align: left; padding: 12px 16px; font-size: 11px; font-weight: var(--sc-w-bold); color: var(--sc-ink-3); text-transform: uppercase; letter-spacing: 0.06em; font-family: var(--sc-font-display); }
.lb-table td { padding: 14px 16px; border-top: 1px solid var(--sc-rule-soft); font-size: 14px; color: var(--sc-ink-2); }
.lb-rank { font-weight: var(--sc-w-bold); color: var(--sc-ink); width: 44px; }
.lb-rank--gold { color: var(--sc-carrot); }
.lb-ava { width: 28px; height: 28px; border-radius: 50%; background: var(--sc-beige); display: inline-flex; align-items: center; justify-content: center; margin-right: 10px; vertical-align: middle; font-weight: 700; color: var(--sc-carrot); font-size: 12px; }

/* ─────────────────────────────────────────────────────────────────────
   PRICING
   ───────────────────────────────────────────────────────────────────── */
.price-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.price-card { background: #fff; border: 1px solid var(--sc-rule); border-radius: var(--sc-r-md); padding: var(--sc-s-6); position: relative; }
.price-card--pro {
  border: 2px solid transparent;
  background:
    linear-gradient(#fff, #fff) padding-box,
    var(--sc-grad-brand) border-box;
  box-shadow: var(--sc-shadow-2);
}
.price-label { font: var(--sc-w-bold) 12px/1 var(--sc-font-display); letter-spacing: 0.06em; text-transform: uppercase; color: var(--sc-muted); margin-bottom: 6px; }
.price-num { font: var(--sc-w-black) 44px/1 var(--sc-font-display); color: var(--sc-ink); margin: 6px 0; letter-spacing: -0.02em; }
.price-num small { font-size: 15px; color: var(--sc-muted); font-weight: var(--sc-w-medium); }
.price-features { list-style: none; padding: 0; margin: 18px 0 24px; }
.price-features li { padding: 6px 0; font-size: 14px; color: var(--sc-ink-2); display: flex; align-items: flex-start; gap: 8px; }
.price-features .fa { color: var(--sc-success); margin-top: 3px; }

/* ─────────────────────────────────────────────────────────────────────
   LAYOUT GRIDS
   Generic two/three column patterns. Stack to single column under 768px.
   ───────────────────────────────────────────────────────────────────── */
.cols-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sc-s-7); align-items: center; }
.cols-2--stretch { align-items: stretch; }
.cols-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--sc-s-6); align-items: center; }
/* Critical: min-width: 0 prevents grid children from blowing out the column when
   they contain intrinsically-wide content like Swiper, long URLs, or pre-formatted text. */
.cols-2 > *, .cols-3 > * { min-width: 0; }
@media (max-width: 768px) {
  .cols-2, .cols-3 { grid-template-columns: 1fr; gap: var(--sc-s-5); }
}

/* Vertical text stack - paragraphs separated by spacing-3, body color */
.text-stack > * + * { margin-top: var(--sc-s-3); }
.text-stack p { color: var(--sc-ink-2); line-height: var(--sc-lh-loose); margin: 0; }

/* Section title block - heading + subhead */
.section-title { margin-bottom: var(--sc-s-6); }
.section-title--center { text-align: center; }
.section-title__sub {
  font: var(--sc-w-regular) 16px/1.6 var(--sc-font-body);
  color: var(--sc-ink-3);
  max-width: 640px;
  margin: var(--sc-s-3) 0 0;
}
.section-title--center .section-title__sub { margin-left: auto; margin-right: auto; }

/* ─────────────────────────────────────────────────────────────────────
   HERO VARIANTS
   .hero--split: text left + art right (two-column hero)
   ───────────────────────────────────────────────────────────────────── */
.hero--split {
  text-align: left;
}
.hero--split .hero__inner {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: var(--sc-s-7);
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
}
.hero--split .hero__title,
.hero--split .hero__sub { margin-left: 0; margin-right: 0; }
.hero--split .hero__art img,
.hero--split .hero__art picture { display: block; max-width: 100%; height: auto; margin-left: auto; }
.hero__actions { display: flex; gap: var(--sc-s-3); flex-wrap: wrap; margin-top: var(--sc-s-5); }
@media (max-width: 768px) {
  .hero--split .hero__inner { grid-template-columns: 1fr; }
  .hero--split .hero__art { order: -1; }
  .hero__title { font-size: 40px; }
}

/* ─────────────────────────────────────────────────────────────────────
   STAT CARDS
   Strip of stat tiles with big gradient number + gradient title + body desc.
   ───────────────────────────────────────────────────────────────────── */
.stat-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--sc-s-4);
}
/* .stat-card extends .card visual weight: generous padding, soft shadow,
   left-aligned content. Number leads, title bold, description body-style. */
.stat-card {
  padding: var(--sc-s-6);
  background: var(--sc-bg);
  border: 1px solid var(--sc-rule-soft);
  border-radius: var(--sc-r-md);
  box-shadow: var(--sc-shadow-1);
}
.stat-card__num {
  font: var(--sc-w-black) 48px/1 var(--sc-font-display);
  letter-spacing: -0.02em;
  background: var(--sc-grad-brand);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  display: block;
  margin-bottom: var(--sc-s-3);
}
.stat-card__title {
  font: var(--sc-w-bold) 18px/1.3 var(--sc-font-display);
  color: var(--sc-ink);
  margin: 0 0 var(--sc-s-2);
  letter-spacing: -0.01em;
}
.stat-card__desc {
  font: var(--sc-w-regular) 14px/1.5 var(--sc-font-body);
  color: var(--sc-ink-3);
  margin: 0;
}

/* Tracker strip - hero stat inline. Number + label sit close together;
   no equally-spaced 3-column layout. center alignment keeps the small label
   visually paired with the huge number instead of dropping to its baseline. */
.tracker-strip {
  display: flex;
  align-items: center;
  gap: var(--sc-s-5);
  flex-wrap: wrap;
}
.tracker-strip__total {
  font: var(--sc-w-black) 80px/1 var(--sc-font-display);
  letter-spacing: -0.02em;
  background: var(--sc-grad-brand);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  flex-shrink: 0;
}
.tracker-strip__label {
  font: var(--sc-w-bold) 20px/1.3 var(--sc-font-display);
  color: var(--sc-ink);
  max-width: 360px;
}
.tracker-strip__label strong { background: var(--sc-grad-brand); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

/* Live badge - small pill, inline with hero subtitle. */
.live-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font: var(--sc-w-semibold) 11px/1 var(--sc-font-display);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--sc-danger);
  padding: 4px 10px;
  border-radius: var(--sc-r-pill);
  background: var(--sc-danger-tint);
}
.live-badge .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--sc-danger);
  box-shadow: 0 0 0 3px rgba(195,60,34,.18);
}
@media (max-width: 768px) {
  .tracker-strip__total { font-size: 56px; }
  .tracker-strip__label { font-size: 16px; }
}

/* ─────────────────────────────────────────────────────────────────────
   NUMBERED POINTS
   Giant gradient numeral as background, body text overlaid.
   ───────────────────────────────────────────────────────────────────── */
.numbered-points {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sc-s-5);
}
.numbered-point {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sc-s-4);
  align-items: center;
  padding: var(--sc-s-5);
  border: 1px solid var(--sc-rule-soft);
  border-radius: var(--sc-r-md);
  background: var(--sc-bg);
}
.numbered-point__num {
  font: var(--sc-w-black) 72px/1 var(--sc-font-display);
  letter-spacing: -0.04em;
  background: var(--sc-grad-brand);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  display: inline-block;
}
.numbered-point__body {
  font: var(--sc-w-regular) 15px/1.5 var(--sc-font-body);
  color: var(--sc-ink-2);
  margin: 0;
}
@media (max-width: 768px) {
  .numbered-points { grid-template-columns: 1fr; }
  .numbered-point__num { font-size: 56px; }
}

/* ─────────────────────────────────────────────────────────────────────
   QUOTE BLOCK
   Featured pull-quote in gradient text with decorative quote marks.
   ───────────────────────────────────────────────────────────────────── */
.quote-block {
  position: relative;
  padding: var(--sc-s-7) var(--sc-s-7);
  text-align: center;
}
.quote-block::before, .quote-block::after {
  position: absolute;
  font: var(--sc-w-black) 96px/1 var(--sc-font-display);
  background: var(--sc-grad-brand);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  opacity: .55;
  pointer-events: none; user-select: none;
}
.quote-block::before { content: '\201C'; top: 0; left: var(--sc-s-3); }
.quote-block::after  { content: '\201D'; bottom: -28px; right: var(--sc-s-3); }
.quote-block__text {
  font: var(--sc-w-bold) 28px/1.35 var(--sc-font-display);
  letter-spacing: -0.01em;
  background: var(--sc-grad-brand);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  max-width: 720px;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .quote-block { padding: var(--sc-s-6) var(--sc-s-4); }
  .quote-block__text { font-size: 21px; }
  .quote-block::before, .quote-block::after { font-size: 64px; }
}

/* ─────────────────────────────────────────────────────────────────────
   CALLOUT
   Icon + body block, used for support/contrast pairs (positive/negative).
   ───────────────────────────────────────────────────────────────────── */
.callout {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sc-s-4);
  align-items: start;
  padding: var(--sc-s-5);
  border-radius: var(--sc-r-md);
  border: 1px solid var(--sc-rule-soft);
  background: var(--sc-bg);
}
.callout__icon {
  width: 36px; height: 36px;
  border-radius: var(--sc-r-pill);
  display: inline-flex;
  align-items: center; justify-content: center;
  color: #fff; font-size: 16px;
  flex-shrink: 0;
}
.callout__body {
  font: var(--sc-w-regular) 15px/1.5 var(--sc-font-body);
  color: var(--sc-ink-2);
  margin: 0;
}
.callout--positive { background: var(--sc-success-tint); border-color: rgba(40,167,69,.20); }
.callout--positive .callout__icon { background: var(--sc-success); }
.callout--negative { background: var(--sc-danger-tint); border-color: rgba(195,60,34,.20); }
.callout--negative .callout__icon { background: var(--sc-danger); }
.callout--warning  { background: var(--sc-gold-tint); border-color: var(--sc-gold); }
.callout--warning .callout__icon { background: var(--sc-warning-ink); }

/* ─────────────────────────────────────────────────────────────────────
   UTILITIES
   ───────────────────────────────────────────────────────────────────── */
.mt-1 { margin-top: var(--sc-s-1); } .mt-2 { margin-top: var(--sc-s-2); } .mt-3 { margin-top: var(--sc-s-3); } .mt-4 { margin-top: var(--sc-s-4); } .mt-5 { margin-top: var(--sc-s-5); } .mt-6 { margin-top: var(--sc-s-6); }
.mb-1 { margin-bottom: var(--sc-s-1); } .mb-2 { margin-bottom: var(--sc-s-2); } .mb-3 { margin-bottom: var(--sc-s-3); } .mb-4 { margin-bottom: var(--sc-s-4); } .mb-5 { margin-bottom: var(--sc-s-5); } .mb-6 { margin-bottom: var(--sc-s-6); } .mb-0 { margin-bottom: 0; }
.text-center { text-align: center; }
.d-flex { display: flex; }
.gap-2 { gap: var(--sc-s-2); } .gap-3 { gap: var(--sc-s-3); } .gap-4 { gap: var(--sc-s-4); } .gap-5 { gap: var(--sc-s-5); }
.align-center { align-items: center; }
.justify-center { justify-content: center; }
.flex-wrap { flex-wrap: wrap; }
.flex-1 { flex: 1; }
