/* ============================================================
   GETSORTED.AUTOS — Main Stylesheet
   Fonts: Impact (headlines) · Barlow Semi Condensed (UI/eyebrow) · Barlow (body)
   Colors: --navy / --orange / --white / --gray
   Max site width: 1140px via --max
============================================================ */

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ── Tokens ── */
:root{
  --navy:    #0B1F3A;
  --navy-mid:#142d52;
  --navy-lt: #1e3d6e;
  --orange:  #E8640C;
  --orange-lt:#f07830;
  --white:   #F8F7F4;
  --off:     #EFF2F7;
  --gray:    #8a9ab0;
  --gray-lt: #dce3ed;
  --text:    #1a2e47;
  --mid:     #4a6070;
  --max:     1140px;
  --pad:     40px;
  --impact:  Impact,'Arial Narrow',sans-serif;
  --semi:    'Barlow Semi Condensed',sans-serif;
  --body:    'Barlow',sans-serif;
}

/* ── Base ── */
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--white);color:var(--text);overflow-x:hidden}
img{display:block;max-width:100%}
a{text-decoration:none}

/* ── Layout helpers ── */
.wrap{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
}
.section  {padding:100px 0}
.section-sm{padding:72px 0}

/* ── Typography utilities ── */
.eyebrow{
  font-family:var(--semi);font-weight:700;
  font-size:11px;letter-spacing:3px;text-transform:uppercase;
  color:var(--orange);margin-bottom:14px;
}
.sec-hed{
  font-family:var(--impact);
  font-size:clamp(38px,5.5vw,66px);
  line-height:.93;letter-spacing:-.3px;
  color:var(--navy);margin-bottom:18px;
}
.sec-intro{
  font-size:17px;line-height:1.7;
  color:var(--mid);max-width:580px;margin-bottom:56px;
}
.light{color:var(--white)}
.light-body{color:var(--gray)}

/* ── Buttons ── */
.btn{
  display:inline-block;
  font-family:var(--semi);font-weight:700;
  font-size:13px;letter-spacing:1.5px;text-transform:uppercase;
  padding:14px 32px;border:none;cursor:pointer;
  transition:background .2s,transform .15s,color .2s,border-color .2s;
}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:var(--orange-lt);transform:translateY(-1px)}
.btn-secondary{background:transparent;color:var(--gray);border:1.5px solid rgba(138,154,176,.3)}
.btn-secondary:hover{border-color:var(--white);color:var(--white)}
.btn-white{background:#fff;color:var(--orange)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-lt)}

/* ============================================================
   GLOBAL HEADER
============================================================ */
#site-header{
  position:sticky;top:0;z-index:200;
  background:var(--navy);height:68px;
  display:flex;align-items:center;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.header-inner{
  max-width:var(--max);margin:0 auto;width:100%;
  padding:0 var(--pad);
  display:flex;align-items:center;justify-content:space-between;
}
.header-logo{display:flex;align-items:center}
.header-logo img{height:50px;width:auto;display:block}
.footer-logo-wrap img{height:40px;width:auto;display:block}
.header-nav{display:flex;align-items:center;gap:28px}
.header-nav a{
  font-family:var(--semi);font-weight:600;
  font-size:12px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--gray);transition:color .2s;text-decoration:none;
}
.header-nav a:hover{color:var(--white)}
/* Override color for the CTA button specifically */
.header-nav .btn-primary{
  font-size:12px;padding:10px 22px;letter-spacing:1px;
  color:#fff !important;
}
.header-nav .btn-primary:hover{color:#fff !important}

/* ============================================================
   GLOBAL FOOTER
============================================================ */
#site-footer{
  background:var(--navy);
  border-top:1px solid rgba(255,255,255,.07);
}
.footer-main{
  max-width:var(--max);margin:0 auto;
  padding:64px var(--pad) 48px;
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;
}
.footer-logo-wrap{margin-bottom:18px}
.footer-logo-wrap img{height:30px;width:auto}
.footer-tagline{font-size:14px;color:var(--gray);line-height:1.65;max-width:240px;margin-bottom:20px}
.footer-contact a,.footer-col a{
  display:block;font-size:13px;color:var(--gray);
  margin-bottom:9px;line-height:1.4;transition:color .2s;
}
.footer-contact a:hover,.footer-col a:hover{color:var(--orange)}
.footer-col-label{
  font-family:var(--semi);font-weight:700;
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--white);margin-bottom:16px;
}
.footer-bottom{
  max-width:var(--max);margin:0 auto;
  padding:18px var(--pad);
  border-top:1px solid rgba(255,255,255,.07);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
}
.footer-legal{font-size:12px;color:rgba(138,154,176,.6)}
.footer-legal a{color:rgba(138,154,176,.6);margin-left:16px;transition:color .2s}
.footer-legal a:hover{color:var(--gray)}
.footer-social{display:flex;gap:12px}
.footer-social a{
  width:32px;height:32px;border:1px solid rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;
  color:var(--gray);font-size:12px;font-weight:700;
  transition:border-color .2s,color .2s;
}
.footer-social a:hover{border-color:var(--orange);color:var(--orange)}

