/* ============================================================================
 *  Mpire Automotive — public website (premium dark / electric blue)
 * ========================================================================== */
:root{
  --bg:#08080a; --bg-2:#0d0d11; --bg-3:#111118; --card:#14141b; --line:#23232e;
  --text:#f4f4f7; --muted:#9b9ba8; --dim:#6f6f7d;
  --accent:#2e6bff; --accent-2:#5b8bff; --accent-glow:rgba(46,107,255,.45);
  --max:1180px; --radius:16px;
  --font:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --display:"Sora",var(--font);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0; background:var(--bg); color:var(--text); font-family:var(--font);
  line-height:1.65; -webkit-font-smoothing:antialiased; overflow-x:hidden}
.container{width:100%; max-width:var(--max); margin:0 auto; padding:0 24px}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
h1,h2,h3,h4{font-family:var(--display); line-height:1.08; margin:0 0 .4em; letter-spacing:-.02em; font-weight:800}
.accent{color:var(--accent-2)}
.dim{color:var(--dim)}
.center{text-align:center; margin-top:32px}
.eyebrow{display:inline-block; text-transform:uppercase; letter-spacing:.22em; font-size:.74rem;
  font-weight:700; color:var(--accent-2); font-family:var(--font); margin-bottom:1.1rem}

/* ---- buttons ---- */
.btn{display:inline-flex; align-items:center; gap:.5em; padding:.8em 1.5em; border-radius:999px;
  border:1px solid var(--line); background:#1a1a22; color:var(--text); font-weight:600; font-size:.98rem;
  cursor:pointer; transition:transform .18s, background .18s, border-color .18s, box-shadow .18s; white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-accent{background:var(--accent); border-color:var(--accent); color:#fff; box-shadow:0 12px 34px -12px var(--accent-glow)}
.btn-accent:hover{background:var(--accent-2); border-color:var(--accent-2); box-shadow:0 18px 44px -12px var(--accent-glow)}
.btn-glass{background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.18); backdrop-filter:blur(8px)}
.btn-glass:hover{background:rgba(255,255,255,.12)}
.btn-lg{padding:1em 1.9em; font-size:1.02rem}
.btn-sm{padding:.55em 1.1em; font-size:.88rem}
.btn-block{width:100%; justify-content:center}

/* ---- topbar ---- */
.topbar{background:#050506; border-bottom:1px solid var(--line); font-size:.82rem}
.topbar-inner{display:flex; justify-content:space-between; align-items:center; height:40px; gap:16px}
.topbar-tag{color:var(--accent-2); font-weight:600; letter-spacing:.02em}
.topbar-right{display:flex; gap:18px; align-items:center; color:var(--muted)}
.topbar-right a:hover{color:var(--text)}

/* ---- nav ---- */
.nav{position:sticky; top:0; z-index:60; transition:background .3s, border-color .3s, box-shadow .3s;
  border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(8,8,10,.85); backdrop-filter:blur(14px); border-color:var(--line); box-shadow:0 10px 30px -20px #000}
.nav-inner{display:flex; align-items:center; justify-content:space-between; height:74px}
.brand{display:flex; align-items:center; gap:.65em; font-family:var(--display); font-weight:800; font-size:1.2rem}
.brand-logo{height:42px; width:auto; display:block}
.brand-logo-lg{height:58px}
.brand-mark{display:grid; place-items:center; width:38px; height:38px; border-radius:10px;
  background:linear-gradient(135deg,var(--accent),#15307e); color:#fff; font-weight:800; font-family:var(--display);
  box-shadow:0 8px 22px -8px var(--accent-glow)}
.nav-links{display:flex; align-items:center; gap:2rem; font-weight:500}
.nav-links a:not(.btn){color:var(--muted); position:relative}
.nav-links a:not(.btn):hover{color:var(--text)}
.nav-links a:not(.btn)::after{content:""; position:absolute; left:0; bottom:-6px; height:2px; width:0; background:var(--accent); transition:width .25s}
.nav-links a:not(.btn):hover::after{width:100%}
.nav-toggle{display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px}
.nav-toggle span{width:24px; height:2px; background:var(--text); transition:.25s}

/* ---- hero ---- */
.hero{position:relative; min-height:92vh; display:flex; align-items:center; overflow:hidden; padding:80px 0}
.hero-media{position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.05);
  animation:slowzoom 18s ease-out forwards}
@keyframes slowzoom{to{transform:scale(1.14)}}
.hero-scrim{position:absolute; inset:0;
  background:linear-gradient(100deg,rgba(8,8,10,.94) 18%,rgba(8,8,10,.72) 48%,rgba(8,8,10,.35) 100%),
             radial-gradient(70% 90% at 80% 10%,rgba(46,107,255,.28),transparent 60%)}
.hero-inner{position:relative; max-width:780px}
.hero h1{font-size:clamp(2.6rem,6.4vw,5rem); font-weight:800}
.hero .lead{font-size:clamp(1.05rem,2vw,1.3rem); color:var(--muted); max-width:600px; margin:1.4rem 0 2.2rem}
.hero-cta{display:flex; gap:.9rem; flex-wrap:wrap}
.hero-trust{display:flex; gap:2.4rem; margin-top:3rem; flex-wrap:wrap}
.hero-trust div{display:flex; flex-direction:column}
.hero-trust strong{font-family:var(--display); font-size:1.7rem; color:#fff; line-height:1}
.hero-trust span{color:var(--muted); font-size:.85rem; margin-top:.3rem}
.hero-scroll{position:absolute; left:50%; bottom:26px; transform:translateX(-50%); color:var(--muted);
  font-size:1.3rem; animation:bob 1.8s ease-in-out infinite; z-index:2}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ---- brand marquee ---- */
.marquee{display:flex; align-items:center; gap:28px; padding:24px 0 24px 24px; border-top:1px solid var(--line);
  border-bottom:1px solid var(--line); background:var(--bg-2)}
.marquee-label{flex:none; color:var(--dim); text-transform:uppercase; letter-spacing:.2em; font-size:.72rem; font-weight:700}
.marquee-viewport{flex:1; min-width:0; overflow:hidden;
  -webkit-mask-image:linear-gradient(to right,transparent,#000 6%,#000 88%,transparent);
          mask-image:linear-gradient(to right,transparent,#000 6%,#000 88%,transparent)}
.marquee-track{display:inline-flex; align-items:center; gap:26px; white-space:nowrap;
  animation:scroll 30s linear infinite; will-change:transform}
.marquee-brand{font-family:var(--display); font-weight:700; font-size:1.45rem; color:#34343f; transition:color .2s}
.marquee-brand:hover{color:var(--accent-2)}
.marquee-track i{color:var(--accent); font-style:normal; font-size:1.1rem}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---- sections ---- */
.section{padding:100px 0}
.section-alt{background:var(--bg-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.section-head{max-width:640px; margin:0 auto 56px; text-align:center}
.section-head h2{font-size:clamp(2rem,4.2vw,3rem)}
.section-head p{color:var(--muted); font-size:1.12rem; margin:0}

/* ---- service cards (image) ---- */
.service-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px}
.svc{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  transition:transform .25s, border-color .25s, box-shadow .25s}
.svc:hover{transform:translateY(-6px); border-color:#33333f; box-shadow:0 30px 60px -30px #000}
.svc-img{height:200px; background-size:cover; background-position:center; transition:transform .5s;
  position:relative}
.svc-img::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(20,20,27,.85))}
.svc:hover .svc-img{transform:scale(1.07)}
.svc-body{padding:22px 24px 26px}
.svc-body h3{font-size:1.22rem}
.svc-body p{color:var(--muted); margin:0 0 1rem; font-size:.96rem}
.svc-link{color:var(--accent-2); font-weight:600; font-size:.92rem}
.svc-link:hover{color:#fff}

/* ---- chips ---- */
.chips{display:flex; flex-wrap:wrap; gap:10px; align-items:center; justify-content:center; margin-top:42px}
.chips-label{color:var(--dim); font-weight:600; margin-right:6px}
.chip{padding:.5rem 1rem; border:1px solid var(--line); border-radius:999px; background:var(--bg-3);
  color:var(--muted); font-size:.88rem; font-weight:500}
.chip:hover{border-color:var(--accent); color:var(--text)}

/* ---- split (why us) ---- */
.split{display:grid; grid-template-columns:1fr 1fr; align-items:center; gap:0; background:var(--bg-2);
  border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.split-media{position:relative; min-height:540px; height:100%}
.split-media img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover}
.split-badge{position:absolute; left:0; bottom:40px; background:var(--accent); color:#fff; padding:18px 26px;
  border-radius:0 14px 14px 0; max-width:260px; box-shadow:0 20px 50px -20px var(--accent-glow)}
.split-badge strong{display:block; font-family:var(--display); font-size:1.2rem}
.split-badge span{font-size:.86rem; opacity:.9}
.split-body{padding:80px clamp(28px,5vw,72px)}
.split-body h2{font-size:clamp(1.8rem,3.6vw,2.6rem)}
.split-body p{color:var(--muted)}
.feature-list{list-style:none; padding:0; margin:1.6rem 0 2rem; display:grid; gap:.9rem}
.feature-list li{padding-left:2rem; position:relative; color:var(--muted)}
.feature-list li b{color:var(--text)}
.feature-list li::before{content:""; position:absolute; left:0; top:.55em; width:11px; height:11px; border-radius:3px;
  background:var(--accent); box-shadow:0 0 14px var(--accent-glow)}

/* ---- full-bleed band ---- */
.band{position:relative; padding:120px 0; overflow:hidden}
.band-media{position:absolute; inset:0; background-size:cover; background-position:center; background-attachment:fixed}
.band-scrim{position:absolute; inset:0; background:linear-gradient(90deg,rgba(8,8,10,.92),rgba(8,8,10,.55) 70%,rgba(46,107,255,.18))}
.band-inner{position:relative; max-width:560px}
.band-inner h2{font-size:clamp(2rem,4.4vw,3.2rem)}
.band-inner p{color:var(--muted); font-size:1.12rem; margin-bottom:1.8rem}

/* ---- gallery ---- */
.gallery{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.gallery figure{margin:0; border-radius:14px; overflow:hidden; border:1px solid var(--line); aspect-ratio:4/3}
.gallery img{width:100%; height:100%; object-fit:cover; transition:transform .5s, filter .5s; filter:grayscale(.2)}
.gallery figure:hover img{transform:scale(1.08); filter:grayscale(0)}

/* ---- reviews ---- */
.reviews{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.review{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:28px; margin:0}
.review .stars{color:#fbbf24; letter-spacing:2px; margin-bottom:.6rem}
.review p{font-size:1.05rem; margin:0 0 1rem}
.review footer{color:var(--muted); font-weight:600}

/* ---- promise ---- */
.promise{text-align:center}
.promise>h2{font-size:clamp(1.8rem,4vw,2.8rem); max-width:760px; margin:0 auto .6rem}
.promise-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:48px; text-align:left}
.promise-grid>div{padding:28px; background:var(--card); border:1px solid var(--line); border-radius:var(--radius)}
.pnum{font-family:var(--display); font-size:1.6rem; color:var(--accent-2); font-weight:800}
.promise-grid h3{margin:.6rem 0 .4rem; font-size:1.2rem}
.promise-grid p{color:var(--muted); margin:0}

/* ---- towing CTA ---- */
.towing{background:linear-gradient(120deg,#0f2050,var(--bg) 72%); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.towing-inner{display:flex; align-items:center; justify-content:space-between; gap:28px; padding:56px 0}
.towing h2{font-size:clamp(1.6rem,3.5vw,2.3rem); margin:0}
.towing p{color:var(--muted); margin:.4rem 0 0}

/* ---- contact ---- */
.contact-grid{display:grid; grid-template-columns:.85fr 1.15fr; gap:56px; align-items:start}
.contact-info h2{font-size:clamp(1.8rem,3.6vw,2.6rem)}
.contact-info>p{color:var(--muted)}
.contact-list{list-style:none; padding:0; margin:2rem 0 0; display:grid; gap:1rem}
.contact-list li{display:flex; flex-direction:column; gap:.15rem; padding-bottom:1rem; border-bottom:1px solid var(--line)}
.contact-list li span{color:var(--dim); font-size:.78rem; text-transform:uppercase; letter-spacing:.12em; font-weight:700}
.contact-list a:hover{color:var(--accent-2)}
.contact-form-wrap{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:32px}
.booking{display:grid; gap:16px}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.booking label{display:flex; flex-direction:column; gap:.4rem; font-size:.82rem; font-weight:600; color:var(--muted)}
.booking input,.booking select,.booking textarea{background:#0b0b10; border:1px solid var(--line); color:var(--text);
  padding:.8rem .9rem; border-radius:10px; font:inherit; font-weight:400; transition:border-color .18s, box-shadow .18s}
.booking input:focus,.booking select:focus,.booking textarea:focus{outline:none; border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(46,107,255,.18)}
.form-note{color:var(--dim); font-size:.82rem; margin:0; text-align:center}
.alert{padding:1rem 1.2rem; border-radius:12px; margin-bottom:16px; font-weight:500}
.alert-ok{background:rgba(34,197,94,.12); border:1px solid rgba(34,197,94,.4); color:#86efac}
.alert-err{background:rgba(239,68,68,.12); border:1px solid rgba(239,68,68,.4); color:#fca5a5}

/* ---- footer ---- */
.footer{background:#050506; border-top:1px solid var(--line); padding:64px 0 28px}
.footer-grid{display:grid; grid-template-columns:2fr 1fr 1fr; gap:40px}
.footer h4{font-size:.78rem; text-transform:uppercase; letter-spacing:.14em; color:var(--dim); margin-bottom:1rem; font-family:var(--font)}
.footer-grid a{display:block; color:var(--muted); padding:.25rem 0}
.footer-grid a:hover{color:var(--text)}
.footer .brand{margin-bottom:1rem}
.socials{display:flex; gap:1rem; margin-top:1rem}
.socials a{color:var(--accent-2); font-weight:600; display:inline}
.footer-bottom{display:flex; justify-content:space-between; padding-top:28px; margin-top:40px;
  border-top:1px solid var(--line); color:var(--dim); font-size:.86rem}

/* ---- scroll reveal ---- */
.reveal,.reveal-left{opacity:0; transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); transition-delay:var(--d,0s)}
.reveal{transform:translateY(34px)}
.reveal-left{transform:translateX(-40px)}
.reveal.in,.reveal-left.in{opacity:1; transform:none}
@media(prefers-reduced-motion:reduce){.reveal,.reveal-left{opacity:1; transform:none} .hero-media{animation:none} .marquee-track{animation:none}}

/* ---- responsive ---- */
@media(max-width:980px){
  .service-grid,.gallery,.reviews,.promise-grid{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr}
  .split-media{min-height:380px}
  .split-body{padding:56px 28px}
  .contact-grid{grid-template-columns:1fr; gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .band-media{background-attachment:scroll}
}
@media(max-width:680px){
  .topbar{display:none}
  .nav-toggle{display:flex}
  .brand-logo{height:34px}
  .brand-logo-lg{height:50px}
  .marquee{flex-direction:column; align-items:center; gap:12px; padding:20px 0}
  .marquee-label{text-align:center}
  .marquee-viewport{width:100%}
  .marquee-brand{font-size:1.2rem}
  .nav-links{position:fixed; inset:74px 0 auto 0; flex-direction:column; gap:0; background:var(--bg-2);
    border-bottom:1px solid var(--line); padding:0 24px; max-height:0; overflow:hidden; transition:max-height .3s, padding .3s}
  .nav-links.open{max-height:360px; padding:14px 24px 22px}
  .nav-links a:not(.btn){padding:.8rem 0; width:100%; border-bottom:1px solid var(--line)}
  .nav-links .btn{margin-top:12px; width:100%; justify-content:center}
  .section{padding:72px 0}
  .service-grid,.reviews,.promise-grid,.form-row,.footer-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr; gap:10px}
  .hero{min-height:88vh}
  .hero-cta{flex-direction:column; align-items:stretch}
  .hero-cta .btn{width:100%; justify-content:center}
  .hero-trust{gap:1.6rem}
  .towing-inner{flex-direction:column; align-items:flex-start; text-align:left}
}
