/* =========================================================
   Fierce Auto Marketing — design system
   Navy #0d244d  ·  Gold accent  ·  Sora / Inter
   ========================================================= */

:root{
  /* Brand */
  --navy-900:#081834;
  --navy-800:#0d244d;   /* primary — sampled from logo */
  --navy-700:#143367;
  --navy-600:#1d4488;
  --navy-100:#e8edf6;
  --navy-50:#f4f7fc;

  --gold-500:#e8b04b;
  --gold-600:#d4972b;
  --gold-100:#fbeecb;

  --ink:#10182a;
  --slate:#516079;
  --line:#dce3ef;
  --white:#ffffff;
  --cream:#f7f9fd;

  --ok:#1f9d63;

  --font-display:'Sora',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;

  --wrap:1180px;
  --radius:18px;
  --radius-sm:10px;
  --shadow-sm:0 2px 8px rgba(13,36,77,.08);
  --shadow-md:0 14px 40px rgba(13,36,77,.12);
  --shadow-lg:0 30px 70px rgba(8,24,52,.22);

  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--white);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{font-family:var(--font-display);line-height:1.08;margin:0;letter-spacing:-.02em;font-weight:700}
p{margin:0 0 1.1rem}
p:last-child{margin-bottom:0}

.wrap{width:min(100% - 2.6rem,var(--wrap));margin-inline:auto}

.skip-link{position:absolute;left:-999px;top:0;background:var(--gold-500);color:var(--navy-900);
  padding:.6rem 1rem;border-radius:0 0 8px 0;z-index:200;font-weight:700}
.skip-link:focus{left:0}

:focus-visible{outline:3px solid var(--gold-500);outline-offset:3px;border-radius:4px}

/* ---------- Eyebrow / section heads ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--font-display);font-weight:700;font-size:.74rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--gold-600);
  margin:0 0 1rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--gold-500);display:inline-block}
.eyebrow--light{color:var(--gold-500)}
.eyebrow--center{justify-content:center}

.section{padding:clamp(3.5rem,7vw,6.5rem) 0}
.section--cream{background:var(--cream)}
.section--navy{background:var(--navy-800);color:#dfe7f4}
.section--navy h1,.section--navy h2,.section--navy h3{color:#fff}

.section-head{max-width:680px;margin-bottom:3rem}
.section-head--center{margin-inline:auto;text-align:center}
.section-title{font-size:clamp(1.9rem,4vw,2.9rem)}
.lead{font-size:1.18rem;color:var(--slate)}
.section--navy .lead{color:#aebfd9}

/* ---------- Buttons ---------- */
.btn{
  --b:var(--navy-800);
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--font-display);font-weight:700;font-size:.98rem;
  padding:.95rem 1.7rem;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,color .25s;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn--sm{padding:.65rem 1.2rem;font-size:.9rem}