/* ============================================================
   HERO
============================================================ */
.hero{
  background:var(--navy);
  min-height:calc(100vh - 68px);
  position:relative;overflow:hidden;
  padding-bottom:48px;
}
.hero-glow{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 45% 60% at 25% 50%,rgba(30,61,110,.5) 0%,transparent 60%),
    radial-gradient(ellipse 28% 38% at 12% 88%,rgba(232,100,12,.07) 0%,transparent 55%);
}
.hero-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:40px var(--pad) 0;
  display:grid;
  grid-template-columns:1fr 1fr;
  height:calc(100vh - 68px);
  min-height:600px;
  max-height:900px;
  position:relative;z-index:2;
  align-items:center;
}
.hero-left{
  padding:0 40px 0 0;
  display:flex;flex-direction:column;justify-content:center;
  overflow:hidden;
}
.hero-hed{
  font-family:var(--impact);
  font-size:clamp(42px,5.5vw,72px);
  line-height:.95;letter-spacing:-.5px;
  color:var(--white);margin-bottom:20px;
}
.hero-hed em{font-style:normal;color:var(--orange)}
.hero-subhed{
  font-family:var(--impact);
  font-size:clamp(20px,2.8vw,32px);
  color:rgba(138,154,176,.85);
  letter-spacing:1px;margin-bottom:28px;line-height:1.1;
}
.hero-body{font-size:16px;line-height:1.75;color:var(--gray);max-width:440px;margin-bottom:40px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:48px}
.hero-divider{border:none;border-top:1px solid rgba(255,255,255,.07);margin-bottom:32px}
.hero-stats{display:flex;gap:40px;flex-wrap:wrap}
.stat-num{font-family:var(--impact);font-size:38px;color:var(--white);line-height:1}
.stat-num em{color:var(--orange);font-style:normal}
.stat-label{font-size:12px;color:var(--gray);margin-top:4px;line-height:1.4;max-width:120px}

/* ── Cycling stat display ── */
.hero-right{
  display:flex !important;
  align-items:center;
  justify-content:center;
  padding:0 0 0 32px;
  overflow:visible;
}

.stat-cycler{
  width:100%;
  max-width:480px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  padding:0;
}

.sc-num{
  font-family:var(--impact);
  font-size:clamp(120px,14vw,200px);
  color:#E8640C;
  line-height:.88;
  letter-spacing:-3px;
  margin-bottom:24px;
  opacity:0;
  white-space:nowrap;
  display:block;
  width:100%;
  text-align:center;
}

.sc-label{
  font-family:var(--impact);
  font-size:clamp(22px,2.4vw,32px);
  color:var(--white);
  line-height:1.15;
  letter-spacing:.3px;
  max-width:380px;
  margin:0 auto 10px;
  opacity:0;
  text-align:center;
}

.sc-source{
  font-family:'Barlow Semi Condensed',sans-serif;
  font-weight:600;
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--gray);
  opacity:0;
  margin-bottom:20px;
  text-align:center;
}

.sc-dots{
  display:flex;
  gap:10px;
  justify-content:center;
  margin:0;
  padding:0;
}

