/* ═══════════════════════════════════════════════════════════════════════════
   Rapideal Design System v2
   OKLCH-based tokens, semantic aliases, dark mode, motion, glass, scroll-reveal
   Built on the luxury-css-patterns skill
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Modern CSS Reset ─────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
.lenis.lenis-stopped { overflow: hidden; }

body {
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
img, picture, video, canvas, svg { display: block; max-width: 100%; }
input, button, textarea, select { font: inherit; color: inherit; }
button { background: none; border: none; cursor: pointer; }
p, h1, h2, h3, h4, h5, h6 { overflow-wrap: break-word; }
h1, h2, h3, h4 { text-wrap: balance; }
ul[role="list"], ol[role="list"] { list-style: none; }
a { color: inherit; text-decoration: none; }

/* ── Design Tokens (OKLCH) ───────────────────────────────────────────────── */
:root {
  /* Color: Brand scale (deep navy + premium gold) */
  --navy-950: oklch(12% 0.02 250);
  --navy-900: oklch(15% 0.03 250);
  --navy-800: oklch(20% 0.04 250);
  --navy-700: oklch(28% 0.05 250);
  --navy-600: oklch(38% 0.06 250);
  --navy-500: oklch(50% 0.05 250);

  --gold-300: oklch(82% 0.12 90);
  --gold-400: oklch(76% 0.15 88);
  --gold-500: oklch(72% 0.17 85);
  --gold-600: oklch(64% 0.18 82);
  --gold-700: oklch(52% 0.17 80);

  --slate-50:  oklch(98% 0 0);
  --slate-100: oklch(95% 0.01 250);
  --slate-200: oklch(90% 0.02 250);
  --slate-300: oklch(80% 0.03 250);
  --slate-400: oklch(70% 0.03 250);
  --slate-500: oklch(60% 0.03 250);
  --slate-600: oklch(50% 0.03 250);
  --slate-700: oklch(38% 0.04 250);
  --slate-800: oklch(28% 0.04 250);
  --slate-900: oklch(18% 0.03 250);

  /* Semantic tokens — these are the public API */
  --background:        oklch(11% 0.02 250);
  --background-soft:   oklch(14% 0.02 250);
  --surface:           oklch(16% 0.03 250);
  --surface-raised:    oklch(20% 0.03 250);
  --surface-overlay:   oklch(22% 0.04 250);

  /* foreground tokens — all pass WCAG AA 4.5:1 at 16px */
  --foreground:        oklch(98% 0.005 250);   /* #f5f7fa  near-white   */
  --foreground-soft:   oklch(86% 0.02 250);   /* #d4d9e2  soft white   */
  --foreground-muted:  oklch(70% 0.03 250);   /* #9da8b8  muted grey    */
  --foreground-faint:  oklch(52% 0.03 250);   /* #737d8f  faint grey    */

  --primary:           oklch(80% 0.16 88);     /* gold - brighter for AA contrast */
  --primary-hover:     oklch(85% 0.14 90);
  --primary-foreground: oklch(12% 0.02 250);  /* deep navy text on gold */

  --secondary:         oklch(20% 0.04 250);    /* surface-raised */
  --secondary-foreground: oklch(96% 0.005 250);

  --accent:            oklch(80% 0.16 88);     /* gold - AA compliant */
  --accent-foreground: oklch(12% 0.02 250);

  --muted:             oklch(18% 0.03 250);
  --muted-foreground:  oklch(60% 0.03 250);

  --border:            oklch(28% 0.04 250 / 0.4);
  --border-strong:     oklch(40% 0.05 250 / 0.6);
  --border-accent:     oklch(72% 0.17 85 / 0.3);

  --input:             oklch(22% 0.03 250);
  --ring:              oklch(80% 0.16 88);

  --destructive:       oklch(58% 0.22 25);
  --success:           oklch(60% 0.18 155);
  --warning:           oklch(75% 0.16 85);

  /* Property/Deal semantic states */
  --proceed:           oklch(60% 0.18 155);
  --proceed-bg:        oklch(60% 0.18 155 / 0.12);
  --marginal:          oklch(75% 0.16 85);
  --marginal-bg:       oklch(75% 0.16 85 / 0.12);
  --pass:              oklch(58% 0.22 25);
  --pass-bg:           oklch(58% 0.22 25 / 0.12);

  /* Typography */
  --font-heading: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-body:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;

  /* Type scale — fluid with clamp() */
  --text-2xs: 0.625rem;
  --text-xs:  0.75rem;
  --text-sm:  0.875rem;
  --text-base: 1rem;
  --text-lg:  1.0625rem;
  --text-xl:  1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: clamp(1.5rem, 2.5vw + 0.5rem, 1.875rem);
  --text-4xl: clamp(1.75rem, 3vw + 0.5rem, 2.25rem);
  --text-5xl: clamp(2rem, 4vw + 0.5rem, 3rem);
  --text-6xl: clamp(2.5rem, 5vw + 0.5rem, 3.75rem);
  --text-7xl: clamp(3rem, 6vw + 0.5rem, 4.5rem);
  --text-hero: clamp(2.5rem, 5.5vw + 0.5rem, 4.5rem);

  --leading-none:    1;
  --leading-tight:   1.15;
  --leading-snug:    1.3;
  --leading-normal:  1.55;
  --leading-relaxed: 1.7;

  --tracking-tight:  -0.025em;
  --tracking-normal:  0;
  --tracking-wide:    0.025em;
  --tracking-wider:   0.08em;
  --tracking-caps:    0.14em;

  /* Spacing (8px base, fluid) */
  --space-0:   0;
  --space-px:  1px;
  --space-1:   0.25rem;
  --space-2:   0.5rem;
  --space-3:   0.75rem;
  --space-4:   1rem;
  --space-5:   1.25rem;
  --space-6:   1.5rem;
  --space-7:   1.75rem;
  --space-8:   2rem;
  --space-10:  2.5rem;
  --space-12:  3rem;
  --space-14:  3.5rem;
  --space-16:  4rem;
  --space-20:  5rem;
  --space-24:  6rem;
  --space-28:  7rem;
  --space-32:  8rem;

  --gutter:         clamp(1rem, 3vw, 1.75rem);
  --section-pad:    clamp(4rem, 8vw, 7rem);
  --section-pad-sm: clamp(2.5rem, 5vw, 4rem);

  /* Layout */
  --container-max:   1280px;
  --container-wide:  1440px;
  --container-text:   720px;

  /* Radius (driven by base) */
  --radius:      0.625rem;
  --radius-sm:   calc(var(--radius) * 0.6);
  --radius-md:   calc(var(--radius) * 1);
  --radius-lg:   calc(var(--radius) * 1.5);
  --radius-xl:   calc(var(--radius) * 2);
  --radius-2xl:  calc(var(--radius) * 2.5);
  --radius-3xl:  calc(var(--radius) * 3.5);
  --radius-full: 9999px;

  /* Shadows */
  --shadow-xs:   0 1px 2px oklch(0% 0 0 / 0.2);
  --shadow-sm:   0 1px 3px oklch(0% 0 0 / 0.3), 0 1px 2px oklch(0% 0 0 / 0.2);
  --shadow-md:   0 4px 8px oklch(0% 0 0 / 0.25), 0 2px 4px oklch(0% 0 0 / 0.2);
  --shadow-lg:   0 12px 24px oklch(0% 0 0 / 0.3), 0 4px 8px oklch(0% 0 0 / 0.2);
  --shadow-xl:   0 24px 48px oklch(0% 0 0 / 0.4), 0 8px 16px oklch(0% 0 0 / 0.2);
  --shadow-2xl:  0 32px 64px oklch(0% 0 0 / 0.5);
  --shadow-gold: 0 0 0 1px oklch(72% 0.17 85 / 0.15), 0 8px 24px oklch(72% 0.17 85 / 0.2);
  --shadow-glow: 0 0 32px oklch(72% 0.17 85 / 0.25);

  /* Gradients */
  --gradient-gold:   linear-gradient(135deg, oklch(88% 0.13 92) 0%, oklch(80% 0.16 88) 50%, oklch(70% 0.18 84) 100%);
  --gradient-gold-soft: linear-gradient(135deg, oklch(82% 0.14 90) 0%, oklch(80% 0.16 88) 100%);
  --gradient-dark:   linear-gradient(180deg, oklch(11% 0.02 250) 0%, oklch(15% 0.03 250) 100%);
  --gradient-card:   linear-gradient(180deg, oklch(18% 0.03 250) 0%, oklch(14% 0.02 250) 100%);
  --gradient-hero:   radial-gradient(ellipse 1000px 600px at 50% -10%, oklch(28% 0.06 85 / 0.2) 0%, transparent 60%);
  --gradient-mesh:   radial-gradient(at 20% 30%, oklch(28% 0.05 85 / 0.12), transparent 50%),
                     radial-gradient(at 80% 70%, oklch(30% 0.05 250 / 0.12), transparent 50%);

  /* Motion */
  --ease-out:     cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in:      cubic-bezier(0.4, 0, 1, 1);
  --ease-in-out:  cubic-bezier(0.45, 0, 0.55, 1);
  --ease-spring:  cubic-bezier(0.34, 1.56, 0.64, 1);

  --duration-instant: 100ms;
  --duration-fast:    200ms;
  --duration-base:    300ms;
  --duration-slow:    500ms;
  --duration-slower:  800ms;

  /* z-index scale */
  --z-base:     1;
  --z-raised:   10;
  --z-sticky:   100;
  --z-dropdown: 200;
  --z-overlay:  300;
  --z-modal:    400;
  --z-toast:    500;
}

