/* ============================================
   PropertyFi Design System — Colors & Type
   v3 — AI-first. Light surface. Violet primary.
   ============================================
   Direction: Stripe × DeepMind. Clean whites, 
   premium violet accent, geometric sans, 
   isometric imagery. We are the AI leader.
   ============================================ */


:root {
    /* ------------------------------------------- 
       Base palette
       ------------------------------------------- */

    /* Violet — the AI signal. Deep, premium, unmistakable. */
    --violet-50:  #F5F3FF;
    --violet-100: #EDE9FE;
    --violet-200: #DDD6FE;
    --violet-300: #C4B5FD;
    --violet-400: #A78BFA;
    --violet-500: #8B5CF6;
    --violet-600: #7C3AED;   /* PRIMARY */
    --violet-700: #6D28D9;
    --violet-800: #5B21B6;
    --violet-900: #4C1D95;
    --violet-950: #2E1065;

    /* White — clean, slightly off to avoid fluorescence */
    --white: #FFFFFF;
    --off-white: #FAFAFB;
    --canvas: #F7F7F9;       /* subtle raised surface */
    --canvas-deep: #F1F1F4;  /* sunken */

    /* Ink — near-black with a cool tint, never warm */
    --ink-950: #0A0B12;      /* headlines only */
    --ink-900: #14161F;      /* primary text */
    --ink-800: #1F2230;
    --ink-700: #2B2F3E;

    /* Slate — cool neutral ramp (replaces the warm "stone" of v1) */
    --slate-50:  #F8FAFC;
    --slate-100: #F1F5F9;
    --slate-200: #E2E8F0;
    --slate-300: #CBD5E1;
    --slate-400: #94A3B8;
    --slate-500: #64748B;
    --slate-600: #475569;
    --slate-700: #334155;
    --slate-800: #1E293B;
    --slate-900: #0F172A;

    /* Semantic accents */
    --emerald: #10B981;      /* success / verified */
    --emerald-deep: #059669;
    --emerald-tint: #D1FAE5;

    --amber: #F59E0B;        /* warning / flag */
    --amber-deep: #D97706;
    --amber-tint: #FEF3C7;

    --rose: #E11D48;         /* alert / danger */
    --rose-deep: #BE123C;
    --rose-tint: #FFE4E6;

    --sky: #0EA5E9;          /* data / map layers */
    --sky-deep: #0284C7;
    --sky-tint: #E0F2FE;

    /* ------------------------------------------- 
       Semantic tokens — light (default)
       ------------------------------------------- */
    --bg: var(--white);
    --bg-raised: var(--white);
    --bg-sunken: var(--canvas);
    --bg-inverse: var(--ink-950);
    --bg-tinted: var(--violet-50);

    --fg: var(--ink-900);
    --fg-muted: var(--slate-600);
    --fg-subtle: var(--slate-500);
    --fg-faint: var(--slate-400);
    --fg-inverse: var(--white);

    --border: var(--slate-200);
    --border-strong: var(--slate-300);
    --border-hairline: rgba(15, 23, 42, 0.06);
    --border-focus: var(--violet-500);

    --accent: var(--violet-600);
    --accent-fg: var(--white);
    --accent-hover: var(--violet-700);
    --accent-soft: var(--violet-50);
    --accent-soft-fg: var(--violet-700);

    --ok: var(--emerald);
    --warn: var(--amber);
    --err: var(--rose);

    /* Radii — generous, Stripe-like */
    --r-sm: 6px;
    --r-md: 8px;
    --r-lg: 12px;
    --r-xl: 16px;
    --r-2xl: 24px;
    --r-pill: 999px;

    /* Spacing — 4px baseline */
    --s-1: 4px; --s-2: 8px; --s-3: 12px; --s-4: 16px; --s-5: 20px; --s-6: 24px;
    --s-8: 32px; --s-10: 40px; --s-12: 48px; --s-16: 64px; --s-20: 80px; --s-24: 96px;
    --s-32: 128px;

    /* Shadows — refined, not heavy */
    --shadow-xs: 0 1px 2px rgba(15, 23, 42, 0.04);
    --shadow-sm: 0 1px 3px rgba(15, 23, 42, 0.05), 0 1px 2px rgba(15, 23, 42, 0.04);
    --shadow-md: 0 4px 8px -2px rgba(15, 23, 42, 0.06), 0 2px 4px -1px rgba(15, 23, 42, 0.04);
    --shadow-lg: 0 12px 24px -6px rgba(15, 23, 42, 0.08), 0 4px 8px -2px rgba(15, 23, 42, 0.05);
    --shadow-xl: 0 24px 48px -12px rgba(15, 23, 42, 0.12), 0 12px 24px -6px rgba(15, 23, 42, 0.06);
    --shadow-violet: 0 8px 24px -8px rgba(124, 58, 237, 0.35);
    --shadow-focus: 0 0 0 4px rgba(124, 58, 237, 0.16);

    /* Motion */
    --ease: cubic-bezier(0.4, 0, 0.2, 1);
    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
    --dur-micro: 120ms;
    --dur-fast: 180ms;
    --dur-base: 240ms;
    --dur-slow: 400ms;

    /* ------------------------------------------- 
       Type families — Space Grotesk display, Inter body
       ------------------------------------------- */
    --font-display: "Space Grotesk", "Helvetica Neue", "Arial", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    --font-body: "Inter", "Helvetica Neue", "Arial", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    --font-mono: "JetBrains Mono", "SFMono-Regular", Menlo, Consolas, monospace;

    /* Type scale */
    --t-11: 11px; --t-12: 12px; --t-13: 13px; --t-14: 14px; --t-15: 15px;
    --t-16: 16px; --t-18: 18px; --t-20: 20px; --t-24: 24px; --t-28: 28px;
    --t-32: 32px; --t-40: 40px; --t-48: 48px; --t-56: 56px; --t-64: 64px;
    --t-72: 72px; --t-80: 80px; --t-96: 96px;
}

/* ------------------------------------------- 
   Dark surface — for product dashboards, hero panels
   ------------------------------------------- */
[data-surface="dark"],
.surface-dark {
    --bg: var(--ink-950);
    --bg-raised: var(--ink-800);
    --bg-sunken: #060712;
    --bg-inverse: var(--white);

    --fg: var(--white);
    --fg-muted: var(--slate-300);
    --fg-subtle: var(--slate-400);
    --fg-faint: var(--slate-500);
    --fg-inverse: var(--ink-900);

    --border: rgba(255, 255, 255, 0.08);
    --border-strong: rgba(255, 255, 255, 0.14);
    --border-hairline: rgba(255, 255, 255, 0.05);

    --accent: var(--violet-400);
    --accent-hover: var(--violet-300);
    --accent-soft: rgba(139, 92, 246, 0.12);
    --accent-soft-fg: var(--violet-300);

    color: var(--fg);
    background: var(--bg);
}

/* ------------------------------------------- 
   Legacy token aliases (stop old files from crashing)
   ------------------------------------------- */
:root {
    --paper: var(--white);
    --paper-deep: var(--canvas);
    --paper-edge: var(--slate-200);
    --ink: var(--ink-900);
    --ink-soft: var(--ink-800);
    --ink-mute: var(--ink-700);
    --signal: var(--violet-600);
    --signal-deep: var(--violet-700);
    --signal-tint: var(--violet-50);
    --datum: var(--emerald);
    --datum-deep: var(--emerald-deep);
    --datum-tint: var(--emerald-tint);
    --caution: var(--amber);
    --caution-deep: var(--amber-deep);
    --caution-tint: var(--amber-tint);
    --stone-1: var(--slate-50);
    --stone-2: var(--slate-100);
    --stone-3: var(--slate-200);
    --stone-4: var(--slate-300);
    --stone-5: var(--slate-500);
    --stone-6: var(--slate-700);
    --stone-7: var(--slate-900);
    --iron-1: var(--slate-50);
    --iron-2: var(--slate-100);
    --iron-3: var(--slate-200);
    --iron-4: var(--slate-300);
    --iron-5: var(--slate-500);
    --iron-6: var(--slate-700);
    --iron-7: var(--slate-900);
    --bone: var(--white);
    --bone-soft: var(--canvas);
    --bone-edge: var(--slate-200);
    --graphite: var(--ink-950);
    --graphite-soft: var(--ink-800);
    --graphite-lift: var(--ink-700);
    --midnight: var(--slate-800);
    --midnight-soft: var(--slate-700);
    --midnight-deep: var(--slate-900);
    --volt: var(--violet-600);
    --volt-deep: var(--violet-700);
    --volt-tint: var(--violet-50);
    --ember: var(--rose);
    --moss: var(--emerald);
    --cobalt: var(--sky);
    --cobalt-tint: var(--sky-tint);
    --cobalt-deep: var(--sky-deep);
}

/* ============================================
   Base
   ============================================ */
html, body {
    background: var(--bg);
    color: var(--fg);
    font-family: var(--font-body);
    font-size: var(--t-16);
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "ss01", "cv11";
}
* { box-sizing: border-box; }

/* ============================================
   Semantic type classes
   Display: Space Grotesk (geometric, confident)
   Body: Inter (neutral, legible)
   Data: JetBrains Mono (tabular, precise)
   ============================================ */

.t-display-xl,
.t-h0 {
    font-family: var(--font-display);
    font-size: clamp(3rem, 6vw, var(--t-96));
    line-height: 0.96;
    letter-spacing: -0.04em;
    font-weight: 500;
    color: var(--fg);
}

.t-display,
.t-h1 {
    font-family: var(--font-display);
    font-size: clamp(2.25rem, 4.5vw, var(--t-64));
    line-height: 1.02;
    letter-spacing: -0.035em;
    font-weight: 500;
    color: var(--fg);
}

.t-h2 {
    font-family: var(--font-display);
    font-size: clamp(1.75rem, 3vw, var(--t-40));
    line-height: 1.1;
    letter-spacing: -0.028em;
    font-weight: 500;
    color: var(--fg);
}

.t-h3 {
    font-family: var(--font-display);
    font-size: var(--t-24);
    line-height: 1.2;
    letter-spacing: -0.022em;
    font-weight: 500;
    color: var(--fg);
}

.t-h4 {
    font-family: var(--font-display);
    font-size: var(--t-18);
    line-height: 1.3;
    letter-spacing: -0.014em;
    font-weight: 500;
    color: var(--fg);
}

.t-lede {
    font-family: var(--font-body);
    font-size: var(--t-18);
    line-height: 1.6;
    font-weight: 400;
    color: var(--fg-muted);
    max-width: 62ch;
    letter-spacing: -0.005em;
}

.t-body {
    font-family: var(--font-body);
    font-size: var(--t-15);
    line-height: 1.6;
    font-weight: 400;
    color: var(--fg);
    max-width: 68ch;
}

.t-body-sm {
    font-family: var(--font-body);
    font-size: var(--t-13);
    line-height: 1.5;
    color: var(--fg-muted);
}

.t-eyebrow {
    font-family: var(--font-mono);
    font-size: var(--t-12);
    line-height: 1;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-weight: 500;
    color: var(--fg-muted);
}

.t-data-xl {
    font-family: var(--font-display);
    font-size: var(--t-64);
    line-height: 1;
    letter-spacing: -0.04em;
    font-weight: 500;
    font-feature-settings: "tnum", "zero", "ss01";
    color: var(--fg);
}

.t-data {
    font-family: var(--font-display);
    font-size: var(--t-28);
    line-height: 1.1;
    letter-spacing: -0.022em;
    font-weight: 600;
    font-feature-settings: "tnum", "zero", "ss01";
    color: var(--fg);
}

.t-meta {
    font-family: var(--font-mono);
    font-size: var(--t-12);
    line-height: 1.4;
    letter-spacing: 0;
    font-feature-settings: "tnum";
    color: var(--fg-subtle);
}

.t-label {
    font-family: var(--font-body);
    font-size: var(--t-13);
    line-height: 1.2;
    font-weight: 500;
    color: var(--fg-muted);
}

/* Utility */
.fg-violet { color: var(--violet-600); }
.fg-emerald { color: var(--emerald-deep); }
.fg-amber { color: var(--amber-deep); }
.fg-rose { color: var(--rose); }
.fg-sky { color: var(--sky-deep); }

::selection {
    background: var(--violet-200);
    color: var(--violet-950);
}

/* bust */
/* ============================================
   PropertyFi v3 — Landing
   Clean. Calculator-led. Loop-focused.
   ============================================ */

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', system-ui, sans-serif;
  color: var(--ink-900);
  background: var(--white);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }

:root {
  --page: 1200px;
  --gutter: 40px;
  --font-display: 'Space Grotesk', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --border: #E4E4E8;
  --border-strong: #D4D4DA;
}

@media (max-width: 720px) {
  :root { --gutter: 22px; }
}

/* ──────── shared type + buttons ──────── */
.eyebrow {
  font: 500 11px var(--font-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--violet-700);
  display: inline-flex; align-items: center; gap: 10px;
}
.eyebrow::before {
  content: ''; width: 5px; height: 5px; border-radius: 50%;
  background: var(--violet-600);
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: -0.028em;
  line-height: 1.04;
  color: var(--ink-950);
  text-wrap: balance;
}
h1 { font-size: clamp(40px, 5.4vw, 72px); }
h2 { font-size: clamp(30px, 3.6vw, 46px); }
h3 { font-size: clamp(22px, 2.2vw, 28px); letter-spacing: -0.022em; }
h4 { font-size: 19px; letter-spacing: -0.018em; line-height: 1.22; }

em { font-style: normal; color: var(--violet-700); }
/* Purple emphasis in any h1/h2 always breaks to its own line so it pops. */
h1 em, h2 em { display: block; }

.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font: 500 15px/1 'Inter', sans-serif;
  padding: 14px 22px;
  border-radius: 10px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 180ms var(--ease);
  text-decoration: none;
  white-space: nowrap;
}
.btn-primary {
  background: var(--ink-950); color: white;
  box-shadow: 0 1px 2px rgba(10,11,18,0.2), 0 0 0 1px rgba(255,255,255,0.06) inset;
}
.btn-primary:hover { background: var(--violet-700); transform: translateY(-1px); box-shadow: 0 8px 24px -8px rgba(124,58,237,0.4); }
.btn-ghost { background: transparent; color: var(--ink-900); border-color: var(--border-strong); }
.btn-ghost:hover { border-color: var(--ink-900); }
.btn-sm { padding: 10px 16px; font-size: 14px; }
.btn-lg { padding: 18px 28px; font-size: 16px; }