.sc-dot{
  width:8px;height:8px;
  border-radius:50%;
  background:var(--gray);
  transition:background .3s, transform .3s;
}

.sc-dot.active{
  background:var(--orange);
  transform:scale(1.5);
}

/* ============================================================
   PROOF BAND (stats)
============================================================ */
.proof-band{
  background:var(--orange);padding:28px var(--pad);
}
.proof-inner{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:center;justify-content:space-around;
  gap:24px;flex-wrap:wrap;
}
.proof-stat{text-align:center}
.proof-num{
  font-family:var(--impact);font-size:42px;
  color:#fff;line-height:1;
}
.proof-label{font-size:13px;color:rgba(255,255,255,.8);margin-top:4px;line-height:1.4;max-width:180px}

/* ============================================================
   MARK BAND
============================================================ */
.mark-band{
  background:var(--navy-mid);padding:64px var(--pad);text-align:center;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.mark-quote{
  font-family:var(--impact);
  font-size:clamp(24px,3.8vw,46px);
  color:var(--white);line-height:1.05;letter-spacing:-.3px;
  max-width:820px;margin:0 auto 20px;
}
.mark-quote em{color:var(--orange);font-style:normal}
.mark-body{font-size:17px;color:var(--gray);max-width:580px;margin:0 auto;line-height:1.7}
.mark-body strong{color:var(--white)}

/* ============================================================
   STACKED DECK
============================================================ */
.stacked{background:var(--navy)}
.dealer-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:56px}
.dc{
  background:var(--navy-mid);padding:40px 32px;
  position:relative;overflow:hidden;transition:background .2s;
}
.dc:hover{background:var(--navy-lt)}
.dc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--orange)}
.dc-ghost{
  position:absolute;top:4px;right:14px;
  font-family:var(--impact);font-size:110px;
  color:var(--orange);opacity:.07;line-height:1;
}
.dc-icon{font-size:28px;margin-bottom:18px}
.dc-title{font-family:var(--impact);font-size:28px;color:var(--white);margin-bottom:14px;line-height:1.05;letter-spacing:.3px}
.dc-body{font-size:14px;line-height:1.7;color:var(--gray)}
.dc-body strong{color:var(--white)}