/* ── Base body & type ─────────────────────────────────────────────────────── */
body {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  color: var(--foreground);
  background: var(--background);
  min-height: 100vh;
  position: relative;
  overflow-x: hidden;
}

/* Subtle background mesh glow */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background: var(--gradient-mesh);
  pointer-events: none;
  z-index: 0;
}

main, .container { position: relative; z-index: 1; }

h1, .h1 {
  font-family: var(--font-heading);
  font-size: var(--text-hero);
  font-weight: 800;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--foreground);
}
h2, .h2 {
  font-family: var(--font-heading);
  font-size: var(--text-5xl);
  font-weight: 700;
  line-height: var(--leading-snug);
  letter-spacing: var(--tracking-tight);
  color: var(--foreground);
}
h3, .h3 {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: 600;
  line-height: var(--leading-snug);
  color: var(--foreground);
}
h4, .h4 {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: 600;
  line-height: var(--leading-snug);
  color: var(--foreground);
}
h5, .h5 {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--foreground);
}

p { color: var(--foreground-soft); line-height: var(--leading-relaxed); font-size: 1.0625rem; }

::selection { background: oklch(72% 0.17 85 / 0.3); color: var(--foreground); }

/* Focus visible — gold ring on keyboard nav only */
:focus { outline: none; }
:focus-visible {
  outline: 2px solid var(--ring);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* ── Eyebrow label ────────────────────────────────────────────────────────── */
.eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 700;
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--gold-300);
  margin-bottom: var(--space-4);
}
.eyebrow--centered { display: block; text-align: center; }