.arrow-i {
  width: 14px; height: 14px;
  display: inline-flex; align-items: center; justify-content: center;
}

/* ──────── Nav ──────── */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,0.88);
  backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid var(--border);
}
.nav-inner {
  max-width: var(--page); margin: 0 auto;
  padding: 16px var(--gutter);
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
}
.nav-brand { display: flex; align-items: center; gap: 10px; }
.nav-brand img.logo-mark { width: 30px; height: 30px; border-radius: 6px; }
.nav-brand .logo-word {
  font: 600 17px var(--font-display); letter-spacing: -0.018em; color: var(--ink-950);
}
.nav-brand .logo-word .lb { color: var(--violet-600); font-weight: 500; }
.nav-links { display: flex; gap: 6px; }
.nav-link {
  font: 500 14px 'Inter'; color: var(--slate-600);
  padding: 8px 14px; border-radius: 7px;
  text-decoration: none; transition: all 150ms;
}
.nav-link:hover { color: var(--ink-950); background: var(--canvas); }
.nav-right { display: flex; align-items: center; gap: 10px; }
@media (max-width: 860px) {
  .nav-links { display: none; }
}

/* ──────── HERO ──────── */
.hero {
  position: relative;
  max-width: none;
  margin: 0;
  padding: 0;
  min-height: 760px;
  display: flex; align-items: stretch; justify-content: center;
  overflow: hidden;
  isolation: isolate;
}
.hero-content {
  position: relative;
  z-index: 2;
  max-width: 1280px;
  padding: 76px var(--gutter) 84px;
  display: grid;
  grid-template-columns: minmax(0, 590px) minmax(420px, 1fr);
  gap: clamp(36px, 6vw, 86px);
  align-items: center;
  text-align: left;
  margin: 0 auto;
  width: 100%;
  min-width: 0;
}
.hero-copy {
  position: relative;
  z-index: 3;
  max-width: 590px;
  min-width: 0;
  width: 100%;
}
.hero-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(98px, 1fr));
  gap: 8px;
  margin-bottom: 28px;
  width: 100%;
}
.hero-stat {
  min-height: 70px;
  border-radius: 8px;
  border: 1px solid rgba(124,58,237,0.14);
  background: rgba(255,255,255,0.82);
  backdrop-filter: blur(14px) saturate(130%);
  box-shadow: 0 12px 30px -24px rgba(10,11,18,0.32);
  padding: 13px 14px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 7px;
}
.hero-stat span {
  font: 600 10px/1 var(--font-mono);
  color: var(--slate-500);
  letter-spacing: 0.02em;
}
.hero-stat strong {
  font: 600 18px/1 var(--font-display);
  color: var(--violet-700);
  letter-spacing: 0;
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font: 500 11px var(--font-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--slate-600);
  background: rgba(255,255,255,0.72);
  backdrop-filter: blur(10px) saturate(130%);
  border: 1px solid rgba(124,58,237,0.13);
  padding: 8px 14px;
  border-radius: 999px;
  margin-bottom: 26px;
  max-width: 100%;
}
.hero-eyebrow .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--violet-600);
  box-shadow: 0 0 10px var(--violet-500);
  animation: pulse 2s ease-in-out infinite;
}
.hero h1 {
  max-width: 15.5ch;
  margin: 0 0 24px;
}
.hero .lede {
  font-size: clamp(18px, 1.8vw, 22px);
  color: var(--slate-600);
  max-width: 50ch;
  margin: 0 0 34px;
  line-height: 1.5;
  text-wrap: pretty;
}
.hero-zip {
  display: flex;
  align-items: stretch;
  gap: 0;
  background: white;
  border: 1px solid var(--border-strong);
  border-radius: 14px;
  padding: 6px;
  box-shadow: 0 1px 3px rgba(10,11,18,0.06), 0 24px 48px -24px rgba(124,58,237,0.22);
  margin: 0 0 18px;
  max-width: 560px;
  width: fit-content;
}
.hero-zip input {
  flex: 1;
  min-width: 320px;
  border: none; outline: none;
  padding: 12px 18px;
  font: 500 15px 'Inter', sans-serif;
  color: var(--ink-900);
  background: transparent;
  text-overflow: ellipsis;
}
.hero-zip input::placeholder { color: var(--slate-400); font-weight: 400; }
.hero-zip .btn { border-radius: 10px; }
.hero-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin: 0 0 18px;
}
.hero-fineprint {
  font: 500 12px var(--font-mono);
  color: var(--slate-500); letter-spacing: 0.08em; text-transform: uppercase;
  display: inline-flex; gap: 10px; align-items: center;
  flex-wrap: wrap;
}
.hero-fineprint .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--emerald); }

/* ──────── HERO BACKGROUND ──────── */
.hero-bg {
  position: absolute; inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}
.hero-bg-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center right;
  opacity: 0.98;
  transform: scale(1.01);
}
.hero-bg-glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  opacity: 0.55;
}
.hero-bg-glow.a {
  width: 620px; height: 440px;
  top: -170px; left: 22%;
  background: radial-gradient(ellipse, rgba(124,58,237,0.18), transparent 68%);
  animation: glow-drift 18s ease-in-out infinite;
}
.hero-bg-glow.b {
  width: 680px; height: 520px;
  bottom: -130px; right: -120px;
  background: radial-gradient(ellipse, rgba(16,185,129,0.14), transparent 66%);
  animation: glow-drift 22s ease-in-out infinite reverse;
}
.hero-bg-soft {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg,
      rgba(255,255,255,0.99) 0%,
      rgba(255,255,255,0.94) 27%,
      rgba(255,255,255,0.64) 45%,
      rgba(255,255,255,0.2) 67%,
      rgba(255,255,255,0.36) 100%),
    linear-gradient(180deg,
      rgba(255,255,255,0.18) 0%,
      rgba(255,255,255,0.02) 56%,
      rgba(255,255,255,0.96) 100%);
}
.hero-bg-vignette {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 80% 72% at 78% 43%, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 54%, rgba(255,255,255,0.72) 100%),
    linear-gradient(180deg, rgba(255,255,255,0) 72%, white 100%);
  pointer-events: none;
}

@keyframes glow-drift {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50%      { transform: translate(60px, 40px) scale(1.1); }
}

.hero-visual {
  position: relative;
  min-height: 560px;
  align-self: stretch;
  z-index: 2;
}
.hero-route-lines {
  position: absolute;
  inset: 10px 0 0 -26px;
  width: 100%;
  height: 100%;
  overflow: visible;
  filter: drop-shadow(0 0 10px rgba(124,58,237,0.32));
}
.route-line {
  fill: none;
  stroke: rgba(124,58,237,0.78);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-dasharray: 10 10;
  animation: route-move 16s linear infinite;
}
.route-line.branch {
  stroke: rgba(255,255,255,0.86);
  stroke-width: 1.5;
  stroke-dasharray: 4 8;
}
.route-line.b2 {
  animation-duration: 18s;
  opacity: 0.86;
}
.route-node {
  fill: white;
  stroke: var(--violet-600);
  stroke-width: 3;
}
.route-node.emerald {
  stroke: var(--emerald);
}
@keyframes route-move {
  from { stroke-dashoffset: 0; }
  to   { stroke-dashoffset: -120; }
}
.hero-signal-cloud {
  position: absolute;
  inset: 0;
}
.hero-signal-card,
.hero-outreach-card,
.hero-reply-card {
  position: absolute;
  border-radius: 8px;
  border: 1px solid rgba(124,58,237,0.16);
  background: rgba(255,255,255,0.82);
  backdrop-filter: blur(16px) saturate(140%);
  box-shadow: 0 18px 46px -30px rgba(10,11,18,0.42), 0 1px 0 rgba(255,255,255,0.72) inset;
}
.hero-signal-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 13px;
  min-width: 150px;
  animation: hero-float 13s ease-in-out infinite;
}
.hero-signal-card.s1 { top: 56px; left: 50px; }
.hero-signal-card.s2 { top: 22px; left: 242px; animation-delay: -4s; }
.hero-signal-card.s3 { top: 98px; right: 18px; animation-delay: -7s; }
.hero-signal-card.s4 { top: 150px; left: 126px; min-width: 176px; animation-delay: -9s; }
.signal-icon,
.hoc-icon {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: none;
  color: var(--violet-700);
  background: rgba(124,58,237,0.1);
}
.signal-icon svg,
.hoc-icon svg {
  width: 17px;
  height: 17px;
}
.signal-copy {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}
.signal-copy span,
.hoc-head span,
.reply-head span,
.reply-meta {
  font: 600 10px/1.1 var(--font-mono);
  color: var(--slate-500);
  letter-spacing: 0.02em;
}
.signal-copy strong,
.hoc-head strong,
.reply-head strong {
  font: 600 13px/1.1 'Inter';
  color: var(--ink-900);
  letter-spacing: 0;
}
.hero-outreach-card {
  width: 188px;
  right: 250px;
  top: 238px;
  padding: 14px;
}
.hoc-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(15,23,42,0.07);
}
.hoc-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 12px;
}
.hoc-row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 38px;
  font: 600 13px/1 'Inter';
  color: var(--ink-900);
}
.hero-reply-card {
  width: 220px;
  right: -2px;
  top: 266px;
  padding: 12px;
  animation: hero-float 14s ease-in-out infinite -6s;
}
.reply-head {
  display: flex;
  align-items: center;
  gap: 7px;
  padding-bottom: 10px;
}
.reply-head span:last-child {
  margin-left: auto;
  color: var(--slate-400);
}
.reply-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--violet-600);
  box-shadow: 0 0 0 4px rgba(124,58,237,0.12), 0 0 14px rgba(124,58,237,0.5);
}
.hero-reply-card img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 7px;
  border: 1px solid rgba(15,23,42,0.08);
  margin-bottom: 11px;
}
.reply-address {
  font: 700 14px/1.1 'Inter';
  color: var(--ink-950);
  margin-bottom: 5px;
}
.reply-meta {
  color: var(--violet-700);
  margin-bottom: 12px;
}
.reply-status {
  min-height: 28px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-top: 1px solid rgba(15,23,42,0.07);
  font: 600 12px/1 'Inter';
  color: var(--slate-600);
}
.reply-status svg {
  color: var(--emerald-deep);
}
.reply-status.ok {
  color: var(--ink-900);
}
@keyframes hero-float {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50%      { transform: translate3d(0, -10px, 0); }
}

/* homes — slow rightward drift */
.home-layer {
  animation: home-drift 80s linear infinite;
}
@keyframes home-drift {
  from { transform: translateX(0); }
  to   { transform: translateX(-200px); }
}
.home rect {
  transition: all 400ms ease;
}
.home.hot .dot-hot {
  animation: dot-pulse 2.2s ease-in-out infinite;
  transform-origin: center;
  transform-box: fill-box;
}
.home.low .dot-low {
  animation: dot-pulse 2.6s ease-in-out infinite 0.6s;
  transform-origin: center;
  transform-box: fill-box;
}
.glow-hot {
  animation: glow-pulse 2.2s ease-in-out infinite;
  transform-origin: center;
  transform-box: fill-box;
}
.glow-low {
  animation: glow-pulse 2.6s ease-in-out infinite 0.6s;
  transform-origin: center;
  transform-box: fill-box;
  opacity: 0.7;
}
@keyframes dot-pulse {
  0%, 100% { opacity: 0.85; transform: scale(1); }
  50%      { opacity: 1; transform: scale(1.6); }
}
@keyframes glow-pulse {
  0%, 100% { opacity: 0.35; transform: scale(0.85); }
  50%      { opacity: 1; transform: scale(1.15); }
}

/* scan sweep */
.scan-group { mix-blend-mode: screen; }
.scan-bar {
  animation: scan-sweep 8s cubic-bezier(0.65, 0, 0.35, 1) infinite;
  opacity: 0.8;
}
@keyframes scan-sweep {
  0%    { transform: translateX(-100px); opacity: 0; }
  10%   { opacity: 0.9; }
  90%   { opacity: 0.9; }
  100%  { transform: translateX(1100px); opacity: 0; }
}

/* floating chips — atmosphere, not content */
.hero-chip {
  position: absolute;
  z-index: 2;
  display: inline-flex; align-items: center; gap: 7px;
  background: rgba(255,255,255,0.75);
  backdrop-filter: blur(6px);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 6px 11px 6px 9px;
  box-shadow: 0 1px 2px rgba(10,11,18,0.04), 0 8px 20px -12px rgba(10,11,18,0.12);
  font: 500 10px var(--font-mono);
  letter-spacing: 0.1em; text-transform: uppercase;
  opacity: 0.7;
  animation: chip-float 12s ease-in-out infinite;
}
.hero-chip .chip-dot {
  width: 5px; height: 5px; border-radius: 50%;
  box-shadow: 0 0 6px currentColor;
}
.hero-chip .chip-k { color: var(--slate-500); }
.hero-chip .chip-v { color: var(--slate-600); font-family: 'Inter'; font-size: 11px; text-transform: none; letter-spacing: 0; font-weight: 500; }

.hero-chip.c1 { top: 10%; left: 4%;  animation-delay: 0s; }
.hero-chip.c2 { top: 12%; right: 5%; animation-delay: -3s; animation-duration: 13s; }
.hero-chip.c3 { bottom: 14%; left: 5%; animation-delay: -5s; animation-duration: 14s; }
.hero-chip.c4 { bottom: 16%; right: 4%; animation-delay: -7s; animation-duration: 11s; }

@keyframes chip-float {
  0%, 100% { transform: translate(0, 0); }
  50%      { transform: translate(6px, -10px); }
}

@media (max-width: 860px) {
  .hero { min-height: auto; }
  .hero-content {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 62px var(--gutter) 70px;
  }
  .hero-copy {
    max-width: 640px;
    width: 100%;
  }
  .hero-visual {
    min-height: 360px;
    max-width: 620px;
    width: 100%;
    margin: 0 auto;
  }
  .hero-bg-image {
    object-position: 68% center;
    opacity: 0.86;
    filter: saturate(1.04) contrast(1.02);
  }
  .hero-bg-soft {
    background:
      linear-gradient(180deg, rgba(255,255,255,0.96) 0%, rgba(255,255,255,0.86) 42%, rgba(255,255,255,0.42) 70%, rgba(255,255,255,0.82) 100%),
      linear-gradient(90deg, rgba(255,255,255,0.96) 0%, rgba(255,255,255,0.68) 46%, rgba(255,255,255,0.16) 100%);
  }
  .hero-signal-card.s1 { top: 8px; left: 4px; }
  .hero-signal-card.s2 { top: 38px; left: auto; right: 14px; }
  .hero-signal-card.s3,
  .hero-signal-card.s4 { display: none; }
  .hero-outreach-card {
    top: 126px;
    right: 212px;
  }
  .hero-reply-card {
    top: 116px;
    right: 6px;
  }
  .hero-route-lines {
    inset: 8px 0 0 0;
  }
}

