/* ============================================================
   REDLINE AUTO PRO — Lean Lead Engine
   Brand: dark charcoal + red accent
   ============================================================ */

/* Safety net: enforce [hidden] attribute across browsers/resets */
[hidden] { display: none !important; }

/* ---------- Tokens ---------- */
:root, [data-theme="dark"] {
  --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm: clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.0625rem);
  --text-lg: clamp(1.125rem, 1rem + 0.6vw, 1.4rem);
  --text-xl: clamp(1.5rem, 1.2rem + 1.25vw, 2.1rem);
  --text-2xl: clamp(2rem, 1.3rem + 2.4vw, 3.4rem);
  --text-hero: clamp(2.6rem, 1.2rem + 5vw, 5.2rem);

  --space-1:.25rem; --space-2:.5rem; --space-3:.75rem; --space-4:1rem;
  --space-5:1.25rem; --space-6:1.5rem; --space-8:2rem; --space-10:2.5rem;
  --space-12:3rem; --space-16:4rem; --space-20:5rem; --space-24:6rem; --space-32:8rem;

  --radius-sm:.375rem; --radius-md:.625rem; --radius-lg:1rem; --radius-xl:1.4rem; --radius-full:9999px;
  --content-wide:1200px; --content-default:980px;

  --font-display: 'Clash Display', 'Arial Black', system-ui, sans-serif;
  --font-body: 'Satoshi', 'Helvetica Neue', system-ui, sans-serif;

  --transition: 200ms cubic-bezier(.16,1,.3,1);

  --accent: #ff2b2b;
  --accent-hover: #ff4d4d;
  --accent-soft: #ff7373;
  --accent-glow: rgba(255,43,43,.32);
}

/* DARK (default) */
[data-theme="dark"], :root {
  --color-bg:#0c0e13;
  --color-surface:#13161d;
  --color-surface-2:#191c24;
  --color-surface-3:#20242e;
  --color-border:#2b303c;
  --color-border-soft:#222732;
  --color-text:#f3f4f6;
  --color-text-muted:#aeb6c7;
  --color-text-faint:#717a8d;
  --rp-badge:#151821;
  --rp-badge-stroke:#3a4050;
  --hero-grid: rgba(255,255,255,.04);
  --shadow-lg: 0 24px 60px rgba(0,0,0,.55);
  --shadow-md: 0 10px 30px rgba(0,0,0,.4);
}

/* LIGHT */
[data-theme="light"] {
  --color-bg:#f4f4f1;
  --color-surface:#ffffff;
  --color-surface-2:#f8f8f5;
  --color-surface-3:#eeeee9;
  --color-border:#dad7ce;
  --color-border-soft:#e6e3da;
  --color-text:#15171d;
  --color-text-muted:#525a68;
  --color-text-faint:#8b93a2;
  --rp-badge:#15171d;
  --rp-badge-stroke:#2b303c;
  --hero-grid: rgba(0,0,0,.045);
  --shadow-lg: 0 24px 60px rgba(20,22,28,.16);
  --shadow-md: 0 10px 30px rgba(20,22,28,.1);
}

