/* ===========================================
   RateLaunchpad — Design Tokens & Components
   =========================================== */

:root {
  /* Type Scale */
  --text-xs:   clamp(0.75rem,  0.7rem  + 0.25vw, 0.875rem);
  --text-sm:   clamp(0.875rem, 0.8rem  + 0.35vw, 1rem);
  --text-base: clamp(1rem,     0.95rem + 0.25vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 1rem    + 0.75vw, 1.5rem);
  --text-xl:   clamp(1.5rem,   1.2rem  + 1.25vw, 2.25rem);
  --text-2xl:  clamp(2rem,     1.2rem  + 2.5vw,  3.25rem);

  /* Spacing */
  --space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem;
  --space-4: 1rem; --space-5: 1.25rem; --space-6: 1.5rem;
  --space-8: 2rem; --space-10: 2.5rem; --space-12: 3rem;
  --space-16: 4rem; --space-20: 5rem; --space-24: 6rem;

  /* Fonts */
  --font-display: 'Cabinet Grotesk', 'Inter', sans-serif;
  --font-body: 'Satoshi', 'Inter', sans-serif;

  /* Radius */
  --radius-sm: 0.375rem; --radius-md: 0.5rem; --radius-lg: 0.75rem;
  --radius-xl: 1rem; --radius-2xl: 1.25rem; --radius-full: 9999px;

  /* Transitions */
  --transition-fast: 160ms cubic-bezier(0.16, 1, 0.3, 1);
  --transition-mid: 300ms cubic-bezier(0.16, 1, 0.3, 1);

  /* Widths */
  --w-narrow: 640px; --w-default: 960px; --w-wide: 1200px;
}

/* ── LIGHT ── */
:root, [data-theme="light"] {
  --color-bg: #f4f3ef; --color-surface: #ffffff; --color-surface-2: #fafaf7;
  --color-surface-offset: #eae9e5; --color-divider: #dddcd8; --color-border: #ccc;
  --color-text: #1b2431; --color-text-muted: #5b6678; --color-text-faint: #99a2ae;
  --color-text-inv: #ffffff;
  --color-accent: #e8651a; --color-accent-hover: #d45a14; --color-accent-active: #b84d10;
  --color-accent-light: #fef0e6;
  --color-navy: #1b2431; --color-navy-light: #253344;
  --color-success: #1a8a4a; --color-success-light: #e6f5ed;
  --color-error: #c4342d; --color-error-light: #fde8e7;
  --shadow-sm: 0 1px 3px rgba(27,36,49,.06); --shadow-md: 0 4px 14px rgba(27,36,49,.08);
  --shadow-lg: 0 12px 36px rgba(27,36,49,.12); --shadow-xl: 0 20px 50px rgba(27,36,49,.16);
}

/* ── DARK ── */
[data-theme="dark"] {
  --color-bg: #0f1620; --color-surface: #1b2431; --color-surface-2: #212d3f;
  --color-surface-offset: #17202e; --color-divider: #2b3a50; --color-border: #344460;
  --color-text: #e2e6eb; --color-text-muted: #8995a6; --color-text-faint: #5b6678;
  --color-text-inv: #1b2431;
  --color-accent: #f0843e; --color-accent-hover: #e8651a; --color-accent-active: #d45a14;
  --color-accent-light: #2a2118;
  --color-navy: #e2e6eb; --color-navy-light: #c8d0da;
  --color-success: #4ab870; --color-success-light: #1a2a20;
  --color-error: #e86060; --color-error-light: #2a1a1a;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.2); --shadow-md: 0 4px 14px rgba(0,0,0,.3);
  --shadow-lg: 0 12px 36px rgba(0,0,0,.4); --shadow-xl: 0 20px 50px rgba(0,0,0,.5);
}
@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --color-bg: #0f1620; --color-surface: #1b2431; --color-surface-2: #212d3f;
    --color-surface-offset: #17202e; --color-divider: #2b3a50; --color-border: #344460;
    --color-text: #e2e6eb; --color-text-muted: #8995a6; --color-text-faint: #5b6678;
    --color-text-inv: #1b2431;
    --color-accent: #f0843e; --color-accent-hover: #e8651a; --color-accent-active: #d45a14;
    --color-accent-light: #2a2118;
    --color-navy: #e2e6eb; --color-navy-light: #c8d0da;
    --color-success: #4ab870; --color-success-light: #1a2a20;
    --color-error: #e86060; --color-error-light: #2a1a1a;
    --shadow-sm: 0 1px 3px rgba(0,0,0,.2); --shadow-md: 0 4px 14px rgba(0,0,0,.3);
    --shadow-lg: 0 12px 36px rgba(0,0,0,.4); --shadow-xl: 0 20px 50px rgba(0,0,0,.5);
  }
}