@media (max-width: 720px) {
  .hero-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .hero-eyebrow {
    border-radius: 8px;
    line-height: 1.45;
    align-items: flex-start;
    display: flex;
    width: 100%;
    overflow-wrap: anywhere;
  }
  .hero-zip {
    width: 100%;
    max-width: none;
  }
  .hero-zip input {
    min-width: 0;
  }
  .hero-visual {
    min-height: 330px;
  }
  .hero-outreach-card {
    width: 166px;
    right: auto;
    left: 0;
    top: 132px;
  }
  .hero-reply-card {
    width: 190px;
    top: 116px;
  }
}

@media (max-width: 520px) {
  .nav-inner {
    gap: 10px;
  }
  .nav-brand {
    gap: 8px;
    min-width: 0;
  }
  .nav-brand img.logo-mark {
    width: 28px;
    height: 28px;
  }
  .nav-brand .logo-word {
    font-size: 16px;
  }
  .nav-right {
    display: none;
  }
  .hero-content {
    padding-top: 46px;
    min-width: 0;
    max-width: 100vw;
    overflow: hidden;
  }
  .hero-copy {
    width: 100%;
    max-width: 346px;
  }
  .hero h1 {
    font-size: clamp(38px, 11vw, 46px);
    max-width: 10.8ch;
  }
  .hero .lede {
    font-size: 17px;
    max-width: 100%;
  }
  .hero-bg-image {
    opacity: 0.68;
    object-position: 72% center;
  }
  .hero-bg-soft {
    background:
      linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.9) 48%, rgba(255,255,255,0.56) 72%, rgba(255,255,255,0.88) 100%),
      linear-gradient(90deg, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.68) 100%);
  }
  .hero-zip {
    flex-direction: column;
    gap: 6px;
  }
  .hero-zip .btn {
    justify-content: center;
  }
  .hero-stats {
    display: none;
  }
  .hero-fineprint {
    font-size: 10px;
    letter-spacing: 0.06em;
  }
  .hero-visual {
    display: none;
  }
  .hero-signal-card {
    min-width: 136px;
    padding: 9px 10px;
  }
  .hero-signal-card.s2 {
    right: -12px;
  }
  .hero-outreach-card {
    display: none;
  }
  .hero-reply-card {
    right: -4px;
    top: 112px;
    width: 176px;
  }
  .hero-route-lines {
    width: 120%;
    left: -16%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .home-layer, .scan-bar, .hero-chip, .glow-hot, .glow-low, .dot-hot, .dot-low, .hero-bg-glow, .hero-eyebrow .dot, .route-line, .hero-signal-card, .hero-reply-card {
    animation: none !important;
  }
}

/* ──────── CALCULATOR ──────── */
.calc {
  max-width: var(--page); margin: 0 auto;
  padding: 0 var(--gutter) 96px;
}
.calc-wrap {
  background: var(--ink-950);
  border-radius: 28px;
  padding: 40px;
  position: relative; overflow: hidden;
  color: white;
  box-shadow: 0 2px 4px rgba(10,11,18,0.2), 0 32px 80px -32px rgba(124,58,237,0.35);
}
.calc-wrap::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 500px 300px at 10% 0%, rgba(124,58,237,0.3), transparent 65%),
    radial-gradient(ellipse 700px 400px at 100% 120%, rgba(139,92,246,0.2), transparent 60%);
}
.calc-grid {
  position: relative;
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 40px;
  align-items: stretch;
}
@media (max-width: 960px) {
  .calc-grid { grid-template-columns: 1fr; }
  .calc-wrap { padding: 28px; }
}

.calc-controls {
  display: flex; flex-direction: column; gap: 22px;
}
.calc-step {
  display: flex; flex-direction: column; gap: 10px;
}
.calc-step .lbl {
  font: 500 11px var(--font-mono); letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--violet-300);
  display: flex; align-items: center; gap: 8px;
}
.calc-step .lbl .n {
  width: 18px; height: 18px; border-radius: 50%;
  background: rgba(255,255,255,0.08);
  color: white; font-size: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid rgba(255,255,255,0.12);
}
.verts {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px;
}
.vert-chip {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  padding: 10px 8px;
  font: 500 12px 'Inter';
  color: white;
  cursor: pointer;
  text-align: center;
  transition: all 150ms;
  display: flex; flex-direction: column; gap: 4px; align-items: center;
}
.vert-chip .ic { opacity: 0.85; }
.vert-chip:hover { background: rgba(255,255,255,0.1); }
.vert-chip.active {
  background: var(--violet-600);
  border-color: var(--violet-400);
  box-shadow: 0 0 0 3px rgba(124,58,237,0.25);
}

/* "Coming soon" variant — dashed, amber dot, feels different */
.vert-chip.soon {
  background: rgba(255,255,255,0.03);
  border: 1px dashed rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.78);
  position: relative;
}
.vert-chip.soon::after {
  content: '';
  position: absolute; top: 6px; right: 6px;
  width: 5px; height: 5px; border-radius: 50%;
  background: #F59E0B;
  box-shadow: 0 0 0 3px rgba(245,158,11,0.2);
}
.vert-chip.soon:hover {
  background: rgba(245,158,11,0.08);
  border-color: rgba(245,158,11,0.4);
  color: white;
}
.vert-chip.soon.active {
  background: rgba(245,158,11,0.15);
  border: 1px solid rgba(245,158,11,0.6);
  color: white;
  box-shadow: 0 0 0 3px rgba(245,158,11,0.18);
}
.vert-chip.soon.active::after { background: #FBBF24; box-shadow: 0 0 0 3px rgba(251,191,36,0.3); }

.verts.verts-soon {
  grid-template-columns: repeat(3, 1fr);
  gap: 5px;
}
.verts-label-row {
  display: flex; justify-content: space-between; align-items: baseline;
  font: 500 10px 'JetBrains Mono', monospace;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin-bottom: 8px;
}
.verts-hint { color: rgba(245,158,11,0.85); text-transform: none; letter-spacing: 0; font-size: 11px; }

@media (max-width: 520px) {
  .verts.verts-soon { grid-template-columns: repeat(3, 1fr); }
}

/* "Coming soon" explainer on the left when a soon vert is selected */
.calc-soon-note {
  display: flex; gap: 14px; align-items: flex-start;
  background: rgba(245,158,11,0.08);
  border: 1px solid rgba(245,158,11,0.2);
  border-radius: 12px;
  padding: 16px 18px;
  color: rgba(255,255,255,0.85);
}
.calc-soon-note .pulse-dot {
  flex: none; width: 10px; height: 10px; border-radius: 50%;
  background: #FBBF24;
  margin-top: 6px;
  box-shadow: 0 0 0 0 rgba(251,191,36,0.6);
  animation: pulseAmber 2s infinite;
}
@keyframes pulseAmber {
  0%   { box-shadow: 0 0 0 0 rgba(251,191,36,0.55); }
  70%  { box-shadow: 0 0 0 10px rgba(251,191,36,0); }
  100% { box-shadow: 0 0 0 0 rgba(251,191,36,0); }
}
.calc-soon-note strong { color: white; font-weight: 600; display: block; margin-bottom: 4px; }
.calc-soon-note p { margin: 0; font-size: 13px; line-height: 1.5; color: rgba(255,255,255,0.7); }

/* Waitlist panel on the right (replaces metrics when soon is selected) */
.calc-waitlist { display: flex; flex-direction: column; min-height: 100%; }
.calc-out-head .a.soon {
  background: rgba(245,158,11,0.18);
  color: #FBBF24;
  border: 1px solid rgba(245,158,11,0.3);
}
.waitlist-body {
  flex: 1;
  display: flex; flex-direction: column; align-items: flex-start;
  padding: 32px 28px;
  gap: 16px;
}
.waitlist-icon {
  width: 52px; height: 52px; border-radius: 14px;
  background: rgba(245,158,11,0.15);
  border: 1px solid rgba(245,158,11,0.25);
  color: #FBBF24;
  display: inline-flex; align-items: center; justify-content: center;
}
.waitlist-icon svg { width: 26px; height: 26px; }
.waitlist-body h3 {
  color: white;
  font: 600 24px 'Inter Tight', 'Inter', sans-serif;
  letter-spacing: -0.02em;
  margin: 0;
  line-height: 1.1;
  max-width: 22ch;
}
.waitlist-body > p {
  color: rgba(255,255,255,0.65);
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  max-width: 46ch;
}
.waitlist-form {
  display: flex; gap: 8px; width: 100%; margin-top: 6px;
  flex-wrap: wrap;
}
.waitlist-form input {
  flex: 1; min-width: 220px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 10px;
  padding: 12px 14px;
  color: white;
  font: 500 14px 'Inter', sans-serif;
  outline: none;
}
.waitlist-form input::placeholder { color: rgba(255,255,255,0.35); }
.waitlist-form input:focus { border-color: var(--violet-400); box-shadow: 0 0 0 3px rgba(124,58,237,0.2); }
.waitlist-ok {
  display: flex; gap: 12px; align-items: flex-start;
  background: rgba(16,185,129,0.08);
  border: 1px solid rgba(16,185,129,0.25);
  border-radius: 12px;
  padding: 14px 16px;
  width: 100%;
}
.waitlist-ok .check {
  flex: none;
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(16,185,129,0.2);
  color: #10B981;
  display: inline-flex; align-items: center; justify-content: center;
  font: 600 14px 'Inter';
}
.waitlist-ok strong { color: white; display: block; margin-bottom: 2px; }
.waitlist-ok p { margin: 0; font-size: 13px; color: rgba(255,255,255,0.65); line-height: 1.5; }
.waitlist-ok p em { font-style: normal; color: rgba(255,255,255,0.85); font-weight: 500; }
.waitlist-fine {
  font-size: 12px;
  color: rgba(255,255,255,0.45);
  margin-top: auto;
  padding-top: 8px;
}
.waitlist-fine a { color: var(--violet-300); text-decoration: none; }
.waitlist-fine a:hover { color: white; }
.slider-wrap {
  display: flex; flex-direction: column; gap: 8px;
}
.slider-row {
  display: flex; align-items: center; justify-content: space-between;
  font: 500 12px var(--font-mono); color: rgba(255,255,255,0.7);
}
.slider-row .val { color: white; font-size: 15px; font-family: var(--font-display); }
.slider-row .val strong { color: var(--violet-300); font-weight: 500; }
.slider {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 4px; border-radius: 999px;
  background: rgba(255,255,255,0.12);
  outline: none; cursor: pointer;
}
.slider::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 18px; height: 18px; border-radius: 50%;
  background: white; border: 4px solid var(--violet-500);
  box-shadow: 0 0 0 3px rgba(124,58,237,0.2);
  cursor: pointer;
}
.slider::-moz-range-thumb {
  width: 18px; height: 18px; border-radius: 50%;
  background: white; border: 4px solid var(--violet-500); cursor: pointer;
}

.calc-out {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  padding: 28px;
  display: flex; flex-direction: column; gap: 20px;
}
.calc-out-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.calc-out-head .t {
  font: 500 11px var(--font-mono); color: rgba(255,255,255,0.5);
  letter-spacing: 0.14em; text-transform: uppercase;
}
.calc-out-head .a {
  font: 500 11px var(--font-mono); color: var(--emerald);
  letter-spacing: 0.1em; text-transform: uppercase;
  display: inline-flex; gap: 8px; align-items: center;
}
.calc-out-head .a::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--emerald); box-shadow: 0 0 12px var(--emerald);
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }

.calc-metrics {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px;
}
.calc-metrics.single {
  grid-template-columns: 1fr;
}
.calc-metrics.single .metric.hero-n .n {
  font-size: clamp(56px, 8vw, 96px);
  line-height: 1;
}
@media (max-width: 720px) {
  .calc-metrics { grid-template-columns: 1fr; }
}
.metric {
  display: flex; flex-direction: column; gap: 6px;
  padding: 14px 0;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.metric .n {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(48px, 5.5vw, 68px);
  line-height: 1;
  letter-spacing: -0.03em;
  color: white;
  transition: color 180ms;
  display: inline-flex;
  align-items: baseline;
}
/* Smaller, muted "×" for multiplier-style metrics (e.g. "33×" ROI) */
.metric .n .n-unit {
  font-size: 0.55em;
  color: rgba(255,255,255,0.5);
  margin-left: 4px;
  font-weight: 500;
  letter-spacing: -0.02em;
}
.metric.hero-n .n { color: var(--violet-300); }
.metric .lbl {
  font: 500 12px var(--font-mono);
  letter-spacing: 0.08em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.metric .sub {
  font-size: 13px; color: rgba(255,255,255,0.7);
  line-height: 1.45;
  margin-top: 2px;
}

.calc-cta {
  display: flex; align-items: center; justify-content: space-between;
  gap: 20px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.08);
  flex-wrap: wrap;
}
.calc-cta .msg {
  font: 500 14px 'Inter';
  color: rgba(255,255,255,0.85);
  max-width: 44ch;
  line-height: 1.5;
}
.calc-cta .msg strong { color: white; font-weight: 600; }
.calc-cta .btn-primary { background: white; color: var(--ink-950); }
.calc-cta .btn-primary:hover { background: var(--violet-200); color: var(--ink-950); }

/* ──────── THE LOOP ──────── */
.loop {
  max-width: var(--page); margin: 0 auto;
  padding: 96px var(--gutter);
  text-align: center;
}
.loop .eyebrow { margin-bottom: 20px; }
.loop h2 { max-width: 24ch; margin: 0 auto 20px; }
.loop .sub {
  font-size: 18px; color: var(--slate-600);
  max-width: 54ch; margin: 0 auto 56px;
  line-height: 1.55;
}
.loop-diagram {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  gap: 20px;
  align-items: stretch;
  text-align: left;
}
.loop-step {
  background: white;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 28px 26px;
  display: flex; flex-direction: column; gap: 14px;
  transition: all 240ms var(--ease);
  box-shadow: 0 1px 3px rgba(10,11,18,0.03);
}
.loop-step:hover { border-color: var(--violet-200); box-shadow: 0 16px 40px -16px rgba(124,58,237,0.15); transform: translateY(-2px); }
.loop-step .num {
  font: 500 11px var(--font-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--violet-600);
}
.loop-step h3 { font-size: 22px; color: var(--ink-950); }
.loop-step p {
  font-size: 15px; color: var(--slate-600);
  line-height: 1.55;
}
.loop-step .pill-row {
  display: flex; gap: 6px; flex-wrap: wrap; margin-top: auto;
  padding-top: 14px;
  border-top: 1px dashed var(--border-strong);
}
.pill {
  font: 500 11px var(--font-mono);
  padding: 4px 9px; border-radius: 999px;
  background: var(--canvas);
  color: var(--slate-700);
  border: 1px solid var(--border);
  white-space: nowrap;
}
.pill.em { background: var(--violet-50); color: var(--violet-700); border-color: var(--violet-100); }
.loop-arrow {
  display: flex; align-items: center; justify-content: center;
  color: var(--slate-400);
}
@media (max-width: 960px) {
  .loop-diagram {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .loop-arrow { transform: rotate(90deg); padding: 4px 0; }
}

.loop-step.us {
  background: var(--ink-950);
  color: white; border: none;
  position: relative; overflow: hidden;
}
.loop-step.us::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 300px 200px at 20% 0%, rgba(124,58,237,0.25), transparent 70%);
}
.loop-step.us .num { color: var(--violet-300); position: relative; }
.loop-step.us h3 { color: white; position: relative; }
.loop-step.us p { color: rgba(255,255,255,0.75); position: relative; }
.loop-step.us .pill { background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.85); border-color: rgba(255,255,255,0.12); }
.loop-step.us .pill.em { background: var(--violet-600); color: white; border-color: var(--violet-500); }
.loop-step.us .pill-row { border-top-color: rgba(255,255,255,0.1); position: relative; }