/* ── Container ────────────────────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.container--wide { max-width: var(--container-wide); }
.container--text { max-width: var(--container-text); }

.section { padding-block: var(--section-pad); position: relative; }
.section--sm { padding-block: var(--section-pad-sm); }
.section--flush { padding-block: 0; }

/* ── Scroll-reveal utility ────────────────────────────────────────────────── */
@keyframes reveal-up {
  from { opacity: 0; transform: translateY(32px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes reveal-scale {
  from { opacity: 0; transform: scale(0.96); }
  to   { opacity: 1; transform: scale(1); }
}

.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity var(--duration-slower) var(--ease-out),
              transform var(--duration-slower) var(--ease-out);
}
.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.reveal--scale { transform: scale(0.96); }
.reveal--scale.is-visible { transform: scale(1); }

/* Stagger children */
.reveal-stagger > * {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity var(--duration-slower) var(--ease-out),
              transform var(--duration-slower) var(--ease-out);
}
.reveal-stagger.is-visible > * { opacity: 1; transform: translateY(0); }
.reveal-stagger.is-visible > *:nth-child(1) { transition-delay: 0ms; }
.reveal-stagger.is-visible > *:nth-child(2) { transition-delay: 80ms; }
.reveal-stagger.is-visible > *:nth-child(3) { transition-delay: 160ms; }
.reveal-stagger.is-visible > *:nth-child(4) { transition-delay: 240ms; }
.reveal-stagger.is-visible > *:nth-child(5) { transition-delay: 320ms; }
.reveal-stagger.is-visible > *:nth-child(6) { transition-delay: 400ms; }

/* Motion disabled — stop ALL animation/transform, including floats and hover effects */
@media (prefers-reduced-motion: reduce) {
  .reveal,
  .reveal-stagger > *,
  .animate-float {
    opacity: 1;
    transform: none;
    transition: none;
    animation: none;
  }
  /* Disable card, button, step hover lifts */
  .card:hover,
  .btn:hover,
  .arch-card:hover,
  .stat-card:hover,
  .step:hover {
    transform: none;
    box-shadow: var(--shadow-md);
    border-color: var(--border);
  }
  /* Disable sticky CTA slide-in */
  .sticky-cta { transform: none !important; }
  html { scroll-behavior: auto; }
}

/* ── Nav (glass, sticky, scroll-aware) ────────────────────────────────────── */
.nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: var(--z-sticky);
  padding-block: var(--space-3);
  transition: background var(--duration-base) var(--ease-out),
              box-shadow var(--duration-base) var(--ease-out),
              padding var(--duration-base) var(--ease-out),
              backdrop-filter var(--duration-base) var(--ease-out);
}
.nav.is-scrolled {
  background: oklch(11% 0.02 250 / 0.78);
  backdrop-filter: blur(18px) saturate(180%);
  -webkit-backdrop-filter: blur(18px) saturate(180%);
  box-shadow: 0 1px 0 oklch(28% 0.04 250 / 0.5), 0 8px 24px oklch(0% 0 0 / 0.2);
  padding-block: var(--space-2);
}
.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.nav__brand {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: 800;
  letter-spacing: var(--tracking-tight);
  color: var(--foreground);
}
.nav__brand img { width: 32px; height: 32px; }
.nav__brand-text { background: var(--gradient-gold); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.nav__links {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  list-style: none;
}
.nav__link {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--foreground);
  letter-spacing: var(--tracking-wide);
  padding: var(--space-2) 0;
  position: relative;
  transition: color var(--duration-fast) var(--ease-out);
}
.nav__link:hover { color: var(--foreground); }
.nav__link::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 2px;
  background: var(--gradient-gold);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--duration-base) var(--ease-out);
}
.nav__link:hover::after { transform: scaleX(1); }
.nav__cta { margin-left: var(--space-3); }