/* ── LAYOUT ── */
body { display: flex; flex-direction: column; }
main { flex: 1; }
.container { max-width: var(--w-wide); margin-inline: auto; padding-inline: var(--space-4); }
.container--narrow { max-width: var(--w-narrow); }
.container--default { max-width: var(--w-default); }

/* ── HEADER ── */
.header {
  position: sticky; top: 0; z-index: 100;
  background: oklch(from var(--color-bg) l c h / .92);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--color-divider);
  padding: var(--space-3) 0;
}
.header__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); }
.header__logo { display: flex; align-items: center; gap: var(--space-2); text-decoration: none; color: var(--color-text); }
.header__logo svg { width: 32px; height: 32px; }
.header__wordmark { font-family: var(--font-display); font-weight: 800; font-size: var(--text-lg); letter-spacing: -.02em; }
.header__wordmark span { color: var(--color-accent); }
.header__right { display: flex; align-items: center; gap: var(--space-4); }
.header__link { font-size: var(--text-sm); font-weight: 500; color: var(--color-text-muted); text-decoration: none; }
.header__link:hover { color: var(--color-text); }
.btn-cta {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: var(--space-2) var(--space-5); background: var(--color-accent); color: #fff;
  font-size: var(--text-sm); font-weight: 600; border-radius: var(--radius-full);
  text-decoration: none; white-space: nowrap;
}
.btn-cta:hover { background: var(--color-accent-hover); }
.btn-cta:active { background: var(--color-accent-active); }
.theme-toggle { padding: var(--space-2); border-radius: var(--radius-md); color: var(--color-text-muted); display: flex; align-items: center; }
.theme-toggle:hover { color: var(--color-text); background: var(--color-surface-offset); }
.mobile-toggle { display: none; padding: var(--space-2); color: var(--color-text); }
@media (max-width: 768px) {
  .header__right .header__link { display: none; }
  .mobile-toggle { display: flex; }
  .header__right.open .header__link {
    display: block; position: absolute; top: 100%; left: 0; right: 0;
    background: var(--color-surface); padding: var(--space-4);
    border-bottom: 1px solid var(--color-divider); box-shadow: var(--shadow-lg);
  }
}

/* ── HERO ── */
.hero {
  padding: clamp(var(--space-12), 7vw, var(--space-24)) 0;
  background: var(--color-navy); color: var(--color-text-inv);
  position: relative; overflow: hidden;
}
[data-theme="dark"] .hero { background: var(--color-surface); color: var(--color-text); }
.hero::after {
  content: ''; position: absolute; top: -40%; right: -15%; width: 55%; height: 180%;
  background: radial-gradient(ellipse, rgba(232,101,26,.1) 0%, transparent 65%);
  pointer-events: none;
}
.hero__grid { display: grid; grid-template-columns: 1fr 420px; gap: var(--space-12); align-items: center; position: relative; z-index: 1; }
@media (max-width: 900px) { .hero__grid { grid-template-columns: 1fr; gap: var(--space-8); } }
.hero__badge {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: var(--space-1) var(--space-3); background: rgba(232,101,26,.15);
  color: var(--color-accent); font-size: var(--text-xs); font-weight: 700;
  border-radius: var(--radius-full); margin-bottom: var(--space-4);
  text-transform: uppercase; letter-spacing: .06em;
}
[data-theme="dark"] .hero__badge { background: rgba(240,131,62,.12); }
.hero__title {
  font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 800;
  line-height: 1.08; letter-spacing: -.03em; margin-bottom: var(--space-4);
}
.hero__title em { font-style: normal; color: var(--color-accent); }
.hero__sub { font-size: var(--text-base); opacity: .85; line-height: 1.65; margin-bottom: var(--space-6); max-width: 48ch; }
.hero__stats { display: flex; gap: var(--space-8); margin-top: var(--space-6); flex-wrap: wrap; }
.hero__stat b { display: block; font-family: var(--font-display); font-size: var(--text-xl); font-weight: 800; color: var(--color-accent); }
.hero__stat small { font-size: var(--text-xs); opacity: .7; }