/* ──────── VERTICALS ──────── */
.verticals {
  background: var(--canvas);
  padding: 96px var(--gutter);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.verticals-inner {
  max-width: var(--page); margin: 0 auto;
}
.verticals-head {
  text-align: center;
  margin-bottom: 48px;
}
.verticals-head .eyebrow { margin-bottom: 20px; }
.verticals-head h2 { max-width: 20ch; margin: 0 auto; }
.verticals-sub {
  font-size: 16px;
  color: var(--slate-600);
  max-width: 52ch;
  margin: 16px auto 0;
  line-height: 1.5;
}

.vert-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
@media (max-width: 960px) { .vert-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .vert-grid { grid-template-columns: 1fr; } }

.vert-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 22px 22px 20px;
  display: flex; flex-direction: column; gap: 12px;
  transition: all 240ms var(--ease);
  position: relative;
}
.vert-card:hover {
  border-color: var(--violet-200);
  box-shadow: 0 16px 40px -16px rgba(124,58,237,0.12);
  transform: translateY(-3px);
}
.vert-card-head {
  display: flex; justify-content: space-between; align-items: center;
}
.vert-card .ic-wrap {
  width: 40px; height: 40px; border-radius: 10px;
  background: var(--violet-50);
  color: var(--violet-700);
  display: inline-flex; align-items: center; justify-content: center;
}
.vert-status-chip {
  font: 500 10px var(--font-mono);
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid transparent;
  display: inline-flex; align-items: center; gap: 5px;
}
.vert-status-chip.live {
  background: rgba(16,185,129,0.1);
  color: #047857;
  border-color: rgba(16,185,129,0.2);
}
.vert-status-chip.live::before {
  content: ''; width: 5px; height: 5px; border-radius: 50%;
  background: #10B981;
  box-shadow: 0 0 0 2px rgba(16,185,129,0.25);
}
.vert-status-chip.soon {
  background: rgba(245,158,11,0.1);
  color: #B45309;
  border-color: rgba(245,158,11,0.2);
}
.vert-status-chip.soon::before {
  content: ''; width: 5px; height: 5px; border-radius: 50%;
  background: #F59E0B;
  box-shadow: 0 0 0 2px rgba(245,158,11,0.25);
}
.vert-card h4 {
  font-size: 19px;
  color: var(--ink-950);
  margin: 0;
  letter-spacing: -0.015em;
}
.vert-card .reads {
  font: 500 12px var(--font-mono);
  color: var(--slate-600);
  line-height: 1.55;
}
.vert-card .reads strong { color: var(--violet-700); font-weight: 500; }

/* "Coming soon" card variant — dim the icon/reads, show request-access link */
.vert-card.soon .ic-wrap {
  background: rgba(245,158,11,0.08);
  color: #B45309;
}
.vert-card.soon .reads { color: var(--slate-500); }
.vert-card.soon .reads strong { color: var(--slate-600); }
.vert-waitlist-link {
  font: 500 12px 'Inter', sans-serif;
  color: var(--violet-700);
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 6px;
  padding-top: 8px;
  margin-top: auto;
  border-top: 1px dashed var(--border);
  transition: color 150ms, gap 200ms;
}
.vert-waitlist-link:hover {
  color: var(--violet-900);
  gap: 9px;
}
.vert-waitlist-link svg { stroke-width: 2; }

