/* ============================================================
   EASY RIDE CANADA — shared.css
   Single cached stylesheet for all 48 pages.
   Replaces inline <style> blocks that were duplicated per-page.
   Version: 2.0 | Optimized for PageSpeed 90+
   ============================================================ */

/* ── SELF-HOSTED FONTS ─────────────────────────────────────── */
@font-face{font-family:'Manrope';src:url('/fonts/Manrope-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap;ascent-override:90%;descent-override:25%;line-gap-override:0%;size-adjust:100%}
@font-face{font-family:'Manrope';src:url('/fonts/Manrope-SemiBold.woff2') format('woff2');font-weight:600;font-style:normal;font-display:optional;ascent-override:90%;descent-override:25%;line-gap-override:0%;size-adjust:100%}
@font-face{font-family:'Manrope';src:url('/fonts/Manrope-Bold.woff2') format('woff2');font-weight:700;font-style:normal;font-display:optional;ascent-override:90%;descent-override:25%;line-gap-override:0%;size-adjust:100%}
@font-face{font-family:'Cormorant';src:url('/fonts/Cormorant-Bold.woff2') format('woff2');font-weight:700;font-style:normal;font-display:optional;ascent-override:85%;descent-override:22%;line-gap-override:0%;size-adjust:107%}

/* ── RESET & BASE ──────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
*{-webkit-tap-highlight-color:transparent}
a,button,input,select,textarea{touch-action:manipulation}
img{max-width:100%;height:auto}

/* ── CSS VARIABLES ─────────────────────────────────────────── */
:root{
  --red:#D0102A;
  --black:#0e0e0e;
  --grey:#444444;
  --light:#f4f4f2;
  --border:#e4e4e4;
  --white:#ffffff;
}

/* ── HTML & BODY ───────────────────────────────────────────── */
/* NOTE: Removed zoom:0.9 — non-standard property that breaks
   accessibility zoom, causes CLS, and is penalised by PageSpeed.
   Replaced with explicit font-size on body where needed. */
html{scroll-behavior:smooth}
body{
  font-family:'Manrope',sans-serif;
  background:var(--white);
  color:var(--black);
  overflow-x:hidden;
  text-rendering:optimizeSpeed;
  -webkit-font-smoothing:antialiased;
}

/* ── PERFORMANCE: PAINT CONTAINMENT ───────────────────────── */
nav,.urgency-bar,.topbar{contain:layout style}

/* ── STICKY NAV HIDE-ON-SCROLL ─────────────────────────────── */
.urgency-bar,.topbar,nav{transition:transform .3s ease}
html.nav-hidden .urgency-bar,
html.nav-hidden .topbar,
html.nav-hidden nav{transform:translateY(-200px)}

/* ── URGENCY BAR ───────────────────────────────────────────── */
.urgency-bar{
  height:38px;
  background:linear-gradient(100deg,#1a0408 0%,#6b0618 28%,#D0102A 58%,#e8253d 80%,#c4102a 100%);
  display:flex;align-items:center;justify-content:center;
  padding:0 20px;
  position:sticky;top:0;left:0;right:0;
  z-index:902;
  gap:6px;
  box-shadow:0 1px 0 rgba(255,255,255,0.06) inset,0 2px 12px rgba(208,16,42,0.35);
}
.urgency-bar span{font-size:11.5px;font-weight:600;color:#fff;letter-spacing:0.3px;white-space:nowrap}
.urgency-bar .ub-sep{color:rgba(255,255,255,0.4);margin:0 6px}
@media(max-width:768px){.urgency-bar{display:none}}

/* ── TOP BAR ───────────────────────────────────────────────── */
/* Desktop: sits below urgency bar (top:38px)
   Mobile:  urgency bar hidden, so topbar sits at top:0 */
.topbar{
  height:32px;background:#080808;
  display:flex;align-items:center;justify-content:flex-end;
  padding:0 52px;
  position:sticky;top:38px;left:0;right:0;
  z-index:901;
}
@media(max-width:768px){
  .topbar{top:0;padding:0 20px}
}
.topbar-right{display:flex;align-items:center;gap:0}
.topbar-social{display:flex;align-items:center}
.topbar-social a{
  color:rgba(255,255,255,0.6);text-decoration:none;
  transition:color 0.18s;display:flex;align-items:center;
  padding:0 12px;height:32px;
  border-right:1px solid rgba(255,255,255,0.06);
}
.topbar-social a:hover{color:rgba(255,255,255,0.85)}
.topbar-phone{
  font-size:11px;font-weight:600;color:rgba(255,255,255,0.7);
  text-decoration:none;display:flex;align-items:center;gap:7px;
  letter-spacing:0.8px;text-transform:uppercase;
  padding:0 0 0 16px;height:32px;transition:color 0.18s;
}
.topbar-phone:hover{color:rgba(255,255,255,0.85)}
@media(max-width:768px){.topbar-social a{padding:0 10px}}

/* ── NAV ───────────────────────────────────────────────────── */
/* Desktop: below urgency(38) + topbar(32) = top:70px
   Mobile:  below topbar only = top:32px */
nav{
  position:sticky;top:70px;left:0;right:0;
  height:64px;
  display:flex;align-items:center;justify-content:center;
  padding:0 52px;
  background:rgba(255,255,255,0.98);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(0,0,0,0.08);
  z-index:900;
}
@media(max-width:768px){
  nav{top:32px;padding:0 24px}
}
.nav-inner{
  max-width:1100px;width:100%;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
}

/* ── LOGO ──────────────────────────────────────────────────── */
.logo{text-decoration:none;display:flex;align-items:center;gap:10px}
.logo-mark{display:flex;align-items:center;gap:0}
/* Maple leaf logo: 32×26 viewBox (wider than tall) */
.logo-icon{width:30px;height:24px;flex-shrink:0}
.logo-text{display:flex;flex-direction:column;line-height:1;gap:1px}
.logo-wordmark{font-family:'Cormorant',serif;font-size:18px;font-weight:900;color:var(--black);letter-spacing:-0.5px;line-height:1}
.logo-sub{font-size:8px;font-weight:700;letter-spacing:3.5px;text-transform:uppercase;color:var(--red);line-height:1}

/* ── NAV LINKS ─────────────────────────────────────────────── */
.nav-links{display:flex;align-items:center;gap:18px}
.nav-links a{text-decoration:none;color:#595959;font-size:11.5px;font-weight:500;letter-spacing:0.15px;transition:color 0.18s}
.nav-links a:hover{color:var(--black)}
.nav-cta{
  background:linear-gradient(135deg,#ff1f3a 0%,#D0102A 50%,#9e0a1e 100%) !important;
  color:#fff !important;
  padding:9px 20px !important;
  font-size:12px !important;font-weight:600 !important;
  letter-spacing:0.5px !important;text-transform:uppercase !important;
  transition:all 0.2s !important;
  box-shadow:0 2px 10px rgba(208,16,42,0.3) !important;
}
.nav-cta:hover{
  background:linear-gradient(135deg,#ff3d55 0%,#c4102a 50%,#800a18 100%) !important;
  color:#fff !important;transform:translateY(-1px) !important;
  box-shadow:0 4px 16px rgba(208,16,42,0.45) !important;
}
@media(max-width:768px){.nav-links{display:none !important}}

/* ── MOBILE NAV TOGGLE ─────────────────────────────────────── */
.mob-btn{
  display:none;background:none;border:none;cursor:pointer;
  padding:4px;flex-direction:column;gap:5px;z-index:910;
}
.mob-btn span{display:block;width:22px;height:2px;background:var(--black)}
@media(max-width:768px){.mob-btn{display:flex}}

/* ── MOBILE NAV OVERLAY ────────────────────────────────────── */
.mob-nav{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(255,255,255,0.98);backdrop-filter:blur(12px);
  z-index:950;flex-direction:column;align-items:center;justify-content:center;
  gap:28px;padding:40px;
}
.mob-nav.open{display:flex}
.mob-nav a{font-size:20px;font-weight:600;color:var(--black);text-decoration:none;transition:color 0.2s}
.mob-nav a:hover{color:var(--red)}
.mob-nav .mob-cta{background:var(--red);color:#fff !important;padding:14px 32px;font-size:15px;font-weight:700;letter-spacing:0.5px;margin-top:12px}
.mob-nav .mob-cta-big{background:var(--red);color:#fff !important;padding:14px 36px;font-size:15px;font-weight:700;letter-spacing:0.4px;text-transform:uppercase;margin-top:12px;font-family:'Manrope',sans-serif;text-decoration:none;transition:background .2s}
.mob-nav .mob-cta-big:hover{background:#b00d24}
.mob-close{position:absolute;top:20px;right:24px;background:none;border:none;font-size:28px;cursor:pointer;color:var(--black)}

/* ── PAGE HERO ─────────────────────────────────────────────── */
/* Desktop top offset: urgency(38) + topbar(32) + nav(64) = 134px padding-top
   Using clamp to be safe across zoom levels. */
.page-hero{padding:140px 52px 80px;background:var(--white);border-bottom:1px solid var(--border)}
.page-hero-inner{max-width:800px}
@media(max-width:768px){.page-hero{padding:120px 24px 56px}}

.back-link{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--grey);text-decoration:none;margin-bottom:36px;font-weight:500;transition:color 0.2s}
.back-link:hover{color:var(--black)}

.hero-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.hero-eyebrow .line{width:28px;height:2px;background:var(--red);flex-shrink:0}
.hero-eyebrow span{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--grey)}
.hero-note{font-size:11px;color:#777;margin-top:12px;letter-spacing:.3px}
.hero-actions{margin-top:24px;margin-bottom:8px}
.content-body p{font-size:15px;color:#333;line-height:1.85;font-weight:400;margin-bottom:20px}

.page-hero h1{
  font-family:'Cormorant',serif;
  font-size:clamp(34px,4vw,58px);
  font-weight:900;line-height:1.05;letter-spacing:-1.5px;
  color:var(--black);margin-bottom:24px;
}
.page-hero h1 em{font-style:italic;color:var(--red)}

.page-hero .hero-sub{font-size:16px;color:#444;line-height:1.75;max-width:600px;margin-bottom:28px;font-weight:400}

.hero-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.hero-meta span{font-size:12px;color:#aaa;font-weight:500}
.hero-meta .dot{width:4px;height:4px;background:#ddd;border-radius:50%;flex-shrink:0}

/* ── TRUST STRIP ───────────────────────────────────────────── */
.trust-strip{
  background:var(--black);padding:24px 52px;
  display:flex;align-items:center;justify-content:space-around;
  flex-wrap:wrap;gap:20px;
}
.trust-strip-label{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.45)}
.trust-items{display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:center}
.trust-item .ti-n{font-family:'Cormorant',serif;font-size:22px;font-weight:700;color:#fff}
.ti-n{font-family:'Cormorant',serif;font-size:22px;font-weight:700;color:#fff}
.trust-item .ti-n sup{color:var(--red);font-size:11px}
.ti-n sup{color:var(--red);font-size:11px}
.trust-item .ti-l{font-size:11px;color:rgba(255,255,255,0.5)}
.ti-l{font-size:11px;color:rgba(255,255,255,0.5)}
.trust-divider{width:1px;height:28px;background:rgba(255,255,255,0.1)}
.t-div{width:1px;height:28px;background:rgba(255,255,255,0.1)}
@media(max-width:768px){.trust-strip{padding:20px 24px}.trust-divider{display:none}}

/* ── SECTION WRAPPER SYSTEM ────────────────────────────────── */
.sw{padding:88px 48px}
.sw.light{background:var(--light)}
.sw.bt{border-top:1px solid var(--border)}
.sw.btb{border-top:1px solid var(--black)}
.si{max-width:1100px;margin:0 auto;padding:0 48px}
@media(max-width:768px){.sw{padding:64px 24px}.si{padding:0}}

/* ── SECTION HEADINGS ──────────────────────────────────────── */
.section-tag{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.section-tag .tl{width:24px;height:2px;background:var(--red);flex-shrink:0}
.section-tag span{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#666}

.sh2{
  font-family:'Cormorant',serif;
  font-size:clamp(26px,3vw,44px);
  font-weight:900;letter-spacing:-1px;
  color:var(--black);line-height:1.1;margin-bottom:14px;
}
.sh2 em{font-style:italic;color:var(--red)}
.sh2.white{color:#fff}

.slead{font-size:15px;color:#444;line-height:1.75;font-weight:400;margin-bottom:48px;max-width:540px}

/* ── GRID LAYOUTS ──────────────────────────────────────────── */
.grid3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:2px;background:var(--border);margin-top:40px}
@media(max-width:900px){.grid3{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.grid3{grid-template-columns:1fr;gap:1px}}

.two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:72px;align-items:start}
@media(max-width:900px){.two-col{grid-template-columns:1fr;gap:48px}}

/* ── GRID BLOCKS (cards) ───────────────────────────────────── */
.grid-block{background:var(--white);padding:32px 28px;transition:background .2s;position:relative}
.grid-block:hover{background:#f9f9f7}
.gb-bar{width:32px;height:3px;background:var(--red);margin-bottom:16px}
.gb-icon{font-size:22px;margin-bottom:10px}
.grid-block h3{font-family:'Cormorant',serif;font-size:19px;font-weight:900;color:var(--black);margin-bottom:10px;letter-spacing:-.2px;line-height:1.2}
.grid-block p{font-size:13px;color:#444;line-height:1.75;font-weight:400}

/* ── PROSE (blog/article body) ─────────────────────────────── */
.prose h2{font-family:'Cormorant',serif;font-size:clamp(20px,2.4vw,30px);font-weight:900;letter-spacing:-0.5px;color:var(--black);line-height:1.2;margin-bottom:14px;margin-top:48px;padding-top:32px;border-top:1px solid var(--border)}
.prose h2 em{font-style:italic;color:var(--red)}
.prose h2:first-child{margin-top:0;padding-top:0;border-top:none}
.prose h3{font-size:16px;font-weight:700;color:var(--black);margin-bottom:10px;margin-top:28px}
.prose p{font-size:14.5px;color:#333;line-height:1.85;font-weight:400;margin-bottom:18px}
.prose p strong{color:var(--black);font-weight:700}
.prose p a{color:var(--red);text-decoration:none;font-weight:500;border-bottom:1px solid rgba(208,16,42,0.2)}
.prose p a:hover{border-color:var(--red)}
.prose ul{margin:12px 0 20px 18px}
.prose ul li{font-size:14.5px;color:#333;line-height:1.8;font-weight:400;margin-bottom:6px}
.prose ul li strong{color:var(--black);font-weight:700}

/* ── TABLE ─────────────────────────────────────────────────── */
.fee-table{width:100%;border-collapse:collapse;margin:20px 0}
.fee-table th{padding:10px 16px;font-size:11px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;text-align:left;border-bottom:2px solid var(--black);color:var(--black);background:var(--light)}
.fee-table td{padding:12px 16px;font-size:13px;border-bottom:1px solid var(--border);color:#444;font-weight:400}
.fee-table td:first-child{font-weight:600;color:var(--black)}

/* ── HIGHLIGHT BOX ─────────────────────────────────────────── */
.highlight-box{border-left:4px solid var(--red);background:var(--light);padding:22px 26px;margin:28px 0}
.highlight-box p{margin:0;font-size:14px;color:var(--black);line-height:1.7;font-weight:400}
.highlight-box p strong{color:var(--red);font-weight:700}

/* ── CTA BLOCK ─────────────────────────────────────────────── */
.cta-block{
  background:var(--black);padding:40px 44px;margin:48px 0;
  display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center;
}
@media(max-width:640px){.cta-block{grid-template-columns:1fr;gap:20px;padding:28px 24px}}
.cta-block.light{background:var(--light);border:1px solid var(--border)}
.cb-label{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:8px}
.cta-block.light .cb-label{color:var(--grey)}
.cta-block h3{font-family:'Cormorant',serif;font-size:20px;font-weight:900;color:#fff;line-height:1.2;margin-bottom:6px}
.cta-block.light h3{color:var(--black)}
.cta-block p{font-size:13px;color:rgba(255,255,255,0.48);line-height:1.6;margin:0;font-weight:300}
.cta-block.light p{color:var(--grey)}

/* ── BUTTONS ───────────────────────────────────────────────── */
.btn-cta{
  background:var(--red);color:#fff;padding:13px 28px;
  font-size:12px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;
  text-decoration:none;display:inline-block;white-space:nowrap;
  transition:background 0.2s;border:none;cursor:pointer;
  font-family:'Manrope',sans-serif;
}
.btn-cta:hover{background:#b00d24}

.btn-main{background:var(--black);color:#fff;padding:14px 32px;font-size:13px;font-weight:600;letter-spacing:0.8px;text-transform:uppercase;border:none;cursor:pointer;font-family:'Manrope',sans-serif;transition:background 0.2s;text-decoration:none;display:inline-block}
.btn-main:hover{background:#2a2a2a}

.btn-main-red{
  background:linear-gradient(135deg,#ff1f3a 0%,#D0102A 45%,#9e0a1e 100%);
  color:#fff;padding:14px 32px;font-size:13px;font-weight:600;
  letter-spacing:0.8px;text-transform:uppercase;
  border:none;cursor:pointer;font-family:'Manrope',sans-serif;
  transition:all 0.25s cubic-bezier(0.34,1.56,0.64,1);
  text-decoration:none;display:inline-flex;align-items:center;gap:8px;
  box-shadow:0 0 0 1px rgba(255,255,255,0.08) inset,0 4px 16px rgba(208,16,42,0.35);
  position:relative;overflow:hidden;
}
.btn-main-red:hover{
  background:linear-gradient(135deg,#ff3d55 0%,#c4102a 45%,#800a18 100%);
  transform:translateY(-2px) scale(1.01);
  box-shadow:0 0 0 1px rgba(255,255,255,0.12) inset,0 8px 28px rgba(208,16,42,0.5);
}

.btn-outline{background:transparent;color:var(--black);padding:13px 32px;font-size:13px;font-weight:600;letter-spacing:0.8px;text-transform:uppercase;border:1.5px solid var(--black);cursor:pointer;font-family:'Manrope',sans-serif;transition:all 0.2s;display:inline-block;text-decoration:none}
.btn-outline:hover{background:var(--black);color:#fff}

/* ── FAQ ACCORDION ─────────────────────────────────────────── */
.faq-list{margin-top:28px}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;background:none;border:none;padding:20px 0;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-family:'Manrope',sans-serif;font-size:14.5px;font-weight:700;color:var(--black);text-align:left;gap:16px}
.faq-icon{color:var(--red);font-size:20px;flex-shrink:0;transition:transform 0.3s;line-height:1}
.faq-q.open .faq-icon{transform:rotate(45deg)}
.faq-a{font-size:13.5px;color:#333;line-height:1.75;font-weight:400;padding:0 0 20px;display:block;max-height:0;overflow:hidden;transition:max-height 0.35s ease}
.faq-a.open{max-height:600px}
.faq-a a{color:var(--red);text-decoration:none;font-weight:500}
/* faq-arr is alternate icon selector used on some pages */
.faq-arr{color:var(--red);font-size:20px;flex-shrink:0;line-height:1}

/* ── STEPS LIST ────────────────────────────────────────────── */
.steps-list{display:flex;flex-direction:column;margin-top:36px}
.step-row{display:flex;gap:20px;padding:24px 0;border-bottom:1px solid var(--border);align-items:flex-start}
.step-row:first-child{padding-top:0}
.step-n{font-family:'Cormorant',serif;font-size:32px;font-weight:900;color:#e8e8e8;line-height:1;min-width:40px;flex-shrink:0}
.step-content .step-accent{width:14px;height:2px;background:var(--red);margin-bottom:8px}
.step-content h3{font-size:14px;font-weight:700;color:var(--black);margin-bottom:6px}
.step-content p{font-size:13px;color:#444;line-height:1.7;font-weight:400;margin:0}

/* ── FINAL CTA SECTION ─────────────────────────────────────── */
.final-cta{
  background:var(--black);padding:100px 52px;
  display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;
}
@media(max-width:768px){.final-cta{grid-template-columns:1fr;gap:36px;padding:72px 24px}}
.final-cta-right p{font-size:15px;color:rgba(255,255,255,0.6);line-height:1.75;font-weight:400;margin-bottom:32px;max-width:360px}
.final-note{margin-top:12px;font-size:11px;color:rgba(255,255,255,0.35)}

/* ── FOOTER ────────────────────────────────────────────────── */
footer{background:#080808;padding:72px 52px 32px}
.footer-logo{text-decoration:none;display:flex;align-items:center;gap:10px;margin-bottom:4px}
.footer-logo svg{flex-shrink:0}
.footer-logo-text{display:flex;flex-direction:column;line-height:1;gap:2px}
.footer-wordmark{font-family:'Cormorant',serif;font-size:17px;font-weight:900;color:#ffffff;letter-spacing:-0.5px;line-height:1}
.footer-sub-text{font-size:8px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.85);line-height:1}
.footer-tagline{font-size:12px;color:rgba(255,255,255,0.55);line-height:1.7;font-weight:400;margin-top:12px;max-width:220px}
.footer-inner{max-width:1100px;margin:0 auto;padding:0 52px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 3fr;gap:28px;align-items:start;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,0.07)}
.footer-brand-tagline{font-size:13px;color:rgba(255,255,255,0.6);line-height:1.7;font-weight:400;margin-top:16px;max-width:220px}
.footer-col h3{font-size:9.5px;font-weight:700;color:rgba(255,255,255,0.55);text-transform:uppercase;letter-spacing:2px;margin-bottom:20px}
.footer-col a{display:block;color:rgba(255,255,255,0.65);font-size:12px;text-decoration:none;margin-bottom:2px;padding:5px 0;transition:color 0.18s;font-weight:400;line-height:1;min-height:24px}
.footer-col a:hover{color:rgba(255,255,255,0.85)}
.footer-col .footer-phone{color:rgba(255,255,255,0.7);font-weight:600;font-size:12.5px;letter-spacing:0.3px;margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,0.07)}
.footer-col .footer-phone:hover{color:#fff}
.footer-trust-row{display:flex;align-items:center;gap:10px;margin-top:24px;flex-wrap:wrap}
.footer-badge{display:flex;align-items:center;gap:7px;border:1px solid rgba(255,255,255,0.1);padding:6px 11px}
.fb-dot{width:5px;height:5px;background:var(--red);border-radius:50%;flex-shrink:0}
.fb-label{font-size:10.5px;font-weight:600;color:rgba(255,255,255,0.65);letter-spacing:0.2px}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.07);padding-top:24px;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px}
.footer-bottom p{font-size:11.5px;color:rgba(255,255,255,0.5);letter-spacing:0.2px}
.footer-bottom-links{display:flex;gap:24px}
.footer-bottom-links a{font-size:11.5px;color:rgba(255,255,255,0.5);text-decoration:none;transition:color 0.18s}
.footer-bottom-links a:hover{color:rgba(255,255,255,0.8)}
/* Mobile footer: collapse to 2-column grid */
@media(max-width:768px){
  footer{padding:56px 24px 28px}
  .footer-inner{padding:0}
  .footer-top{grid-template-columns:1fr 1fr;gap:24px}
  .footer-cities-wrap{grid-column:1/-1;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
}
@media(max-width:480px){
  .footer-top{grid-template-columns:1fr}
  .footer-cities-wrap{grid-template-columns:1fr 1fr}
}

/* ── POPUP / OVERLAY ───────────────────────────────────────── */
/* ── OVERLAY & POPUP SHELL ─────────────────────────────────── */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:1000;align-items:center;justify-content:center;padding:16px}
.overlay.active{display:flex}
.popup{
  background:#fff;width:100%;max-width:480px;position:relative;
  max-height:92vh;overflow-y:auto;border-top:3px solid var(--red);
  padding:36px 32px 28px;
  box-shadow:0 24px 64px rgba(0,0,0,0.25);
}
.close-btn{position:absolute;top:14px;right:18px;background:none;border:none;color:#ccc;font-size:26px;cursor:pointer;line-height:1;transition:color .15s}
.close-btn:hover{color:#0e0e0e}

/* ── PROGRESS BAR ──────────────────────────────────────────── */
.pop-progress{height:3px;background:var(--border);margin-bottom:20px;overflow:hidden}
.pop-progress-bar{height:100%;background:var(--red);width:0%;transition:width .35s cubic-bezier(.4,0,.2,1)}
.pop-step-label{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#bbb;margin-bottom:18px}

/* ── STEP CONTENT ──────────────────────────────────────────── */
.pop-step{animation:popStepIn .22s ease}
@keyframes popStepIn{from{opacity:0;transform:translateX(8px)}to{opacity:1;transform:none}}
.pop-h{font-family:'Cormorant',serif;font-size:26px;font-weight:900;color:var(--black);letter-spacing:-.5px;line-height:1.1;margin-bottom:7px}
.pop-sub{font-size:13.5px;color:#888;line-height:1.55;font-weight:400;margin-bottom:22px}

/* ── INPUTS ────────────────────────────────────────────────── */
.pop-input{
  display:block;width:100%;background:#fafaf8;border:1.5px solid var(--border);
  padding:14px 16px;font-size:16px;font-family:'Manrope',sans-serif;color:#0e0e0e;
  outline:none;transition:border-color .15s,background .15s;margin-bottom:14px;
}
.pop-input:focus{border-color:var(--red);background:#fff}
.pop-input-error{border-color:#e02030!important;background:#fff8f8!important}
.pop-input::placeholder{color:#bbb}
.pop-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:480px){.pop-row{grid-template-columns:1fr}}

/* ── CHIP SELECTORS ────────────────────────────────────────── */
.pop-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.pop-chip{
  padding:10px 16px;border:1.5px solid var(--border);background:#fff;
  font-size:13px;font-weight:600;color:#555;cursor:pointer;font-family:'Manrope',sans-serif;
  transition:all .14s;line-height:1;white-space:nowrap;
}
.pop-chip:hover{border-color:#aaa;color:#0e0e0e}
.pop-chip.selected{border-color:var(--red);background:var(--red);color:#fff}

/* ── BUTTONS ───────────────────────────────────────────────── */
.pop-next-btn{
  width:100%;background:var(--red);color:#fff;padding:16px;border:none;
  font-size:13px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;
  cursor:pointer;font-family:'Manrope',sans-serif;transition:background .15s;
  box-shadow:0 3px 14px rgba(208,16,42,.28);
}
.pop-next-btn:hover{background:#b00d24}
.pop-next-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}
.pop-back-btn{
  display:block;width:100%;background:transparent;border:none;color:#bbb;
  padding:11px;font-size:12px;font-weight:600;cursor:pointer;margin-top:6px;
  font-family:'Manrope',sans-serif;transition:color .15s;letter-spacing:.3px;
}
.pop-back-btn:hover{color:#555}
.pop-note{font-size:11px;color:#ccc;text-align:center;margin-top:14px;line-height:1.5}

/* ── LEGACY COMPAT (form-group pages not yet migrated) ──────── */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:11px;font-weight:600;color:var(--grey);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.8px}
.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--light);border:1.5px solid var(--border);padding:12px 14px;color:var(--black);font-size:16px;font-family:'Manrope',sans-serif;transition:border-color 0.2s;outline:none}
.form-group input:focus,.form-group select:focus{border-color:var(--red)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.submit-btn{width:100%;background:var(--black);color:#fff;padding:15px;border:none;font-size:13px;font-weight:600;letter-spacing:0.8px;text-transform:uppercase;cursor:pointer;margin-top:8px;transition:background 0.2s;font-family:'Manrope',sans-serif}
.submit-btn:hover{background:#2a2a2a}
.submit-btn:disabled{opacity:0.4;cursor:not-allowed}
.back-btn{width:100%;background:transparent;border:1px solid var(--border);color:var(--grey);padding:12px;font-size:13px;font-weight:500;cursor:pointer;margin-top:8px;font-family:'Manrope',sans-serif;transition:all 0.2s}
.back-btn:hover{border-color:#aaa;color:var(--black)}
.form-note{font-size:11px;color:#bbb;text-align:center;margin-top:12px}

/* ── THANK YOU ─────────────────────────────────────────────── */
.thank-you{text-align:center;padding:28px 0}
.ty-icon{font-size:52px;margin-bottom:16px}
.thank-you h3{font-family:'Cormorant',serif;font-size:26px;font-weight:900;color:var(--red);margin-bottom:10px;letter-spacing:-.5px}
.thank-you p{font-size:14px;color:#777;line-height:1.65;font-weight:400}
/* legacy thank-you checkmark */
.thank-you .checkmark{font-size:52px;margin-bottom:16px}

@media(max-width:480px){.popup{padding:28px 20px 24px}}

/* ── GRID STABILITY (prevents overflow blowout) ────────────── */
*,*::before,*::after{box-sizing:border-box}
.si,.nav-inner,.proof-strip-inner,.footer-inner,.testi-strip-inner,
.calc-inner,.content-wrap,.video-section-inner{width:100%;max-width:1100px;min-width:0}
.fear-right,.steps-grid,.testi-grid,.grid3,.why-grid,.bc-grid,
.situations-grid,.reviews-grid,.score-grid,.city-grid,.suv-grid,
.resources-grid,.info-strip-inner,.testi-strip-inner,.final-stats,
.blog-grid,.content-grid,.two-col{min-width:0}
.fear-right>*,.steps-grid>*,.testi-grid>*,.grid3>*,.why-grid>*,
.bc-grid>*,.situations-grid>*,.reviews-grid>*,.score-grid>*,
.city-grid>*,.suv-grid>*,.resources-grid>*,.info-strip-inner>*,
.testi-strip-inner>*,.final-stats>*,.blog-grid>*,.content-grid>*,.two-col>*{
  min-width:0;word-break:break-word;
}

/* ── LENDER TICKER ─────────────────────────────────────────── */
.lender-ticker-track{contain:layout style;transform:translateZ(0)}

/* ── ADDITIONAL SHARED COMPONENTS ──────────────────────────── */

/* Score grid (credit score pages) */
.score-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:32px}
@media(max-width:768px){.score-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.score-grid{grid-template-columns:1fr}}

/* City grid */
.city-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:32px}
@media(max-width:900px){.city-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.city-grid{grid-template-columns:1fr 1fr}}

/* ── AD BANNER (city + credit score pages) ─────────────────── */
.ad-banner{
  background:var(--black);
  padding:18px 52px;
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;flex-wrap:wrap;
  border-bottom:3px solid var(--red);
}
.ad-banner-text{font-size:13px;font-weight:600;color:#fff;line-height:1.4}
.ad-banner-text span{font-weight:300;color:rgba(255,255,255,.6);margin-left:4px}
.ad-banner a{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--red);color:#fff;
  padding:10px 22px;
  font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;
  text-decoration:none;white-space:nowrap;
  transition:background .2s;
  font-family:'Manrope',sans-serif;
}
.ad-banner a:hover{background:#b00d24}
@media(max-width:768px){.ad-banner{padding:14px 24px}.ad-banner a{width:100%;justify-content:center}}

/* ── FOOTER NAV CTA LINK ────────────────────────────────────── */
/* "Get Pre-Approved" anchor inside .footer-col nav list */
.footer-col a[onclick*="openPopup"]{
  color:var(--red) !important;
  font-weight:700 !important;
}

/* Guide section grouping */
.guide-section{margin-bottom:64px}
.guide-section-header{margin-bottom:20px;padding-bottom:14px;border-bottom:2px solid var(--border)}
.guide-section-label{font-family:'Cormorant',serif;font-size:22px;font-weight:900;color:var(--black);letter-spacing:-.3px;margin-bottom:5px}
.guide-section-desc{font-size:12px;color:#999;font-weight:400;line-height:1.5}

/* Blog grid — tight 2px-gap card layout */
.blog-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:2px;background:var(--border);margin-top:0}
@media(max-width:900px){.blog-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.blog-grid{grid-template-columns:1fr;gap:1px}}

/* Blog card */
.blog-card{background:#fff;text-decoration:none;display:flex;flex-direction:column;padding:24px 24px 20px;position:relative;transition:background .18s;min-height:160px}
.blog-card:hover{background:var(--light)}
.blog-card-tag{font-size:9px;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;color:var(--red);margin-bottom:10px}
.blog-card-title{font-family:'Cormorant',serif;font-size:18px;font-weight:900;color:var(--black);line-height:1.2;letter-spacing:-.2px;margin-bottom:10px;flex-grow:1}
.blog-card-desc{font-size:12px;color:#777;line-height:1.6;font-weight:400;margin-bottom:12px}
.blog-card-meta{display:flex;gap:12px;font-size:10px;color:#bbb;font-weight:500}
.blog-card-arrow{font-size:12px;font-weight:700;color:var(--red);display:block;margin-top:12px;transition:transform .15s}
.blog-card:hover .blog-card-arrow{transform:translateX(5px)}

/* Inline CTA band */
.cta-band{background:var(--black);padding:40px 36px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-top:48px}
.cta-band-text h2{font-family:'Cormorant',serif;font-size:26px;font-weight:900;color:#fff;letter-spacing:-.3px;margin-bottom:6px}
.cta-band-text p{font-size:12px;color:rgba(255,255,255,.4);line-height:1.5;margin:0}
.cta-band a{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;padding:14px 28px;font-size:12px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;text-decoration:none;white-space:nowrap;transition:background .2s}
.cta-band a:hover{background:#b00d24}
@media(max-width:700px){.cta-band{flex-direction:column;align-items:flex-start;padding:32px 24px}}

/* Testi grid */
.testi-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-top:32px}
@media(max-width:900px){.testi-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.testi-grid{grid-template-columns:1fr}}

/* Why grid */
.why-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-top:40px}
@media(max-width:900px){.why-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.why-grid{grid-template-columns:1fr}}

/* Steps grid (horizontal) */
.steps-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;margin-top:48px}
@media(max-width:900px){.steps-grid{grid-template-columns:1fr 1fr;gap:1px}}
@media(max-width:500px){.steps-grid{grid-template-columns:1fr}}

/* BC grid */
.bc-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:64px;align-items:center}
@media(max-width:900px){.bc-grid{grid-template-columns:1fr;gap:40px}}

/* Situations grid */
.situations-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:32px}
@media(max-width:600px){.situations-grid{grid-template-columns:1fr}}

/* Resources grid */
.resources-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-top:32px}
@media(max-width:900px){.resources-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.resources-grid{grid-template-columns:1fr}}

/* SUV grid */
.suv-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;margin-top:36px}
@media(max-width:900px){.suv-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.suv-grid{grid-template-columns:1fr}}

/* Content grid */
.content-grid{display:grid;grid-template-columns:2fr 1fr;gap:64px;align-items:start}
@media(max-width:900px){.content-grid{grid-template-columns:1fr;gap:40px}}

/* Info strip */
.info-strip-inner{display:flex;flex-wrap:wrap;gap:32px;align-items:center;justify-content:space-between}

/* Testi strip */
.testi-strip-inner{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0}
@media(max-width:768px){.testi-strip-inner{grid-template-columns:1fr}}

/* Fear section */
.fear-right{display:flex;flex-direction:column;gap:0}

/* Final stats */
.final-stats{display:flex;flex-wrap:wrap;gap:0;justify-content:space-between}

/* Calc inner */
.calc-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:768px){.calc-inner{grid-template-columns:1fr;gap:32px}}

/* ── BLOG POST LAYOUT ──────────────────────────────────────── */

/* Two-column article layout: wide prose left, sticky sidebar right */
.blog-layout{display:grid;grid-template-columns:1fr 320px;gap:64px;align-items:start;margin-top:48px}
@media(max-width:960px){.blog-layout{grid-template-columns:1fr;gap:40px}}

/* Article hero — uses .page-hero but with max-width constraint */
.blog-hero-inner{max-width:760px}

/* Meta line (date · read time · location) */
.blog-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:32px}
.blog-meta span{font-size:11px;color:#bbb;font-weight:500;letter-spacing:0.2px}

/* Blog body wraps all prose content */
.blog-content{max-width:100%}
.blog-content h2{font-family:'Cormorant',serif;font-size:clamp(20px,2.4vw,30px);font-weight:900;letter-spacing:-.5px;color:var(--black);line-height:1.2;margin-bottom:14px;margin-top:48px;padding-top:32px;border-top:1px solid var(--border)}
.blog-content h2:first-child{margin-top:0;padding-top:0;border-top:none}
.blog-content h2 em{font-style:italic;color:var(--red)}
.blog-content h3{font-size:16px;font-weight:700;color:var(--black);margin-bottom:10px;margin-top:28px}
.blog-content p{font-size:14.5px;color:#333;line-height:1.85;font-weight:400;margin-bottom:18px}
.blog-content p strong{color:var(--black);font-weight:700}
.blog-content p a{color:var(--red);text-decoration:none;font-weight:500;border-bottom:1px solid rgba(208,16,42,.2)}
.blog-content p a:hover{border-color:var(--red)}
.blog-content ul{margin:12px 0 20px 18px}
.blog-content ul li{font-size:14.5px;color:#333;line-height:1.8;font-weight:400;margin-bottom:6px}
.blog-content ul li strong{color:var(--black);font-weight:700}
.blog-content ul li a{color:var(--red);text-decoration:none;font-weight:500;border-bottom:1px solid rgba(208,16,42,.2)}
.blog-content ul li a:hover{border-color:var(--red)}

/* Inline CTA box inside articles */
.blog-cta-box{background:var(--black);padding:36px 40px;margin:40px 0}
.blog-cta-box h3{font-family:'Cormorant',serif;font-size:22px;font-weight:900;color:#fff;margin-bottom:8px;line-height:1.2}
.blog-cta-box p{font-size:13px;color:rgba(255,255,255,.55);line-height:1.65;font-weight:300;margin-bottom:20px}
@media(max-width:640px){.blog-cta-box{padding:28px 24px}}

/* Related links row */
.blog-related{margin-top:48px;padding-top:32px;border-top:1px solid var(--border)}
.blog-related-label{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--grey);margin-bottom:16px}
.blog-related-links{display:flex;flex-wrap:wrap;gap:10px}
.blog-related-links a{font-size:13px;font-weight:600;color:var(--red);text-decoration:none;border:1px solid var(--border);padding:8px 14px;transition:border-color .2s,background .2s}
.blog-related-links a:hover{border-color:var(--red);background:rgba(208,16,42,.04)}

/* Sticky sidebar */
.blog-sidebar{position:sticky;top:160px}
.blog-sidebar-cta{background:var(--black);padding:32px 28px}
.blog-sidebar-cta .sc-eyebrow{font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:12px}
.blog-sidebar-cta h3{font-family:'Cormorant',serif;font-size:22px;font-weight:900;color:#fff;line-height:1.15;margin-bottom:10px}
.blog-sidebar-cta p{font-size:12px;color:rgba(255,255,255,.5);line-height:1.65;font-weight:300;margin-bottom:20px}
.blog-sidebar-cta .sc-btn{display:block;width:100%;background:var(--red);color:#fff;padding:13px 20px;font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;text-align:center;text-decoration:none;border:none;cursor:pointer;font-family:'Manrope',sans-serif;transition:background .2s}
.blog-sidebar-cta .sc-btn:hover{background:#b00d24}
.blog-sidebar-cta .sc-note{font-size:10px;color:rgba(255,255,255,.3);text-align:center;margin-top:10px}

/* ── UTILITY ────────────────────────────────────────────────── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
@media(max-width:768px){.hide-mob{display:none !important}}

/* ── WHY-BLOCK CARDS (why.html, sell-my-car.html) ───────────── */
.why-grid{gap:2px;background:var(--border)}
.why-block{background:var(--white);padding:32px 28px;transition:background .2s}
.why-block:hover{background:#f9f9f7}
.wb-bar{width:32px;height:3px;background:var(--red);margin-bottom:16px}
.wb-icon{font-size:22px;margin-bottom:10px}
.why-block h3{font-family:'Cormorant',serif;font-size:19px;font-weight:900;color:var(--black);margin-bottom:10px;letter-spacing:-.2px;line-height:1.2}
.why-block p{font-size:13px;color:#444;line-height:1.75;font-weight:400}

/* ── BC-BLOCK CARDS (why.html) ──────────────────────────────── */
.bc-grid{gap:2px;background:var(--border)}
.bc-block{background:var(--white);padding:32px 28px;transition:background .2s}
.bc-block:hover{background:#f9f9f7}
.bc-bar{width:32px;height:3px;background:var(--red);margin-bottom:16px}
.bc-icon{font-size:22px;margin-bottom:10px}
.bc-block h3{font-family:'Cormorant',serif;font-size:19px;font-weight:900;color:var(--black);margin-bottom:10px;letter-spacing:-.2px;line-height:1.2}
.bc-block p{font-size:13px;color:#444;line-height:1.75;font-weight:400}

/* ── SITUATION-BLOCK CARDS (bad-credit-car-loans-bc.html) ────── */
.situations-grid{gap:2px;background:var(--border)}
.situation-block{background:var(--white);padding:32px 28px;transition:background .2s}
.situation-block:hover{background:#f9f9f7}
.sb-bar{width:32px;height:3px;background:var(--red);margin-bottom:16px}
.sb-icon{font-size:22px;margin-bottom:10px}
.sb-num{font-family:'Cormorant',serif;font-size:28px;font-weight:900;color:var(--red);margin-bottom:8px;line-height:1}
.situation-block h3{font-family:'Cormorant',serif;font-size:19px;font-weight:900;color:var(--black);margin-bottom:10px;letter-spacing:-.2px;line-height:1.2}
.situation-block p{font-size:13px;color:#444;line-height:1.75;font-weight:400}

/* ── SUV-CARD (best-suvs-canada.html, index.html) ───────────── */
.suv-grid{gap:2px;background:var(--border)}
.suv-card{background:var(--white);padding:32px 28px;transition:background .2s;position:relative}
.suv-card:hover{background:#f9f9f7}
.sc-rank{font-family:'Cormorant',serif;font-size:32px;font-weight:900;color:var(--border);line-height:1;margin-bottom:4px}
.sc-bar{width:32px;height:3px;background:var(--red);margin-bottom:16px}
.suv-card h3{font-family:'Cormorant',serif;font-size:20px;font-weight:900;color:var(--black);margin-bottom:6px;letter-spacing:-.2px;line-height:1.2}
.sc-price{font-size:12px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}
.suv-card p{font-size:13px;color:#555;line-height:1.75;font-weight:300}
.sc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}
.sc-tag{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;background:var(--light);color:var(--grey);padding:4px 10px}

/* ── CITY-CARD LINKS (bc-cities.html) ───────────────────────── */
.city-card{display:block;background:var(--white);border:1px solid var(--border);padding:20px 18px;text-decoration:none;transition:background .2s,border-color .2s;color:inherit}
.city-card:hover{background:#f9f9f7;border-color:#ccc}
.city-card-name{font-family:'Cormorant',serif;font-size:16px;font-weight:700;color:var(--black);line-height:1.2}
.city-card-region{font-size:11px;color:#999;margin-top:3px;font-weight:300}
.city-card-cta{font-size:11px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.5px;margin-top:8px}

/* ── REVIEW-BLOCK (why.html) ─────────────────────────────────── */
.reviews-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:2px;background:var(--border);margin-top:40px}
@media(max-width:900px){.reviews-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.reviews-grid{grid-template-columns:1fr}}
.review-block{background:var(--white);overflow:hidden;display:flex;flex-direction:column}
.review-img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top;display:block}
.review-body{padding:24px 20px;flex:1;display:flex;flex-direction:column;gap:8px}
.review-stars{color:var(--red);font-size:14px;letter-spacing:2px}
.review-block blockquote{font-size:13.5px;color:#333;line-height:1.75;font-weight:400;font-style:italic;margin:0;flex:1}
.review-name{font-size:11px;font-weight:700;color:var(--black);text-transform:uppercase;letter-spacing:.5px;margin-top:4px}

/* ── INFO-BLOCK (car-loan-calculator-bc.html) ────────────────── */
.info-strip-inner{display:flex;flex-wrap:wrap;gap:2px;background:var(--border);margin-top:40px}
.info-block{background:var(--white);padding:28px 24px;flex:1;min-width:200px;transition:background .2s}
.info-block:hover{background:#f9f9f7}
.ib-icon{font-size:22px;margin-bottom:10px}
.info-block h4{font-family:'Cormorant',serif;font-size:18px;font-weight:900;color:var(--black);margin-bottom:8px;letter-spacing:-.2px;line-height:1.2}
.info-block p{font-size:12px;color:#555;line-height:1.7;font-weight:300}

/* ── QUICK-FORM CARD (credit score pages, 44 pages) ──────────── */
.quick-form-card{background:var(--white);border:1px solid var(--border);padding:36px 32px;margin-top:40px;max-width:480px}
.qf-tag{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.quick-form-card h2{font-family:'Cormorant',serif;font-size:28px;font-weight:900;color:var(--black);margin-bottom:8px;line-height:1.1}
.quick-form-card p{font-size:13px;color:#444;line-height:1.7;font-weight:400;margin-bottom:20px}
.qf-field{display:block;width:100%;box-sizing:border-box;border:1px solid var(--border);padding:13px 14px;font-size:14px;font-family:'Manrope',sans-serif;color:var(--black);background:var(--white);margin-bottom:12px;outline:none;transition:border-color .2s}
.qf-field:focus{border-color:var(--black)}
.qf-submit{display:block;width:100%;background:var(--red);color:#fff;border:none;padding:15px 20px;font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;font-family:'Manrope',sans-serif;transition:background .2s;margin-top:4px}
.qf-submit:hover{background:#b00d24}
.qf-note{font-size:10px;color:#aaa;text-align:center;margin-top:12px;font-weight:300}

/* ── LP FORM CARD (lp-bad-credit-bc.html) ────────────────────── */
.lp-form-wrap{background:var(--black);padding:80px 52px}
@media(max-width:768px){.lp-form-wrap{padding:56px 24px}}
.lp-form-card{background:var(--white);padding:48px 40px;max-width:520px;margin:0 auto}
@media(max-width:560px){.lp-form-card{padding:32px 24px}}
.lp-form-title{font-family:'Cormorant',serif;font-size:32px;font-weight:900;color:var(--black);margin-bottom:8px;line-height:1.1}
.lp-form-sub{font-size:13px;color:#555;line-height:1.7;font-weight:300;margin-bottom:28px}
.lp-form-lock{font-size:11px;color:#aaa;text-align:center;margin-top:16px;font-weight:300}

/* ── LP TESTIMONIALS (lp-bad-credit-bc.html) ─────────────────── */
.lp-testi-inner{padding:80px 52px;background:var(--light)}
@media(max-width:768px){.lp-testi-inner{padding:56px 24px}}
.lp-testi-tag{font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.lp-testi-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:2px;background:var(--border);margin-top:36px}
@media(max-width:900px){.lp-testi-grid{grid-template-columns:1fr}}
.lp-testi-card{background:var(--white);padding:32px 28px}
.lp-testi-stars{color:var(--red);font-size:13px;letter-spacing:2px;margin-bottom:12px}
.lp-testi-quote{font-size:13.5px;color:#333;line-height:1.75;font-weight:400;font-style:italic;margin:0 0 16px}
.lp-testi-name{font-size:12px;font-weight:700;color:var(--black);text-transform:uppercase;letter-spacing:.5px}
.lp-testi-loc{font-size:11px;color:#888;font-weight:300;margin-top:2px}

/* ── CALC-WRAP / CALC-CARD (car-loan-calculator-bc.html) ─────── */
.calc-wrap{padding:80px 52px;background:var(--white)}
@media(max-width:768px){.calc-wrap{padding:56px 24px}}
.calc-card{background:var(--light);border:1px solid var(--border);padding:36px 32px}
.calc-card-title{font-family:'Cormorant',serif;font-size:22px;font-weight:900;color:var(--black);margin-bottom:4px}
.calc-card-sub{font-size:12px;color:#888;font-weight:300;margin-bottom:28px}

/* ── TOC SIDEBAR (buying-a-car-in-bc.html) ───────────────────── */
.toc{position:sticky;top:100px}
.toc-inner{background:var(--light);border:1px solid var(--border);padding:28px 24px}
.toc-inner h4{font-family:'Cormorant',serif;font-size:16px;font-weight:900;color:var(--black);margin-bottom:16px;text-transform:uppercase;letter-spacing:.5px}
.toc-inner ol{padding-left:18px;margin:0}
.toc-inner li{font-size:12px;color:#555;line-height:1.7;font-weight:300;margin-bottom:6px}
.toc-inner a{color:#555;text-decoration:none;transition:color .2s}
.toc-inner a:hover{color:var(--red)}
.toc-cta{margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}
.toc-cta p{font-size:12px;color:#888;font-weight:300;margin-bottom:12px;line-height:1.6}

/* ── AFFORDABILITY CALCULATOR ── */
.afford-calc{background:var(--light);border:1px solid var(--border);padding:32px;margin-bottom:40px}
.afford-calc-title{font-family:'Cormorant',serif;font-size:22px;font-weight:900;color:var(--black);margin-bottom:4px;letter-spacing:-.3px}
.afford-calc-sub{font-size:12px;color:var(--grey);margin-bottom:24px}
.afford-calc-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.afford-calc-group{display:flex;flex-direction:column;gap:6px}
.afford-calc-label{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#888}
.afford-calc-range{-webkit-appearance:none;width:100%;height:4px;background:var(--border);outline:none;border-radius:2px}
.afford-calc-range::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--red);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.afford-calc-range::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--red);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.afford-calc-val{font-family:'Cormorant',serif;font-size:28px;font-weight:900;color:var(--red);line-height:1}
.afford-calc-result{background:var(--black);padding:24px;text-align:center;margin-top:8px}
.afford-calc-result-label{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:8px}
.afford-calc-result-amt{font-family:'Cormorant',serif;font-size:44px;font-weight:900;color:#fff;line-height:1;letter-spacing:-1px}
.afford-calc-result-amt em{color:var(--red);font-style:normal;font-size:20px;vertical-align:super}
.afford-calc-result-note{font-size:11px;color:rgba(255,255,255,.35);margin-top:10px}
.afford-calc-cta{display:block;background:var(--red);color:#fff;text-decoration:none;padding:13px;text-align:center;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;margin-top:12px;transition:background .15s}
.afford-calc-cta:hover{background:#b00d24}
@media(max-width:640px){.afford-calc-row{grid-template-columns:1fr}.afford-calc{padding:24px}}

/* ── TEASER / BLURRED INVENTORY CARDS ── */
.v-teaser{position:relative;overflow:hidden}
.v-teaser .v-body,.v-teaser .v-img{filter:blur(6px);-webkit-filter:blur(6px);pointer-events:none;user-select:none}
.v-teaser-overlay{position:absolute;inset:0;z-index:5;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;background:rgba(255,255,255,.7)}
.v-teaser-overlay h4{font-family:'Cormorant',serif;font-size:20px;font-weight:900;color:#0e0e0e;letter-spacing:-.3px;margin-bottom:8px}
.v-teaser-overlay p{font-size:12px;color:#555;margin-bottom:16px;max-width:200px;line-height:1.5}
.v-teaser-cta{display:inline-flex;align-items:center;gap:8px;background:#D0102A;color:#fff;padding:12px 22px;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;text-decoration:none;transition:background .15s}
.v-teaser-cta:hover{background:#b00d24}

/* ── STICKY MOBILE CTA ─────────────────────────────────────── */
.mob-sticky-cta{
  display:none;
  position:fixed;
  bottom:0;
  left:0;right:0;
  z-index:998;
  background:#0e0e0e;
  padding:12px 20px 12px;
  padding-bottom:calc(12px + env(safe-area-inset-bottom, 0px));
  align-items:center;
  justify-content:space-between;
  gap:12px;
  box-shadow:0 -4px 20px rgba(0,0,0,.15);
}
@media(max-width:768px){
  .mob-sticky-cta{display:flex}
}
.mob-sticky-cta-text{font-size:11px;color:rgba(255,255,255,.5);font-weight:300;line-height:1.3}
.mob-sticky-cta-text strong{color:#fff;font-weight:700;font-size:13px;display:block}
.mob-sticky-cta .btn-main-red{padding:12px 20px;font-size:13px;white-space:nowrap;flex-shrink:0}

/* ── HOMEPAGE: HIDE DUPLICATE SECTIONS ON MOBILE ──────────── */
/* These sections are still fully visible on desktop.           */
/* No other hero/body/animation rules — just visibility toggles */
@media(max-width:768px){
  #home-lender-ticker,
  #home-choose-path,
  #home-vehicles-approved,
  #home-affordability,
  #home-vehicle-preview,
  #home-trusted-bc,
  #guidedFunnel{display:none}
}

/* ── MOBILE: RECENTLY APPROVED CARDS + SPACING ─────────────── */
@media(max-width:768px){
  /* Approval cards scroll area tighter on mobile */
  #home-recent-approved .si{padding:0 20px}
  #home-recent-approved .sh2{font-size:clamp(24px,5vw,32px)}
}

/* ── LEGAL PAGES: privacy.html / terms.html / legal.html ─────── */
.page-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.page-eyebrow .line{width:28px;height:2px;background:var(--red);flex-shrink:0}
.page-eyebrow span{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--grey)}
.page-hero .updated{font-size:12px;color:var(--grey);margin-bottom:20px;font-weight:500;letter-spacing:0.2px}
.page-content{padding:64px 52px;background:var(--white)}
.page-content-inner{max-width:780px;margin:0 auto}
.page-content h2{font-family:'Cormorant',serif;font-size:clamp(18px,2.2vw,26px);font-weight:900;letter-spacing:-.4px;color:var(--black);line-height:1.2;margin:44px 0 14px;padding-top:32px;border-top:1px solid var(--border)}
.page-content h2:first-child{margin-top:0;padding-top:0;border-top:none}
.page-content h3{font-size:15px;font-weight:700;color:var(--black);margin:24px 0 8px}
.page-content p{font-size:14.5px;color:#333;line-height:1.85;font-weight:400;margin-bottom:16px}
.page-content p a{color:var(--red);text-decoration:none;font-weight:500;border-bottom:1px solid rgba(208,16,42,.2)}
.page-content p a:hover{border-color:var(--red)}
.page-content ul,.page-content ol{margin:10px 0 18px 20px}
.page-content ul li,.page-content ol li{font-size:14.5px;color:#333;line-height:1.8;margin-bottom:6px}
.page-content address{font-style:normal;font-size:14.5px;color:#333;line-height:1.8;margin-bottom:16px}
@media(max-width:768px){
  .page-content{padding:44px 24px}
  .page-content h2{font-size:18px}
}