/* ── QUOTE CARD ── */
.quote-card {
  background: var(--color-surface); border-radius: var(--radius-2xl);
  padding: var(--space-6) var(--space-6) var(--space-5); box-shadow: var(--shadow-xl);
  color: var(--color-text); position: relative;
}
.quote-card__head { text-align: center; margin-bottom: var(--space-5); }
.quote-card__title { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; }
.quote-card__sub { font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-1); }

/* Progress */
.progress { display: flex; gap: var(--space-2); margin-bottom: var(--space-5); }
.progress__bar { flex: 1; height: 4px; border-radius: var(--radius-full); background: var(--color-surface-offset); transition: background var(--transition-mid); }
.progress__bar.done { background: var(--color-success); }
.progress__bar.active { background: var(--color-accent); }

/* Steps indicator */
.steps-ind { display: flex; justify-content: space-between; margin-bottom: var(--space-4); }
.steps-ind__item { display: flex; flex-direction: column; align-items: center; gap: var(--space-1); font-size: var(--text-xs); color: var(--color-text-faint); }
.steps-ind__item.active { color: var(--color-accent); font-weight: 600; }
.steps-ind__item.done { color: var(--color-success); }
.steps-ind__dot {
  width: 26px; height: 26px; border-radius: var(--radius-full);
  display: flex; align-items: center; justify-content: center;
  background: var(--color-surface-offset); font-size: var(--text-xs); font-weight: 700;
}
.steps-ind__item.active .steps-ind__dot { background: var(--color-accent); color: #fff; }
.steps-ind__item.done .steps-ind__dot { background: var(--color-success); color: #fff; }

/* Form */
.form-step { display: none; animation: fadeUp .35s ease; }
.form-step.active { display: block; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
.form-group { margin-bottom: var(--space-4); }
.form-label { display: block; font-size: var(--text-sm); font-weight: 600; margin-bottom: var(--space-2); }
.form-input, .form-select {
  width: 100%; padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  font-size: var(--text-base); background: var(--color-bg); color: var(--color-text);
}
.form-input:focus, .form-select:focus { outline: none; border-color: var(--color-accent); box-shadow: 0 0 0 3px rgba(232,101,26,.15); }
.form-input.err, .form-select.err { border-color: var(--color-error); }
.form-err { font-size: var(--text-xs); color: var(--color-error); margin-top: var(--space-1); display: none; }
.form-err.show { display: block; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
@media (max-width: 480px) { .form-row { grid-template-columns: 1fr; } }

/* Zip big input */
.zip-wrap { text-align: center; padding: var(--space-4) 0; }
.zip-input {
  width: 100%; max-width: 260px; padding: var(--space-4);
  font-size: var(--text-xl); text-align: center;
  border: 2px solid var(--color-border); border-radius: var(--radius-xl);
  font-family: var(--font-display); font-weight: 700; letter-spacing: .12em;
  background: var(--color-bg); color: var(--color-text); margin: 0 auto var(--space-4); display: block;
}
.zip-input:focus { outline: none; border-color: var(--color-accent); box-shadow: 0 0 0 4px rgba(232,101,26,.15); }
.zip-hint { font-size: var(--text-sm); color: var(--color-text-muted); margin-bottom: var(--space-4); }

/* Consent checkbox */
.consent-wrap { display: flex; gap: var(--space-3); align-items: flex-start; margin-bottom: var(--space-4); }
.consent-wrap input[type="checkbox"] {
  width: 18px; height: 18px; margin-top: 3px; flex-shrink: 0;
  accent-color: var(--color-accent); cursor: pointer;
}
.consent-wrap label { font-size: 11px; color: var(--color-text-muted); line-height: 1.45; cursor: pointer; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  padding: var(--space-3) var(--space-6); border-radius: var(--radius-lg);
  font-size: var(--text-sm); font-weight: 600; cursor: pointer; border: none;
  transition: all var(--transition-fast); min-height: 48px;
}
.btn--primary { background: var(--color-accent); color: #fff; width: 100%; }
.btn--primary:hover { background: var(--color-accent-hover); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn--primary:active { background: var(--color-accent-active); transform: translateY(0); }
.btn--secondary { background: var(--color-surface-offset); color: var(--color-text); }
.btn--secondary:hover { background: var(--color-border); }
.form-nav { display: flex; gap: var(--space-3); margin-top: var(--space-5); }
.form-nav .btn { flex: 1; }

/* ── TRUST BAR ── */
.trust-bar {
  display: flex; justify-content: center; gap: var(--space-8); flex-wrap: wrap;
  padding: var(--space-5) 0;
  border-bottom: 1px solid var(--color-divider);
}
.trust-item { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); color: var(--color-text-muted); }
.trust-item svg { width: 18px; height: 18px; color: var(--color-success); flex-shrink: 0; }

/* ── SECTION ── */
.section { padding: clamp(var(--space-12), 6vw, var(--space-24)) 0; }
.section--alt { background: var(--color-surface); }
.section__head { margin-bottom: var(--space-10); max-width: 540px; }
.section__eyebrow {
  font-size: var(--text-xs); font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; color: var(--color-accent); margin-bottom: var(--space-2);
}
.section__title { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 800; letter-spacing: -.02em; margin-bottom: var(--space-3); }
.section__sub { font-size: var(--text-base); color: var(--color-text-muted); line-height: 1.6; }

/* ── HOW IT WORKS ── */
.how-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--space-6); }
@media (max-width: 768px) { .how-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .how-grid { grid-template-columns: 1fr; } }
.how-card { padding: var(--space-6); background: var(--color-surface); border-radius: var(--radius-xl); border: 1px solid oklch(from var(--color-text) l c h / .06); }
.how-card__num { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 800; color: var(--color-accent); opacity: .18; line-height: 1; margin-bottom: var(--space-3); }
.how-card__title { font-family: var(--font-display); font-size: var(--text-base); font-weight: 700; margin-bottom: var(--space-2); }
.how-card__desc { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.55; }

/* ── BENEFITS ── */
.benefits-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: var(--space-12); align-items: center; }
@media (max-width: 768px) { .benefits-grid { grid-template-columns: 1fr; } }
.benefit-list { list-style: none; display: flex; flex-direction: column; gap: var(--space-3); }
.benefit-item { display: flex; gap: var(--space-4); padding: var(--space-4); border-radius: var(--radius-lg); }
.benefit-item:hover { background: var(--color-surface-offset); }
.benefit-icon { width: 38px; height: 38px; flex-shrink: 0; color: var(--color-accent); display: flex; align-items: center; justify-content: center; }
.benefit-item strong { display: block; font-size: var(--text-sm); font-weight: 700; margin-bottom: 2px; }
.benefit-item p { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.5; margin: 0; }

/* Benefit visual panel */
.benefit-visual {
  background: var(--color-surface); border-radius: var(--radius-2xl);
  padding: var(--space-8); border: 1px solid oklch(from var(--color-text) l c h / .06);
  text-align: center;
}
.benefit-visual__big { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 800; color: var(--color-accent); }
.benefit-visual__label { font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-2); }
.benefit-visual__row { display: flex; justify-content: center; gap: var(--space-8); margin-top: var(--space-6); }
.benefit-visual__stat b { display: block; font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; }
.benefit-visual__stat small { font-size: var(--text-xs); color: var(--color-text-muted); }

/* ── TESTIMONIALS ── */
.test-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--space-6); }
@media (max-width: 768px) { .test-grid { grid-template-columns: 1fr; } }
.test-card { padding: var(--space-6); background: var(--color-surface); border-radius: var(--radius-xl); border: 1px solid oklch(from var(--color-text) l c h / .06); }
.test-card__stars { color: #f59e0b; font-size: var(--text-sm); margin-bottom: var(--space-3); letter-spacing: .08em; }
.test-card__text { font-size: var(--text-sm); line-height: 1.65; margin-bottom: var(--space-4); font-style: italic; }
.test-card__author { font-size: var(--text-xs); font-weight: 600; color: var(--color-text-muted); }
.test-card__role { font-size: var(--text-xs); color: var(--color-text-faint); }

/* ── AGENT SECTION ── */
.agent-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); }
@media (max-width: 768px) { .agent-grid { grid-template-columns: 1fr; } }
.agent-card {
  padding: var(--space-6); background: var(--color-bg); border-radius: var(--radius-xl);
  border: 1px solid oklch(from var(--color-text) l c h / .06);
}
.agent-card__icon { width: 40px; height: 40px; color: var(--color-accent); margin-bottom: var(--space-3); }
.agent-card__title { font-family: var(--font-display); font-weight: 700; font-size: var(--text-base); margin-bottom: var(--space-2); }
.agent-card__desc { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.55; }