/* ──────── ROOFING ACQUISITION PAGE ──────── */
.roofing-page {
  min-height: 100vh;
  background:
    radial-gradient(circle at 12% 8%, rgba(124, 58, 237, 0.12), transparent 28%),
    radial-gradient(circle at 88% 3%, rgba(16, 185, 129, 0.1), transparent 24%),
    linear-gradient(180deg, #fff 0%, #f7f7f9 45%, #fff 100%);
  color: var(--ink-900);
  overflow-x: hidden;
}
.roofing-page .btn svg {
  flex: 0 0 auto;
}
.roof-nav {
  position: sticky;
  top: 0;
  z-index: 40;
  max-width: var(--page);
  margin: 0 auto;
  min-height: 72px;
  padding: 14px var(--gutter);
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 24px;
  align-items: center;
  background: rgba(255,255,255,0.82);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--border-hairline);
}
.roof-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--ink-950);
  text-decoration: none;
  font: 700 22px/1 var(--font-display);
}
.roof-brand img {
  width: 34px;
  height: 34px;
  border-radius: 9px;
}
.roof-brand span span {
  color: var(--violet-600);
}
.roof-nav-links {
  justify-self: center;
  display: flex;
  align-items: center;
  gap: 28px;
}
.roof-nav-links a {
  color: var(--slate-600);
  text-decoration: none;
  font: 600 14px/1 var(--font-body);
}
.roof-nav-links a:hover {
  color: var(--ink-900);
}
.roof-kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--violet-700);
  font: 700 11px/1.2 var(--font-mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.roof-kicker span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--violet-600);
  box-shadow: 0 0 0 5px rgba(124,58,237,0.12);
}
.roof-hero {
  max-width: var(--page);
  margin: 0 auto;
  padding: 92px var(--gutter) 72px;
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(420px, 1.05fr);
  gap: 48px;
  align-items: center;
}
.roof-hero-copy h1 {
  margin: 22px 0 20px;
  max-width: 11ch;
  color: var(--ink-950);
  font: 700 clamp(54px, 7vw, 94px)/0.94 var(--font-display);
  letter-spacing: 0;
}
.roof-hero-copy p {
  max-width: 620px;
  margin: 0;
  color: var(--slate-600);
  font-size: 20px;
  line-height: 1.55;
}
.roof-hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 30px;
}
.roof-proof-strip {
  margin-top: 26px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.roof-proof-strip span {
  padding: 8px 11px;
  border: 1px solid rgba(124,58,237,0.18);
  border-radius: 999px;
  background: rgba(255,255,255,0.72);
  color: var(--slate-700);
  font: 700 11px/1 var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.roof-hero-visual {
  position: relative;
  min-height: 640px;
  border: 1px solid rgba(124,58,237,0.18);
  border-radius: 28px;
  overflow: hidden;
  background: var(--ink-950);
  box-shadow: 0 30px 80px -44px rgba(10, 11, 18, 0.35);
}
.roof-hero-visual img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.08) contrast(1.02);
}
.roof-hero-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(10,11,18,0.08), rgba(255,255,255,0.18) 52%, rgba(255,255,255,0.82)),
    radial-gradient(circle at 34% 30%, rgba(124,58,237,0.42), transparent 24%),
    linear-gradient(180deg, transparent 42%, rgba(10,11,18,0.24));
}
.roof-scan-grid {
  position: absolute;
  inset: 56px;
  z-index: 2;
  border: 2px solid rgba(167,139,250,0.88);
  border-radius: 26px;
  transform: rotate(-6deg);
  box-shadow:
    0 0 24px rgba(124,58,237,0.58),
    inset 0 0 32px rgba(124,58,237,0.24);
}
.roof-scan-grid::before,
.roof-scan-grid::after {
  content: "";
  position: absolute;
  inset: 22%;
  border: 1px dashed rgba(255,255,255,0.72);
  border-radius: 20px;
}
.roof-scan-grid::after {
  inset: 42% 18% 18% 34%;
}
.roof-float,
.roof-reply-card {
  position: absolute;
  z-index: 4;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(124,58,237,0.16);
  border-radius: 14px;
  box-shadow: 0 18px 44px -24px rgba(10,11,18,0.38);
  backdrop-filter: blur(16px);
}
.roof-float {
  min-width: 180px;
  padding: 16px 18px;
  display: grid;
  gap: 6px;
}
.roof-float span,
.roof-reply-card p {
  color: var(--slate-500);
  font: 700 11px/1.2 var(--font-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.roof-float strong,
.roof-reply-card strong {
  color: var(--ink-950);
  font-size: 20px;
  line-height: 1.1;
}
.roof-float-a { top: 36px; right: 34px; }
.roof-float-b { top: 176px; left: 34px; }
.roof-float-c { right: 42px; bottom: 180px; }
.roof-reply-card {
  left: 34px;
  right: 34px;
  bottom: 34px;
  padding: 18px;
}
.roof-reply-card div {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--violet-700);
  font: 700 12px var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.roof-reply-card strong {
  display: block;
  margin-top: 12px;
  font-size: 28px;
}
.roof-reply-card p {
  margin: 8px 0 0;
  line-height: 1.4;
}
.live-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--emerald);
  box-shadow: 0 0 0 5px rgba(16,185,129,0.12);
}
.roof-section {
  max-width: var(--page);
  margin: 0 auto;
  padding: 84px var(--gutter);
}
.roof-section-head {
  max-width: 850px;
  margin: 0 auto 38px;
  text-align: center;
}
.roof-section-head.left {
  text-align: left;
  margin: 0;
}
.roof-section-head h2,
.roof-launch-copy h2,
.roof-signup-copy h2 {
  margin: 18px 0 14px;
  color: var(--ink-950);
  font: 700 clamp(38px, 5vw, 68px)/0.98 var(--font-display);
  letter-spacing: 0;
}
.roof-section-head p,
.roof-launch-copy p,
.roof-signup-copy p {
  margin: 0;
  color: var(--slate-600);
  font-size: 18px;
  line-height: 1.6;
}
.roof-problem-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.roof-problem-card,
.roof-signal-card,
.roof-step,
.roof-day-col,
.roof-form {
  background: white;
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: 0 1px 3px rgba(10,11,18,0.04), 0 20px 50px -34px rgba(10,11,18,0.2);
}
.roof-problem-card {
  padding: 22px;
  min-height: 220px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.roof-problem-card span,
.roof-signal-card span {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  display: inline-grid;
  place-items: center;
}
.roof-problem-card span {
  color: var(--slate-500);
  background: var(--slate-100);
}
.roof-problem-card h3,
.roof-signal-card h3,
.roof-step h3 {
  margin: 4px 0 0;
  color: var(--ink-950);
  font: 700 22px/1.1 var(--font-display);
}
.roof-problem-card p,
.roof-signal-card p,
.roof-step p {
  margin: 0;
  color: var(--slate-600);
  font-size: 15px;
  line-height: 1.5;
}
.roof-system-card {
  padding: 46px;
  border-radius: 28px;
  color: white;
  background:
    linear-gradient(120deg, rgba(46,16,101,0.96), rgba(10,11,18,0.98)),
    url("assets/sections/propertyfi-outreach-routing.jpg") center / cover;
  box-shadow: 0 28px 70px -40px rgba(10,11,18,0.5);
}
.roof-system-card .roof-section-head h2,
.roof-system-card .roof-section-head p {
  color: white;
}
.roof-system-card .roof-section-head p {
  color: rgba(255,255,255,0.72);
}
.roof-step-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 34px;
}
.roof-step {
  padding: 22px;
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.12);
  box-shadow: none;
}
.roof-step-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.roof-step-num {
  color: var(--violet-300);
  font: 700 12px var(--font-mono);
  letter-spacing: 0.12em;
}
.roof-step-icon {
  width: 38px;
  height: 38px;
  display: inline-grid;
  place-items: center;
  border-radius: 12px;
  color: var(--violet-200);
  background: rgba(255,255,255,0.1);
}
.roof-step h3 {
  margin-top: 24px;
  color: white;
}
.roof-step p {
  margin-top: 10px;
  color: rgba(255,255,255,0.72);
}
.roof-signal-layout {
  display: grid;
  grid-template-columns: minmax(360px, 0.95fr) minmax(0, 1.05fr);
  gap: 26px;
  align-items: stretch;
}
.roof-signal-image {
  min-height: 560px;
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(124,58,237,0.18);
  background: var(--ink-950);
}
.roof-signal-image img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.roof-signal-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.82)),
    radial-gradient(circle at 52% 42%, rgba(124,58,237,0.48), transparent 30%);
}
.roof-signal-chip {
  position: absolute;
  z-index: 2;
  display: grid;
  gap: 4px;
  min-width: 142px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(124,58,237,0.18);
  background: rgba(255,255,255,0.92);
  box-shadow: 0 18px 42px -24px rgba(10,11,18,0.3);
}
.roof-signal-chip strong {
  color: var(--ink-950);
  font-size: 22px;
}
.roof-signal-chip span {
  color: var(--slate-500);
  font: 700 11px var(--font-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.roof-signal-chip.top { top: 28px; right: 28px; }
.roof-signal-chip.mid { left: 28px; top: 46%; }
.roof-signal-chip.low { right: 30px; bottom: 28px; }
.roof-signal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.roof-signal-card {
  padding: 22px;
  min-height: 172px;
}
.roof-signal-card span {
  color: var(--violet-700);
  background: var(--violet-50);
  box-shadow: inset 0 0 0 1px rgba(124,58,237,0.12);
}
.roof-signal-card h3 {
  margin-top: 18px;
}
.roof-signal-card p {
  margin-top: 8px;
}
.roof-day-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
.roof-day-col {
  overflow: hidden;
}
.roof-day-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 18px 20px;
  color: var(--slate-600);
  background: #FAFAFB;
  border-bottom: 1px solid var(--border);
  font: 700 12px var(--font-mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.roof-day-col.new .roof-day-head {
  color: var(--violet-700);
  background: var(--violet-50);
}
.roof-day-row {
  min-height: 86px;
  padding: 20px;
  display: flex;
  align-items: center;
  color: var(--slate-700);
  font-size: 18px;
  line-height: 1.4;
  border-bottom: 1px solid var(--border);
}
.roof-day-row:last-child {
  border-bottom: none;
}
.roof-day-col.new .roof-day-row {
  color: var(--ink-950);
  font-weight: 650;
  background: linear-gradient(90deg, rgba(124,58,237,0.06), rgba(124,58,237,0.02));
}
.roof-launch,
.roof-signup {
  max-width: var(--page);
  margin: 0 auto;
  padding: 86px var(--gutter);
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(360px, 1fr);
  gap: 36px;
  align-items: center;
}
.roof-launch {
  border-radius: 30px;
}
.roof-launch-copy h2,
.roof-signup-copy h2 {
  max-width: 11ch;
}
.roof-launch-copy .btn {
  margin-top: 28px;
}
.roof-launch-list {
  display: grid;
  gap: 12px;
}
.roof-launch-row {
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 18px;
  align-items: start;
  padding: 20px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: white;
  box-shadow: 0 1px 3px rgba(10,11,18,0.04);
}
.roof-launch-row span {
  color: var(--violet-700);
  font: 700 13px var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.roof-launch-row p {
  margin: 0;
  color: var(--slate-700);
  font-size: 17px;
  line-height: 1.45;
}
.roof-signup {
  margin-top: 36px;
  margin-bottom: 36px;
  padding: 58px;
  color: white;
  background:
    linear-gradient(120deg, rgba(10,11,18,0.98), rgba(46,16,101,0.92)),
    url("assets/sections/propertyfi-results-proof.jpg") center / cover;
  border-radius: 30px;
  overflow: hidden;
}
.roof-signup-copy h2,
.roof-signup-copy p {
  color: white;
}
.roof-signup-copy p {
  color: rgba(255,255,255,0.72);
}
.roof-signup-points {
  display: grid;
  gap: 12px;
  margin-top: 26px;
}
.roof-signup-points span {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: rgba(255,255,255,0.9);
  font: 650 15px var(--font-body);
}
.roof-signup-points svg {
  color: var(--emerald);
}
.roof-form {
  display: grid;
  gap: 14px;
  padding: 24px;
}
.roof-form label {
  display: grid;
  gap: 7px;
  color: var(--slate-600);
  font: 700 11px var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.roof-form input,
.roof-form textarea,
.roof-form select {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 13px 14px;
  background: white;
  color: var(--ink-900);
  font: 500 15px/1.35 var(--font-body);
  outline: none;
}
.roof-form textarea {
  resize: vertical;
}
.roof-form input:focus,
.roof-form textarea:focus,
.roof-form select:focus {
  border-color: var(--violet-500);
  box-shadow: var(--shadow-focus);
}
.roof-form .btn {
  margin-top: 4px;
}
.roof-form-note {
  margin: 0;
  color: var(--slate-500);
  font-size: 12px;
  line-height: 1.45;
}
.roof-form-market {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.roof-form-market span {
  padding: 10px 12px;
  border-radius: 10px;
  background: var(--violet-50);
  color: var(--violet-800);
  font: 700 12px/1.25 var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.roof-form-success {
  align-content: center;
  min-height: 430px;
}
.roof-form-icon {
  width: 54px;
  height: 54px;
  border-radius: 16px;
  display: inline-grid;
  place-items: center;
  color: var(--emerald-deep);
  background: var(--emerald-tint);
}
.roof-form-success h3 {
  margin: 10px 0 0;
  color: var(--ink-950);
  font: 700 30px/1.1 var(--font-display);
}
.roof-form-success p {
  margin: 0;
  color: var(--slate-600);
  font-size: 16px;
  line-height: 1.55;
}
.roof-footer {
  max-width: var(--page);
  margin: 0 auto;
  padding: 32px var(--gutter) 44px;
  display: flex;
  justify-content: space-between;
  gap: 20px;
  color: var(--slate-500);
  font-size: 13px;
}
.roof-footer > span {
  color: var(--ink-950);
  font-weight: 800;
}
.roof-footer span span {
  color: var(--violet-600);
}
.roof-footer a {
  color: var(--slate-600);
  text-decoration: none;
}
.roof-footer a:hover {
  color: var(--violet-700);
}

.roof-hunter {
  padding-top: 92px;
}
.roof-hunter-grid {
  display: grid;
  grid-template-columns: minmax(320px, 0.76fr) minmax(0, 1.24fr);
  gap: 22px;
  align-items: stretch;
}
.roof-market-panel,
.roof-credit-card,
.roof-plan-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: 0 1px 3px rgba(10,11,18,0.04), 0 22px 54px -36px rgba(10,11,18,0.22);
}
.roof-market-panel {
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.roof-market-panel label {
  display: grid;
  gap: 8px;
  color: var(--slate-600);
  font: 700 11px var(--font-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.roof-market-panel select {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 12px;
  color: var(--ink-950);
  background: white;
  font: 650 15px/1.25 var(--font-body);
  outline: none;
}
.roof-market-panel select:focus {
  border-color: var(--violet-500);
  box-shadow: var(--shadow-focus);
}
.roof-market-stat {
  display: grid;
  gap: 8px;
  padding: 18px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--ink-950), #2E1065);
  color: white;
}
.roof-market-stat span,
.roof-map-card span {
  color: rgba(255,255,255,0.7);
  font: 700 11px var(--font-mono);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.roof-market-stat strong {
  font: 750 50px/0.95 var(--font-display);
  letter-spacing: 0;
}
.roof-market-mini {
  display: grid;
  gap: 8px;
}
.roof-market-mini span {
  display: flex;
  align-items: center;
  min-height: 40px;
  padding: 10px 12px;
  border: 1px solid rgba(124,58,237,0.14);
  border-radius: 12px;
  background: var(--violet-50);
  color: var(--violet-800);
  font: 700 12px/1.25 var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.roof-preview-map {
  position: relative;
  min-height: 520px;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(124,58,237,0.18);
  background: var(--ink-950);
}
.roof-preview-map img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.08);
}
.roof-preview-map::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.82), rgba(255,255,255,0.18) 46%, rgba(10,11,18,0.18)),
    radial-gradient(circle at 64% 38%, rgba(124,58,237,0.56), transparent 28%);
}
.roof-map-card {
  position: absolute;
  z-index: 2;
  display: grid;
  gap: 5px;
  width: min(260px, calc(100% - 40px));
  padding: 16px 18px;
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: 16px;
  background: rgba(10,11,18,0.82);
  color: white;
  backdrop-filter: blur(16px);
}
.roof-map-card.top { top: 24px; left: 24px; }
.roof-map-card.bottom { right: 24px; bottom: 24px; }
.roof-map-card strong {
  font: 750 38px/1 var(--font-display);
}
.roof-map-card p {
  margin: 0;
  color: rgba(255,255,255,0.72);
  font-size: 14px;
}
.roof-map-route {
  position: absolute;
  z-index: 2;
  inset: 120px 86px 112px 140px;
  border: 2px solid rgba(167,139,250,0.82);
  border-radius: 44% 56% 38% 62%;
  transform: rotate(-10deg);
  box-shadow: 0 0 28px rgba(124,58,237,0.55), inset 0 0 28px rgba(124,58,237,0.28);
}
.roof-credits {
  padding-top: 72px;
}
.roof-credit-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.roof-credit-card {
  padding: 20px;
  min-height: 178px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 18px;
}
.roof-credit-card div {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: start;
}
.roof-credit-card h3 {
  margin: 0;
  color: var(--ink-950);
  font: 700 22px/1.12 var(--font-display);
}
.roof-credit-card strong {
  flex: 0 0 auto;
  padding: 8px 10px;
  border-radius: 999px;
  background: var(--violet-50);
  color: var(--violet-800);
  font: 800 13px/1 var(--font-mono);
  letter-spacing: 0.02em;
}
.roof-credit-card p {
  margin: 0;
  color: var(--slate-600);
  font-size: 14px;
  line-height: 1.5;
}
.roof-selfserve-pricing {
  padding-top: 72px;
}
.roof-plan-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.roof-plan-card {
  position: relative;
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  min-height: 520px;
}
.roof-plan-card.featured {
  border-color: rgba(124,58,237,0.42);
  box-shadow: 0 0 0 1px rgba(124,58,237,0.18), 0 26px 70px -38px rgba(124,58,237,0.48);
}
.roof-plan-badge {
  align-self: flex-start;
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--emerald-tint);
  color: var(--emerald-deep);
  font: 800 11px/1 var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.roof-plan-card h3 {
  margin: 0;
  color: var(--ink-950);
  font: 750 28px/1 var(--font-display);
}
.roof-plan-price {
  display: flex;
  align-items: end;
  gap: 8px;
}
.roof-plan-price strong {
  color: var(--ink-950);
  font: 750 46px/0.92 var(--font-display);
}
.roof-plan-price span {
  color: var(--slate-500);
  font-size: 13px;
  padding-bottom: 4px;
}
.roof-plan-credits {
  display: grid;
  gap: 8px;
}
.roof-plan-credits span {
  padding: 10px 12px;
  border: 1px solid rgba(124,58,237,0.14);
  border-radius: 10px;
  color: var(--violet-800);
  background: var(--violet-50);
  font: 750 12px/1.25 var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.roof-plan-card ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
  color: var(--slate-700);
  font-size: 14px;
  line-height: 1.35;
}
.roof-plan-card li {
  display: flex;
  gap: 8px;
  align-items: flex-start;
}
.roof-plan-card li svg {
  flex: 0 0 auto;
  color: var(--emerald-deep);
  margin-top: 2px;
}
.roof-plan-card .btn {
  margin-top: auto;
  justify-content: center;
}

@media (max-width: 980px) {
  .roof-nav {
    grid-template-columns: 1fr auto;
  }
  .roof-nav-links {
    display: none;
  }
  .roof-hero,
  .roof-signal-layout,
  .roof-launch,
  .roof-signup {
    grid-template-columns: 1fr;
  }
  .roof-hero {
    padding-top: 64px;
  }
  .roof-hero-copy h1,
  .roof-launch-copy h2,
  .roof-signup-copy h2 {
    max-width: 13ch;
  }
  .roof-step-grid,
  .roof-problem-grid,
  .roof-credit-grid,
  .roof-plan-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .roof-hunter-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .roofing-page {
    width: 100%;
    max-width: 100vw;
  }
  .roof-nav {
    min-height: 64px;
    padding: 12px var(--gutter);
    width: 100%;
    max-width: 100vw;
  }
  .roof-brand {
    font-size: 18px;
  }
  .roof-brand img {
    width: 30px;
    height: 30px;
  }
  .roof-nav .btn {
    display: none;
  }
  .roof-hero,
  .roof-section,
  .roof-launch,
  .roof-signup {
    width: 100%;
    max-width: 100vw;
    min-width: 0;
    overflow: hidden;
    padding-left: 22px;
    padding-right: 22px;
    padding-top: 56px;
    padding-bottom: 56px;
  }
  .roof-hero {
    grid-template-columns: minmax(0, calc(100vw - 44px));
    justify-content: center;
  }
  .roof-hero > *,
  .roof-section > *,
  .roof-launch > *,
  .roof-signup > * {
    min-width: 0;
    max-width: 100%;
  }
  .roof-hero-copy,
  .roof-hero-actions,
  .roof-proof-strip,
  .roof-hero-visual,
  .roof-section-head,
  .roof-problem-grid,
  .roof-step-grid,
  .roof-signal-layout,
  .roof-day-grid,
  .roof-hunter-grid,
  .roof-credit-grid,
  .roof-plan-grid {
    width: calc(100vw - 44px);
    max-width: calc(100vw - 44px);
  }
  .roof-hero-copy h1,
  .roof-section-head h2,
  .roof-launch-copy h2,
  .roof-signup-copy h2 {
    font-size: 42px;
    line-height: 0.98;
    max-width: calc(100vw - 44px);
  }
  .roof-hero-copy p,
  .roof-section-head p,
  .roof-launch-copy p,
  .roof-signup-copy p {
    font-size: 16px;
    max-width: calc(100vw - 44px);
    overflow-wrap: anywhere;
  }
  .roof-hero-actions,
  .roof-hero-actions .btn {
    width: 100%;
  }
  .roof-hero-actions .btn {
    justify-content: center;
  }
  .roof-proof-strip {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
    max-width: 100%;
  }
  .roof-proof-strip span {
    text-align: center;
    min-width: 0;
  }
  .roof-hero-visual {
    width: 100%;
    max-width: 100%;
    min-height: 520px;
    border-radius: 20px;
  }
  .roof-scan-grid {
    inset: 42px 24px 150px;
  }
  .roof-float {
    min-width: 0;
    padding: 13px 14px;
  }
  .roof-float strong {
    font-size: 17px;
  }
  .roof-float-a {
    top: 22px;
    right: 18px;
    left: 18px;
  }
  .roof-float-b {
    top: auto;
    left: 18px;
    bottom: 146px;
  }
  .roof-float-c {
    display: none;
  }
  .roof-reply-card {
    left: 18px;
    right: 18px;
    bottom: 18px;
  }
  .roof-reply-card strong {
    font-size: 23px;
  }
  .roof-problem-grid,
  .roof-step-grid,
  .roof-signal-grid,
  .roof-day-grid,
  .roof-credit-grid,
  .roof-plan-grid {
    grid-template-columns: 1fr;
  }
  .roof-market-stat strong {
    font-size: 42px;
  }
  .roof-preview-map {
    min-height: 430px;
  }
  .roof-map-card.top,
  .roof-map-card.bottom {
    left: 18px;
    right: 18px;
    width: auto;
  }
  .roof-map-card.top {
    top: 18px;
  }
  .roof-map-card.bottom {
    bottom: 18px;
  }
  .roof-map-route {
    inset: 118px 34px 118px;
  }
  .roof-form-market {
    grid-template-columns: 1fr;
  }
  .roof-system-card {
    padding: 28px 18px;
    border-radius: 20px;
  }
  .roof-step {
    padding: 20px;
  }
  .roof-signal-image {
    min-height: 420px;
    border-radius: 18px;
  }
  .roof-signal-chip.top,
  .roof-signal-chip.mid,
  .roof-signal-chip.low {
    left: 18px;
    right: 18px;
  }
  .roof-signal-chip.top {
    top: 18px;
  }
  .roof-signal-chip.mid {
    top: auto;
    bottom: 92px;
  }
  .roof-signal-chip.low {
    bottom: 18px;
  }
  .roof-day-row {
    min-height: auto;
    padding: 18px;
    font-size: 16px;
  }
  .roof-launch-row {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .roof-signup {
    padding: 34px 18px;
    border-radius: 22px;
  }
  .roof-form {
    padding: 18px;
  }
  .roof-footer {
    flex-direction: column;
  }
}

/* ──────── COMPARE ──────── */
.compare {
  max-width: var(--page);
  margin: 0 auto;
  padding: 96px var(--gutter);
}
.compare-inner { display: flex; flex-direction: column; gap: 40px; }
.compare-head { text-align: center; max-width: 820px; margin: 0 auto; }
.compare-head .eyebrow { margin-bottom: 20px; }
.compare-head h2 { margin: 0 auto 16px; max-width: 22ch; }
.compare-sub {
  font-size: 18px;
  color: var(--slate-600);
  line-height: 1.55;
  text-wrap: pretty;
}

.compare-table {
  display: grid;
  grid-template-columns: minmax(140px, 0.9fr) repeat(4, 1fr);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  background: white;
  box-shadow: 0 1px 3px rgba(10,11,18,0.04), 0 24px 60px -32px rgba(10,11,18,0.1);
}
.compare-head-row, .compare-row {
  display: contents;
}

.compare-corner {
  background: #FAFAFB;
  border-bottom: 1px solid var(--border);
}
.compare-col-head {
  padding: 20px 16px 18px;
  background: #FAFAFB;
  border-left: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 6px;
  position: relative;
}
.compare-col-head.us {
  background: linear-gradient(180deg, rgba(124,58,237,0.08), rgba(124,58,237,0.03));
  border-left-color: rgba(124,58,237,0.25);
  padding-top: 38px;
}
.cch-name {
  font: 600 14px 'Inter', sans-serif;
  color: var(--ink-900);
  line-height: 1.3;
}
.compare-col-head.us .cch-name { color: var(--violet-700); }
.cch-sub {
  font-size: 12px;
  color: var(--slate-500);
  line-height: 1.4;
}
.cch-badge {
  position: absolute; top: 10px; right: 10px;
  font: 600 10px var(--font-mono);
  letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--violet-600); color: white;
  padding: 4px 8px; border-radius: 6px;
}

.compare-row-label {
  padding: 16px;
  background: #FAFAFB;
  border-top: 1px solid var(--border);
  font: 500 12px var(--font-mono);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--slate-600);
  display: flex; align-items: center;
}
.compare-row:first-of-type .compare-row-label { border-top: none; }

.compare-cell {
  padding: 16px;
  border-left: 1px solid var(--border);
  border-top: 1px solid var(--border);
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--slate-700);
  display: flex; align-items: flex-start;
}
.compare-row:first-of-type .compare-cell { border-top: none; }
.compare-cell.us {
  background: rgba(124,58,237,0.03);
  border-left-color: rgba(124,58,237,0.15);
  color: var(--ink-900);
  font-weight: 500;
}
.compare-cell.best.us {
  background: rgba(124,58,237,0.06);
}

.compare-mobile {
  display: none;
}

.compare-mobile-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(10,11,18,0.04), 0 18px 44px -32px rgba(10,11,18,0.18);
}
.cm-card-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: center;
  padding: 16px 18px;
  background: #FAFAFB;
  border-bottom: 1px solid var(--border);
}
.cm-num {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: inline-grid;
  place-items: center;
  background: rgba(124,58,237,0.1);
  color: var(--violet-700);
  font: 700 11px var(--font-mono);
  letter-spacing: 0.04em;
}
.cm-card-head h3 {
  margin: 0;
  color: var(--ink-900);
  font: 700 17px/1.25 'Inter', sans-serif;
}
.cm-us {
  padding: 18px;
  background: linear-gradient(180deg, rgba(124,58,237,0.1), rgba(124,58,237,0.035));
  border-bottom: 1px solid rgba(124,58,237,0.16);
}
.cm-us-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--violet-700);
  font: 700 12px var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.cm-us-icon {
  width: 26px;
  height: 26px;
  border-radius: 8px;
  display: inline-grid;
  place-items: center;
  background: white;
  color: var(--violet-700);
  box-shadow: inset 0 0 0 1px rgba(124,58,237,0.16);
}
.cm-us p {
  margin: 10px 0 0;
  color: var(--ink-900);
  font-size: 15px;
  line-height: 1.45;
  font-weight: 600;
}
.cm-alt-list {
  display: grid;
}
.cm-alt {
  display: grid;
  gap: 5px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
}
.cm-alt:last-child {
  border-bottom: none;
}
.cm-alt-name {
  color: var(--slate-500);
  font: 700 11px var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.cm-alt-copy {
  color: var(--slate-700);
  font-size: 14px;
  line-height: 1.45;
}

.compare-foot {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 24px 28px;
  background: #FAFAFB;
  border: 1px solid var(--border);
  border-radius: 14px;
}
.compare-foot-msg {
  font-size: 15px;
  color: var(--slate-700);
  line-height: 1.55;
}
.compare-foot-msg strong { color: var(--ink-900); }

@media (max-width: 720px) {
  .compare-table {
    display: none;
  }
  .compare-mobile {
    display: grid;
    gap: 16px;
  }
  .compare-foot { grid-template-columns: 1fr; padding: 20px; }
}

/* ──────── RESERVE (LOI) ──────── */
.reserve {
  max-width: var(--page);
  margin: 0 auto;
  padding: 96px var(--gutter);
}
.reserve-inner {
  background: var(--ink-950);
  color: white;
  border-radius: 28px;
  padding: 56px 48px;
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
  box-shadow: 0 32px 80px -32px rgba(124,58,237,0.35);
}
.reserve-inner::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 600px 360px at 0% 0%, rgba(124,58,237,0.3), transparent 65%),
    radial-gradient(ellipse 700px 400px at 100% 120%, rgba(139,92,246,0.2), transparent 60%);
}
.reserve-inner > * { position: relative; z-index: 1; }
.reserve-left { display: flex; flex-direction: column; gap: 20px; }
.reserve-left .eyebrow { color: var(--violet-300); }
.reserve-left .eyebrow::before { background: var(--violet-400); box-shadow: 0 0 10px var(--violet-400); }
.reserve-left h2 { color: white; font-size: clamp(32px, 3.4vw, 44px); margin: 0; }
.reserve-left h2 em { color: var(--violet-300); font-style: normal; }
.reserve-left p { color: rgba(255,255,255,0.75); font-size: 16px; line-height: 1.6; }
.reserve-lede { color: rgba(255,255,255,0.75); font-size: 16px; line-height: 1.6; }

