/* =========================================================================
   VELOCE MOTORS — stylesheet
   Aesthetic: luxury automotive editorial. Near-black ink + warm paper,
   single racing-red accent, Didone display serif over an industrial grotesque.
   All media is external (images/ folder), nothing baked in.
   ========================================================================= */

/* ---------- Tokens ---------- */
:root{
  --ink:#0a0a0c;
  --ink-2:#101013;
  --ink-3:#16161a;
  --paper:#f4f3ef;
  --paper-2:#eae8e2;
  --white:#ffffff;

  --red:#e11414;
  --red-bright:#ff1f1f;
  --red-deep:#9c0d0d;

  --t-dark:#f4f3ef;                 /* primary text on dark */
  --t-dark-muted:rgba(244,243,239,.58);
  --t-dark-faint:rgba(244,243,239,.38);
  --line-dark:rgba(255,255,255,.12);

  --t-light:#15151a;                /* primary text on paper */
  --t-light-muted:#6a6a70;
  --line-light:rgba(0,0,0,.12);

  --serif:'Playfair Display', Georgia, serif;
  --sans:'Archivo', 'Helvetica Neue', Arial, sans-serif;

  --maxw:1280px;
  --pad:clamp(1.25rem, 4vw, 4rem);
  --ease:cubic-bezier(.2,.7,.2,1);
  --radius:3px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--ink);
  color:var(--t-dark);
  line-height:1.6;
  font-size:16px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font-family:inherit;font-size:inherit}
ul{list-style:none}
::selection{background:var(--red);color:#fff}

/* ---------- Scroll progress bar ---------- */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:0;z-index:200;
  background:linear-gradient(90deg,var(--red-deep),var(--red),var(--red-bright));
  box-shadow:0 0 12px rgba(225,20,20,.7);
  transition:width .08s linear;
}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:clamp(4rem,8vw,7.5rem)}
.section--paper{background:var(--paper);color:var(--t-light)}
.section--ink{background:var(--ink);color:var(--t-dark)}

/* ---------- Eyebrow / kicker ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-size:.68rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  color:var(--red);margin-bottom:1.4rem;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--red);display:inline-block}
.section--ink .eyebrow{color:var(--red-bright)}

/* ---------- Section titles ---------- */
.s-title{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(2rem,4.4vw,3.4rem);
  line-height:1.04;
  letter-spacing:-.01em;
}
.s-title .accent{color:var(--red)}
.s-lead{
  max-width:46ch;color:var(--t-light-muted);margin-top:1.3rem;font-size:1.02rem;
}
.section--ink .s-lead{color:var(--t-dark-muted)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  padding:1rem 1.9rem;font-size:.74rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;border-radius:var(--radius);
  transition:transform .35s var(--ease),background .3s,color .3s,box-shadow .3s,border-color .3s;
  will-change:transform;position:relative;overflow:hidden;white-space:nowrap;
}
.btn svg{width:15px;height:15px}
.btn-red{background:var(--red);color:#fff;box-shadow:0 8px 30px -10px rgba(225,20,20,.7)}
.btn-red:hover{background:var(--red-bright);box-shadow:0 14px 44px -10px rgba(225,20,20,.9)}
.btn-outline{border:1px solid var(--line-dark);color:var(--t-dark);backdrop-filter:blur(4px)}
.btn-outline:hover{border-color:var(--t-dark);background:rgba(255,255,255,.06)}
.section--paper .btn-outline{border-color:rgba(0,0,0,.25);color:var(--t-light)}
.section--paper .btn-outline:hover{background:#15151a;color:#fff;border-color:#15151a}
.btn-ghost{
  font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.6rem;color:var(--t-light);
  transition:gap .3s,color .3s;
}
.btn-ghost svg{transition:transform .3s var(--ease)}
.btn-ghost:hover{color:var(--red)}
.btn-ghost:hover svg{transform:translateX(6px)}
.section--ink .btn-ghost{color:var(--t-dark)}
.section--ink .btn-ghost:hover{color:var(--red-bright)}

/* shine sweep on solid buttons */
.btn-red::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform .7s var(--ease);
}
.btn-red:hover::after{transform:translateX(120%)}

/* =========================================================================
   HEADER
   ========================================================================= */
.header{
  position:fixed;top:0;left:0;width:100%;z-index:150;
  transition:background .4s,backdrop-filter .4s,box-shadow .4s,padding .4s;
  padding-block:1.1rem;
}
.header.scrolled{
  background:rgba(8,8,10,.82);backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line-dark);padding-block:.65rem;
}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.brand img{height:82px;width:auto;transition:height .4s;flex-shrink:0}
.header.scrolled .brand img{height:60px}
.nav{display:flex;align-items:center;gap:1.75rem}
.nav a{
  font-size:.74rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  color:var(--t-dark-muted);position:relative;padding-block:.3rem;transition:color .3s;
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--red);
  transition:width .35s var(--ease);
}
.nav a:hover,.nav a.active{color:var(--white)}
.nav a:hover::after,.nav a.active::after{width:100%}
.header__cta{display:flex;align-items:center;gap:1.2rem;flex-shrink:0}
.header__cta .btn{padding:.8rem 1.4rem;flex-shrink:0}
.burger{display:none;width:30px;height:22px;position:relative;z-index:160}
.burger span{
  position:absolute;left:0;height:2px;width:100%;background:var(--white);border-radius:2px;
  transition:transform .35s var(--ease),opacity .25s,top .35s;
}
.burger span:nth-child(1){top:2px}
.burger span:nth-child(2){top:10px}
.burger span:nth-child(3){top:18px}
body.menu-open .burger span:nth-child(1){top:10px;transform:rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){top:10px;transform:rotate(-45deg)}