/* ── FAQ ── */
.faq-list { max-width: 720px; display: flex; flex-direction: column; gap: var(--space-3); }
.faq-item { border: 1px solid oklch(from var(--color-text) l c h / .06); border-radius: var(--radius-lg); overflow: hidden; }
.faq-q {
  width: 100%; padding: var(--space-4) var(--space-5); display: flex; align-items: center;
  justify-content: space-between; font-size: var(--text-sm); font-weight: 600;
  color: var(--color-text); text-align: left; background: var(--color-surface); cursor: pointer;
}
.faq-q:hover { background: var(--color-surface-offset); }
.faq-q svg { width: 18px; height: 18px; color: var(--color-text-muted); transition: transform var(--transition-fast); flex-shrink: 0; }
.faq-item.open .faq-q svg { transform: rotate(180deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.faq-a__inner { padding: 0 var(--space-5) var(--space-5); font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.65; }

/* ── CTA BANNER ── */
.cta-banner {
  padding: clamp(var(--space-12), 6vw, var(--space-20)) 0;
  background: var(--color-navy); color: var(--color-text-inv); text-align: center;
}
[data-theme="dark"] .cta-banner { background: var(--color-surface-2); color: var(--color-text); }
.cta-banner__title { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 800; letter-spacing: -.02em; margin-bottom: var(--space-3); }
.cta-banner__sub { font-size: var(--text-base); opacity: .85; margin-bottom: var(--space-6); max-width: 46ch; margin-inline: auto; }
.cta-banner .btn--primary { width: auto; display: inline-flex; padding: var(--space-3) var(--space-8); font-size: var(--text-base); }

/* ── FOOTER ── */
.footer { padding: var(--space-8) 0 var(--space-4); border-top: 1px solid var(--color-divider); }
.footer__top { display: flex; justify-content: space-between; align-items: start; flex-wrap: wrap; gap: var(--space-8); }
.footer__brand { max-width: 280px; }
.footer__brand-logo { display: flex; align-items: center; gap: var(--space-2); text-decoration: none; color: var(--color-text); margin-bottom: var(--space-3); }
.footer__brand-logo svg { width: 26px; height: 26px; }
.footer__brand-name { font-family: var(--font-display); font-weight: 700; font-size: var(--text-base); }
.footer__brand-name span { color: var(--color-accent); }
.footer__brand-desc { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.6; }
.footer__cols { display: flex; gap: var(--space-12); }
.footer__col h4 { font-size: var(--text-sm); font-weight: 700; margin-bottom: var(--space-3); }
.footer__col ul { list-style: none; display: flex; flex-direction: column; gap: var(--space-2); }
.footer__col a { font-size: var(--text-sm); color: var(--color-text-muted); text-decoration: none; }
.footer__col a:hover { color: var(--color-text); }
.footer__bottom {
  margin-top: var(--space-8); padding-top: var(--space-4);
  border-top: 1px solid var(--color-divider);
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--space-3);
  font-size: var(--text-xs); color: var(--color-text-faint);
}
.footer__bottom a { color: var(--color-text-faint); text-decoration: none; }
.footer__bottom a:hover { color: var(--color-text-muted); }
@media (max-width: 768px) {
  .footer__top { flex-direction: column; }
  .footer__cols { gap: var(--space-8); }
}

/* ── THANK-YOU ── */
.thankyou {
  min-height: 60vh; display: flex; align-items: center; justify-content: center;
  text-align: center; padding: var(--space-12) var(--space-4);
}
.thankyou__icon {
  width: 72px; height: 72px; border-radius: var(--radius-full);
  background: var(--color-success-light); color: var(--color-success);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto var(--space-5);
}
.thankyou__title { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 800; margin-bottom: var(--space-3); }
.thankyou__text { font-size: var(--text-base); color: var(--color-text-muted); max-width: 48ch; margin: 0 auto var(--space-6); line-height: 1.6; }

/* Affiliate cards */
.aff-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(240px,1fr)); gap: var(--space-4); max-width: 760px; margin: 0 auto; }
.aff-card {
  padding: var(--space-5); background: var(--color-surface); border-radius: var(--radius-xl);
  border: 1px solid oklch(from var(--color-text) l c h / .06);
  text-align: center; text-decoration: none; color: var(--color-text);
  transition: all var(--transition-fast);
}
.aff-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--color-accent); }
.aff-card__name { font-family: var(--font-display); font-weight: 700; font-size: var(--text-base); margin-bottom: var(--space-1); }
.aff-card__desc { font-size: var(--text-xs); color: var(--color-text-muted); margin-bottom: var(--space-3); }
.aff-card__btn {
  display: inline-flex; padding: var(--space-2) var(--space-4);
  background: var(--color-accent); color: #fff; font-size: var(--text-xs);
  font-weight: 600; border-radius: var(--radius-full);
}