.reserve-bullets { list-style: none; padding: 0; margin: 12px 0 0; display: flex; flex-direction: column; gap: 14px; }
.reserve-bullets li {
  display: flex; gap: 14px; align-items: flex-start;
  font-size: 14.5px; color: rgba(255,255,255,0.82);
  line-height: 1.55;
}
.reserve-bullets li strong { color: white; font-weight: 600; display: block; margin-bottom: 2px; }
.rb-n {
  flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px;
  border-radius: 8px;
  background: rgba(124,58,237,0.18);
  border: 1px solid rgba(124,58,237,0.35);
  color: var(--violet-300);
  font: 600 12px var(--font-mono);
  letter-spacing: 0.04em;
}

.reserve-ticker {
  display: flex; align-items: center; gap: 12px;
  margin-top: 12px;
  padding: 12px 14px;
  background: rgba(16,185,129,0.08);
  border: 1px solid rgba(16,185,129,0.22);
  border-radius: 10px;
}
.ticker-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--emerald);
  box-shadow: 0 0 8px var(--emerald);
  animation: pulse 1.6s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }
.ticker-msg { display: flex; flex-direction: column; gap: 1px; }
.ticker-k {
  font: 600 10px var(--font-mono);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--emerald);
}
.ticker-v { font-size: 13px; color: rgba(255,255,255,0.82); line-height: 1.4; }

/* ── Reserve card (form) ── */
.reserve-right { display: flex; }
.reserve-card {
  width: 100%;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 18px;
  padding: 28px;
  display: flex; flex-direction: column; gap: 14px;
  backdrop-filter: blur(12px);
  box-shadow: 0 32px 80px -28px rgba(0,0,0,0.6);
}
.rc-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 12px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.rc-head-l { display: flex; flex-direction: column; gap: 4px; }
.rc-eyebrow {
  font: 500 11px var(--font-mono);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--violet-300);
}
.rc-title { font: 600 17px 'Inter', sans-serif; color: white; }
.rc-pill {
  flex-shrink: 0;
  font: 600 10px var(--font-mono);
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 5px 9px;
  border-radius: 6px;
  background: rgba(16,185,129,0.15);
  border: 1px solid rgba(16,185,129,0.3);
  color: var(--emerald);
}

.rc-field { display: flex; flex-direction: column; gap: 6px; }
.rc-field label {
  font: 500 11px var(--font-mono);
  letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(255,255,255,0.62);
}
.rc-field input, .rc-field select, .rc-field textarea {
  background: rgba(0,0,0,0.3);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 10px;
  padding: 11px 14px;
  color: white;
  font: 500 15px 'Inter', sans-serif;
  letter-spacing: 0;
  outline: none;
  transition: all 160ms;
  width: 100%;
  resize: vertical;
  font-family: 'Inter', sans-serif;
}
.rc-field textarea { min-height: 64px; }
.rc-field input:focus, .rc-field select:focus, .rc-field textarea:focus {
  border-color: var(--violet-400);
  box-shadow: 0 0 0 3px rgba(124,58,237,0.2);
}
.rc-field input::placeholder, .rc-field textarea::placeholder { color: rgba(255,255,255,0.35); }
.rc-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.rc-hint { font-size: 12px; color: rgba(255,255,255,0.5); line-height: 1.4; }

.rc-submit {
  background: white !important;
  color: var(--ink-950) !important;
  margin-top: 6px;
}
.rc-submit:hover { background: var(--violet-200) !important; }
.rc-submit:disabled {
  opacity: 0.72;
  cursor: wait;
}

.rc-error {
  font-size: 12px;
  line-height: 1.45;
  color: #fecaca;
  background: rgba(239,68,68,0.12);
  border: 1px solid rgba(248,113,113,0.22);
  border-radius: 10px;
  padding: 10px 12px;
}

.rc-foot {
  font-size: 12px;
  color: rgba(255,255,255,0.5);
  line-height: 1.55;
  text-align: center;
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 14px;
}

/* ── Reserve success state ── */
.reserve-ok {
  align-items: flex-start;
  text-align: left;
  background: rgba(16,185,129,0.08);
  border-color: rgba(16,185,129,0.28);
}
.rok-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 48px; height: 48px;
  border-radius: 14px;
  background: rgba(16,185,129,0.18);
  border: 1px solid rgba(16,185,129,0.4);
  color: var(--emerald);
  stroke: var(--emerald);
}
.reserve-ok h3 { color: white; font-size: 20px; margin: 0; letter-spacing: -0.02em; }
.reserve-ok p { color: rgba(255,255,255,0.78); font-size: 14.5px; line-height: 1.55; margin: 0; }
.rok-next {
  display: flex; flex-direction: column; gap: 10px;
  margin-top: 8px; width: 100%;
}
.rok-step {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px;
  color: rgba(255,255,255,0.85);
  font-size: 14px;
}
.rok-n {
  flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  width: 26px; height: 26px;
  border-radius: 7px;
  background: rgba(124,58,237,0.2);
  border: 1px solid rgba(124,58,237,0.4);
  color: var(--violet-300);
  font: 600 11px var(--font-mono);
}
.rok-reset {
  color: var(--violet-300);
  font: 600 13px 'Inter', sans-serif;
  text-decoration: none;
  margin-top: 4px;
}
.rok-reset:hover { color: white; }

/* pricing CTA row */
.pc-cta-row { display: flex; gap: 12px; flex-wrap: wrap; }
.pc-cta-row .btn-ghost {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--ink-900);
}
.pc-cta-row .btn-ghost:hover { background: #FAFAFB; }

@media (max-width: 860px) {
  .reserve-inner { grid-template-columns: 1fr; padding: 36px 24px; gap: 32px; }
  .rc-row { grid-template-columns: 1fr; }
  .reserve { padding: 64px var(--gutter); }
  .compare { padding: 64px var(--gutter); }
}

/* ──────── PRICING ──────── */
.pricing {
  max-width: var(--page);
  margin: 0 auto;
  padding: 96px var(--gutter);
}
.pricing-inner { display: flex; flex-direction: column; gap: 40px; }
.pricing-head { text-align: center; max-width: 820px; margin: 0 auto; }
.pricing-head .eyebrow { margin-bottom: 20px; }
.pricing-head h2 { margin: 0 auto 16px; max-width: 22ch; }
.pricing-sub {
  font-size: 18px;
  color: var(--slate-600);
  line-height: 1.55;
  text-wrap: pretty;
}
.pricing-sub strong { color: var(--ink-900); font-weight: 600; }

.pricing-toggle {
  display: inline-flex;
  gap: 6px;
  background: #F4F4F7;
  border: 1px solid var(--border);
  padding: 6px;
  border-radius: 14px;
  margin: 0 auto;
}
.ptg {
  position: relative;
  display: flex; flex-direction: column; align-items: flex-start;
  gap: 2px;
  padding: 10px 18px;
  background: transparent;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  min-width: 180px;
  text-align: left;
  transition: all 200ms var(--ease);
}
.ptg:hover { background: rgba(255,255,255,0.6); }
.ptg.on {
  background: var(--white);
  box-shadow: 0 1px 3px rgba(10,11,18,0.08), 0 4px 12px -6px rgba(10,11,18,0.1);
}
.ptg-k { font: 600 14px 'Inter', sans-serif; color: var(--ink-900); }
.ptg-v { font: 500 11px var(--font-mono); color: var(--slate-500); letter-spacing: 0.08em; text-transform: uppercase; }
.ptg-badge {
  position: absolute; top: -10px; right: 10px;
  font: 600 10px var(--font-mono);
  letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--violet-600); color: white;
  padding: 4px 8px; border-radius: 6px;
}

