/* =====================================================================
   DI-VOSH — Precision Auto Care
   Dark cinematic · crimson + graphite + chrome · kinetic typography
   ===================================================================== */

:root{
  --bg:#0a0a0c;
  --bg-2:#101015;
  --panel:#15151b;
  --ink:#f4f4f6;
  --ink-dim:#a6a6b2;
  --ink-mute:#7c7c88;
  --line:rgba(255,255,255,.10);
  --red:#ff2d2d;
  --red-deep:#c40d12;
  --chrome:#d7d9de;
  --radius:14px;
  --maxw:1320px;
  --ease:cubic-bezier(.16,1,.3,1);
  --font:'Archivo',system-ui,sans-serif;
  --display:'Archivo Expanded','Archivo',sans-serif;
  --mono:'Space Mono',monospace;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip;background:var(--bg)}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--font);
  background:transparent;
  color:var(--ink);
  line-height:1.55;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.lock{overflow:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{list-style:none}
::selection{background:var(--red);color:#fff}

/* ---------- three.js background ---------- */
.three-bg{position:fixed;inset:0;z-index:-1;pointer-events:none;display:block}

/* ---------- shared layout ---------- */
section{position:relative}
.section-head{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,72px)}
.section-kicker{
  display:inline-flex;align-items:center;gap:12px;
  font:600 12px/1 var(--mono);letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-dim);margin-bottom:26px;
}
.section-kicker i{color:var(--red);font-style:normal}
.section-kicker.light{color:var(--ink-dim)}
.section-title{
  font-family:var(--display);
  font-weight:800;
  font-size:clamp(2rem,6vw,4.6rem);
  line-height:.98;letter-spacing:-.01em;text-transform:uppercase;
}