/* =========================================================================
   HERO
   ========================================================================= */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:var(--ink)}
.hero__bg{
  position:absolute;inset:-8% 0;background:url('images/1-hero.png') center right/cover no-repeat;
  transform:scale(1.08);animation:heroZoom 18s ease-in-out infinite alternate;will-change:transform;
}
@keyframes heroZoom{from{transform:scale(1.08)}to{transform:scale(1.16)}}
.hero__scrim{
  position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(8,8,10,.96) 0%,rgba(8,8,10,.9) 26%,rgba(8,8,10,.5) 56%,rgba(8,8,10,.55) 100%),
    linear-gradient(0deg,var(--ink) 2%,transparent 34%);
}
.hero .container{position:relative;z-index:2;width:100%}
.hero__inner{max-width:780px;padding-top:5rem}
.hero h1{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(2.5rem,5.6vw,4.7rem);line-height:1.04;letter-spacing:-.005em;
  text-shadow:0 2px 30px rgba(0,0,0,.55);
}
.hero h1 .line>span{white-space:nowrap}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line>span{display:block;transform:translateY(110%);opacity:0}
.hero p.sub{
  margin-top:1.8rem;max-width:44ch;color:var(--t-dark-muted);font-size:1.08rem;line-height:1.7;
  opacity:0;transform:translateY(20px);
}
.hero__actions{margin-top:2.6rem;display:flex;gap:1rem;flex-wrap:wrap;opacity:0;transform:translateY(20px)}
.hero__scrolldown{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--t-dark-faint);
}
.hero__scrolldown .mouse{width:22px;height:34px;border:1px solid var(--t-dark-faint);border-radius:12px;position:relative}
.hero__scrolldown .mouse::after{
  content:"";position:absolute;top:6px;left:50%;width:3px;height:6px;background:var(--red);border-radius:2px;
  transform:translateX(-50%);animation:wheel 1.6s infinite;
}
@keyframes wheel{0%{opacity:0;top:6px}40%{opacity:1}100%{opacity:0;top:16px}}