/* ---------- Base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth;scroll-padding-top:5rem}
body{min-height:100dvh;line-height:1.6;font-family:var(--font-body);font-size:var(--text-base);
  color:var(--color-text);background:var(--color-bg);transition:background var(--transition),color var(--transition);overflow-x:hidden}
img,svg{display:block;max-width:100%}
ul[role=list],ol[role=list]{list-style:none}
a{color:inherit;text-decoration:none}
button{cursor:pointer;background:none;border:none;color:inherit;font:inherit}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.05;text-wrap:balance;letter-spacing:-.02em}
p{text-wrap:pretty}
.wrap{width:100%;max-width:var(--content-wide);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2.5rem)}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--radius-sm)}
::selection{background:var(--accent-glow);color:var(--color-text)}
@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-weight:700;font-size:var(--text-sm);letter-spacing:.01em;padding:.85rem 1.5rem;border-radius:var(--radius-full);
  transition:all var(--transition);white-space:nowrap}
.btn-sm{padding:.6rem 1.1rem}
.btn-lg{padding:1.05rem 2rem;font-size:var(--text-base)}
.btn-block{width:100%;padding-block:1rem}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 8px 24px var(--accent-glow)}
.btn-accent:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 14px 32px var(--accent-glow)}
.btn-ghost{border:1.5px solid var(--color-border);color:var(--color-text);background:color-mix(in srgb,var(--color-surface) 50%,transparent)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;
  background:color-mix(in srgb,var(--color-bg) 82%,transparent);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--color-border-soft)}
.header-inner{display:flex;align-items:center;gap:var(--space-4);height:4.6rem}
.brand{display:flex;align-items:center;gap:.65rem;flex-shrink:0}
.brand-mark{flex-shrink:0;filter:drop-shadow(0 4px 10px var(--accent-glow))}
.brand-text{font-family:var(--font-display);font-size:1.02rem;letter-spacing:.02em}
.brand-text strong{color:var(--accent);font-style:italic;font-weight:700}
.brand-text em{font-style:italic;font-weight:600}
.nav{display:flex;gap:var(--space-5);margin-left:auto;font-size:var(--text-sm);font-weight:500;color:var(--color-text-muted)}
.nav a{position:relative;padding:.3rem 0;transition:color var(--transition)}
.nav a:hover{color:var(--color-text)}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--accent);transition:width var(--transition)}
.nav a:hover::after{width:100%}
.header-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}
.theme-toggle{width:2.3rem;height:2.3rem;display:grid;place-items:center;border-radius:var(--radius-full);
  border:1px solid var(--color-border);color:var(--color-text-muted);flex-shrink:0}
.theme-toggle:hover{color:var(--accent);border-color:var(--accent)}

/* Hamburger button */
.nav-hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;
  width:2.3rem;height:2.3rem;border-radius:var(--radius-full);border:1px solid var(--color-border);
  color:var(--color-text-muted);flex-shrink:0;transition:color var(--transition),border-color var(--transition)}
.nav-hamburger span{display:block;width:16px;height:2px;background:currentColor;border-radius:2px;
  transition:all var(--transition);transform-origin:center}
.nav-hamburger:hover{color:var(--accent);border-color:var(--accent)}
.nav-hamburger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-hamburger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav drawer */
.mobile-nav{border-top:1px solid var(--color-border-soft);
  background:color-mix(in srgb,var(--color-bg) 98%,transparent);
  backdrop-filter:blur(16px)}
.mobile-nav a{display:block;padding:.9rem clamp(1.1rem,4vw,2.5rem);font-size:var(--text-base);
  font-weight:600;color:var(--color-text-muted);border-bottom:1px solid var(--color-border-soft);
  transition:color var(--transition),background var(--transition)}
.mobile-nav a:last-child{border-bottom:none}
.mobile-nav a:hover{color:var(--color-text);background:var(--color-surface)}

/* ---------- Hero ---------- */
.hero{position:relative;padding-block:clamp(3rem,8vw,6.5rem) clamp(2.5rem,6vw,5rem);overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-grid{position:absolute;inset:0;
  background-image:linear-gradient(var(--hero-grid) 1px,transparent 1px),linear-gradient(90deg,var(--hero-grid) 1px,transparent 1px);
  background-size:54px 54px;mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 30%,transparent 80%)}
.hero-streak{position:absolute;border-radius:var(--radius-full);filter:blur(2px);opacity:.9;transform:rotate(-32deg)}
.streak-1{top:14%;right:-8%;width:60%;height:5px;background:linear-gradient(90deg,transparent,var(--accent),transparent);box-shadow:0 0 30px var(--accent-glow)}
.streak-2{top:24%;right:2%;width:40%;height:2px;background:linear-gradient(90deg,transparent,var(--accent-soft),transparent);opacity:.5}
.hero-inner{position:relative;z-index:1;max-width:920px}
.eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-size:var(--text-xs);font-weight:600;
  text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-muted);
  border:1px solid var(--color-border);background:var(--color-surface);padding:.45rem .9rem;border-radius:var(--radius-full)}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent)}
.hero h1{font-size:var(--text-hero);font-weight:700;margin-top:var(--space-6);font-style:italic}
.hero h1 .hl{color:var(--accent)}
.hero-sub{font-size:var(--text-lg);color:var(--color-text-muted);max-width:60ch;margin-top:var(--space-5)}
.hero-cta{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-8)}