/* ============================================================
   PRICE STACK
============================================================ */
.pricestack{background:var(--off)}
.stack-wrap{max-width:700px;margin-top:56px}
.srow{display:flex;align-items:stretch;margin-bottom:3px;height:68px}
.sbar{
  display:flex;align-items:center;padding:0 20px;
  font-family:var(--impact);font-size:17px;
  color:#fff;flex-shrink:0;letter-spacing:.5px;
}
.sbar.w100{width:100%;background:#8a9ab0}
.sbar.w87 {width:87%; background:#5a7090}
.sbar.w76 {width:76%; background:#2a4870}
.sbar.w65 {width:65%; background:var(--navy-mid)}
.sbar.w52 {width:52%; background:var(--orange)}
.slabel{display:flex;flex-direction:column;justify-content:center;padding-left:18px;flex:1}
.slabel-t{font-family:var(--semi);font-weight:700;font-size:14px;color:var(--navy)}
.slabel-d{font-size:12px;color:var(--mid);margin-top:2px;line-height:1.4}
.stack-callout{
  margin-top:20px;padding:18px 24px;
  border:1.5px dashed var(--orange);background:rgba(232,100,12,.06);
}
.stack-callout p{font-family:var(--impact);font-size:18px;color:var(--orange);letter-spacing:.3px}
.stack-callout span{font-size:13px;color:var(--mid);display:block;margin-top:4px}

/* ============================================================
   WHERE MONEY HIDES
============================================================ */
.hide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.hcard{border:1.5px solid var(--gray-lt);padding:36px 28px;transition:border-color .2s,box-shadow .2s}
.hcard:hover{border-color:var(--navy);box-shadow:0 8px 32px rgba(11,31,58,.08)}
.htag{
  display:inline-block;background:var(--navy);color:var(--orange);
  font-family:var(--semi);font-weight:700;
  font-size:10px;letter-spacing:2px;text-transform:uppercase;
  padding:4px 12px;margin-bottom:18px;
}
.htitle{font-family:var(--impact);font-size:26px;color:var(--navy);margin-bottom:12px;line-height:1.05;letter-spacing:.3px}
.hbody{font-size:14px;line-height:1.7;color:var(--mid);margin-bottom:20px}
.htraps{border-top:1px solid var(--gray-lt);padding-top:16px}
.htrap-label{
  font-family:var(--semi);font-weight:700;
  font-size:10px;letter-spacing:2px;text-transform:uppercase;
  color:var(--navy);margin-bottom:10px;
}
.htrap{display:flex;gap:10px;margin-bottom:7px}
.htrap::before{content:'▸';color:var(--orange);font-size:11px;flex-shrink:0;margin-top:1px}
.htrap p{font-size:13px;color:var(--mid);line-height:1.5}

/* ============================================================
   SITUATIONS
============================================================ */
.sit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:3px;margin-top:56px}
.scard{
  background:var(--white);padding:44px 40px;
  display:block;transition:background .2s;
}
.scard:hover{background:var(--navy)}
.scard:hover .stitle,.scard:hover .sarrow{color:var(--white)}
.scard:hover .sbody,.scard:hover .sstake{color:var(--gray)}
.scard:hover .sstake-l{color:var(--orange)}
.snum{
  font-family:var(--semi);font-weight:700;
  font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:var(--orange);margin-bottom:14px;
}
.stitle{font-family:var(--impact);font-size:26px;color:var(--navy);margin-bottom:10px;line-height:1.05;letter-spacing:.3px;transition:color .2s}
.sbody{font-size:14px;line-height:1.65;color:var(--mid);margin-bottom:20px;transition:color .2s}
.sstake-l{font-family:var(--semi);font-weight:700;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--navy);margin-bottom:5px;transition:color .2s}
.sstake{font-size:13px;color:var(--mid);line-height:1.5;transition:color .2s}
.sarrow{display:block;margin-top:20px;font-family:var(--semi);font-weight:700;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--navy);transition:color .2s}

/* ============================================================
   HOW IT WORKS
============================================================ */
.how{background:var(--navy)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:56px}
.step{background:var(--navy-mid);padding:36px 28px}
.step-n{font-family:var(--impact);font-size:60px;color:var(--orange);opacity:.22;line-height:1;margin-bottom:16px}
.step-t{font-family:var(--impact);font-size:22px;color:var(--white);margin-bottom:10px;line-height:1.05;letter-spacing:.3px}
.step-b{font-size:13px;color:var(--gray);line-height:1.65}