@media (max-width: 768px) {
  .nav__links > *:not(.nav__cta) { display: none; }
}

/* ── Buttons ───────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  padding: 0.7rem 1.4rem;
  border-radius: var(--radius-md);
  border: 1.5px solid transparent;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  position: relative;
  transition: background var(--duration-fast) var(--ease-out),
              color var(--duration-fast) var(--ease-out),
              border-color var(--duration-fast) var(--ease-out),
              transform var(--duration-fast) var(--ease-spring),
              box-shadow var(--duration-fast) var(--ease-out);
  -webkit-user-select: none;
  user-select: none;
}
.btn:active { transform: translateY(1px) scale(0.99); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; }
.btn svg { width: 16px; height: 16px; flex-shrink: 0; }

.btn--primary {
  background: var(--gradient-gold);
  color: var(--primary-foreground);
  font-weight: 700;
  box-shadow: var(--shadow-gold);
}
.btn--primary:hover {
  background: var(--gradient-gold-soft);
  transform: translateY(-2px);
  box-shadow: 0 0 0 1px oklch(72% 0.17 85 / 0.3), 0 12px 32px oklch(72% 0.17 85 / 0.3);
}

/* Find Deals / secondary CTA — needs a visible border to read as a button */
a.btn--secondary,
button.btn--secondary {
  background: oklch(20% 0.04 250);
  color: var(--foreground);
  border: 1.5px solid oklch(70% 0.12 250);
  font-weight: 600;
}
a.btn--secondary:hover,
button.btn--secondary:hover {
  background: oklch(26% 0.04 250);
  border-color: oklch(80% 0.16 88);
  color: var(--primary);
  transform: translateY(-1px);
  box-shadow: 0 0 16px oklch(80% 0.16 88 / 0.15);
}

.btn--secondary {
  background: oklch(22% 0.04 250);
  color: var(--foreground);
  border: 1.5px solid oklch(80% 0.16 88 / 0.45);
  font-weight: 600;
}
.btn--secondary:hover {
  background: oklch(26% 0.04 250);
  border-color: oklch(80% 0.16 88 / 0.8);
  color: var(--primary);
  transform: translateY(-1px);
  box-shadow: 0 0 16px oklch(80% 0.16 88 / 0.15), var(--shadow-md);
}

.btn--ghost {
  background: transparent;
  color: var(--foreground);
  border-color: transparent;
}
.btn--ghost:hover {
  background: var(--surface);
  color: var(--primary);
}