.pricing-card-wrap { display: flex; justify-content: center; }
.pricing-card {
  width: 100%;
  max-width: 760px;
  background: white;
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 40px;
  display: flex; flex-direction: column; gap: 28px;
  box-shadow: 0 1px 3px rgba(10,11,18,0.04), 0 24px 60px -30px rgba(10,11,18,0.12);
}
.pricing-card.annual {
  border-color: rgba(124,58,237,0.35);
  box-shadow: 0 1px 3px rgba(10,11,18,0.04), 0 32px 80px -28px rgba(124,58,237,0.28);
}
.pc-top { display: flex; flex-direction: column; gap: 10px; }
.pc-label {
  font: 500 11px var(--font-mono);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--violet-600);
}
.pc-price {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 56px;
  line-height: 1;
  color: var(--ink-900);
  letter-spacing: -0.02em;
  display: flex; align-items: baseline; gap: 6px;
}
.pc-price .cur { font-size: 32px; color: var(--slate-500); font-weight: 500; }
.pc-price .per { font-size: 14px; color: var(--slate-500); font-weight: 500; font-family: 'Inter', sans-serif; letter-spacing: 0; margin-left: 8px; }
.pc-tag { font-size: 15px; color: var(--slate-600); }

.pc-lines {
  display: flex; flex-direction: column;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 6px 0;
}
.pc-line {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 24px;
  padding: 14px 0;
  border-bottom: 1px dashed var(--border);
}
.pc-line:last-child { border-bottom: none; }
.pc-line-l { flex: 1; }
.pc-line-k { font: 600 14px 'Inter', sans-serif; color: var(--ink-900); margin-bottom: 2px; }
.pc-line-s { font-size: 13px; color: var(--slate-500); line-height: 1.45; }
.pc-line-v {
  font-family: var(--font-mono);
  font-size: 18px; font-weight: 600;
  color: var(--ink-900);
  white-space: nowrap;
}

.pc-tiers {
  background: #FAFAFB;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
}
.pc-tiers-k {
  font: 500 11px var(--font-mono);
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--slate-500);
  margin-bottom: 10px;
}
.pc-tiers-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.pt { display: flex; flex-direction: column; gap: 2px; }
.pt-k { font-size: 12px; color: var(--slate-600); }
.pt-v { font-family: var(--font-mono); font-size: 16px; font-weight: 600; color: var(--ink-900); }

.pc-proj {
  background: linear-gradient(180deg, rgba(124,58,237,0.04), rgba(124,58,237,0.02));
  border: 1px solid rgba(124,58,237,0.18);
  border-radius: 12px;
  padding: 16px 18px;
}
.pc-proj-k {
  font: 500 11px var(--font-mono);
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--slate-600);
  margin-bottom: 12px;
}
.pc-proj-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.pc-proj-grid > div { display: flex; flex-direction: column; gap: 2px; }
.pc-proj-grid .n {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  color: var(--ink-900);
  letter-spacing: -0.01em;
}
.pc-proj-grid .hi .n { color: var(--violet-600); }
.pc-proj-grid .l { font-size: 11px; color: var(--slate-500); text-transform: uppercase; letter-spacing: 0.06em; font-family: var(--font-mono); font-weight: 500; }

.pc-note {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 12px 14px;
  background: rgba(16,185,129,0.08);
  border: 1px solid rgba(16,185,129,0.22);
  border-radius: 10px;
  font-size: 13px;
  color: var(--ink-900);
  line-height: 1.5;
}
.pc-note svg { stroke: var(--emerald); flex-shrink: 0; margin-top: 3px; }

.pricing-card .btn-lg { align-self: flex-start; }

.pricing-bottom {
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px;
  max-width: 760px; width: 100%; margin: 0 auto;
  padding-top: 16px;
}
.pb-col { display: flex; flex-direction: column; gap: 12px; }
.pb-k {
  display: inline-flex; align-items: center; gap: 8px;
  font: 600 12px var(--font-mono);
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-900);
}
.pb-col:first-child .pb-k svg { stroke: var(--emerald); }
.pb-col:last-child .pb-k svg { stroke: var(--slate-500); }
.pb-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.pb-col li {
  position: relative;
  padding-left: 18px;
  font-size: 14px;
  color: var(--slate-600);
  line-height: 1.5;
}
.pb-col li::before {
  content: ""; position: absolute; left: 0; top: 9px;
  width: 8px; height: 1px; background: var(--slate-400);
}

@media (max-width: 720px) {
  .pricing { padding: 64px var(--gutter); }
  .pricing-card { padding: 28px 22px; }
  .pc-price { font-size: 42px; }
  .pc-proj-grid { grid-template-columns: repeat(2, 1fr); }
  .pc-tiers-row { grid-template-columns: 1fr; }
  .pc-line { flex-direction: column; gap: 6px; }
  .pc-line-v { align-self: flex-end; }
  .pricing-bottom { grid-template-columns: 1fr; gap: 24px; }
  .ptg { min-width: 0; flex: 1; padding: 10px 14px; }
  .ptg-badge { display: none; }
}

/* ──────── PROOF ──────── */
.proof {
  max-width: var(--page); margin: 0 auto;
  padding: 96px var(--gutter);
}
.proof-head {
  text-align: center; margin-bottom: 48px;
}
.proof-head h2 { max-width: 22ch; margin: 0 auto; }
.proof-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 860px) { .proof-grid { grid-template-columns: 1fr; } }

.proof-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 32px 28px;
  display: flex; flex-direction: column; gap: 22px;
}
.proof-metric {
  font-family: var(--font-display); font-weight: 500;
  font-size: 56px;
  line-height: 1;
  color: var(--violet-700);
  letter-spacing: -0.03em;
}
.proof-metric .unit { font-size: 26px; color: var(--slate-500); margin-left: 2px; }
.proof-metric-lbl {
  font: 500 12px var(--font-mono);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--slate-600);
  margin-top: -16px;
}
.proof-quote {
  font-size: 17px;
  color: var(--ink-900);
  line-height: 1.55;
  text-wrap: pretty;
}
.proof-quote em { color: var(--violet-700); }
.proof-foot {
  display: flex; align-items: center; gap: 12px;
  margin-top: auto;
  padding-top: 20px;
  border-top: 1px solid var(--border);
}
.proof-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--violet-600);
  color: white;
  font: 600 13px 'Inter';
  display: inline-flex; align-items: center; justify-content: center;
}
.proof-name { font: 500 14px 'Inter'; color: var(--ink-950); }
.proof-role { font: 400 13px 'Inter'; color: var(--slate-500); }

/* ──────── CTA ──────── */
.cta-band {
  max-width: var(--page); margin: 0 auto 96px;
  padding: 0 var(--gutter);
}
.cta-inner {
  background: var(--ink-950);
  border-radius: 28px;
  padding: 72px 48px;
  text-align: center;
  position: relative; overflow: hidden;
  color: white;
}
.cta-inner::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 800px 400px at 50% 0%, rgba(124,58,237,0.35), transparent 60%),
    radial-gradient(ellipse 500px 300px at 100% 100%, rgba(14,165,233,0.15), transparent 60%);
}
.cta-inner > * { position: relative; }
.cta-inner h2 { color: white; max-width: 20ch; margin: 0 auto 20px; }
.cta-inner .sub {
  font-size: 18px; color: rgba(255,255,255,0.75);
  max-width: 52ch; margin: 0 auto 36px;
  line-height: 1.55;
}
.cta-inner .btn-primary { background: white; color: var(--ink-950); }
.cta-inner .btn-primary:hover { background: var(--violet-200); transform: translateY(-1px); }
.cta-fine {
  font: 500 11px var(--font-mono);
  color: rgba(255,255,255,0.45);
  letter-spacing: 0.14em; text-transform: uppercase;
  margin-top: 20px;
  display: inline-flex; gap: 16px; align-items: center;
}
.cta-fine::before, .cta-fine::after {
  content: ''; width: 24px; height: 1px; background: rgba(255,255,255,0.15);
}

/* ──────── Footer ──────── */
.footer {
  border-top: 1px solid var(--border);
  padding: 32px var(--gutter);
  max-width: var(--page); margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
  font-size: 13px; color: var(--slate-500);
}
.footer-left { display: flex; gap: 10px; align-items: center; }
.footer-left .logo-mark { width: 22px; height: 22px; }
.footer-right { display: flex; gap: 22px; }
.footer-right a { color: var(--slate-500); text-decoration: none; }
.footer-right a:hover { color: var(--ink-900); }

/* ═══════════════════════════════════════════════
   v4 additions — operator value prop
   ═══════════════════════════════════════════════ */