/* ============================================================
   SERVICES
============================================================ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:56px}
.svc{border:1.5px solid var(--gray-lt);padding:40px 32px;position:relative;transition:border-color .2s}
.svc:hover{border-color:var(--navy)}
.svc.feat{border-color:var(--navy);border-width:2px}
.svc-pop{
  position:absolute;top:-1px;left:32px;
  background:var(--orange);color:#fff;
  font-family:var(--semi);font-weight:700;
  font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:3px 12px;
}
.svc-tag{font-family:var(--semi);font-weight:700;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--orange);margin-bottom:12px}
.svc-name{font-family:var(--impact);font-size:34px;color:var(--navy);margin-bottom:4px;letter-spacing:.3px}
.svc-who{font-size:13px;color:var(--mid);margin-bottom:20px;font-style:italic;line-height:1.5}
.svc-price{font-family:var(--impact);font-size:46px;color:var(--orange);margin-bottom:24px;line-height:1}
.svc-price span{font-family:var(--body);font-size:14px;color:var(--gray);font-weight:400}
.svc-list{list-style:none;margin-bottom:28px}
.svc-list li{font-size:13px;color:var(--mid);padding:7px 0 7px 18px;border-bottom:1px solid var(--gray-lt);position:relative;line-height:1.5}
.svc-list li::before{content:'→';position:absolute;left:0;color:var(--orange);font-size:11px}
.svc-btn{
  display:block;text-align:center;
  font-family:var(--semi);font-weight:700;
  font-size:13px;letter-spacing:1.5px;text-transform:uppercase;
  padding:13px 20px;transition:background .2s;
  background:var(--navy);color:#fff;
}
.svc-btn:hover{background:var(--navy-lt)}
.svc.feat .svc-btn{background:var(--orange)}
.svc.feat .svc-btn:hover{background:var(--orange-lt)}

/* ============================================================
   LEAD MAGNET
============================================================ */
.lead-band{background:var(--navy-mid)}
.lead-inner{
  max-width:var(--max);margin:0 auto;
  padding:80px var(--pad);
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;
}
.lead-hed{font-family:var(--impact);font-size:clamp(32px,4vw,54px);color:var(--white);line-height:.95;letter-spacing:-.3px;margin-bottom:16px}
.lead-body{font-size:16px;color:var(--gray);line-height:1.7;margin-bottom:28px}
.lead-form{display:flex}
.lead-input{
  flex:1;padding:14px 18px;border:none;
  font-family:var(--body);font-size:14px;
  background:var(--navy-lt);color:var(--white);outline:none;
}
.lead-input::placeholder{color:var(--gray)}
.lead-submit{
  background:var(--orange);color:#fff;
  font-family:var(--semi);font-weight:700;
  font-size:13px;letter-spacing:1.5px;text-transform:uppercase;
  padding:14px 22px;border:none;cursor:pointer;white-space:nowrap;
  transition:background .2s;
}
.lead-submit:hover{background:var(--orange-lt)}
.lead-fine{font-size:11px;color:var(--gray);margin-top:10px}
.pdf-preview{
  background:var(--white);border-radius:4px;
  box-shadow:0 20px 60px rgba(0,0,0,.4),0 4px 16px rgba(0,0,0,.3);
  overflow:hidden;max-width:280px;margin:0 auto;width:100%;
}
.pdf-cover{background:var(--navy);padding:28px 24px;position:relative}
.pdf-accent{position:absolute;top:0;left:0;width:4px;height:100%;background:var(--orange)}
.pdf-eyebrow{font-family:var(--semi);font-weight:700;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--orange);margin-bottom:14px}
.pdf-title{font-family:var(--impact);font-size:22px;color:var(--white);line-height:1.05;margin-bottom:12px}
.pdf-title em{color:var(--orange);font-style:normal}
.pdf-rule{width:50px;height:2px;background:var(--orange);margin:12px 0}
.pdf-sub{font-size:11px;color:var(--gray);line-height:1.5}
.pdf-foot{background:var(--navy-mid);padding:10px 16px;display:flex;align-items:center;justify-content:space-between}
.pdf-foot-logo{font-family:var(--impact);font-size:14px;color:var(--white);letter-spacing:.5px}
.pdf-foot-logo em{color:var(--orange);font-style:normal}
.pdf-foot-tag{font-family:var(--semi);font-weight:700;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--orange)}

/* ============================================================
   TESTIMONIALS
============================================================ */
.testi{background:var(--off)}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:56px}
.tcard{background:var(--white);padding:32px 26px;position:relative}
.tsavings{
  position:absolute;top:0;right:0;
  background:var(--navy);color:var(--orange);
  font-family:var(--impact);font-size:20px;
  padding:8px 14px;line-height:1;text-align:center;
}
.tsavings span{display:block;font-family:var(--semi);font-weight:600;font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--gray);margin-top:2px}
.tmark{font-family:Georgia,serif;font-size:44px;color:var(--orange);line-height:1;margin-bottom:8px}
.tbody{font-size:14px;line-height:1.7;color:var(--text);font-style:italic;margin-bottom:20px}
.tname{font-family:var(--impact);font-size:17px;color:var(--navy);letter-spacing:.5px}
.tdetail{font-size:11px;color:var(--gray);margin-top:2px}