/* ---------- Proof chips ---------- */
.proof-chips{display:flex;flex-wrap:wrap;gap:.4rem var(--space-5);margin-top:var(--space-5);list-style:none}
.proof-chips li{font-size:var(--text-xs);font-weight:600;color:var(--color-text-muted);
  display:inline-flex;align-items:center;gap:.4rem}
.proof-chips li::before{content:"✓";color:var(--accent);font-weight:800}

.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-top:var(--space-10);max-width:760px}
.hero-stats li{border-left:2px solid var(--accent);padding-left:var(--space-4)}
.hero-stats strong{display:block;font-family:var(--font-display);font-size:var(--text-lg);font-weight:700}
.hero-stats span{font-size:var(--text-xs);color:var(--color-text-faint)}

/* ---------- Strip ---------- */
.strip{border-block:1px solid var(--color-border-soft);background:var(--color-surface)}
.strip-inner{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-4) var(--space-8);padding-block:var(--space-5)}
.strip-lead{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.16em;color:var(--color-text-faint);font-weight:600}
.strip-steps{display:flex;flex-wrap:wrap;gap:var(--space-6);font-weight:600;font-size:var(--text-sm)}
.strip-steps li{display:flex;align-items:center;gap:.5rem}
.strip-steps .num{font-family:var(--font-display);color:var(--accent);font-size:var(--text-sm)}

/* ---------- Section scaffolding ---------- */
.section{padding-block:clamp(3rem,7vw,6rem)}
.section-alt{background:var(--color-surface)}
.section-head{max-width:680px;margin-bottom:var(--space-10)}
.kicker{display:inline-block;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.16em;
  font-weight:700;color:var(--accent);margin-bottom:var(--space-3)}
.section-head h2{font-size:var(--text-2xl);font-weight:700;font-style:italic}
.section-head p{color:var(--color-text-muted);margin-top:var(--space-4);font-size:var(--text-base)}

/* ---------- Flow (how it works) ---------- */
.flow{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5)}
.flow-step{position:relative;background:var(--color-surface-2);border:1px solid var(--color-border);
  border-radius:var(--radius-lg);padding:var(--space-8);overflow:hidden}
.flow-step::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--accent),transparent)}
.flow-top{display:flex;align-items:center;justify-content:space-between;color:var(--accent);margin-bottom:var(--space-5)}
.flow-num{font-family:var(--font-display);font-size:2.6rem;font-weight:700;font-style:italic;color:color-mix(in srgb,var(--accent) 30%,var(--color-border))}
.flow-step h3{font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-3)}
.flow-step p{color:var(--color-text-muted);font-size:var(--text-sm)}
.flow-tag{display:inline-block;margin-top:var(--space-5);font-size:var(--text-xs);font-weight:600;
  color:var(--color-text-faint);background:var(--color-surface-3);padding:.35rem .75rem;border-radius:var(--radius-full)}

/* ---------- Two-column form layout ---------- */
.form-two-col{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.form-pitch h2{font-size:var(--text-2xl);font-weight:700;font-style:italic}
.form-contact-alt{margin-top:var(--space-6);font-size:var(--text-sm);color:var(--color-text-muted)}
.form-contact-alt a{color:var(--accent);font-weight:600}
.form-contact-alt a:hover{color:var(--accent-hover)}

/* ---------- City cards ---------- */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5)}
.city-card{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);
  padding:var(--space-6);display:flex;flex-direction:column;transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition)}
.city-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:var(--shadow-md)}
.city-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}
.city-pin{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);
  display:inline-flex;align-items:center;gap:.4rem}
.city-pin::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent)}
.city-rank{font-size:var(--text-xs);color:var(--color-text-faint)}
.city-card h3{font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-3)}
.city-card p{color:var(--color-text-muted);font-size:var(--text-sm);flex:1}
.kw{display:flex;flex-wrap:wrap;gap:.4rem;margin:var(--space-4) 0}
.kw li{font-size:var(--text-xs);color:var(--color-text-faint);background:var(--color-surface-3);
  border:1px solid var(--color-border-soft);padding:.25rem .6rem;border-radius:var(--radius-sm)}
.city-link{font-size:var(--text-sm);font-weight:700;color:var(--accent)}
.city-link:hover{color:var(--accent-hover)}
.city-card-add{border-style:dashed;align-items:flex-start}
.add-mark{font-family:var(--font-display);font-size:2.4rem;color:var(--accent);line-height:1;margin-bottom:var(--space-3)}