/* hero load animation (added via .is-loaded on body) */
body.is-loaded .hero h1 .line>span{animation:riseIn .9s var(--ease) forwards}
body.is-loaded .hero h1 .line:nth-child(1)>span{animation-delay:.15s}
body.is-loaded .hero h1 .line:nth-child(2)>span{animation-delay:.28s}
body.is-loaded .hero h1 .line:nth-child(3)>span{animation-delay:.41s}
body.is-loaded .hero p.sub{animation:fadeUp .8s var(--ease) .6s forwards}
body.is-loaded .hero__actions{animation:fadeUp .8s var(--ease) .75s forwards}
@keyframes riseIn{to{transform:translateY(0);opacity:1}}
@keyframes fadeUp{to{transform:translateY(0);opacity:1}}

/* =========================================================================
   STATS STRIP
   ========================================================================= */
.stats{background:var(--ink-2);border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark)}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{
  display:flex;align-items:center;gap:1.1rem;padding:1.9rem var(--pad);
  border-right:1px solid var(--line-dark);
}
.stats__grid .stat:last-child{border-right:none}
.stat__icon{color:var(--red);flex-shrink:0}
.stat__icon svg{width:30px;height:30px;stroke-width:1.4}
.stat>span:last-child{display:flex;flex-direction:column}
.stat__num{display:block;font-family:var(--serif);font-size:1.55rem;font-weight:600;line-height:1}
.stat__label{display:block;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--t-dark-muted);margin-top:.35rem}

/* =========================================================================
   SECTION HEAD (title + side action)
   ========================================================================= */
.head-row{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;flex-wrap:wrap;margin-bottom:3rem}

/* =========================================================================
   VEHICLE CARDS
   ========================================================================= */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.card{
  background:var(--white);border:1px solid var(--line-light);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s;
  transform-style:preserve-3d;
}
.card:hover{box-shadow:0 30px 60px -28px rgba(0,0,0,.45);border-color:rgba(0,0,0,.2)}
.card__media{position:relative;aspect-ratio:4/3;overflow:hidden;background:#0e0e10}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.card:hover .card__media img{transform:scale(1.07)}
.card__badge{
  position:absolute;top:.85rem;left:.85rem;z-index:2;
  background:var(--red);color:#fff;font-size:.58rem;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;padding:.4rem .65rem;border-radius:2px;
}
.card__badge.alt{background:#15151a}
.card__body{padding:1.4rem;display:flex;flex-direction:column;flex:1}
.card__name{font-family:var(--serif);font-size:1.18rem;font-weight:600;letter-spacing:-.01em;line-height:1.15}
.card__specs{
  display:flex;flex-wrap:wrap;gap:.35rem .7rem;margin-top:.8rem;
  font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--t-light-muted);
}
.card__specs span{position:relative}
.card__specs span:not(:last-child)::after{content:"·";margin-left:.7rem;color:var(--red)}
.card__price{font-family:var(--serif);color:var(--red);font-weight:600;font-size:1.15rem;margin-top:1.1rem}
.card__btn{
  margin-top:1.2rem;width:100%;padding:.85rem;border:1px solid rgba(0,0,0,.2);
  font-size:.68rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;border-radius:2px;
  transition:background .3s,color .3s,border-color .3s;
}
.card__btn:hover{background:#15151a;color:#fff;border-color:#15151a}

/* =========================================================================
   EXCELLENCE (why veloce)
   ========================================================================= */
.excellence{position:relative;overflow:hidden;background:var(--ink)}
.excellence__bg{
  position:absolute;inset:0;background:url('images/6-car-bg.png') center/cover no-repeat;opacity:.5;
}
.excellence__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,var(--ink) 0%,rgba(10,10,12,.6) 40%,var(--ink) 100%)}
.excellence .container{position:relative;z-index:2}
.excellence__head{max-width:560px;margin-bottom:3.4rem}
.feat-row{display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem;border-top:1px solid var(--line-dark);padding-top:2.4rem}
.feat{padding-right:1rem}
.feat__icon{
  width:46px;height:46px;border:1px solid var(--red);border-radius:50%;
  display:grid;place-items:center;color:var(--red-bright);margin-bottom:1.1rem;
  transition:background .35s,transform .35s var(--ease);
}
.feat:hover .feat__icon{background:var(--red);color:#fff;transform:translateY(-4px)}
.feat__icon svg{width:20px;height:20px}
.feat h3{font-size:.92rem;letter-spacing:.04em;font-weight:600;margin-bottom:.5rem}
.feat p{font-size:.82rem;color:var(--t-dark-muted);line-height:1.6}

/* =========================================================================
   SHOWROOM EXPERIENCE
   ========================================================================= */
.showroom__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:3.5rem;align-items:center}
.showroom__copy .s-lead{margin-bottom:2rem}
.showroom__gallery{display:grid;grid-template-columns:1.4fr 1fr;grid-template-rows:1fr 1fr;gap:1rem;height:clamp(360px,42vw,520px)}
.showroom__gallery figure{overflow:hidden;border-radius:var(--radius);position:relative}
.showroom__gallery figure:first-child{grid-row:1/3}
.showroom__gallery img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.showroom__gallery figure:hover img{transform:scale(1.06)}