.btn--outline {
  background: transparent;
  color: var(--foreground);
  border-color: var(--border-accent);
}
.btn--outline:hover {
  background: oklch(72% 0.17 85 / 0.08);
  border-color: var(--primary);
  color: var(--primary);
  transform: translateY(-2px);
}

.btn--ghost-light {
  background: transparent;
  color: oklch(98% 0 0);
  border-color: oklch(98% 0 0 / 0.3);
}
.btn--ghost-light:hover {
  background: oklch(98% 0 0 / 0.08);
  border-color: oklch(98% 0 0 / 0.6);
  transform: translateY(-2px);
}

.btn--sm { padding: 0.4rem 0.85rem; font-size: var(--text-xs); }
.btn--lg { padding: 0.95rem 2rem; font-size: var(--text-base); }
.btn--block { width: 100%; }

.btn--icon-end::after {
  content: '→';
  font-size: 1.1em;
  transition: transform var(--duration-fast) var(--ease-out);
}
.btn--icon-end:hover::after { transform: translateX(3px); }

/* ── Card ──────────────────────────────────────────────────────────────────── */
.card {
  background: var(--gradient-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  position: relative;
  overflow: hidden;
  transition: transform var(--duration-base) var(--ease-out),
              border-color var(--duration-base) var(--ease-out),
              box-shadow var(--duration-base) var(--ease-out);
}
.card:hover {
  transform: translateY(-4px);
  border-color: var(--border-accent);
  box-shadow: var(--shadow-lg);
}
.card--interactive { cursor: pointer; }
.card--gold-accent::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: var(--gradient-gold);
  opacity: 0.4;
  transition: opacity var(--duration-base) var(--ease-out);
}
.card--gold-accent:hover::before { opacity: 1; }

/* Spotlight hover — set --x, --y via JS */
.card--spotlight {
  position: relative;
  overflow: hidden;
}
.card--spotlight::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    300px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),
    oklch(72% 0.17 85 / 0.08),
    transparent 60%
  );
  opacity: 0;
  transition: opacity var(--duration-base) var(--ease-out);
  pointer-events: none;
}
.card--spotlight:hover::after { opacity: 1; }

/* ── Glass surface ─────────────────────────────────────────────────────────── */
.glass {
  background: oklch(99% 0 0 / 0.04);
  backdrop-filter: blur(16px) saturate(180%);
  -webkit-backdrop-filter: blur(16px) saturate(180%);
  border: 1px solid oklch(99% 0 0 / 0.08);
  border-radius: var(--radius-xl);
}
.glass--dark {
  background: oklch(0% 0 0 / 0.2);
  border-color: oklch(99% 0 0 / 0.06);
}

/* ── Form inputs ──────────────────────────────────────────────────────────── */
.field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.field__label {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--foreground-soft);
}
.field__label--required::after {
  content: ' *';
  color: var(--destructive);
}
.field__input,
.field__select,
.field__textarea {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: 1.5px solid var(--input);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--foreground);
  background: var(--input);
  transition: border-color var(--duration-fast) var(--ease-out),
              box-shadow var(--duration-fast) var(--ease-out),
              background var(--duration-fast) var(--ease-out);
  outline: none;
  -webkit-appearance: none;
  appearance: none;
}
.field__input:hover,
.field__select:hover,
.field__textarea:hover {
  border-color: var(--border-strong);
}
.field__input:focus,
.field__select:focus,
.field__textarea:focus {
  border-color: var(--ring);
  background: var(--surface);
  box-shadow: 0 0 0 3px oklch(72% 0.17 85 / 0.15);
}
.field__input::placeholder,
.field__textarea::placeholder {
  color: var(--foreground-faint);
}
.field__textarea {
  resize: vertical;
  min-height: 120px;
  line-height: var(--leading-normal);
}
.field__hint {
  font-size: var(--text-xs);
  color: var(--foreground-soft);
  margin-top: var(--space-1);
}
.field__error {
  font-size: var(--text-xs);
  color: var(--destructive);
  margin-top: var(--space-1);
}