/* ---------- Providers / form card (shared) ---------- */
.providers-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.providers-copy h2{font-size:var(--text-2xl);font-weight:700;font-style:italic}
.lede{color:var(--color-text-muted);font-size:var(--text-base);margin:var(--space-4) 0 var(--space-6)}
.check-list{display:flex;flex-direction:column;gap:var(--space-3)}
.check-list li{display:flex;gap:.75rem;font-size:var(--text-sm);color:var(--color-text)}
.ck{flex-shrink:0;width:1.4rem;height:1.4rem;border-radius:50%;display:grid;place-items:center;
  background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent);font-size:.8rem;font-weight:800}
.trust-row{display:flex;flex-wrap:wrap;gap:.5rem}
.trust-chip{font-size:var(--text-xs);font-weight:600;color:var(--color-text-muted);
  border:1px solid var(--color-border);padding:.4rem .8rem;border-radius:var(--radius-full)}
.providers-form-card{background:var(--color-surface-2);border:1px solid var(--color-border);
  border-radius:var(--radius-xl);padding:clamp(1.5rem,3vw,2.4rem);box-shadow:var(--shadow-lg)}
.providers-form-card h3{font-size:var(--text-lg);font-weight:600}
.form-note{font-size:var(--text-xs);color:var(--color-text-faint);margin-top:.35rem;margin-bottom:var(--space-5)}

/* ---------- Form fields ---------- */
.field{margin-bottom:var(--space-4)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}
.field label{display:block;font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  color:var(--color-text-muted);margin-bottom:.4rem}
.req{color:var(--accent)}
.field input,.field select,.field textarea{width:100%;padding:.75rem .9rem;border-radius:var(--radius-md);
  border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);
  font-size:var(--text-sm);font-family:var(--font-body);transition:border-color var(--transition),box-shadow var(--transition);
  appearance:none;-webkit-appearance:none}
.field textarea{resize:vertical;min-height:80px;line-height:1.5}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.field input::placeholder,.field textarea::placeholder{color:var(--color-text-faint)}
.field select{cursor:pointer}

/* Form feedback */
.form-success{margin-top:var(--space-4);font-size:var(--text-sm);font-weight:600;color:#4cb963;
  background:color-mix(in srgb,#4cb963 12%,transparent);border:1px solid color-mix(in srgb,#4cb963 30%,transparent);
  border-radius:var(--radius-md);padding:var(--space-4);text-align:center}
.form-error{margin-top:var(--space-4);font-size:var(--text-sm);color:var(--accent);
  background:color-mix(in srgb,var(--accent) 10%,transparent);border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);
  border-radius:var(--radius-md);padding:var(--space-4);text-align:center}
.form-error a{color:var(--accent);font-weight:700;text-decoration:underline}

/* ---------- Lead board ---------- */
.board{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}
.board-col{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4)}
.col-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);
  padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-soft)}
.col-head h3{font-size:var(--text-sm);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-body)}
.col-count{font-size:var(--text-xs);font-weight:700;color:var(--color-text-faint);background:var(--color-surface-3);
  width:1.6rem;height:1.6rem;border-radius:var(--radius-sm);display:grid;place-items:center}
.lead{background:var(--color-bg);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);
  padding:var(--space-4);margin-bottom:var(--space-3);transition:transform var(--transition),box-shadow var(--transition)}
.lead:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.lead:last-child{margin-bottom:0}
.lead-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}
.lead-svc{font-size:var(--text-xs);font-weight:700;display:inline-flex;align-items:center;gap:.4rem}
.lead-svc::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--color-text-faint)}
.dot-red::before{background:var(--accent)}
.dot-amber::before{background:#f5a623}
.dot-blue::before{background:#4d8fe0}
.dot-green::before{background:#4cb963}
.lead-src{font-size:var(--text-xs);color:var(--color-text-faint);text-align:right}
.lead p{font-size:var(--text-sm);color:var(--color-text);margin-bottom:.5rem}
.lead-time{font-size:var(--text-xs);color:var(--color-text-faint)}
.lead-done{opacity:.78}

/* ---------- Operator section ---------- */
.op-quickbar{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2) var(--space-3);
  margin-bottom:var(--space-8);padding:var(--space-4) var(--space-5);
  background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg)}
.op-quickbar-label{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  color:var(--color-text-faint);margin-right:var(--space-2)}
.op-quicklink{font-size:var(--text-sm);font-weight:600;color:var(--accent);padding:.35rem .75rem;
  border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);border-radius:var(--radius-full);
  transition:all var(--transition)}