/* ============================================================
   ABOUT
============================================================ */
.about{background:var(--navy)}
.about-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:start}
.about-p{font-size:15px;line-height:1.75;color:var(--gray);margin-bottom:16px}
.cred-list{margin-top:8px}
.cred{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.07);padding:16px 0}
.cred-n{font-family:var(--impact);font-size:13px;letter-spacing:2px;color:var(--orange);min-width:32px;padding-top:2px}
.cred-t{font-size:14px;color:var(--gray);line-height:1.6}
.cred-t strong{display:block;font-family:var(--impact);font-size:17px;letter-spacing:.3px;color:var(--white);margin-bottom:2px}

/* ============================================================
   CTA CLOSE
============================================================ */
.cta-close{background:var(--orange);padding:100px 0;display:grid;grid-template-columns:1fr 1fr}
.cta-close-left{
  display:flex;flex-direction:column;justify-content:center;
  padding:0 48px 0 var(--pad);
  max-width:calc(var(--max)/2 + var(--pad));
  margin-left:auto;
}
.cta-close-hed{
  font-family:var(--impact);
  font-size:clamp(56px,9vw,104px);
  color:#fff;line-height:.88;letter-spacing:-1px;margin-bottom:20px;
}
.cta-close-body{font-size:17px;color:rgba(255,255,255,.8);line-height:1.65;margin-bottom:36px;max-width:380px}
.cta-close-right{
  padding:0 var(--pad) 0 48px;
  max-width:calc(var(--max)/2 + var(--pad));
}
.cal-wrap{background:rgba(0,0,0,.12);padding:36px 32px}
.cal-label{font-family:var(--semi);font-weight:700;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:16px}
.cal-title{font-family:var(--impact);font-size:30px;color:#fff;margin-bottom:6px;line-height:1.05;letter-spacing:.3px}
.cal-sub{font-size:14px;color:rgba(255,255,255,.7);margin-bottom:28px;line-height:1.5}
.cal-slots{display:flex;flex-direction:column;gap:8px}
.cal-slot{
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  padding:12px 18px;display:flex;justify-content:space-between;align-items:center;
  cursor:pointer;transition:background .2s;
}
.cal-slot:hover{background:rgba(255,255,255,.22)}
.cal-slot-day{font-size:13px;color:#fff;font-weight:600}
.cal-slot-time{font-size:12px;color:rgba(255,255,255,.6)}
.cal-slot-badge{background:rgba(255,255,255,.15);color:#fff;font-family:var(--semi);font-weight:700;font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:3px 10px}
.cal-cta{
  display:block;text-align:center;background:#fff;color:var(--orange);
  font-family:var(--semi);font-weight:700;font-size:14px;letter-spacing:1.5px;text-transform:uppercase;
  padding:14px 24px;margin-top:18px;transition:transform .15s;
}
.cal-cta:hover{transform:translateY(-1px)}
.cal-reassure{font-size:11px;color:rgba(255,255,255,.5);text-align:center;margin-top:10px}

/* ============================================================
   RESPONSIVE
============================================================ */

/* Tablet — 960px */
@media(max-width:960px){
  :root{--pad:32px}

  /* Header */
  .header-nav a:not(.btn-primary){display:none}

  /* Hero */
  .hero-inner{grid-template-columns:1fr}
  .hero-right{display:none !important}
  .hero-left{padding:64px 0}

  /* Sections */
  .section{padding:72px 0}
  .section-sm{padding:56px 0}

  /* Grids collapse to 1 col */
  .dealer-cards,
  .hide-grid,
  .svc-grid,
  .t-grid{grid-template-columns:1fr}

  /* Sit grid stays 2 col on tablet */
  .sit-grid{grid-template-columns:1fr 1fr}

  /* Steps 2 col */
  .steps{grid-template-columns:repeat(2,1fr)}

  /* Lead magnet */
  .lead-inner{grid-template-columns:1fr}
  .pdf-preview{display:none}

  /* About */
  .about-inner{grid-template-columns:1fr;gap:40px}

  /* CTA close */
  .cta-close{grid-template-columns:1fr;padding:72px 0}
  .cta-close-left,.cta-close-right{max-width:100%;padding:0 var(--pad);margin:0 auto;max-width:var(--max)}
  .cta-close-left{margin-bottom:48px}

  /* Footer */
  .footer-main{grid-template-columns:1fr 1fr}

  /* Proof band */
  .proof-inner{gap:32px}
}

/* Mobile — 600px */
@media(max-width:600px){
  :root{--pad:20px}

  .section{padding:56px 0}
  .section-sm{padding:44px 0}

  /* Hero */
  .hero-hed{font-size:clamp(56px,14vw,80px)}
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn{text-align:center}
  .hero-stats{gap:24px}

  /* Sit grid single col on mobile */
  .sit-grid{grid-template-columns:1fr}
  .scard{padding:32px 24px}

  /* Steps single col */
  .steps{grid-template-columns:1fr}

  /* Lead form stack */
  .lead-form{flex-direction:column}
  .lead-submit{padding:14px}

  /* Proof band stack */
  .proof-inner{flex-direction:column;gap:20px;text-align:center}

  /* CTA close */
  .cta-close-hed{font-size:clamp(48px,12vw,72px)}

  /* Footer single col */
  .footer-main{grid-template-columns:1fr;padding:48px var(--pad) 32px}
  .footer-bottom{flex-direction:column;text-align:center;padding:16px var(--pad)}
  .footer-social{justify-content:center}

  /* Mark band */
  .mark-band{padding:48px var(--pad)}

  /* Stack callout */
  .stack-wrap{max-width:100%}
  .srow{height:auto;min-height:56px}
  .sbar{font-size:13px;padding:0 12px}
}

/* Accessibility */
@media(prefers-reduced-motion:reduce){
  *{transition:none !important;animation:none !important}
}

/* ============================================================
   NARRATIVE BAND
============================================================ */
.narrative-band{
  background:var(--off);
  padding:100px 0;
}
.narrative-inner{
  display:grid;
  grid-template-columns:1fr 1.6fr;
  gap:80px;
  align-items:start;
}
.narrative-hed{
  font-family:var(--impact);
  font-size:clamp(40px,5vw,64px);
  color:var(--navy);
  line-height:.95;
  letter-spacing:-.5px;
  margin-top:14px;
}
.narrative-body{
  font-size:17px;
  line-height:1.8;
  color:var(--text-mid);
  margin-bottom:18px;
}
.narrative-highlight{
  font-style:italic;
  color:var(--navy);
  font-weight:600;
  border-left:3px solid var(--orange);
  padding-left:16px;
  margin-left:0;
}

/* ============================================================
   MONEY SECTION
============================================================ */
.money-section{ background:var(--navy) }
.money-section .sec-hed{ color:var(--white) }
.money-section .sec-intro{ color:var(--gray) }

.money-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
  margin-top:56px;
}

.money-card{
  background:var(--navy-mid);
  padding:36px 28px;
  position:relative;
  transition:background .2s;
}
.money-card:hover{ background:var(--navy-lt) }
.money-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--orange);
}