/* ── Hero pattern: split ──────────────────────────────────────────────────── */
.hero-split {
  min-height: min(820px, 92vh);
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  align-items: center;
  gap: var(--space-12);
  padding-block: var(--section-pad);
  position: relative;
}
.hero-split > .container { width: auto; max-width: none; padding-inline: 0; }
.hero-split__eyebrow { margin-bottom: var(--space-5); }
.hero-split__heading { margin-bottom: var(--space-6); }
.hero-split__subtext {
  font-size: var(--text-lg);
  color: var(--foreground-soft);
  margin-bottom: var(--space-8);
  line-height: var(--leading-relaxed);
  max-width: 540px;
}
.hero-split__ctas {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-bottom: var(--space-12);
}
.hero-split__stats {
  display: flex;
  gap: var(--space-10);
  padding-top: var(--space-7);
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
}
.hero-split__stat-value {
  font-family: var(--font-heading);
  font-size: var(--text-3xl);
  font-weight: 800;
  background: var(--gradient-gold);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  letter-spacing: var(--tracking-tight);
  line-height: 1;
}
/* .stat-label overrides style.css .stat-label which uses var(--text-mid) at ~50% L */
.stat-label,
.hero-split__stat-label {
  color: var(--foreground-soft) !important;
  font-weight: 600;
  letter-spacing: 0.06em;
}
.hero-split__visual {
  position: relative;
  border-radius: var(--radius-3xl);
  overflow: hidden;
  aspect-ratio: 4 / 5;
  box-shadow: var(--shadow-2xl);
  border: 1px solid var(--border);
}
.hero-split__visual img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.hero-split__visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, oklch(11% 0.02 250 / 0.4));
  pointer-events: none;
}
.hero-split__floating-card {
  position: absolute;
  bottom: var(--space-6);
  left: var(--space-6);
  right: var(--space-6);
  z-index: 2;
  padding: var(--space-5);
  display: flex;
  align-items: center;
  gap: var(--space-4);
}
.hero-split__floating-icon {
  width: 44px; height: 44px;
  border-radius: var(--radius-md);
  background: var(--gradient-gold);
  color: var(--primary-foreground);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.hero-split__floating-text {
  font-size: var(--text-sm);
  color: var(--foreground);
}
.hero-split__floating-text strong { display: block; font-weight: 700; margin-bottom: 2px; }
.hero-split__floating-text span { color: var(--foreground-muted); font-size: var(--text-xs); }

/* ── Step pattern ──────────────────────────────────────────────────────────── */
.steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
  margin-block: var(--space-12);
  position: relative;
}
/* Horizontal connector line across all four columns */
.steps--line::before {
  content: '';
  position: absolute;
  top: 3.5rem;
  left: calc(25% - 1rem);
  right: calc(25% - 1rem);
  height: 1px;
  background: linear-gradient(
    to right,
    transparent,
    var(--border) 15%,
    var(--border) 85%,
    transparent
  );
  pointer-events: none;
}
.step {
  position: relative;
  display: grid;
  justify-items: center;
  text-align: center;
  padding: var(--space-7) var(--space-6);
}
.step__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-lg);
  background: oklch(80% 0.16 88 / 0.12);
  color: var(--primary);
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: 800;
  margin-bottom: var(--space-5);
  border: 1px solid oklch(80% 0.16 88 / 0.3);
  flex-shrink: 0;
}
.step__heading {
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--foreground);
  margin-bottom: var(--space-3);
  text-align: center;
}
.step__body {
  font-size: var(--text-base);
  color: var(--foreground-soft);
  line-height: var(--leading-relaxed);
  max-width: 32ch;
  text-align: center;
}
@media (max-width: 900px) {
  .steps { grid-template-columns: repeat(2, 1fr); }
  .steps--line::before { display: none; }
}