/* ---------- buttons ---------- */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  padding:1.05em 1.9em;border-radius:60px;
  font:700 13px/1 var(--font);letter-spacing:.06em;text-transform:uppercase;
  transition:transform .5s var(--ease),background .4s,color .4s,box-shadow .4s;
  will-change:transform;
}
.btn--primary{background:var(--red);color:#fff;box-shadow:0 10px 40px -12px rgba(255,45,45,.7)}
.btn--primary:hover{background:#fff;color:#0a0a0c;box-shadow:0 14px 50px -10px rgba(255,255,255,.3)}
.btn--ghost{border:1px solid var(--line);color:var(--ink)}
.btn--ghost:hover{border-color:var(--ink);background:rgba(255,255,255,.04)}
.btn--sm{padding:.75em 1.3em;font-size:11px}
.btn--block{width:100%}

/* ---------- preloader ---------- */
.preloader{position:fixed;inset:0;z-index:1000;background:var(--bg);display:grid;place-items:center}
.preloader__logo{display:flex;flex-direction:column;align-items:center;gap:26px}
.dv-mark{width:200px;height:60px;overflow:visible}
.dv-stroke{fill:none;stroke-width:9;stroke-linecap:round;stroke-dasharray:60;stroke-dashoffset:60;
  animation:drawDV .8s var(--ease) forwards}
.dv-stroke--red{stroke:var(--red)}
.dv-stroke--white{stroke:var(--ink)}
.dv-stroke:nth-child(2){animation-delay:.08s}
.dv-stroke:nth-child(3){animation-delay:.18s}
.dv-stroke:nth-child(4){animation-delay:.26s}
@keyframes drawDV{to{stroke-dashoffset:0}}
.preloader__count{font:700 14px/1 var(--mono);color:var(--ink-dim);letter-spacing:.1em}
.preloader__count i{color:var(--red);font-style:normal}
.preloader.done{transform:translateY(-101%);transition:transform 1s var(--ease)}

/* ---------- cursor ---------- */
.cursor{position:fixed;top:0;left:0;width:34px;height:34px;border:1px solid var(--red);
  border-radius:50%;pointer-events:none;z-index:900;transform:translate(-50%,-50%);
  transition:width .3s var(--ease),height .3s var(--ease),background .3s,border-color .3s;mix-blend-mode:difference}
.cursor span{position:absolute;top:50%;left:50%;width:4px;height:4px;background:var(--red);border-radius:50%;transform:translate(-50%,-50%)}
.cursor.hover{width:64px;height:64px;background:rgba(255,45,45,.12);border-color:transparent}
.cursor.hover span{opacity:0}
@media (hover:none){.cursor{display:none}}

/* ---------- header ---------- */
.header{
  position:fixed;top:0;left:0;width:100%;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px clamp(20px,5vw,72px);
  transition:padding .4s var(--ease),background .4s,backdrop-filter .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.header.scrolled{padding:14px clamp(20px,5vw,72px);background:rgba(10,10,12,.72);backdrop-filter:blur(16px);border-bottom-color:var(--line)}
.brand{display:flex;align-items:center;gap:12px;z-index:210}
.brand__mark{width:54px;height:auto}
.bm{fill:none;stroke-width:7;stroke-linecap:round}
.bm--r{stroke:var(--red)}.bm--w{stroke:var(--ink)}
.brand__type{font-family:var(--display);font-weight:800;font-size:18px;letter-spacing:.04em}
.brand__type i{color:var(--red);font-style:normal;margin:0 1px}
.nav{display:flex;gap:34px}
.nav a{position:relative;font:600 13px/1 var(--font);letter-spacing:.04em;color:var(--ink-dim);text-transform:uppercase;transition:color .3s}
.nav a::after{content:"";position:absolute;left:0;bottom:-7px;width:0;height:1px;background:var(--red);transition:width .4s var(--ease)}
.nav a:hover{color:var(--ink)}
.nav a:hover::after{width:100%}
.header__right{display:flex;align-items:center;gap:20px;z-index:210}
.lang{display:flex;align-items:center;gap:6px;font:700 12px/1 var(--mono)}
.lang button{color:var(--ink-mute);transition:color .3s;padding:4px}
.lang button.is-active{color:var(--ink)}
.lang span{color:var(--ink-mute)}
.burger{display:none;flex-direction:column;gap:5px;width:30px;height:30px;justify-content:center;align-items:center}
.burger i{width:22px;height:2px;background:var(--ink);transition:transform .4s var(--ease),opacity .3s}
.burger.open i:nth-child(1){transform:translateY(3.5px) rotate(45deg)}
.burger.open i:nth-child(2){transform:translateY(-3.5px) rotate(-45deg)}

/* ---------- mobile menu ---------- */
.mobile-menu{position:fixed;inset:0;z-index:190;background:var(--bg-2);
  display:flex;flex-direction:column;justify-content:center;gap:8px;padding:0 30px;
  clip-path:inset(0 0 100% 0);transition:clip-path .7s var(--ease);pointer-events:none}
.mobile-menu.open{clip-path:inset(0 0 0 0);pointer-events:auto}
.mobile-menu nav{display:flex;flex-direction:column;gap:6px}
.mobile-menu nav a{font-family:var(--display);font-weight:800;font-size:13vw;text-transform:uppercase;line-height:1;color:var(--ink);transition:color .3s}
.mobile-menu nav a:hover{color:var(--red)}
.mobile-menu__phone{margin-top:40px;font:700 18px/1 var(--mono);color:var(--red)}

/* ---------- hero ---------- */
.hero{min-height:100svh;display:flex;align-items:center;position:relative;overflow:hidden;
  padding:140px clamp(20px,5vw,72px) 80px}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero__grain{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background:radial-gradient(120% 80% at 75% 10%,rgba(255,45,45,.16),transparent 55%),
             radial-gradient(100% 70% at 0% 100%,rgba(40,40,60,.4),transparent 60%);
  mix-blend-mode:screen}
.hero__inner{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;width:100%}
.hero__eyebrow{display:inline-flex;align-items:center;gap:10px;font:600 12px/1 var(--mono);
  letter-spacing:.24em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:30px}
.hero__eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 14px var(--red);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.hero__title{font-family:var(--display);font-weight:900;line-height:.85;letter-spacing:-.02em;
  text-transform:uppercase;font-size:clamp(3.2rem,13vw,11rem);margin-bottom:34px}
.hero__title .line{display:block;overflow:hidden}
.hero__title .word{display:inline-block}
.hero__title .outline{color:transparent;-webkit-text-stroke:1.5px var(--ink)}
.hero__title .red{color:var(--red)}
.hero__lead{max-width:540px;font-size:clamp(1rem,1.5vw,1.18rem);color:var(--ink-dim);margin-bottom:40px}
.hero__actions{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:64px}
.hero__meta{display:flex;flex-wrap:wrap;gap:clamp(28px,5vw,72px)}
.hero__meta>div{display:flex;flex-direction:column;gap:4px}
.hero__meta b{font-family:var(--display);font-weight:800;font-size:clamp(1.8rem,3vw,2.6rem);color:var(--ink)}
.hero__meta span{font:400 12px/1.3 var(--mono);letter-spacing:.06em;color:var(--ink-mute);text-transform:uppercase;max-width:120px}
.hero__scroll{position:absolute;left:50%;bottom:28px;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:10px;font:400 10px/1 var(--mono);
  letter-spacing:.3em;text-transform:uppercase;color:var(--ink-mute)}
.hero__scroll i{width:1px;height:48px;background:linear-gradient(var(--red),transparent);animation:scrollLine 2s var(--ease) infinite}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- marquee ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;background:var(--bg-2);padding:24px 0}
.marquee__track{display:flex;align-items:center;gap:34px;white-space:nowrap;width:max-content;
  animation:marq 28s linear infinite}
.marquee__track span{font-family:var(--display);font-weight:800;font-size:clamp(1.4rem,3vw,2.4rem);
  text-transform:uppercase;color:transparent;-webkit-text-stroke:1px var(--ink-mute)}
.marquee__track em{color:var(--red);font-size:1.4rem;font-style:normal}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- statement ---------- */
.statement{padding:clamp(90px,15vw,200px) clamp(20px,5vw,72px);max-width:1100px;margin:0 auto}
.statement__text{font-family:var(--display);font-weight:700;font-size:clamp(1.6rem,4.2vw,3.4rem);
  line-height:1.18;text-transform:uppercase;letter-spacing:-.01em}
.statement__text .reveal-word{display:inline;color:var(--ink-mute);transition:color .5s}
.statement__text .reveal-word.accent.lit,.statement__text .reveal-word.accent{color:var(--red)}
.statement__text .reveal-word.lit{color:var(--ink)}

/* ---------- services ---------- */
.services{padding:clamp(60px,9vw,120px) 0}
.services .section-head{margin-bottom:60px}
.svc-list{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,72px);border-top:1px solid var(--line)}
.svc{position:relative;display:grid;grid-template-columns:90px 1.1fr 1.6fr 60px;gap:30px;align-items:center;
  padding:38px 0;border-bottom:1px solid var(--line);transition:padding .5s var(--ease)}
.svc::before{content:"";position:absolute;left:-100vw;right:-100vw;top:0;bottom:0;
  background:linear-gradient(90deg,transparent,rgba(255,45,45,.05),transparent);opacity:0;transition:opacity .5s;z-index:-1}
.svc:hover::before{opacity:1}
.svc:hover{padding-left:18px;padding-right:18px}
.svc__no{font:700 14px/1 var(--mono);color:var(--red)}
.svc__name{font-family:var(--display);font-weight:700;font-size:clamp(1.3rem,2.6vw,2rem);text-transform:uppercase;line-height:1;transition:transform .5s var(--ease)}
.svc:hover .svc__name{transform:translateX(8px)}
.svc__desc{color:var(--ink-dim);font-size:.97rem;max-width:480px}
.svc__plus{font-size:28px;color:var(--ink-mute);text-align:right;transition:transform .5s var(--ease),color .4s}
.svc:hover .svc__plus{transform:rotate(90deg);color:var(--red)}

/* ---------- diagnostics ---------- */
.diag{padding:clamp(80px,12vw,160px) clamp(20px,5vw,72px);overflow:hidden}
.diag__bg{position:absolute;inset:0;background:
  radial-gradient(70% 90% at 85% 50%,rgba(255,45,45,.10),transparent 60%);z-index:0}
.diag__grid{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}
.diag__copy p{color:var(--ink-dim);font-size:1.05rem;margin:24px 0 30px;max-width:480px}
.diag__copy .section-title{margin-bottom:0}
.diag__list{display:grid;gap:14px}
.diag__list li{position:relative;padding-left:26px;color:var(--ink);font-size:.98rem}
.diag__list li::before{content:"";position:absolute;left:0;top:.5em;width:10px;height:10px;
  border:1px solid var(--red);transform:rotate(45deg)}
.diag__hud{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--line);
  border-radius:var(--radius);padding:clamp(26px,4vw,46px);display:grid;gap:30px;
  box-shadow:0 40px 100px -50px rgba(0,0,0,.9)}