.money-num{
  font-family:var(--impact);
  font-size:52px;
  color:var(--orange);
  opacity:.15;
  line-height:1;
  margin-bottom:12px;
  letter-spacing:-1px;
}

.money-title{
  font-family:var(--impact);
  font-size:26px;
  color:var(--white);
  margin-bottom:14px;
  line-height:1.05;
  letter-spacing:.3px;
}

.money-body{
  font-size:14px;
  line-height:1.75;
  color:var(--gray);
  margin-bottom:24px;
}

.money-saving{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:16px;
}
.money-saving-label{
  font-family:var(--semi);
  font-weight:700;
  font-size:10px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--gray);
  margin-bottom:6px;
}
.money-saving-val{
  font-family:var(--impact);
  font-size:22px;
  color:var(--orange);
  letter-spacing:.3px;
}

.money-total{
  margin-top:3px;
  background:var(--orange);
  padding:36px 40px;
  display:flex;
  align-items:center;
  gap:40px;
  flex-wrap:wrap;
}
.money-total-label{
  font-family:var(--semi);
  font-weight:700;
  font-size:12px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.8);
  flex:0 0 auto;
}
.money-total-val{
  font-family:var(--impact);
  font-size:clamp(32px,4vw,52px);
  color:#fff;
  letter-spacing:-1px;
  line-height:1;
  flex:0 0 auto;
}
.money-total-note{
  font-size:14px;
  color:rgba(255,255,255,.8);
  line-height:1.55;
  flex:1;
  min-width:200px;
}