/* ── Badge / Pill ──────────────────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}
.badge--gold {
  background: oklch(72% 0.17 85 / 0.12);
  color: var(--primary);
  border: 1px solid oklch(72% 0.17 85 / 0.25);
}
.badge--proceed { background: var(--proceed-bg); color: var(--proceed); border: 1px solid oklch(60% 0.18 155 / 0.3); }
.badge--marginal { background: var(--marginal-bg); color: var(--marginal); border: 1px solid oklch(75% 0.16 85 / 0.3); }
.badge--pass { background: var(--pass-bg); color: var(--pass); border: 1px solid oklch(58% 0.22 25 / 0.3); }
.badge--neutral { background: var(--surface); color: var(--foreground-soft); border: 1px solid var(--border); }
.badge--dot::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
}

/* Archetype situation chips — small category pills on archetype cards */
.chip {
  font-size: var(--text-2xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  padding: 2px 10px;
  border-radius: 999px;
  display: inline-block;
  border: 1px solid;
  white-space: nowrap;
}
.chip--speed      { background: oklch(65% 0.18  65 / 0.12); color: oklch(82% 0.14  65); border-color: oklch(65% 0.18  65 / 0.25); }  /* amber = urgency */
.chip--problem    { background: oklch(65% 0.18  25 / 0.12); color: oklch(80% 0.15  25); border-color: oklch(65% 0.18  25 / 0.25); }  /* red = danger */
.chip--title      { background: oklch(70% 0.16 280 / 0.12); color: oklch(82% 0.14 280); border-color: oklch(70% 0.16 280 / 0.25); }  /* purple = legal */
.chip--commercial  { background: oklch(60% 0.18 250 / 0.12); color: oklch(78% 0.13 250); border-color: oklch(60% 0.18 250 / 0.25); }  /* blue = corporate */
.chip--residential { background: oklch(60% 0.18 158 / 0.12); color: oklch(78% 0.13 158); border-color: oklch(60% 0.18 158 / 0.25); }  /* green = home */
.chip--landlord    { background: oklch(70% 0.14  75 / 0.12); color: oklch(85% 0.12  75); border-color: oklch(70% 0.14  75 / 0.25); }  /* amber = investment */
.chip--specialist  { background: oklch(60% 0.12 250 / 0.12); color: oklch(78% 0.10 250); border-color: oklch(60% 0.12 250 / 0.25); }  /* navy = specialist */

/* ── Archetype card (per-situation) ────────────────────────────────────── */
.arch-grid {
  display: grid;
  /* Locked 4×7 grid — 28 archetypes across 4 columns. */
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}
.arch-card { transition: transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out), border-color var(--duration-base) var(--ease-out); }
.arch-card:hover { transform: translateY(-3px); border-color: oklch(80% 0.16 88 / 0.5); box-shadow: var(--shadow-lg); }
.arch-card__icon {
  width: 44px; height: 44px;
  border-radius: var(--radius-md);
  background: oklch(80% 0.16 88 / 0.1);
  border: 1px solid oklch(80% 0.16 88 / 0.2);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.arch-card__title {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--foreground);
  margin-bottom: var(--space-2);
  line-height: var(--leading-snug);
  text-wrap: balance;
}
.arch-card__body {
  font-size: var(--text-sm);
  color: var(--foreground-soft);
  line-height: var(--leading-relaxed);
  margin: 0;
}
/* Per-archetype micro-strip — the "this card is specific" differentiator */
.arch-card__strip {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-3) 0;
  margin-top: var(--space-3);
  border-top: 1px solid oklch(80% 0.16 88 / 0.15);
}
.arch-card__strip-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--foreground-muted);
  font-weight: 500;
  letter-spacing: 0.01em;
  line-height: 1.3;
}
.arch-card__strip-item svg { color: var(--foreground-faint); flex-shrink: 0; }
.arch-card__strip-item--benefit { color: var(--foreground-soft); font-weight: 600; }
.arch-card__strip-item--benefit svg { color: var(--primary); }
/* Per-archetype CTA — reads as a button, not just text */
.arch-card__cta {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: oklch(80% 0.16 88 / 0.08);
  border: 1px solid oklch(80% 0.16 88 / 0.2);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  color: var(--primary);
  font-weight: 700;
  transition: background var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out);
}
.arch-card:hover .arch-card__cta {
  background: oklch(80% 0.16 88 / 0.18);
  border-color: oklch(80% 0.16 88 / 0.5);
}
.arch-card__cta-text { line-height: 1; }

@media (max-width: 1100px) {
  /* Tablet — keep 2 columns instead of cramming 4 narrow cards */
  .arch-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  /* Mobile — single column for readability */
  .arch-grid { grid-template-columns: 1fr; }
}

/* ── Trust band / logo strip ──────────────────────────────────────────────── */
.trust-band {
  padding-block: var(--space-10);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: oklch(14% 0.02 250 / 0.5);
}
.trust-band__label {
  text-align: center;
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--foreground-soft);
  margin-bottom: var(--space-6);
  font-weight: 600;
}
.trust-band__logos {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-12);
  flex-wrap: wrap;
  list-style: none;
}
.trust-band__logo {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--foreground-muted);
  letter-spacing: var(--tracking-tight);
  transition: color var(--duration-base) var(--ease-out);
}
.trust-band__logo:hover { color: var(--primary); }