/* =========================================================================
   SERVICES
   ========================================================================= */
.services{position:relative;overflow:hidden;background:var(--ink-2)}
.services__bg{position:absolute;inset:0;background:url('images/10a-carrear-bg.png') center right/cover no-repeat;opacity:.55}
.services__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--ink) 8%,rgba(16,16,19,.3) 70%,rgba(16,16,19,.7))}
.services .container{position:relative;z-index:2}
.services__head{max-width:520px;margin-bottom:3rem}
.serv-row{display:grid;grid-template-columns:repeat(5,1fr);gap:1.4rem;border-top:1px solid var(--line-dark);padding-top:2.4rem}
.serv__icon{color:var(--red-bright);margin-bottom:1rem}
.serv__icon svg{width:26px;height:26px;stroke-width:1.4}
.serv h3{font-size:.9rem;font-weight:600;margin-bottom:.45rem}
.serv p{font-size:.8rem;color:var(--t-dark-muted)}

/* =========================================================================
   PERFORMANCE SPOTLIGHT
   ========================================================================= */
.spotlight{
  position:relative;overflow:hidden;
  background:linear-gradient(100deg,var(--ink) 0%,var(--ink) 40%,#2a2a2e 62%,#cfcdc8 100%);
  padding-block:clamp(4rem,7vw,6.5rem);
}
.spotlight__grid{display:grid;grid-template-columns:1fr 1.25fr;gap:2rem;align-items:center;position:relative;z-index:2}
.spotlight__copy{max-width:440px}
.spotlight h2{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:600;line-height:1.02;margin-bottom:.4rem}
.spotlight .tagline{font-family:var(--serif);font-style:italic;color:var(--red-bright);font-size:1.2rem;margin-bottom:1.3rem}
.spotlight p.desc{color:var(--t-dark-muted);font-size:1rem;margin-bottom:1.8rem}
.spec-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem 1rem;margin-bottom:2rem}
.spec{display:flex;gap:.8rem;align-items:flex-start}
.spec__icon{color:var(--red-bright);flex-shrink:0;margin-top:2px}
.spec__icon svg{width:20px;height:20px;stroke-width:1.4}
.spec>span:last-child{display:flex;flex-direction:column}
.spec__num{display:block;font-family:var(--serif);font-size:1.4rem;font-weight:600;line-height:1}
.spec__cap{display:block;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--t-dark-muted);margin-top:.3rem}
.spotlight__price{font-family:var(--serif);color:var(--red-bright);font-size:1.5rem;font-weight:600;margin-bottom:1.4rem}
.spotlight__car{position:relative}
.spotlight__car img{width:100%;height:auto;filter:drop-shadow(0 40px 50px rgba(0,0,0,.4));transform:translateX(40px);opacity:0;transition:transform 1s var(--ease),opacity 1s var(--ease)}
.spotlight.in-view .spotlight__car img{transform:translateX(0);opacity:1}