.op-quicklink:hover{background:color-mix(in srgb,var(--accent) 12%,transparent);border-color:var(--accent)}
.operator-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.operator-intro h2{font-size:var(--text-2xl);font-weight:700;font-style:italic}
.progress-wrap{margin-top:var(--space-6)}
.progress-bar{height:8px;border-radius:var(--radius-full);background:var(--color-surface-3);overflow:hidden}
.progress-fill{height:100%;width:0;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--accent),var(--accent-soft));transition:width 350ms cubic-bezier(.16,1,.3,1)}
.progress-label{display:inline-block;margin-top:var(--space-3);font-size:var(--text-xs);font-weight:600;color:var(--color-text-muted)}
.op-list{display:flex;flex-direction:column;gap:var(--space-3)}
.op-item{display:flex;gap:var(--space-4);align-items:flex-start;background:var(--color-surface-2);
  border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);transition:border-color var(--transition)}
.op-item.done{border-color:color-mix(in srgb,var(--accent) 45%,var(--color-border))}
.op-check{flex-shrink:0;margin-top:.15rem}
.op-check .box{display:block;width:1.5rem;height:1.5rem;border-radius:var(--radius-sm);
  border:2px solid var(--color-border);position:relative;transition:all var(--transition)}
.op-check[aria-pressed=true] .box{background:var(--accent);border-color:var(--accent)}
.op-check[aria-pressed=true] .box::after{content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;
  border:solid #fff;border-width:0 2.5px 2.5px 0;transform:rotate(45deg)}
.op-item h3{font-size:var(--text-base);font-weight:600;margin-bottom:.25rem;font-family:var(--font-body)}
.op-item.done h3{text-decoration:line-through;color:var(--color-text-muted)}
.op-item p{font-size:var(--text-sm);color:var(--color-text-muted)}

/* ---------- Timeline ---------- */
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5);position:relative}
.tl-item{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);
  padding:var(--space-6);position:relative}
.tl-item::before{content:"";position:absolute;top:-1px;left:var(--space-6);right:var(--space-6);height:3px;
  background:var(--color-border)}
.tl-item:first-child::before{background:var(--accent)}
.tl-phase{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-faint)}
.tl-item h3{font-size:var(--text-lg);font-weight:600;margin:var(--space-3) 0}
.tl-item p{font-size:var(--text-sm);color:var(--color-text-muted)}
.tl-pill{display:inline-block;margin-top:var(--space-5);font-size:var(--text-xs);font-weight:600;
  color:var(--color-text-muted);border:1px solid var(--color-border);padding:.35rem .7rem;border-radius:var(--radius-full)}