/* ============================================================
   CARMAX BAND
============================================================ */
.carmax-band{
  background:var(--white);
  padding:100px 0;
  border-top:1px solid var(--gray-lt);
}
.carmax-inner{
  display:grid;
  grid-template-columns:1fr 1.6fr;
  gap:80px;
  align-items:start;
}
.carmax-hed{
  font-family:var(--impact);
  font-size:clamp(32px,4vw,50px);
  color:var(--navy);
  line-height:1;
  letter-spacing:-.3px;
  margin-top:14px;
}
.carmax-body{
  font-size:17px;
  line-height:1.8;
  color:var(--text-mid);
  margin-bottom:18px;
}
.carmax-highlight{
  color:var(--navy);
  font-weight:600;
}

/* ============================================================
   SERVICES — guarantee + launch offer
============================================================ */
.svc-grid-3{
  grid-template-columns:repeat(3,1fr);
}
.svc-guarantee{
  background:rgba(232,100,12,.08);
  border:1px solid rgba(232,100,12,.3);
  color:var(--orange);
  font-family:var(--semi);
  font-weight:700;
  font-size:12px;
  line-height:1.4;
  padding:10px 14px;
  margin-bottom:20px;
}

.svc-launch{
  margin-top:24px;
  background:var(--navy);
  padding:24px 32px;
}
.svc-launch-inner{
  display:flex;
  align-items:flex-start;
  gap:16px;
}
.svc-launch-icon{
  color:var(--orange);
  font-size:20px;
  flex-shrink:0;
  margin-top:2px;
}
.svc-launch-text{
  font-size:15px;
  color:var(--gray);
  line-height:1.65;
}
.svc-launch-text strong{
  color:var(--white);
}
.svc-launch-text a{
  color:var(--orange);
  font-weight:700;
}
.svc-launch-text a:hover{
  text-decoration:underline;
}

/* ============================================================
   RESPONSIVE ADDITIONS
============================================================ */
@media(max-width:960px){
  .narrative-inner{ grid-template-columns:1fr; gap:32px }
  .carmax-inner{ grid-template-columns:1fr; gap:32px }
  .money-grid{ grid-template-columns:1fr }
  .money-total{ flex-direction:column; gap:16px }
  .svc-grid-3{ grid-template-columns:1fr }
}

/* ── Contact form ── */
.contact-form{
  display:flex;flex-direction:column;gap:10px;
}
.cf-row{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
.cf-input{
  width:100%;padding:13px 16px;border:none;
  background:rgba(255,255,255,.12);
  color:#fff;font-family:var(--body);font-size:14px;
  outline:none;transition:background .2s;
}
.cf-input::placeholder{color:rgba(255,255,255,.45)}
.cf-input:focus{background:rgba(255,255,255,.2)}
.cf-textarea{height:90px;resize:vertical}
.cf-submit{
  background:#fff;color:var(--orange);
  font-family:var(--semi);font-weight:700;
  font-size:14px;letter-spacing:1.5px;text-transform:uppercase;
  padding:15px 24px;border:none;cursor:pointer;
  transition:transform .15s,box-shadow .15s;
  margin-top:4px;
}
.cf-submit:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,.2)}
.cf-fine{
  font-size:11px;color:rgba(255,255,255,.45);
  margin-top:4px;line-height:1.5;
}
@media(max-width:600px){
  .cf-row{grid-template-columns:1fr}
}

/* ── Form success state ── */
.cf-success{
  display:none;
  padding:40px 32px;
  text-align:center;
}
.cf-success-icon{
  font-size:48px;
  color:var(--orange);
  margin-bottom:16px;
  line-height:1;
}
.cf-success-title{
  font-family:var(--impact);
  font-size:36px;
  color:#fff;
  letter-spacing:.3px;
  margin-bottom:12px;
}
.cf-success-body{
  font-size:15px;
  color:rgba(255,255,255,.7);
  line-height:1.6;
  max-width:320px;
  margin:0 auto;
}