/* =========================================================================
   TESTIMONIALS
   ========================================================================= */
.testimonials{background:var(--ink)}
.test__head{margin-bottom:3rem}
.test-track{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem}
.test{position:relative;padding-left:1rem}
.test::before{
  content:"\201C";position:absolute;top:-1.6rem;left:-.4rem;
  font-family:var(--serif);font-size:5rem;color:var(--red);line-height:1;opacity:.85;
}
.test p{font-size:1rem;line-height:1.75;color:var(--t-dark);margin-bottom:1.6rem;font-style:italic}
.test__name{font-weight:600;font-size:.9rem;letter-spacing:.04em}
.test__city{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--t-dark-faint);margin-top:.2rem}
.test__divider{width:30px;height:2px;background:var(--red);margin-top:1.2rem}
.test-dots{display:none;justify-content:center;gap:.6rem;margin-top:2.2rem}
.test-dots button{width:9px;height:9px;border-radius:50%;background:var(--line-dark);transition:background .3s,transform .3s}
.test-dots button.active{background:var(--red);transform:scale(1.25)}

/* =========================================================================
   BRAND STRIP
   ========================================================================= */
.brands{background:var(--ink);padding-block:3.4rem;border-top:1px solid var(--line-dark)}
.brands .container{max-width:1640px}
.brands img{margin-inline:auto;max-height:240px;width:auto;max-width:100%;opacity:.9;filter:grayscale(1) contrast(1.05);transition:opacity .4s,filter .4s}
.brands:hover img{opacity:1;filter:grayscale(0)}

/* =========================================================================
   CONTACT
   ========================================================================= */
.contact{background:var(--paper);color:var(--t-light)}
.contact__grid{display:grid;grid-template-columns:1fr 1.15fr 1.05fr;gap:2.5rem;align-items:start}
.contact__info h2{margin-block:1rem 2rem}
.info-row{display:flex;gap:1rem;padding-block:1.1rem;border-top:1px solid var(--line-light)}
.info-row:last-child{border-bottom:1px solid var(--line-light)}
.info-row .ic{color:var(--red);flex-shrink:0;margin-top:3px}
.info-row .ic svg{width:18px;height:18px;stroke-width:1.6}
.info-row .lbl{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--t-light-muted)}
.info-row .val{font-weight:500;margin-top:.15rem}
.contact__map{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line-light);position:relative;min-height:320px;height:100%}
.contact__map img{width:100%;height:100%;object-fit:cover}
.contact__map .pin-pulse{
  position:absolute;top:46%;left:48%;width:16px;height:16px;border-radius:50%;
  background:var(--red);transform:translate(-50%,-50%);box-shadow:0 0 0 0 rgba(225,20,20,.6);
  animation:pinPulse 2s infinite;
}
@keyframes pinPulse{0%{box-shadow:0 0 0 0 rgba(225,20,20,.55)}70%{box-shadow:0 0 0 22px rgba(225,20,20,0)}100%{box-shadow:0 0 0 0 rgba(225,20,20,0)}}