.pill-live{color:var(--accent);border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;padding-block:clamp(3.5rem,8vw,6rem);
  background:linear-gradient(135deg,#191c24,#0c0e13);border-block:1px solid var(--color-border)}
[data-theme="light"] .cta-band{background:linear-gradient(135deg,#15171d,#23262f)}
.cta-band::before{content:"";position:absolute;top:-30%;right:-10%;width:50%;height:160%;transform:rotate(-30deg);
  background:linear-gradient(90deg,transparent,var(--accent-glow),transparent)}
.cta-inner{position:relative;text-align:center;max-width:720px;margin-inline:auto;color:#f3f4f6}
.cta-inner h2{font-size:var(--text-2xl);font-weight:700;font-style:italic}
.cta-inner p{color:#aeb6c7;margin:var(--space-4) 0 var(--space-8)}
.cta-inner .hero-cta{justify-content:center}
.cta-band .btn-ghost{color:#f3f4f6;border-color:rgba(243,244,246,.35)}
.cta-band .btn-ghost:hover{color:#fff;border-color:rgba(243,244,246,.75);background:rgba(255,255,255,.06);transform:translateY(-2px)}

/* ---------- Footer ---------- */
.site-footer{background:var(--color-bg);border-top:1px solid var(--color-border);padding-block:var(--space-10)}
.footer-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-6)}
.footer-brand{display:flex;align-items:center;gap:var(--space-4)}
.footer-name{font-family:var(--font-display);font-weight:700;font-style:italic;font-size:var(--text-lg)}
.footer-tag{font-size:var(--text-xs);color:var(--color-text-faint);max-width:46ch;margin-top:.2rem}
.footer-contact{font-size:var(--text-sm);margin-top:var(--space-2)}
.footer-contact a{color:var(--accent);font-weight:600}
.footer-contact a:hover{color:var(--accent-hover)}
.footer-note{font-size:var(--text-xs);color:var(--color-text-faint);max-width:38ch}

/* ---------- Revenue / pricing ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5);align-items:stretch}
.price-card{position:relative;background:var(--color-surface-2);border:1px solid var(--color-border);
  border-radius:var(--radius-lg);padding:var(--space-8);display:flex;flex-direction:column}
.price-card-feature{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 18px 44px var(--accent-glow);background:var(--color-surface-3)}
.price-stage{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-faint)}
.price-card-feature .price-stage{color:var(--accent)}
.price-card h3{font-size:var(--text-lg);font-weight:600;margin:var(--space-3) 0 var(--space-4);font-family:var(--font-body)}
.price-amt{font-family:var(--font-display);font-style:italic;font-weight:700;font-size:var(--text-xl);color:var(--color-text);line-height:1}
.price-amt span{font-family:var(--font-body);font-style:normal;font-weight:600;font-size:var(--text-sm);color:var(--color-text-faint)}
.price-desc{color:var(--color-text-muted);font-size:var(--text-sm);margin:var(--space-4) 0 var(--space-5)}
.price-feat{display:flex;flex-direction:column;gap:.55rem;margin-top:auto}
.price-feat li{position:relative;padding-left:1.4rem;font-size:var(--text-sm);color:var(--color-text)}
.price-feat li::before{content:"";position:absolute;left:0;top:.45rem;width:8px;height:8px;border-radius:50%;
  background:color-mix(in srgb,var(--accent) 30%,transparent);border:2px solid var(--accent)}
.price-flag{display:inline-block;margin-top:var(--space-5);align-self:flex-start;font-size:var(--text-xs);font-weight:700;
  color:#fff;background:var(--accent);padding:.4rem .8rem;border-radius:var(--radius-full)}
.price-foot{text-align:center;margin-top:var(--space-8);font-size:var(--text-sm);color:var(--color-text-muted)}
.price-foot strong{color:var(--color-text)}

/* ---------- Partner profiles ---------- */
.partner-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5)}
.partner-card{position:relative;background:var(--color-surface-2);border:1px solid var(--color-border);
  border-radius:var(--radius-lg);padding:var(--space-6);display:flex;flex-direction:column}
.partner-featured{border-color:var(--accent)}
.partner-badge{position:absolute;top:-.7rem;left:var(--space-6);font-size:var(--text-xs);font-weight:700;color:#fff;
  background:var(--accent);padding:.3rem .7rem;border-radius:var(--radius-full);box-shadow:0 6px 16px var(--accent-glow)}
.partner-head{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-5)}
.partner-featured .partner-head{margin-top:var(--space-3)}
.partner-avatar{flex-shrink:0;width:3rem;height:3rem;border-radius:var(--radius-md);display:grid;place-items:center;
  font-family:var(--font-display);font-style:italic;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),#b51d1d)}
.avatar-alt{background:linear-gradient(135deg,#3a4050,#20242e);color:var(--color-text)}
.avatar-empty{background:transparent;border:2px dashed var(--color-border);color:var(--accent);font-size:1.6rem}
.partner-card h3{font-size:var(--text-base);font-weight:700;font-family:var(--font-body)}
.partner-meta{font-size:var(--text-xs);color:var(--color-text-faint);margin-top:.15rem}
.partner-stats{display:flex;flex-wrap:wrap;gap:var(--space-4);padding:var(--space-4) 0;border-block:1px solid var(--color-border-soft);font-size:var(--text-xs);color:var(--color-text-muted)}
.partner-stats strong{font-family:var(--font-display);font-style:italic;color:var(--color-text);margin-right:.2rem}
.partner-stats .verified{color:#4cb963;font-weight:700}
.partner-quote{font-size:var(--text-sm);color:var(--color-text-muted);font-style:italic;margin-top:var(--space-4)}
.partner-empty{align-items:flex-start;border-style:dashed}
.partner-empty .partner-avatar{margin-bottom:var(--space-3)}
.partner-empty .city-link{margin-top:var(--space-3)}

/* ---------- Capture / follow-up ---------- */
.capture-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.capture-copy h2{font-size:var(--text-2xl);font-weight:700;font-style:italic}
.capture-list{display:flex;flex-direction:column;gap:var(--space-5);margin-top:var(--space-2)}
.capture-list li{display:flex;gap:var(--space-4)}
.cap-ic{flex-shrink:0;width:2.6rem;height:2.6rem;border-radius:var(--radius-md);display:grid;place-items:center;
  font-size:1.2rem;background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}
.capture-list strong{display:block;font-size:var(--text-base);margin-bottom:.2rem}
.capture-list p{font-size:var(--text-sm);color:var(--color-text-muted)}
.capture-panel{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-xl);
  padding:clamp(1.4rem,3vw,2rem);box-shadow:var(--shadow-lg)}
.panel-kicker{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.12em;font-weight:700;
  color:var(--color-text-faint);margin-bottom:var(--space-4)}
.prompt-list{display:flex;flex-direction:column;gap:var(--space-3)}
.prompt{display:flex;gap:var(--space-3);align-items:flex-start;background:var(--color-bg);border:1px solid var(--color-border-soft);
  border-radius:var(--radius-md);padding:var(--space-4)}
.prompt-dot{flex-shrink:0;width:10px;height:10px;border-radius:50%;background:var(--color-text-faint);margin-top:.4rem}
.prompt-due{border-left:3px solid var(--accent)}
.prompt-due .prompt-dot{background:var(--accent);box-shadow:0 0 8px var(--accent);animation:pulse 2s infinite}
.prompt-review{border-left:3px solid #f5a623}
.prompt-review .prompt-dot{background:#f5a623}
.prompt strong{display:block;font-size:var(--text-sm)}
.prompt span{font-size:var(--text-xs);color:var(--color-text-faint)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ---------- Lead status tags + source legend ---------- */
.lead-foot{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.4rem}
.status-tag{font-size:var(--text-xs);font-weight:700;padding:.25rem .55rem;border-radius:var(--radius-sm)}
.status-booked{color:#4cb963;background:color-mix(in srgb,#4cb963 16%,transparent)}
.status-notbooked{color:var(--color-text-faint);background:var(--color-surface-3)}
.status-review{color:#f5a623;background:color-mix(in srgb,#f5a623 16%,transparent)}
.source-legend{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;margin-top:var(--space-8);
  padding-top:var(--space-6);border-top:1px solid var(--color-border-soft)}
.legend-label{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-faint)}
.legend-chip{font-size:var(--text-xs);font-weight:600;color:var(--color-text-muted);background:var(--color-surface-3);
  border:1px solid var(--color-border-soft);padding:.3rem .7rem;border-radius:var(--radius-full)}
.legend-note{flex-basis:100%;font-size:var(--text-xs);color:var(--color-text-faint);margin-top:.3rem}

/* ---------- Reveal animation
   KEY: only hide after .js-ready is set. Without JS, everything stays visible.
   ---------- */
.js-ready .reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s cubic-bezier(.16,1,.3,1)}
.js-ready .reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .nav{display:none}
  .nav-hamburger{display:flex}
  .desktop-cta{display:none}
  .flow,.card-grid,.timeline,.price-grid,.partner-grid{grid-template-columns:repeat(2,1fr)}
  .form-two-col,.providers-grid,.operator-grid,.capture-grid{grid-template-columns:1fr}
  .board{grid-template-columns:repeat(2,1fr)}
  .price-card-feature{grid-column:1 / -1}
}
@media (max-width:600px){
  .section{padding-block:clamp(1.75rem,5vw,3rem)}
  .hero-stats{grid-template-columns:repeat(2,1fr);margin-top:var(--space-8)}
  .flow,.card-grid,.timeline,.board,.price-grid,.partner-grid{grid-template-columns:1fr}
  .price-card-feature{grid-column:auto}
  .field-row{grid-template-columns:1fr}
  .strip-inner{gap:var(--space-3)}
  .section-head{margin-bottom:var(--space-6)}
  .op-quickbar{gap:var(--space-2)}
  .proof-chips{gap:.35rem var(--space-4)}
}
@media (max-width:480px){
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{width:100%;justify-content:center}
}