/* ── Footer ────────────────────────────────────────────────────────────────── */
.footer {
  border-top: 1px solid var(--border);
  padding-block: var(--space-16) var(--space-8);
  margin-top: var(--space-16);
  background: var(--background-soft);
}
.footer__grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: var(--space-10);
  margin-bottom: var(--space-12);
}
.footer__brand-name {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: 800;
  background: var(--gradient-gold);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: var(--space-3);
}
.footer__tagline {
  font-size: var(--text-sm);
  color: var(--foreground-muted);
  line-height: var(--leading-relaxed);
  max-width: 340px;
  margin-top: var(--space-4);
}
.footer__links {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  list-style: none;
}
.footer__links a {
  font-size: var(--text-sm);
  color: var(--foreground-soft);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-out);
}
.footer__links a:hover { color: var(--primary); }
.footer__bottom {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
  align-items: center;
  gap: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--border);
  font-size: var(--text-sm);
  color: var(--foreground-muted);
}
.footer__bottom-left {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  align-items: flex-start;
}
.footer__copyright {
  font-size: var(--text-sm);
  color: var(--foreground-soft);
  font-weight: 600;
  letter-spacing: 0.01em;
}
.footer__service {
  font-size: var(--text-xs);
  color: var(--foreground-faint);
  letter-spacing: 0.04em;
}
.footer__disclaimer {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--foreground-faint);
  line-height: var(--leading-relaxed);
  text-align: right;
}
@media (max-width: 768px) {
  .footer__grid { grid-template-columns: 1fr 1fr; gap: var(--space-8); }
  .footer__bottom { grid-template-columns: 1fr; text-align: center; }
  .footer__bottom-left { align-items: center; }
  .footer__disclaimer { text-align: center; }
}

/* ── Utility classes ──────────────────────────────────────────────────────── */
.flow > * + * { margin-top: var(--space-4); }
.flow-sm > * + * { margin-top: var(--space-2); }
.flow-lg > * + * { margin-top: var(--space-8); }

.text-center { text-align: center; }
.text-muted { color: var(--foreground-muted); }
.text-soft  { color: var(--foreground-soft); }
.text-primary { color: var(--primary); }

.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0);
  white-space: nowrap; border: 0;
}

/* Accessibility: skip-to-content link (a11y) */
.skip-link {
  position: absolute;
  top: -100px;
  left: var(--space-4);
  z-index: var(--z-toast);
  padding: var(--space-3) var(--space-5);
  background: var(--primary);
  color: var(--primary-foreground);
  font-weight: 700;
  font-size: var(--text-sm);
  border-radius: var(--radius-md);
  text-decoration: none;
  box-shadow: var(--shadow-lg);
  transition: top var(--duration-fast) var(--ease-out);
}
.skip-link:focus {
  top: var(--space-4);
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.line-clamp-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.aspect-4-3 { aspect-ratio: 4 / 3; }
.aspect-3-2 { aspect-ratio: 3 / 2; }
.aspect-1-1 { aspect-ratio: 1; }
.aspect-16-9 { aspect-ratio: 16 / 9; }

/* ── Animation: float (subtle hero visual hover) ──────────────────────────── */
@keyframes float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
.animate-float { animation: float 6s var(--ease-in-out) infinite; }

/* ── Animation: shimmer (loading/empty states) ────────────────────────────── */
@keyframes shimmer { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } }
.shimmer {
  background: linear-gradient(90deg, var(--surface) 0%, var(--surface-raised) 50%, var(--surface) 100%);
  background-size: 200% 100%;
  animation: shimmer 2s linear infinite;
}

/* ── Decorative divider ────────────────────────────────────────────────────── */
.divider-gradient {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border-accent), transparent);
  margin-block: var(--space-12);
}

/* ── Decorative gold underline (eyebrow flourish) ─────────────────────────── */
.eyebrow--decorated {
  position: relative;
  padding-bottom: var(--space-3);
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
}
.eyebrow--decorated::after {
  content: '';
  width: 32px;
  height: 1px;
  background: var(--gradient-gold);
}

/* ── Archetype section headers ─────────────────────── */
.arch-section__head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-4);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--border);
}
.arch-section__title {
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--foreground);
  margin: 0 0 var(--space-2);
  letter-spacing: var(--tracking-tight);
}
.arch-section__desc {
  font-size: var(--text-sm);
  color: var(--foreground-soft);
  margin: 0;
  line-height: var(--leading-relaxed);
}
.arch-section__count {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--foreground-muted);
  white-space: nowrap;
  flex-shrink: 0;
  padding-bottom: 2px;
}