/* form */
.form-card{background:var(--white);border:1px solid var(--line-light);border-radius:var(--radius);padding:1.8rem}
.form-card h3{font-family:var(--serif);font-size:1.4rem;font-weight:600;margin-bottom:1.4rem}
.field{margin-bottom:.9rem}
.field input,.field textarea{
  width:100%;padding:.95rem 1rem;background:var(--paper);border:1px solid var(--line-light);
  border-radius:2px;color:var(--t-light);transition:border-color .3s,background .3s;
}
.field input::placeholder,.field textarea::placeholder{color:#9a9aa0;font-size:.92rem}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--red);background:#fff}
.field textarea{resize:vertical;min-height:90px}
.field.err input,.field.err textarea{border-color:var(--red)}
.form-card .btn{width:100%;margin-top:.4rem}
.form-success{
  text-align:center;padding:2rem 1rem;display:none;
}
.form-success.show{display:block;animation:fadeUp .5s var(--ease)}
.form-success .check{width:54px;height:54px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;margin:0 auto 1rem}
.form-success h4{font-family:var(--serif);font-size:1.3rem;margin-bottom:.4rem}
.form-success p{color:var(--t-light-muted);font-size:.9rem}

/* =========================================================================
   FOOTER
   ========================================================================= */
.footer{background:#070708;color:var(--t-dark);padding-top:clamp(3rem,5vw,4.5rem)}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1.2fr;gap:2.2rem;padding-bottom:3rem;border-bottom:1px solid var(--line-dark)}
.footer__brand img{height:68px;width:auto;margin-bottom:1.2rem}
.footer__brand p{font-size:.85rem;color:var(--t-dark-muted);max-width:30ch;margin-bottom:1.4rem}
.socials{display:flex;gap:.7rem}
.socials a{
  width:38px;height:38px;border:1px solid var(--line-dark);border-radius:50%;
  display:grid;place-items:center;color:var(--t-dark-muted);transition:all .3s;
}
.socials a:hover{background:var(--red);color:#fff;border-color:var(--red);transform:translateY(-3px)}
.socials svg{width:16px;height:16px}
.fcol h4{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--t-dark-faint);margin-bottom:1.2rem}
.fcol a{display:block;font-size:.88rem;color:var(--t-dark-muted);padding-block:.4rem;transition:color .3s,padding-left .3s}
.fcol a:hover{color:var(--white);padding-left:6px}
.fnews p{font-size:.85rem;color:var(--t-dark-muted);margin-bottom:1rem}
.fnews form{display:flex;border:1px solid var(--line-dark);border-radius:2px;overflow:hidden}
.fnews input{flex:1;background:transparent;border:none;padding:.85rem 1rem;color:#fff}
.fnews input:focus{outline:none}
.fnews input::placeholder{color:var(--t-dark-faint)}
.fnews button{background:var(--red);color:#fff;width:50px;display:grid;place-items:center;transition:background .3s}
.fnews button:hover{background:var(--red-bright)}
.fnews .msg{font-size:.74rem;color:var(--red-bright);margin-top:.6rem;height:1rem}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-block:1.6rem;flex-wrap:wrap}
.footer__bottom p{font-size:.76rem;color:var(--t-dark-faint)}
.footer__legal{display:flex;gap:1.6rem}
.footer__legal a{font-size:.76rem;color:var(--t-dark-faint);transition:color .3s}
.footer__legal a:hover{color:var(--t-dark)}

/* =========================================================================
   MODAL (vehicle detail)
   ========================================================================= */
.modal{
  position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;
  padding:1.5rem;opacity:0;pointer-events:none;transition:opacity .35s;
}
.modal.open{opacity:1;pointer-events:auto}
.modal__overlay{position:absolute;inset:0;background:rgba(5,5,7,.8);backdrop-filter:blur(6px)}
.modal__box{
  position:relative;width:min(960px,100%);max-height:90vh;overflow:auto;
  background:var(--ink-2);border:1px solid var(--line-dark);border-radius:var(--radius);
  display:grid;grid-template-columns:1.1fr 1fr;transform:translateY(24px) scale(.98);
  transition:transform .4s var(--ease);
}
.modal.open .modal__box{transform:translateY(0) scale(1)}
.modal__media{position:relative;background:#0c0c0e;min-height:320px}
.modal__media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.modal__close{
  position:absolute;top:1rem;right:1rem;z-index:5;width:40px;height:40px;border-radius:50%;
  background:rgba(0,0,0,.5);color:#fff;display:grid;place-items:center;transition:background .3s,transform .3s;
}
.modal__close:hover{background:var(--red);transform:rotate(90deg)}
.modal__body{padding:2.2rem}
.modal__badge{display:inline-block;background:var(--red);color:#fff;font-size:.58rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;padding:.35rem .6rem;border-radius:2px;margin-bottom:1rem}
.modal__name{font-family:var(--serif);font-size:1.9rem;font-weight:600;line-height:1.05;margin-bottom:.4rem}
.modal__price{font-family:var(--serif);color:var(--red-bright);font-size:1.4rem;font-weight:600;margin-bottom:1.4rem}
.modal__specs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-dark);border:1px solid var(--line-dark);margin-bottom:1.6rem}
.modal__specs div{background:var(--ink-2);padding:.85rem 1rem}
.modal__specs .k{font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--t-dark-faint)}
.modal__specs .v{font-weight:600;margin-top:.2rem;font-size:.95rem}
.modal__desc{color:var(--t-dark-muted);font-size:.92rem;margin-bottom:1.6rem;line-height:1.7}
.modal__actions{display:flex;gap:.8rem;flex-wrap:wrap}

/* =========================================================================
   INVENTORY PAGE
   ========================================================================= */
.page-head{
  position:relative;padding-top:clamp(8rem,14vw,11rem);padding-bottom:clamp(3rem,5vw,4rem);
  background:var(--ink);overflow:hidden;
}
.page-head__bg{position:absolute;inset:0;background:url('images/7-showroom1.png') center/cover no-repeat;opacity:.34}
.page-head__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,12,.6),var(--ink))}
.page-head .container{position:relative;z-index:2}
.page-head h1{font-family:var(--serif);font-size:clamp(2.4rem,6vw,4.2rem);font-weight:500;line-height:1;letter-spacing:-.01em}
.page-head .crumb{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--t-dark-faint);margin-bottom:1rem}
.page-head .crumb a:hover{color:var(--red-bright)}