/* ── SCROLL REVEAL ── */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .55s ease, transform .55s ease; }
.reveal.vis { opacity: 1; transform: translateY(0); }

/* ── MULTI-ENTRY CARDS ── */
.multi-entry {
  background: var(--color-surface-offset); border-radius: var(--radius-lg);
  padding: var(--space-4); margin-bottom: var(--space-3);
  border: 1px solid oklch(from var(--color-text) l c h / .06);
  transition: opacity .2s ease, transform .2s ease;
}
.multi-entry__header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--space-3); padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-divider);
}
.multi-entry__label {
  display: flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-sm); font-weight: 700; color: var(--color-text);
}
.multi-entry__label svg { color: var(--color-accent); }
.btn-remove {
  display: inline-flex; align-items: center; gap: var(--space-1);
  font-size: 12px; font-weight: 600; color: var(--color-error);
  background: var(--color-error-light); padding: 4px 10px;
  border-radius: var(--radius-full); cursor: pointer; border: none;
  transition: all var(--transition-fast);
}
.btn-remove:hover { background: var(--color-error); color: #fff; }
.btn-add {
  display: flex; align-items: center; justify-content: center; gap: var(--space-2);
  width: 100%; padding: var(--space-3); margin-bottom: var(--space-4);
  font-size: var(--text-sm); font-weight: 600; color: var(--color-accent);
  background: transparent; border: 2px dashed var(--color-border);
  border-radius: var(--radius-lg); cursor: pointer;
  transition: all var(--transition-fast);
}
.btn-add:hover { border-color: var(--color-accent); background: var(--color-accent-light); }
.btn-add svg { flex-shrink: 0; }

/* Multi-entry inner form groups need tighter spacing */
.multi-entry .form-group { margin-bottom: var(--space-3); }
.multi-entry .form-group:last-child { margin-bottom: 0; }
.multi-entry .form-row { margin-bottom: 0; }

/* ── Form section label ── */
.form-section-label {
  font-size: var(--text-xs); font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--color-text-muted);
  margin: var(--space-3) 0 var(--space-2); padding-top: var(--space-2);
  border-top: 1px solid var(--color-divider);
}
.form-opt { font-weight: 400; color: var(--color-text-faint); text-transform: none; letter-spacing: 0; }
.form-hint { font-size: var(--text-xs); color: var(--color-text-faint); margin-top: var(--space-1); }