.hud__ring{position:relative;width:220px;height:220px;margin:0 auto}
.hud__ring svg{transform:rotate(-90deg);width:100%;height:100%}
.hud__track{fill:none;stroke:var(--line);stroke-width:3}
.hud__prog{fill:none;stroke:var(--red);stroke-width:3;stroke-linecap:round;
  stroke-dasharray:578;stroke-dashoffset:578;filter:drop-shadow(0 0 6px var(--red))}
.hud__center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}
.hud__center b{font-family:var(--display);font-weight:800;font-size:2.6rem}
.hud__center span{font:400 10px/1 var(--mono);letter-spacing:.25em;color:var(--ink-mute)}
.hud__rows{display:grid;gap:14px}
.hud__row{display:grid;grid-template-columns:70px 1fr 34px;align-items:center;gap:14px;font:400 11px/1 var(--mono);letter-spacing:.1em;color:var(--ink-dim)}
.hud__row .bar{height:4px;background:var(--line);border-radius:4px;position:relative;overflow:hidden}
.hud__row .bar::after{content:"";position:absolute;inset:0;width:calc(var(--v)*100%);background:linear-gradient(90deg,var(--red-deep),var(--red));border-radius:4px;transform:scaleX(0);transform-origin:left;transition:transform 1.2s var(--ease)}
.hud__row.lit .bar::after{transform:scaleX(1)}
.hud__row b{color:#39d98a;text-align:right}

/* ---------- process ---------- */
.process{padding:clamp(60px,9vw,120px) 0}
.process .section-head{margin-bottom:60px}
.steps{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,72px);
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.step{background:var(--bg);padding:38px 30px;display:flex;flex-direction:column;gap:16px;transition:background .4s}
.step:hover{background:var(--panel)}
.step__no{font-family:var(--display);font-weight:900;font-size:3rem;color:transparent;-webkit-text-stroke:1px var(--red);line-height:1}
.step h3{font-family:var(--display);font-weight:700;font-size:1.25rem;text-transform:uppercase}
.step p{color:var(--ink-dim);font-size:.94rem}

/* ---------- stats ---------- */
.stats{max-width:var(--maxw);margin:0 auto;padding:clamp(50px,7vw,90px) clamp(20px,5vw,72px);
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stat{display:flex;flex-direction:column;gap:8px}
.stat b{font-family:var(--display);font-weight:900;font-size:clamp(2.6rem,5vw,4.5rem);line-height:1}
.stat span{font:400 12px/1.4 var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute)}

/* ---------- parts ---------- */
.parts{padding:clamp(80px,12vw,160px) clamp(20px,5vw,72px)}
.parts__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,6vw,90px);align-items:center}
.parts__copy p{color:var(--ink-dim);font-size:1.05rem;margin:24px 0 34px;max-width:440px}
.parts__cards{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.pcard{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:28px;transition:transform .5s var(--ease),border-color .4s,background .4s}
.pcard:hover{transform:translateY(-6px);border-color:rgba(255,45,45,.4)}
.pcard__tag{font:700 10px/1 var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--red)}
.pcard h4{font-family:var(--display);font-weight:700;font-size:1.2rem;text-transform:uppercase;margin:14px 0 8px}
.pcard p{color:var(--ink-dim);font-size:.9rem}