.filters{
  position:sticky;top:0;z-index:90;background:rgba(8,8,10,.9);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line-dark);padding-block:1rem;
}
.filters__inner{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.chip-row{display:flex;gap:.5rem;flex-wrap:wrap}
.chip{
  padding:.55rem 1rem;border:1px solid var(--line-dark);border-radius:40px;
  font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--t-dark-muted);
  transition:all .3s;
}
.chip:hover{border-color:var(--t-dark-muted);color:var(--white)}
.chip.active{background:var(--red);border-color:var(--red);color:#fff}
.filters__right{margin-left:auto;display:flex;gap:.7rem;align-items:center;flex-wrap:wrap}
.search-box{position:relative}
.search-box svg{position:absolute;left:.8rem;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--t-dark-faint)}
.search-box input{
  background:var(--ink-3);border:1px solid var(--line-dark);border-radius:40px;
  padding:.6rem 1rem .6rem 2.3rem;color:#fff;width:200px;transition:border-color .3s,width .3s;
}
.search-box input:focus{outline:none;border-color:var(--red);width:240px}
.select-box select{
  background:var(--ink-3);border:1px solid var(--line-dark);border-radius:40px;
  padding:.6rem 2.2rem .6rem 1rem;color:var(--t-dark-muted);
  appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath d='M1 3l4 4 4-4' stroke='%23888' fill='none' stroke-width='1.4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center;
}
.select-box select:focus{outline:none;border-color:var(--red)}
.inv-meta{padding-block:1.6rem .4rem;color:var(--t-dark-muted);font-size:.8rem;letter-spacing:.05em}
.inv-meta b{color:var(--white);font-weight:600}
.inv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;padding-bottom:2rem}
.inv-grid .card{background:var(--ink-2);border-color:var(--line-dark);color:var(--t-dark)}
.inv-grid .card:hover{box-shadow:0 30px 60px -28px rgba(0,0,0,.7);border-color:rgba(255,255,255,.25)}
.inv-grid .card__name{color:var(--t-dark)}
.inv-grid .card__specs{color:var(--t-dark-muted)}
.inv-grid .card__btn{border-color:var(--line-dark);color:var(--t-dark)}
.inv-grid .card__btn:hover{background:var(--red);border-color:var(--red);color:#fff}
.inv-empty{grid-column:1/-1;text-align:center;padding:4rem 1rem;color:var(--t-dark-muted)}
.inv-empty h3{font-family:var(--serif);font-size:1.6rem;color:var(--t-dark);margin-bottom:.5rem}
/* card enter animation on inventory */
.inv-grid .card{opacity:0;transform:translateY(24px)}
.inv-grid .card.in{opacity:1;transform:translateY(0);transition:opacity .5s var(--ease),transform .5s var(--ease)}

/* CTA banner on inventory */
.inv-cta{background:var(--ink-2);border-top:1px solid var(--line-dark);text-align:center;padding-block:clamp(3.5rem,6vw,5.5rem)}
.inv-cta h2{font-family:var(--serif);font-size:clamp(1.8rem,3.6vw,2.8rem);font-weight:500;margin-bottom:1rem}
.inv-cta p{color:var(--t-dark-muted);max-width:48ch;margin:0 auto 1.8rem}

/* =========================================================================
   SCROLL REVEAL
   ========================================================================= */
[data-reveal]{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].revealed{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.08s}
[data-reveal-delay="2"]{transition-delay:.16s}
[data-reveal-delay="3"]{transition-delay:.24s}
[data-reveal-delay="4"]{transition-delay:.32s}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width:1024px){
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .stat{border-bottom:1px solid var(--line-dark)}
  .cards{grid-template-columns:repeat(2,1fr)}
  .feat-row{grid-template-columns:repeat(3,1fr);gap:2rem 1.5rem}
  .serv-row{grid-template-columns:repeat(3,1fr);gap:2rem 1.4rem}
  .inv-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .nav,.header__cta .btn{display:none}
  .burger{display:block}
  .nav{
    position:fixed;inset:0;flex-direction:column;justify-content:center;gap:1.8rem;
    background:rgba(8,8,10,.97);backdrop-filter:blur(16px);
    transform:translateX(100%);transition:transform .45s var(--ease);
  }
  body.menu-open .nav{transform:translateX(0);display:flex}
  .nav a{font-size:1.1rem}
  .showroom__grid{grid-template-columns:1fr;gap:2.2rem}
  .spotlight{background:linear-gradient(180deg,var(--ink) 0%,var(--ink) 55%,#bdbbb6 100%)}
  .spotlight__grid{grid-template-columns:1fr;gap:1.5rem}
  .spotlight__car img{transform:translateY(30px)}
  .spotlight.in-view .spotlight__car img{transform:translateY(0)}
  .test-track{grid-template-columns:1fr;grid-auto-flow:column;grid-auto-columns:100%;overflow:hidden}
  .test-track.carousel{display:flex}
  .test-track.carousel .test{min-width:100%;transition:transform .5s var(--ease)}
  .test-dots{display:flex}
  .contact__grid{grid-template-columns:1fr;gap:2rem}
  .footer__top{grid-template-columns:1fr 1fr;gap:2rem}
  .footer__brand{grid-column:1/-1}
  .modal__box{grid-template-columns:1fr;max-height:88vh}
  .modal__media{min-height:240px;position:relative}
  .modal__media img{position:relative}
}
@media (max-width:560px){
  .brand img{height:58px}
  .header.scrolled .brand img{height:48px}
  .brands img{max-height:120px}
  .cards{grid-template-columns:1fr}
  .feat-row,.serv-row{grid-template-columns:1fr 1fr;gap:2rem 1.2rem}
  .inv-grid{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column;text-align:center}
  .hero__inner{padding-top:6rem}
  .filters__right{width:100%}
  .search-box,.search-box input{width:100%}
  .spec-grid{grid-template-columns:1fr 1fr}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .hero__bg{animation:none}
}