/* ── 3-column row ── */
.form-row--3 { grid-template-columns: 1fr 1fr 1fr; }
@media (max-width: 480px) { .form-row--3 { grid-template-columns: 1fr; } }

/* ── Tight toggle row ── */
.form-row--tight { display: flex; gap: var(--space-2); }
.form-row--tight .btn { min-height: 40px; padding: var(--space-2) var(--space-4); flex: 1; }

/* ── 5-column how grid ── */
.how-grid--5 { grid-template-columns: repeat(5, 1fr); }
@media (max-width: 900px) { .how-grid--5 { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px) { .how-grid--5 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 400px) { .how-grid--5 { grid-template-columns: 1fr; } }

/* ── Score Badge ── */
.score-badge {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: var(--space-2) var(--space-4); border-radius: var(--radius-full);
  font-size: var(--text-xs); font-weight: 600;
  background: var(--color-success-light); color: var(--color-success);
}
.score-badge svg { flex-shrink: 0; }
.score--high { background: var(--color-success-light); color: var(--color-success); }
.score--mid { background: var(--color-accent-light); color: var(--color-accent); }
.score--low { background: var(--color-surface-offset); color: var(--color-text-muted); }

/* ── LOADING SPINNER ── */
.spinner { display: inline-block; width: 18px; height: 18px; border: 2px solid rgba(255,255,255,.3); border-top-color: #fff; border-radius: 50%; animation: spin .6s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