/* ---------- contact ---------- */
.contact{padding:clamp(80px,12vw,160px) clamp(20px,5vw,72px);background:
  radial-gradient(80% 100% at 0% 0%,rgba(255,45,45,.07),transparent 55%)}
.contact__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px)}
.contact__copy p{color:var(--ink-dim);font-size:1.05rem;margin:24px 0 38px;max-width:420px}
.contact__info{display:grid;gap:22px}
.contact__info li{display:flex;flex-direction:column;gap:4px;border-bottom:1px solid var(--line);padding-bottom:18px}
.contact__info span{font:400 11px/1 var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute)}
.contact__info a,.contact__info li>span:last-child{font-size:1.02rem;color:var(--ink);transition:color .3s}
.contact__info a:hover{color:var(--red)}
.contact__form{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-content:start}
.field{position:relative}
.field--full{grid-column:1/-1}
.field input,.field select,.field textarea{width:100%;background:transparent;border:0;border-bottom:1px solid var(--line);
  padding:16px 0 12px;color:var(--ink);font:400 1rem var(--font);transition:border-color .3s}
.field select{color:var(--ink);cursor:pointer}
.field select option{background:var(--bg-2);color:var(--ink)}
.field textarea{resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--red)}
.field label{position:absolute;left:0;top:16px;color:var(--ink-mute);font-size:1rem;pointer-events:none;transition:transform .3s var(--ease),font-size .3s,color .3s}
.field input:focus+label,.field input:not(:placeholder-shown)+label,
.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label,
.field .label--static{transform:translateY(-26px);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--red);font-family:var(--mono)}
.field input,.field textarea{}
.field input::placeholder,.field textarea::placeholder{color:transparent}
.field input,.field textarea{}
.label--static{top:16px}
.form__note{grid-column:1/-1;font:400 13px var(--mono);color:#39d98a;min-height:18px}
.form__note.error{color:var(--red)}

/* placeholder trick so floating labels work */
.field input,.field textarea{}
.field input:not(:focus):placeholder-shown,.field textarea:not(:focus):placeholder-shown{}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--line);padding:clamp(50px,7vw,90px) clamp(20px,5vw,72px) 30px}
.footer__top{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.3fr 2fr;gap:50px}
.footer__brand .brand__mark{width:64px;margin-bottom:18px}
.footer__brand p{color:var(--ink-dim);max-width:280px;font-size:.95rem}
.footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.footer__cols h5{font:600 11px/1 var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:18px}
.footer__cols a{display:block;color:var(--ink-dim);font-size:.95rem;margin-bottom:10px;transition:color .3s}
.footer__cols a:hover{color:var(--red)}
.footer__bottom{max-width:var(--maxw);margin:50px auto 0;padding-top:24px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font:400 12px var(--mono);color:var(--ink-mute);letter-spacing:.05em}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- legal pages ---------- */
.legal{max-width:860px;margin:0 auto;padding:160px clamp(20px,5vw,40px) 100px}
.legal h1{font-family:var(--display);font-weight:800;font-size:clamp(2rem,6vw,3.4rem);text-transform:uppercase;margin-bottom:14px}
.legal .legal__upd{font:400 12px var(--mono);color:var(--ink-mute);letter-spacing:.1em;text-transform:uppercase;margin-bottom:50px}
.legal h2{font-family:var(--display);font-weight:700;font-size:1.4rem;text-transform:uppercase;margin:42px 0 14px;color:var(--ink)}
.legal p,.legal li{color:var(--ink-dim);margin-bottom:14px;font-size:1rem}
.legal ul{padding-left:22px;list-style:disc}
.legal a{color:var(--red)}
.legal .back{display:inline-flex;align-items:center;gap:8px;margin-bottom:40px;font:600 12px var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim)}
.legal .back:hover{color:var(--red)}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:1080px){
  .nav{display:none}
  .burger{display:flex}
  .cta-book{display:none}
  .diag__grid,.parts__grid,.contact__grid{grid-template-columns:1fr}
  .parts__cards{order:-1}
  .steps{grid-template-columns:repeat(2,1fr)}
  .footer__top{grid-template-columns:1fr}
}
@media (max-width:720px){
  .header{padding:16px 20px}
  .header.scrolled{padding:12px 20px}
  .hero{padding:120px 20px 80px}
  .hero__title{font-size:clamp(2.8rem,17vw,5rem)}
  .svc{grid-template-columns:46px 1fr;grid-template-areas:"no name" "desc desc";gap:8px 16px;padding:26px 0}
  .svc__no{grid-area:no}.svc__name{grid-area:name}.svc__desc{grid-area:desc;max-width:none}
  .svc__plus{display:none}
  .svc:hover{padding-left:0;padding-right:0}
  .stats{grid-template-columns:1fr 1fr;gap:30px}
  .contact__form{grid-template-columns:1fr}
  .footer__cols{grid-template-columns:1fr 1fr}
  .footer__bottom{flex-direction:column;gap:8px}
  .hero__meta{gap:24px}
}
@media (max-width:440px){
  .steps{grid-template-columns:1fr}
  .parts__cards{grid-template-columns:1fr}
  .footer__cols{grid-template-columns:1fr}
}

/* ---------- keyboard focus ---------- */
a:focus-visible,button:focus-visible,
.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible{
  outline:2px solid var(--red);outline-offset:3px;border-radius:2px}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.01ms!important;scroll-behavior:auto!important}
  .hero__scroll i,.hero__eyebrow .dot{animation:none!important}
  .cursor{display:none!important}
}