.btn--gold{background:var(--gold-500);color:var(--navy-900);box-shadow:0 10px 24px rgba(212,151,43,.35)}
.btn--gold:hover{background:var(--gold-600);box-shadow:0 14px 30px rgba(212,151,43,.45)}
.btn--navy{background:var(--navy-800);color:#fff}
.btn--navy:hover{background:var(--navy-700)}
.btn--ghost{background:transparent;border-color:var(--navy-800);color:var(--navy-800)}
.btn--ghost:hover{background:var(--navy-800);color:#fff}
.btn--ghost-light{background:transparent;border-color:rgba(255,255,255,.6);color:#fff}
.btn--ghost-light:hover{background:#fff;color:var(--navy-900);border-color:#fff}

/* =========================================================
   Header / nav
   ========================================================= */
.site-header{
  position:sticky;top:0;z-index:100;
  background:var(--navy-800);
  transition:background .3s,box-shadow .3s;
}
.site-header.scrolled{box-shadow:0 6px 24px rgba(8,24,52,.28)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  min-height:74px}

.brand{display:flex;align-items:center}
.brand-logo{height:46px;width:auto}
.brand-logo--dark{display:none}

.primary-nav{display:flex;align-items:center;gap:2rem}
.primary-nav ul{display:flex;gap:1.5rem;list-style:none;margin:0;padding:0}
.primary-nav a{
  font-family:var(--font-display);font-weight:600;font-size:.92rem;color:#cdd8ee;
  padding:.4rem 0;position:relative;transition:color .2s;
}
.primary-nav a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--gold-500);
  transition:width .25s var(--ease);
}
.primary-nav a:hover{color:#fff}
.primary-nav a:hover::after,
.primary-nav a[aria-current="page"]::after{width:100%}
.primary-nav a[aria-current="page"]{color:#fff}

.nav-call{
  display:flex;flex-direction:column;line-height:1.1;
  padding:.5rem 1.1rem;border-radius:12px;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);transition:background .2s;
}
.nav-call:hover{background:rgba(232,176,75,.2)}
.nav-call__label{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-500);font-weight:700}
.nav-call__num{font-family:var(--font-display);font-weight:700;color:#fff;font-size:1.02rem}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:26px;height:2px;background:#fff;border-radius:2px;transition:.3s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* =========================================================
   Hero
   ========================================================= */
.hero{
  position:relative;overflow:hidden;
  background:
    linear-gradient(100deg,rgba(8,24,52,.78) 0%,rgba(13,36,77,.55) 45%,rgba(13,36,77,.35) 100%),
    url("../img/360_F_926260609_e8QS1OeQznCoj3JnE167VdAJu3pvzscg.jpg");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  color:#fff;
  padding:clamp(3.5rem,7vw,6rem) 0 clamp(4rem,8vw,7rem);
}
/* signature: forward-leaning speed stripes echoing the logo F */
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:repeating-linear-gradient(115deg,rgba(255,255,255,.035) 0 2px,transparent 2px 46px);
  mask-image:linear-gradient(90deg,transparent,#000 40%);
}
.hero__inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:3.5rem;align-items:center}
.hero__eyebrow{color:var(--gold-500)}
.hero h1{font-size:clamp(2.4rem,5.4vw,4.1rem);font-weight:800;letter-spacing:-.03em}
.hero h1 .accent{color:var(--gold-500)}
.hero__sub{font-size:1.2rem;color:#b9c8e4;max-width:48ch;margin-top:1.4rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.2rem}
.hero__stats{display:flex;gap:2.4rem;margin-top:3rem;flex-wrap:wrap}
.hero__stat .n{font-family:var(--font-display);font-weight:800;font-size:2rem;color:#fff;line-height:1}
.hero__stat .l{font-size:.82rem;color:#9fb2d4;letter-spacing:.04em;margin-top:.35rem}

.hero__panel{
  position:relative;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);padding:2rem;backdrop-filter:blur(4px);
  box-shadow:var(--shadow-lg);
}
.hero__panel h3{color:#fff;font-size:1.15rem;margin-bottom:1.2rem}
.hero__panel .quote-name{color:var(--gold-500);font-weight:600;margin-top:1rem;font-family:var(--font-display)}
.hero__panel-pic{display:flex;gap:1rem;align-items:center;margin-bottom:1.2rem}
.hero__panel-pic img{width:64px;height:64px;border-radius:50%;object-fit:cover;border:2px solid var(--gold-500)}
.hero__panel-pic .role{font-size:.82rem;color:#9fb2d4}
.hero__panel-pic .role strong{display:block;color:#fff;font-family:var(--font-display);font-size:1rem}

/* =========================================================
   Generic page hero (interior pages)
   ========================================================= */
.page-hero{
  background:linear-gradient(150deg,var(--navy-900),var(--navy-800));
  color:#fff;padding:clamp(3rem,6vw,5rem) 0;position:relative;overflow:hidden;
}
.page-hero::after{
  content:"";position:absolute;right:-60px;top:-40px;width:320px;height:320px;
  background:radial-gradient(circle,rgba(232,176,75,.18),transparent 70%);
}
.page-hero__inner{position:relative;max-width:760px}
.page-hero h1{font-size:clamp(2.1rem,4.6vw,3.4rem);font-weight:800;margin-top:.6rem}
.page-hero p{color:#b9c8e4;font-size:1.15rem;margin-top:1rem}

/* =========================================================
   Cards / grids
   ========================================================= */
.grid{display:grid;gap:1.6rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:2rem;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.card h3{font-size:1.25rem;margin-bottom:.6rem;color:var(--navy-800)}
.card p{color:var(--slate);margin:0}
.card__icon{
  width:52px;height:52px;border-radius:14px;display:grid;place-items:center;
  background:var(--navy-50);color:var(--navy-700);margin-bottom:1.2rem;
}
.card__icon svg{width:26px;height:26px}

/* numbered step cards */
.step{position:relative;padding-top:2.6rem}
.step__num{
  position:absolute;top:0;left:2rem;transform:translateY(-50%);
  width:48px;height:48px;border-radius:14px;background:var(--gold-500);color:var(--navy-900);
  font-family:var(--font-display);font-weight:800;font-size:1.25rem;
  display:grid;place-items:center;box-shadow:0 8px 18px rgba(212,151,43,.35);
}

/* =========================================================
   Split content blocks
   ========================================================= */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.split--media-right{direction:ltr}
.split__media img{border-radius:var(--radius);box-shadow:var(--shadow-md);width:100%}
.split__body p{color:var(--slate);font-size:1.05rem}
.split__body .section-title{margin-bottom:1.2rem}

/* feature list with checks */
.checklist{list-style:none;padding:0;margin:1.5rem 0 0;display:grid;gap:.9rem}
.checklist li{display:flex;gap:.8rem;align-items:flex-start;color:var(--ink)}
.checklist svg{flex:0 0 22px;width:22px;height:22px;color:var(--ok);margin-top:2px}

/* =========================================================
   Stats strip
   ========================================================= */
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.stat-block .n{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,4vw,2.8rem);color:var(--gold-500);line-height:1}
.stat-block .l{color:#aebfd9;font-size:.92rem;margin-top:.4rem}

/* =========================================================
   Money / table
   ========================================================= */
.money-table{
  width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-md);background:#fff;
}
.money-table th,.money-table td{padding:1.1rem 1.3rem;text-align:left}
.money-table thead th{background:var(--navy-800);color:#fff;font-family:var(--font-display);font-size:.86rem;
  letter-spacing:.03em;font-weight:600}
.money-table tbody td{border-top:1px solid var(--line);font-size:1.05rem}
.money-table .big{font-family:var(--font-display);font-weight:800;font-size:1.6rem;color:var(--gold-600)}

/* =========================================================
   FAQ accordion
   ========================================================= */
.faq{max-width:880px;margin-inline:auto;display:grid;gap:.9rem}
.faq__item{border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;overflow:hidden;
  transition:box-shadow .25s,border-color .25s}
.faq__item[open]{box-shadow:var(--shadow-sm);border-color:var(--navy-100)}
.faq__q{
  cursor:pointer;list-style:none;padding:1.25rem 1.4rem;display:flex;gap:1rem;align-items:center;
  font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--navy-800);
}
.faq__q::-webkit-details-marker{display:none}
.faq__q::before{
  content:"";flex:0 0 26px;width:26px;height:26px;border-radius:8px;background:var(--navy-50);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230d244d' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M12 5v14M5 12h14'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;background-size:16px;transition:transform .3s;
}
.faq__item[open] .faq__q::before{transform:rotate(45deg)}
.faq__num{color:var(--gold-600);font-weight:800;margin-right:.2rem}
.faq__a{padding:0 1.4rem 1.4rem calc(1.4rem + 26px + 1rem);color:var(--slate)}
.faq__a p{margin-bottom:.8rem}

/* =========================================================
   Testimonials
   ========================================================= */
.quote-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem;
  box-shadow:var(--shadow-sm);position:relative;
}
.quote-card::before{
  content:"\201C";position:absolute;top:.4rem;left:1.4rem;font-family:Georgia,serif;
  font-size:4rem;color:var(--gold-500);opacity:.35;line-height:1;
}
.quote-card p{font-style:italic;color:var(--ink);margin:1rem 0 1.2rem;position:relative}
.quote-card .who{font-family:var(--font-display);font-weight:700;color:var(--navy-800)}

/* results gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.gallery a{display:block;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);background:#fff;transition:transform .3s var(--ease),box-shadow .3s}
.gallery a:hover{transform:translateY(-4px) scale(1.01);box-shadow:var(--shadow-md)}
.gallery img{width:100%;height:100%;object-fit:cover}

/* =========================================================
   Pricing / product
   ========================================================= */
.price-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-md);max-width:560px;margin-inline:auto;
}
.price-card__top{background:var(--navy-800);color:#fff;padding:2rem;text-align:center}
.price-card__top .was{color:#9fb2d4;text-decoration:line-through;font-size:1.1rem}
.price-card__top .now{font-family:var(--font-display);font-weight:800;font-size:2.8rem;color:var(--gold-500)}
.price-card__body{padding:2rem}
.price-card__body p{color:var(--slate)}
.badge{display:inline-block;background:var(--gold-100);color:var(--gold-600);font-weight:700;
  font-family:var(--font-display);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.35rem .8rem;border-radius:999px;margin-bottom:1rem}

/* note / callout */
.note{
  background:var(--navy-50);border-left:4px solid var(--gold-500);border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  padding:1.3rem 1.5rem;color:var(--slate);
}
.note strong{color:var(--navy-800)}

/* compliance state pills */
.state-list{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.5rem}
.state-list a{
  font-family:var(--font-display);font-weight:600;font-size:.86rem;
  padding:.55rem 1.1rem;border-radius:999px;background:#fff;border:1px solid var(--line);
  color:var(--navy-800);transition:.2s;
}
.state-list a:hover{background:var(--navy-800);color:#fff;border-color:var(--navy-800)}

/* =========================================================
   Contact
   ========================================================= */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.contact-cta{background:var(--navy-800);color:#fff;border-radius:var(--radius);padding:2.5rem;box-shadow:var(--shadow-md)}
.contact-cta h3{color:#fff;font-size:1.5rem;margin-bottom:1rem}
.contact-cta .big-phone{font-family:var(--font-display);font-weight:800;font-size:2.4rem;color:var(--gold-500);display:block;margin:1rem 0}
.form-field{margin-bottom:1.2rem}
.form-field label{display:block;font-family:var(--font-display);font-weight:600;font-size:.9rem;margin-bottom:.4rem;color:var(--navy-800)}
.form-field input,.form-field textarea{
  width:100%;padding:.85rem 1rem;border:1px solid var(--line);border-radius:var(--radius-sm);
  font-family:var(--font-body);font-size:1rem;transition:border-color .2s,box-shadow .2s;background:#fff;
}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--navy-600);box-shadow:0 0 0 3px rgba(29,68,136,.15)}

/* =========================================================
   CTA band + footer
   ========================================================= */
.cta-band{
  background:linear-gradient(120deg,var(--gold-500),var(--gold-600));
  color:var(--navy-900);
}
.cta-band__inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;
  padding:clamp(2.2rem,4vw,3rem) 0;flex-wrap:wrap}
.cta-band__eyebrow{font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  letter-spacing:.14em;font-size:.78rem;margin:0 0 .4rem}
.cta-band__title{font-size:clamp(1.5rem,3vw,2.1rem);color:var(--navy-900)}
.cta-band__actions{display:flex;gap:1rem;flex-wrap:wrap}
.cta-band .btn--ghost-light{border-color:var(--navy-900);color:var(--navy-900)}
.cta-band .btn--ghost-light:hover{background:var(--navy-900);color:#fff}

.site-footer{background:var(--navy-900);color:#aebfd9}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1.3fr;gap:2.5rem;
  padding:clamp(3rem,5vw,4.5rem) 0 2.5rem}
.footer-logo{height:54px;width:auto;margin-bottom:1rem}
.footer-motto{font-family:var(--font-display);font-style:italic;color:var(--gold-500);font-size:1.1rem}
.footer-nav h3,.footer-contact h3{font-family:var(--font-display);color:#fff;font-size:1rem;
  letter-spacing:.06em;text-transform:uppercase;margin-bottom:1.1rem}
.footer-nav ul{list-style:none;padding:0;margin:0;display:grid;gap:.6rem}
.footer-nav a:hover{color:var(--gold-500)}
.footer-phone{font-family:var(--font-display);font-weight:800;font-size:1.7rem;color:#fff;display:block;margin-bottom:.8rem}
.footer-phone:hover{color:var(--gold-500)}
.footer-contact p{font-size:.95rem;margin-bottom:1.2rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1)}
.footer-bottom__inner{display:flex;justify-content:space-between;gap:1rem;padding:1.4rem 0;flex-wrap:wrap;font-size:.88rem}
.footer-bottom a:hover{color:var(--gold-500)}

/* =========================================================
   Reveal-on-scroll
   ========================================================= */
/* Content is visible by default; the hidden start state only applies when JS is
   active (html.js), so no-JS users and pre-observer paint never see blank gaps. */
.reveal{opacity:1;transform:none}
.js .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal.in{opacity:1;transform:none}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:960px){
  .hero__inner{grid-template-columns:1fr;gap:2.5rem}
  .split{grid-template-columns:1fr;gap:2rem}
  .split__media{order:-1}
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .stats-strip{grid-template-columns:repeat(2,1fr);gap:2rem}
  .contact-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:760px){
  .nav-toggle{display:flex}
  .primary-nav{
    position:fixed;inset:74px 0 auto 0;background:var(--navy-900);
    flex-direction:column;align-items:stretch;gap:0;padding:1rem 1.3rem 1.6rem;
    transform:translateY(-120%);transition:transform .35s var(--ease);
    box-shadow:0 20px 40px rgba(0,0,0,.4);max-height:calc(100vh - 74px);overflow:auto;
  }
  .primary-nav.open{transform:translateY(0)}
  .primary-nav ul{flex-direction:column;gap:0}
  .primary-nav li{border-bottom:1px solid rgba(255,255,255,.08)}
  .primary-nav a{display:block;padding:.95rem 0;font-size:1.05rem}
  .primary-nav a::after{display:none}
  .nav-call{margin-top:1.2rem;flex-direction:row;justify-content:center;gap:.5rem;align-items:baseline}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .cta-band__inner{flex-direction:column;align-items:flex-start}
  .footer-bottom__inner{flex-direction:column}
}
@media (max-width:520px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .hero__stats{gap:1.6rem}
  .money-table{display:block;overflow-x:auto}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .js .reveal{opacity:1;transform:none}
}