/* ─── Why band (stop doing / start doing) ─── */
.why-band {
  background: linear-gradient(180deg, #fafafb 0%, #ffffff 100%);
  padding: 96px var(--gutter);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.why-inner {
  max-width: var(--page);
  margin: 0 auto;
}
.why-head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 48px;
}
.why-head h2 {
  font-size: clamp(34px, 4vw, 48px);
  margin: 18px 0 14px;
}
.why-head h2 em {
  color: var(--violet-600);
  font-style: normal;
  font-weight: 500;
}
.why-sub {
  font-size: 17px;
  color: var(--slate-600);
  line-height: 1.55;
}
.why-table {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  background: white;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
}
.why-col {
  display: flex;
  flex-direction: column;
}
.why-col-stop {
  background: #fbfafa;
}
.why-col-start {
  background: linear-gradient(180deg, #faf7ff 0%, #f6f1ff 100%);
  border-left: 1px solid var(--border);
}
.why-col-head {
  font: 500 11px var(--font-mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 18px 24px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid var(--border);
}
.why-col-stop .why-col-head {
  color: var(--slate-500);
  background: #f5f4f4;
}
.why-col-start .why-col-head {
  color: var(--violet-700);
  background: linear-gradient(180deg, #f3ecff 0%, #ede3ff 100%);
}
.why-row {
  padding: 20px 24px;
  font-size: 15.5px;
  line-height: 1.5;
  border-bottom: 1px solid var(--border);
  color: var(--ink-900);
}
.why-row:last-child { border-bottom: none; }
.why-col-stop .why-row {
  color: var(--slate-600);
  text-decoration: line-through;
  text-decoration-color: rgba(15,23,42,0.2);
  text-decoration-thickness: 1px;
}
.why-col-start .why-row {
  color: var(--ink-950);
  font-weight: 500;
}
@media (max-width: 720px) {
  .why-head {
    max-width: 100%;
  }
  .why-head h2 {
    font-size: clamp(28px, 7.4vw, 32px);
    max-width: 11ch;
    margin-left: auto;
    margin-right: auto;
  }
  .why-sub {
    max-width: 26ch;
    margin-left: auto;
    margin-right: auto;
  }
  .why-table { grid-template-columns: 1fr; }
  .why-col-start { border-left: none; border-top: 1px solid var(--border); }
  .why-band { padding: 64px var(--gutter); }
}

/* ─── Calc head band ─── */
.calc-head-band {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 40px;
  position: relative;
  z-index: 1;
}
.calc-head-band .eyebrow {
  color: var(--violet-300);
}
.calc-head-band .eyebrow::before {
  background: var(--violet-400);
  box-shadow: 0 0 10px var(--violet-400);
}
.calc-head-band h2 {
  font-size: clamp(32px, 3.6vw, 44px);
  margin: 18px 0 14px;
  color: white;
}
.calc-head-sub {
  font-size: 16.5px;
  color: rgba(255,255,255,0.72);
  line-height: 1.55;
}

/* ─── Calc breakdown (funnel rows) ─── */
.calc-breakdown {
  margin-top: 28px;
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  background: #fafaf9;
}
.bd-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 12px 18px;
  font-size: 14px;
  border-bottom: 1px solid var(--border);
}
.bd-row:last-child { border-bottom: none; }
.bd-lbl {
  color: var(--slate-600);
  font-family: var(--font-mono);
  font-size: 12.5px;
}
.bd-val {
  font-weight: 600;
  color: var(--ink-900);
  font-variant-numeric: tabular-nums;
}
.bd-row-match {
  background: rgba(124, 58, 237, 0.04);
}
.bd-row-match .bd-lbl { color: var(--violet-700); }
.bd-row-final {
  background: linear-gradient(180deg, #f3ecff 0%, #ede3ff 100%);
}
.bd-row-final .bd-lbl { color: var(--violet-700); font-weight: 600; }
.bd-row-final .bd-val { color: var(--violet-700); font-size: 16px; }

/* ─── Slider hint line ─── */
.slider-hint {
  font-size: 12px;
  color: var(--slate-500);
  margin-top: 6px;
  font-family: var(--font-mono);
}
/* Calc dark-panel: slider-hint override for the dark calc surface */
.calc .slider-hint { color: rgba(255,255,255,0.55); }


/* ─── Vertical card — outcome + signal ─── */
.vert-outcome {
  font-size: 15px;
  line-height: 1.45;
  color: var(--ink-900);
  font-weight: 500;
  margin: 8px 0 12px;
  text-wrap: pretty;
}
.vert-signal {
  font: 400 11.5px var(--font-mono);
  color: var(--slate-500);
  letter-spacing: 0.02em;
  padding-top: 10px;
  border-top: 1px dashed var(--border);
  line-height: 1.5;
}
.vert-card.soon .vert-outcome { opacity: 0.8; }

/* ──────── PRICING — Pay As You Grow / annual (simplified) ──────── */
.pc-bullets {
  display: flex; flex-direction: column; gap: 10px;
  padding: 22px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.pc-bullet {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 15px; line-height: 1.5; color: var(--slate-700);
}
.pc-bullet svg {
  color: var(--violet-600);
  flex-shrink: 0;
  margin-top: 4px;
}
.pc-bullet strong { color: var(--ink-900); font-weight: 600; }
.pc-bullet.addon {
  margin-top: 4px;
  padding-top: 14px;
  border-top: 1px dashed rgba(0,0,0,0.1);
  color: var(--slate-500);
  font-size: 13.5px;
}
.pc-bullet.addon svg { color: var(--slate-500); }
.pc-bullet.addon strong { color: var(--ink-900); }
.pricing-card.annual .pc-bullet.addon { border-top-color: rgba(255,255,255,0.14); color: rgba(255,255,255,0.62); }
.pricing-card.annual .pc-bullet.addon svg { color: rgba(255,255,255,0.62); }
.pricing-card.annual .pc-bullet.addon strong { color: white; }
.pricing-sub .sub-note {
  display: block;
  margin-top: 8px;
  font-style: normal;
  font-size: 13px;
  color: var(--slate-500);
}

.pc-good-for {
  font-size: 14px;
  line-height: 1.5;
  color: var(--slate-600);
  padding: 14px 16px;
  background: #FAFAFB;
  border: 1px solid var(--border);
  border-radius: 10px;
}
.pc-good-for .k {
  font: 500 11px var(--font-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-900);
  margin-right: 6px;
}

.pricing-card.annual .pc-bullet svg { color: #10B981; }

/* "Starting at" prefix for annual-tier price */
.pc-price .pc-prefix {
  font-size: 14px;
  color: var(--slate-500);
  font-weight: 500;
  font-family: 'Inter', sans-serif;
  letter-spacing: 0;
  margin-right: 2px;
}

/* ─── Hero secondary CTA (territory reservation hint) ─── */
.hero-ctas-row { display: flex; justify-content: flex-start; margin: 4px 0 24px; }
.hero-second-cta {
  display: inline-flex; align-items: center; gap: 8px;
  font: 500 13px 'Inter', sans-serif; color: var(--slate-600); text-decoration: none;
  padding: 8px 14px; border-radius: 999px;
  background: rgba(255,255,255,0.6); backdrop-filter: blur(6px);
  border: 1px solid var(--border); transition: all 180ms var(--ease);
  line-height: 1.35; max-width: 560px; text-align: left; text-wrap: balance;
}
.hero-second-cta strong { color: var(--violet-700); font-weight: 600; }
.hero-second-cta:hover {
  background: white; border-color: var(--violet-200); color: var(--ink-900);
  box-shadow: 0 8px 24px -12px rgba(124,58,237,0.28);
}
.hero-second-cta svg { stroke: var(--violet-600); flex-shrink: 0; }
.hero-second-cta .pulse-dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--emerald);
  box-shadow: 0 0 0 0 rgba(16,185,129,0.6);
  animation: pulseEmerald 1.8s infinite; flex-shrink: 0;
}
@keyframes pulseEmerald {
  0%   { box-shadow: 0 0 0 0 rgba(16,185,129,0.55); }
  70%  { box-shadow: 0 0 0 8px rgba(16,185,129,0); }
  100% { box-shadow: 0 0 0 0 rgba(16,185,129,0); }
}
@media (prefers-reduced-motion: reduce) { .hero-second-cta .pulse-dot { animation: none; } }

/* ──────── Conversion imagery system ──────── */
.why-visual,
.calc-map-preview,
.compare-visual,
.loop-visual,
.verticals-visual,
.pricing-visual,
.proof-visual,
.reserve-map {
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(124,58,237,0.16);
  box-shadow: 0 24px 70px -42px rgba(10,11,18,0.28);
}
.why-visual img,
.calc-map-preview img,
.loop-visual img,
.verticals-visual img,
.pricing-visual img,
.proof-visual img,
.reserve-map img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.why-visual {
  height: 360px;
  margin: -16px 0 34px;
  background: white;
}
.why-visual::after,
.loop-visual::after,
.pricing-visual::after,
.proof-visual::after,
.reserve-map::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.92) 0%, rgba(255,255,255,0.52) 38%, rgba(255,255,255,0.08) 74%),
    linear-gradient(180deg, rgba(255,255,255,0) 58%, rgba(255,255,255,0.86) 100%);
}
.why-visual-copy,
.why-visual-card,
.calc-map-chip,
.loop-visual-card,
.model-card,
.pricing-visual-card,
.proof-visual-metric,
.reserve-map-card {
  position: absolute;
  z-index: 2;
  border: 1px solid rgba(124,58,237,0.16);
  background: rgba(255,255,255,0.84);
  backdrop-filter: blur(16px) saturate(140%);
  box-shadow: 0 18px 46px -32px rgba(10,11,18,0.5), 0 1px 0 rgba(255,255,255,0.75) inset;
}
.why-visual-copy {
  left: 26px;
  top: 28px;
  max-width: 330px;
  padding: 18px 20px;
  border-radius: 12px;
}
.why-visual-copy span,
.why-visual-card span,
.calc-map-chip span,
.loop-visual-card span,
.model-card span,
.pricing-visual-card span,
.proof-visual-metric span,
.reserve-map-card span {
  display: block;
  font: 600 10px/1.2 var(--font-mono);
  color: var(--slate-500);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.why-visual-copy strong,
.why-visual-card strong,
.calc-map-chip strong,
.loop-visual-card strong,
.model-card strong,
.pricing-visual-card strong,
.reserve-map-card strong {
  display: block;
  margin-top: 6px;
  font: 700 18px/1.2 'Inter';
  color: var(--ink-950);
  letter-spacing: 0;
}
.why-visual-card {
  min-width: 150px;
  padding: 14px 16px;
  border-radius: 10px;
}
.why-visual-card.waste {
  left: 34px;
  bottom: 30px;
}
.why-visual-card.fit {
  right: 34px;
  bottom: 34px;
  border-color: rgba(16,185,129,0.26);
}
.why-visual-card.fit strong {
  color: var(--emerald-deep);
}

.calc-map-preview {
  height: 176px;
  border-color: rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
}
.calc-map-preview::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(10,11,18,0.76) 0%, rgba(10,11,18,0.2) 52%, rgba(10,11,18,0.44) 100%),
    linear-gradient(180deg, rgba(10,11,18,0) 50%, rgba(10,11,18,0.5) 100%);
}
.calc-map-chip {
  border-color: rgba(255,255,255,0.16);
  background: rgba(10,11,18,0.62);
  color: white;
  border-radius: 10px;
  padding: 12px 14px;
}
.calc-map-chip.primary {
  left: 16px;
  bottom: 16px;
}
.calc-map-chip:not(.primary) {
  right: 16px;
  top: 16px;
}
.calc-map-chip span {
  color: rgba(255,255,255,0.56);
}
.calc-map-chip strong {
  color: white;
  font-size: 18px;
}

.compare-visual {
  min-height: 230px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  padding: 22px;
  align-items: end;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.96), rgba(255,255,255,0.7)),
    url("assets/sections/propertyfi-outreach-routing.jpg") center / cover;
}
.compare-channel {
  min-height: 124px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.84);
  backdrop-filter: blur(12px) saturate(130%);
  padding: 16px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  box-shadow: 0 18px 46px -36px rgba(10,11,18,0.42);
}
.compare-channel .channel-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--slate-100);
  color: var(--slate-500);
}
.compare-channel span:last-child {
  font: 700 15px/1.2 'Inter';
  color: var(--ink-900);
}
.compare-channel.cold {
  opacity: 0.7;
}
.compare-channel.winner {
  border-color: rgba(124,58,237,0.32);
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(245,243,255,0.9));
  transform: translateY(-16px);
}
.compare-channel.winner .channel-icon {
  background: var(--violet-600);
  color: white;
}
.compare-channel.winner span:last-child {
  color: var(--violet-700);
}

.loop-visual {
  height: 360px;
  margin: -18px 0 36px;
  text-align: left;
}
.loop-visual::after {
  background:
    linear-gradient(90deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.34) 47%, rgba(255,255,255,0.94) 100%),
    linear-gradient(180deg, rgba(255,255,255,0) 50%, rgba(255,255,255,0.86) 100%);
}
.loop-visual-card {
  min-width: 168px;
  padding: 14px 16px;
  border-radius: 10px;
}
.loop-visual-card.draw { left: 26px; bottom: 28px; }
.loop-visual-card.route { left: 50%; top: 26px; transform: translateX(-50%); }
.loop-visual-card.close { right: 30px; bottom: 36px; }

.verticals-visual {
  height: 390px;
  margin: -12px auto 32px;
  max-width: 980px;
  background: white;
}
.verticals-visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0.28) 54%, rgba(255,255,255,0.94) 100%),
    radial-gradient(ellipse 60% 60% at 50% 50%, rgba(124,58,237,0.05), transparent 70%);
}
.model-card {
  min-width: 154px;
  border-radius: 10px;
  padding: 13px 15px;
}
.model-card.roof {
  right: 26px;
  top: 26px;
  border-color: rgba(124,58,237,0.32);
}
.model-card.roof strong {
  color: var(--violet-700);
}
.model-card.age { right: 64px; top: 120px; }
.model-card.equity { right: 34px; bottom: 88px; }
.model-card.route { right: 230px; bottom: 34px; }

.pricing-visual {
  height: 260px;
  margin: -12px auto 0;
  max-width: 920px;
}
.pricing-visual::after {
  background:
    linear-gradient(90deg, rgba(255,255,255,0.92) 0%, rgba(255,255,255,0.3) 50%, rgba(255,255,255,0.92) 100%),
    linear-gradient(180deg, rgba(255,255,255,0) 52%, rgba(255,255,255,0.9) 100%);
}
.pricing-visual-card {
  width: 250px;
  padding: 16px 18px;
  border-radius: 12px;
}
.pricing-visual-card.left {
  left: 24px;
  bottom: 24px;
}
.pricing-visual-card.right {
  right: 24px;
  top: 24px;
  border-color: rgba(16,185,129,0.26);
}
.pricing-visual-card.right strong {
  color: var(--emerald-deep);
}

.proof-head {
  margin-bottom: 28px;
}
.proof-visual {
  height: 380px;
  margin: 0 0 34px;
}
.proof-visual::after {
  background:
    linear-gradient(90deg, rgba(255,255,255,0.94) 0%, rgba(255,255,255,0.4) 42%, rgba(255,255,255,0.08) 100%),
    linear-gradient(180deg, rgba(255,255,255,0) 62%, rgba(255,255,255,0.88) 100%);
}
.proof-visual-metric {
  min-width: 138px;
  padding: 14px 16px;
  border-radius: 11px;
}
.proof-visual-metric strong {
  display: block;
  font: 700 32px/1 var(--font-display);
  color: var(--violet-700);
  letter-spacing: 0;
}
.proof-visual-metric span {
  margin-top: 4px;
  text-transform: none;
  letter-spacing: 0;
  color: var(--slate-600);
  font-family: 'Inter';
}
.proof-visual-metric.m1 { left: 28px; top: 34px; }
.proof-visual-metric.m2 { left: 64px; bottom: 34px; }
.proof-visual-metric.m3 { right: 34px; bottom: 40px; }

.reserve-map {
  height: 210px;
  border-color: rgba(255,255,255,0.12);
}
.reserve-map::after {
  background:
    linear-gradient(90deg, rgba(10,11,18,0.56), rgba(10,11,18,0.06)),
    linear-gradient(180deg, rgba(10,11,18,0), rgba(10,11,18,0.72));
}
.reserve-map-card {
  left: 16px;
  bottom: 16px;
  right: 16px;
  padding: 14px 16px;
  border-radius: 11px;
  border-color: rgba(255,255,255,0.16);
  background: rgba(10,11,18,0.62);
}
.reserve-map-card span {
  color: rgba(255,255,255,0.58);
}
.reserve-map-card strong {
  color: white;
  font-size: 16px;
}

.cta-inner::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    linear-gradient(90deg, rgba(10,11,18,0.96), rgba(10,11,18,0.82)),
    url("assets/sections/propertyfi-results-proof.jpg") center / cover;
  opacity: 0.5;
}
.cta-inner::before {
  z-index: 1;
}
.cta-inner > * {
  z-index: 2;
}

@media (max-width: 860px) {
  .why-visual,
  .loop-visual,
  .verticals-visual,
  .pricing-visual,
  .proof-visual {
    height: 300px;
  }
  .compare-visual {
    grid-template-columns: repeat(2, 1fr);
    min-height: auto;
  }
  .compare-channel.winner {
    transform: none;
  }
  .pricing-visual-card {
    width: 210px;
  }
}

@media (max-width: 560px) {
  .why-visual,
  .loop-visual,
  .verticals-visual,
  .pricing-visual,
  .proof-visual,
  .reserve-map {
    border-radius: 14px;
  }
  .why-visual {
    height: 280px;
  }
  .why-visual-copy,
  .why-visual-card.waste {
    left: 14px;
    right: 14px;
  }
  .why-visual-copy {
    top: 14px;
    max-width: none;
  }
  .why-visual-copy strong {
    max-width: 22ch;
    font-size: 15px;
  }
  .why-visual-card.waste {
    bottom: 14px;
  }
  .why-visual-card.fit,
  .model-card.age,
  .model-card.equity,
  .model-card.route,
  .proof-visual-metric.m3,
  .pricing-visual-card.left {
    display: none;
  }
  .calc-map-preview {
    height: 150px;
  }
  .calc-map-chip:not(.primary) {
    display: none;
  }
  .compare-visual {
    grid-template-columns: 1fr;
    padding: 14px;
  }
  .compare-channel {
    min-height: 88px;
  }
  .loop-visual {
    height: 280px;
  }
  .loop-visual-card.draw,
  .loop-visual-card.close {
    display: none;
  }
  .loop-visual-card.route {
    left: 14px;
    right: 14px;
    top: auto;
    bottom: 14px;
    transform: none;
  }
  .verticals-visual {
    height: 300px;
  }
  .model-card.roof {
    left: 14px;
    right: 14px;
    top: auto;
    bottom: 14px;
  }
  .pricing-visual {
    height: 230px;
  }
  .pricing-visual-card.right {
    left: 14px;
    right: 14px;
    top: auto;
    bottom: 14px;
    width: auto;
  }
  .proof-visual {
    height: 280px;
  }
  .proof-visual-metric.m1 {
    left: 14px;
    top: 14px;
  }
  .proof-visual-metric.m2 {
    left: 14px;
    bottom: 14px;
  }
}
