/* =========================================================
   GEARSHIFT — Gen-Z car-culture garage
   Clash-y neon: magenta / cyan / lime on near-black
   Display: Darker Grotesque (chunky) + Outfit (body)
   ========================================================= */

:root{
  /* palette */
  --magenta:#ff2e9a;
  --magenta-d:#e0107f;
  --cyan:#00e5ff;
  --cyan-d:#00b8cc;
  --lime:#c6ff2e;
  --lime-d:#a0e000;
  --violet:#7b2ff7;
  --orange:#ff8a2b;

  --ink:#0c0a14;          /* near-black base */
  --ink-2:#15111f;        /* raised surface */
  --ink-3:#1f1830;        /* card */
  --line:#2c2440;
  --line-2:#3a2f55;
  --paper:#f7f4ff;        /* light sections */
  --paper-2:#ece5ff;
  --white:#ffffff;
  --fog:#b7adcf;          /* muted text on dark */
  --fog-d:#7b7299;
  --night-ink:#0c0a14;

  --grad-hero:linear-gradient(120deg,#ff2e9a 0%,#7b2ff7 40%,#00e5ff 100%);
  --grad-neon:linear-gradient(110deg,#ff2e9a,#00e5ff);
  --grad-lime:linear-gradient(120deg,#c6ff2e,#7bff8a);
  --grad-cta:linear-gradient(125deg,#ff2e9a 0%,#7b2ff7 55%,#00e5ff 100%);
  --grad-dusk:radial-gradient(120% 90% at 80% 10%,rgba(255,46,154,.45),transparent 55%),
              radial-gradient(120% 90% at 10% 90%,rgba(0,229,255,.40),transparent 55%),
              linear-gradient(160deg,#15111f,#0c0a14);

  --r-sm:14px;
  --r-md:22px;
  --r-lg:36px;
  --r-pill:999px;

  --shadow:0 24px 60px -22px rgba(255,46,154,.45);
  --shadow-cyan:0 24px 60px -22px rgba(0,229,255,.45);
  --hard:5px 5px 0 var(--ink);
  --hard-w:5px 5px 0 #000;
  --pop:9px 9px 0 var(--ink);
  --glow-m:0 0 0 0 rgba(255,46,154,.5);

  --wrap:1200px;
  --spring:cubic-bezier(.34,1.56,.64,1);

  --display:"Darker Grotesque",sans-serif;
  --body:"Outfit",sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  background:var(--ink);
  color:var(--white);
  line-height:1.62;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 clamp(1.1rem,4vw,2.2rem)}
.center{text-align:center}
.mt-big{margin-top:clamp(2.4rem,4vw,3.6rem)}

h1,h2,h3,h4{font-family:var(--display);font-weight:800;line-height:.94;letter-spacing:-.01em}
strong{font-weight:700}

/* ---------- Section scaffolding ---------- */
section{position:relative}
.sec{padding:clamp(3.4rem,7vw,6rem) 0}
.sec-light{background:var(--paper);color:var(--ink)}
.sec-light h1,.sec-light h2,.sec-light h3,.sec-light h4{color:var(--ink)}
.sec-dark{background:var(--ink)}
.sec-grad{background:var(--grad-dusk)}

.kicker{
  display:inline-flex;align-items:center;gap:.45rem;
  font-family:var(--display);font-weight:700;font-size:1.05rem;
  text-transform:uppercase;letter-spacing:.12em;
  padding:.35rem 1rem;border-radius:var(--r-pill);
  border:2.5px solid currentColor;line-height:1;
}
.kicker.k-magenta{color:var(--magenta)}
.kicker.k-cyan{color:var(--cyan)}
.kicker.k-lime{color:var(--lime-d)}
.kicker.center{margin:0 auto}

.sec-head{max-width:760px}
.sec-head.center{margin:0 auto}
.sec-title{font-size:clamp(2.6rem,6vw,4.6rem);margin:1rem 0 .6rem;text-transform:uppercase}
.sec-sub{font-size:clamp(1.02rem,1.6vw,1.18rem);color:var(--fog);max-width:62ch}
.sec-light .sec-sub{color:#5b5273}

.grad-text{
  background:var(--grad-neon);-webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% 200%;animation:grad-move 7s ease infinite;
}
@keyframes grad-move{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--display);font-weight:800;font-size:1.18rem;
  text-transform:uppercase;letter-spacing:.02em;
  padding:.85rem 1.7rem;border-radius:var(--r-pill);
  border:3px solid var(--ink);cursor:pointer;line-height:1;
  transition:transform .22s var(--spring),box-shadow .22s var(--spring),background .2s,color .2s;
}
.btn .arr{transition:transform .25s var(--spring)}
.btn:hover .arr{transform:translateX(6px)}
.btn-solid{background:var(--lime);color:var(--ink);box-shadow:var(--hard)}
.btn-solid:hover{transform:translate(-3px,-3px);box-shadow:var(--pop)}
.btn-magenta{background:var(--magenta);color:var(--white);box-shadow:var(--hard)}
.btn-magenta:hover{transform:translate(-3px,-3px);box-shadow:var(--pop)}
.btn-cyan{background:var(--cyan);color:var(--ink);box-shadow:var(--hard)}
.btn-cyan:hover{transform:translate(-3px,-3px);box-shadow:var(--pop)}
.btn-ghost{background:transparent;color:var(--white);border-color:var(--white);box-shadow:5px 5px 0 var(--magenta)}
.btn-ghost:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--magenta);background:var(--white);color:var(--ink)}
.sec-light .btn-ghost{color:var(--ink);border-color:var(--ink);box-shadow:5px 5px 0 var(--cyan)}
.sec-light .btn-ghost:hover{box-shadow:9px 9px 0 var(--cyan);background:var(--ink);color:var(--white)}
.btn-lg{font-size:1.32rem;padding:1rem 2rem}

.wobble:hover{animation:wobble .5s var(--spring)}
@keyframes wobble{0%,100%{rotate:0}25%{rotate:-3deg}50%{rotate:2deg}75%{rotate:-1.4deg}}

/* ---------- Sticker / badge ---------- */
.sticker{
  font-family:var(--display);font-weight:800;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.45rem .9rem;border:3px solid var(--ink);border-radius:var(--r-pill);
  box-shadow:var(--hard);background:var(--white);color:var(--ink);line-height:1;
}
.sticker.s-magenta{background:var(--magenta);color:var(--white)}
.sticker.s-cyan{background:var(--cyan);color:var(--ink)}
.sticker.s-lime{background:var(--lime);color:var(--ink)}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:80;background:rgba(12,10,20,.72);backdrop-filter:blur(16px);border-bottom:2.5px solid var(--line)}
.site-header.scrolled{background:rgba(12,10,20,.94);border-bottom-color:var(--magenta)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem 0;position:relative}
.brand{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--display);font-weight:800}
.brand-badge{
  width:40px;height:40px;border-radius:13px;flex:none;display:grid;place-items:center;
  background:var(--grad-neon);box-shadow:var(--hard);border:2.5px solid var(--ink);
  transition:transform .3s var(--spring);
}
.brand:hover .brand-badge{transform:rotate(-12deg) scale(1.05)}
.brand-badge svg{width:22px;height:22px}
.brand-mark{font-size:1.95rem;letter-spacing:-.02em;color:var(--white);line-height:1}
.brand-mark span{color:var(--lime)}
.nav-links{display:flex;gap:.3rem}
.nav-links a{
  font-family:var(--display);font-weight:700;font-size:1.22rem;text-transform:uppercase;letter-spacing:.02em;
  padding:.4rem .95rem;border-radius:var(--r-pill);color:var(--fog);
  transition:background .2s,color .2s;
}
.nav-links a:hover{background:var(--ink-3);color:var(--cyan)}
.nav-links a.active{background:var(--magenta);color:var(--white)}
.nav-cta{display:flex;align-items:center;gap:.9rem}
.nav-phone{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--display);font-weight:700;font-size:1.2rem;color:var(--cyan)}
.nav-phone svg{width:17px;height:17px}
.nav-cta .btn{padding:.55rem 1.15rem;font-size:1rem}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:var(--ink-3);border:2.5px solid var(--magenta);border-radius:12px;padding:9px 8px;cursor:pointer}
.nav-toggle span{width:22px;height:2.8px;background:var(--white);border-radius:2px;transition:.25s}
.nav.open .nav-toggle span:nth-child(1){transform:translateY(7.8px) rotate(45deg);background:var(--magenta)}
.nav.open .nav-toggle span:nth-child(2){opacity:0}
.nav.open .nav-toggle span:nth-child(3){transform:translateY(-7.8px) rotate(-45deg);background:var(--magenta)}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;padding:clamp(2.4rem,5vw,4.2rem) 0 clamp(3rem,5vw,4.6rem);background:var(--grad-dusk)}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(1.8rem,4vw,3.4rem);align-items:center}
.hero-copy h1{font-size:clamp(3.2rem,9vw,7rem);text-transform:uppercase;margin:1rem 0 1.1rem}
.hero-copy h1 .hl{display:block;background:var(--grad-neon);-webkit-background-clip:text;background-clip:text;color:transparent;background-size:200% 200%;animation:grad-move 6s ease infinite}
.hero-tag{font-size:clamp(1.05rem,1.7vw,1.28rem);color:var(--fog);max-width:50ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.7rem}
.hero-trust{display:flex;align-items:center;gap:.9rem;margin-top:1.9rem;flex-wrap:wrap}
.avatars{display:flex}
.avatars span{
  width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--display);font-weight:800;font-size:1.1rem;color:var(--ink);
  border:2.5px solid var(--ink);margin-left:-12px;
}
.avatars span:first-child{margin-left:0}
.avatars span:nth-child(1){background:var(--lime)}
.avatars span:nth-child(2){background:var(--cyan)}
.avatars span:nth-child(3){background:var(--magenta);color:#fff}
.avatars span:nth-child(4){background:var(--orange)}
.hero-trust b{color:var(--white)}
.hero-trust .stars{color:var(--lime);letter-spacing:2px}

.hero-media{position:relative}
.hero-frame{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  border:4px solid var(--ink);box-shadow:14px 14px 0 var(--magenta);
  rotate:-2.5deg;transition:rotate .5s var(--spring);
}
.hero-media:hover .hero-frame{rotate:0deg}
.hero-frame img{width:100%;height:clamp(330px,46vw,520px);object-fit:cover}
.hero-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,transparent 55%,rgba(123,47,247,.32))}

.hero-sticker{position:absolute;z-index:3}
.hero-sticker.s1{top:-22px;right:8%;rotate:9deg}
.hero-sticker.s2{bottom:-20px;left:-14px;rotate:-7deg;flex-direction:column;text-align:center;border-radius:22px;padding:.7rem 1rem;line-height:1}
.hero-sticker.s2 small{font-size:.7rem;letter-spacing:.1em;opacity:.8}
.hero-sticker.s2 b{font-size:1.9rem}
.hero-sticker.s2 span{font-size:.78rem}
.spark{position:absolute;color:var(--lime);font-size:2rem;animation:twinkle 3s ease-in-out infinite}
.spark.k1{top:6%;left:-18px;color:var(--cyan)}
.spark.k2{bottom:14%;right:-10px;animation-delay:1.2s}
@keyframes twinkle{0%,100%{transform:scale(1) rotate(0);opacity:.6}50%{transform:scale(1.4) rotate(20deg);opacity:1}}

/* hero blobs */
.blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.55;z-index:0;pointer-events:none}
.blob-1{width:380px;height:380px;background:var(--magenta);top:-90px;left:-80px}
.blob-2{width:320px;height:320px;background:var(--cyan);bottom:-100px;right:-60px}

/* ---------- Marquee ---------- */
.marquee{background:var(--lime);border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);overflow:hidden;padding:.7rem 0}
.marquee.m-magenta{background:var(--magenta)}
.marquee-track{display:flex;gap:2.4rem;width:max-content;animation:scroll-x 26s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:var(--display);font-weight:800;font-size:1.7rem;text-transform:uppercase;color:var(--ink);display:inline-flex;align-items:center;gap:2.4rem;letter-spacing:.02em}
.marquee.m-magenta .marquee-track span{color:var(--white)}
.marquee-track .dot{width:14px;height:14px;border-radius:50%;background:currentColor;display:inline-block}
@keyframes scroll-x{to{transform:translateX(-50%)}}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.stat{
  background:var(--ink-3);border:3px solid var(--line-2);border-radius:var(--r-md);
  padding:1.6rem 1.3rem;text-align:center;transition:transform .3s var(--spring),border-color .3s;
}
.sec-light .stat{background:var(--white);border-color:var(--ink);box-shadow:var(--hard)}
.stat:hover{transform:translateY(-6px)}
.sec-dark .stat:hover{border-color:var(--cyan)}
.stat-num{font-family:var(--display);font-weight:800;font-size:clamp(2.6rem,5vw,3.8rem);line-height:1;background:var(--grad-neon);-webkit-background-clip:text;background-clip:text;color:transparent}
.sec-light .stat-num{background:var(--grad-cta);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat-lab{font-weight:600;font-size:.96rem;color:var(--fog);margin-top:.4rem}
.sec-light .stat-lab{color:#5b5273}

/* ---------- Services / feature cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.card{
  background:var(--white);color:var(--ink);border:3px solid var(--ink);border-radius:var(--r-md);
  padding:1.7rem 1.6rem;box-shadow:var(--hard);
  transition:transform .26s var(--spring),box-shadow .26s var(--spring);
}
.card:hover{transform:translate(-4px,-4px);box-shadow:var(--pop)}
.card-ico{
  width:58px;height:58px;border-radius:16px;display:grid;place-items:center;margin-bottom:1rem;
  border:3px solid var(--ink);box-shadow:3px 3px 0 var(--ink);
}
.card-ico svg{width:28px;height:28px;color:var(--ink)}
.ico-m{background:var(--magenta)}.ico-m svg{color:#fff}
.ico-c{background:var(--cyan)}
.ico-l{background:var(--lime)}
.ico-v{background:var(--violet)}.ico-v svg{color:#fff}
.ico-o{background:var(--orange)}
.card h3{font-size:1.85rem;text-transform:uppercase;margin-bottom:.4rem}
.card p{color:#5b5273;font-size:1rem}
.card-tag{display:inline-block;margin-top:1rem;font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:1.05rem;color:var(--magenta-d)}

/* ---------- Split / about ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.split-media{position:relative}
.split-frame{border-radius:var(--r-lg);overflow:hidden;border:4px solid var(--ink);box-shadow:12px 12px 0 var(--cyan);rotate:2deg;transition:rotate .5s var(--spring)}
.split-media:hover .split-frame{rotate:0}
.split-frame img{width:100%;height:clamp(380px,48vw,540px);object-fit:cover}
.split-media.flip .split-frame{box-shadow:12px 12px 0 var(--magenta);rotate:-2deg}
.split h2{font-size:clamp(2.4rem,5vw,4rem);text-transform:uppercase;margin:.8rem 0 1rem}
.checklist{display:grid;gap:.8rem;margin:1.5rem 0}
.checklist li{display:flex;gap:.7rem;align-items:flex-start;font-weight:500}
.checklist .tick{width:26px;height:26px;flex:none;border-radius:8px;background:var(--lime);border:2.5px solid var(--ink);display:grid;place-items:center;margin-top:2px}
.checklist .tick svg{width:15px;height:15px;color:var(--ink)}
.sec-dark .checklist li{color:var(--fog)}
.sec-dark .checklist li b{color:var(--white)}

/* float badge over media */
.float-badge{
  position:absolute;background:var(--ink);color:#fff;border:3px solid var(--lime);
  border-radius:20px;padding:.9rem 1.2rem;box-shadow:var(--hard);text-align:center;
}
.float-badge.fb1{right:-18px;top:18px;rotate:6deg}
.float-badge.fb2{left:-22px;bottom:24px;rotate:-5deg;border-color:var(--magenta)}
.float-badge b{font-family:var(--display);font-weight:800;font-size:2rem;display:block;line-height:1;color:var(--lime)}
.float-badge.fb2 b{color:var(--magenta)}
.float-badge span{font-size:.78rem;color:var(--fog)}

/* ---------- Gallery strip ---------- */
.gallery{display:grid;grid-template-columns:1.4fr 1fr;gap:1.2rem}
.gal-item{position:relative;border-radius:var(--r-md);overflow:hidden;border:4px solid var(--ink);box-shadow:var(--hard)}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--spring)}
.gal-item:hover img{transform:scale(1.06)}
.gal-item .gal-cap{position:absolute;left:14px;bottom:14px}
.gal-col{display:grid;gap:1.2rem}

/* ---------- Process ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;counter-reset:step}
.step{position:relative;background:var(--ink-3);border:3px solid var(--line-2);border-radius:var(--r-md);padding:2.4rem 1.4rem 1.5rem}
.step-n{position:absolute;top:-26px;left:18px;width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:1.9rem;color:var(--ink);border:3px solid var(--ink);box-shadow:var(--hard)}
.step:nth-child(1) .step-n{background:var(--magenta);color:#fff}
.step:nth-child(2) .step-n{background:var(--cyan)}
.step:nth-child(3) .step-n{background:var(--lime)}
.step:nth-child(4) .step-n{background:var(--orange)}
.step h3{font-size:1.55rem;text-transform:uppercase;margin-bottom:.4rem;color:#fff}
.step p{color:var(--fog);font-size:.96rem}

/* ---------- Pricing ---------- */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;align-items:stretch}
.price{background:var(--white);color:var(--ink);border:3px solid var(--ink);border-radius:var(--r-lg);padding:2rem 1.8rem;box-shadow:var(--hard);display:flex;flex-direction:column;transition:transform .26s var(--spring),box-shadow .26s var(--spring)}
.price:hover{transform:translateY(-6px);box-shadow:var(--pop)}
.price.feat{background:var(--ink);color:#fff;border-color:var(--magenta);box-shadow:8px 8px 0 var(--magenta)}
.price.feat h3,.price.feat .price-amt{color:#fff}
.price-top{display:flex;justify-content:space-between;align-items:flex-start;gap:.6rem}
.price h3{font-size:1.9rem;text-transform:uppercase}
.price-amt{font-family:var(--display);font-weight:800;font-size:3rem;line-height:1;margin:.8rem 0 .2rem}
.price-amt small{font-size:1rem;color:var(--fog-d);font-family:var(--body);font-weight:600}
.price.feat .price-amt small{color:var(--fog)}
.price-desc{color:#5b5273;font-size:.96rem;margin-bottom:1rem}
.price.feat .price-desc{color:var(--fog)}
.price ul.price-feats{display:grid;gap:.6rem;margin:1rem 0 1.4rem;flex:1}
.price-feats li{display:flex;gap:.6rem;font-weight:500;font-size:.97rem}
.price-feats .tick{color:var(--magenta-d);font-weight:800}
.price.feat .price-feats .tick{color:var(--lime)}
.price .btn{width:100%;justify-content:center}

/* ---------- Filter bar (services) ---------- */
.filters{display:flex;flex-wrap:wrap;gap:.7rem;margin:0 auto 2.4rem;justify-content:center}
.filter-btn{
  font-family:var(--display);font-weight:800;font-size:1.18rem;text-transform:uppercase;letter-spacing:.02em;
  padding:.5rem 1.2rem;border-radius:var(--r-pill);border:3px solid var(--ink);background:var(--white);color:var(--ink);
  cursor:pointer;box-shadow:3px 3px 0 var(--ink);transition:transform .2s var(--spring),background .2s,color .2s;
}
.filter-btn:hover{transform:translate(-2px,-2px)}
.filter-btn.active{background:var(--magenta);color:#fff}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.svc-card{transition:opacity .35s,transform .35s var(--spring)}
.svc-card.hide{display:none}
.svc-card .price-line{display:flex;justify-content:space-between;align-items:baseline;margin-top:1rem;border-top:2px dashed #d9d0f0;padding-top:.9rem}
.svc-card .price-line b{font-family:var(--display);font-weight:800;font-size:1.7rem;color:var(--magenta-d)}
.svc-card .price-line span{font-size:.85rem;color:#7b7299}

/* ---------- Testimonials ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.quote{background:var(--ink-3);border:3px solid var(--line-2);border-radius:var(--r-md);padding:1.7rem;transition:transform .26s var(--spring),border-color .26s}
.quote:hover{transform:translateY(-5px);border-color:var(--lime)}
.quote .stars{color:var(--lime);letter-spacing:2px;font-size:1.05rem}
.quote p{margin:.7rem 0 1.1rem;color:var(--white);font-size:1.05rem}
.quote-by{display:flex;align-items:center;gap:.7rem}
.q-av{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-weight:800;color:var(--ink)}
.quote:nth-child(1) .q-av{background:var(--magenta);color:#fff}
.quote:nth-child(2) .q-av{background:var(--cyan)}
.quote:nth-child(3) .q-av{background:var(--lime)}
.quote-by b{display:block;font-family:var(--display);font-weight:700;font-size:1.2rem}
.quote-by span{font-size:.85rem;color:var(--fog)}

/* ---------- CTA band ---------- */
.cta-band{background:var(--grad-cta);border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);text-align:center;position:relative;overflow:hidden}
.cta-band h2{font-size:clamp(2.6rem,7vw,5rem);text-transform:uppercase;color:#fff;text-shadow:4px 4px 0 rgba(12,10,20,.35)}
.cta-band p{color:rgba(255,255,255,.92);max-width:50ch;margin:1rem auto 1.8rem;font-size:1.15rem}
.cta-band .btn{margin:0 .4rem}

/* ---------- Blog ---------- */
.featured{display:grid;grid-template-columns:1.3fr 1fr;gap:2rem;align-items:center;background:var(--ink-3);border:3px solid var(--line-2);border-radius:var(--r-lg);overflow:hidden;padding:0}
.featured-media{position:relative;height:100%;min-height:340px;overflow:hidden}
.featured-media img{width:100%;height:100%;object-fit:cover;min-height:340px}
.featured-body{padding:clamp(1.6rem,3vw,2.6rem)}
.featured-body h2{font-size:clamp(2rem,4vw,3.2rem);text-transform:uppercase;margin:.8rem 0 .8rem;color:#fff}
.featured-body p{color:var(--fog)}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.post{background:var(--white);color:var(--ink);border:3px solid var(--ink);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--hard);transition:transform .26s var(--spring),box-shadow .26s var(--spring)}
.post:hover{transform:translate(-4px,-4px);box-shadow:var(--pop)}
.post-img{height:200px;overflow:hidden;border-bottom:3px solid var(--ink);background:var(--grad-dusk)}
.post-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--spring)}
.post:hover .post-img img{transform:scale(1.07)}
.post-body{padding:1.4rem 1.5rem 1.6rem}
.post-body h3{font-size:1.6rem;text-transform:uppercase;margin:.5rem 0;line-height:.98}
.post-body p{color:#5b5273;font-size:.96rem}
.tag{display:inline-block;font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:.95rem;letter-spacing:.05em;padding:.2rem .7rem;border-radius:var(--r-pill);border:2.5px solid var(--ink)}
.tag.t-m{background:var(--magenta);color:#fff}
.tag.t-c{background:var(--cyan);color:var(--ink)}
.tag.t-l{background:var(--lime);color:var(--ink)}
.tag.t-o{background:var(--orange);color:var(--ink)}
.post-meta{font-size:.84rem;color:#7b7299;margin-top:.9rem;font-weight:600}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.6rem,4vw,3rem);align-items:start}
.form-card{background:var(--white);color:var(--ink);border:3px solid var(--ink);border-radius:var(--r-lg);padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--hard)}
.form-card h2{font-size:clamp(2rem,4vw,3rem);text-transform:uppercase;margin-bottom:.4rem}
.field{margin-bottom:1.1rem}
.field label{display:block;font-family:var(--display);font-weight:700;font-size:1.18rem;text-transform:uppercase;margin-bottom:.35rem}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--body);font-size:1rem;padding:.85rem 1rem;
  border:3px solid var(--ink);border-radius:14px;background:var(--paper);color:var(--ink);
  transition:box-shadow .2s,border-color .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--magenta);box-shadow:4px 4px 0 var(--cyan)}
.field textarea{min-height:120px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.hp{position:absolute;left:-9999px;opacity:0}
[data-form-note]{margin-top:1rem;font-weight:700;font-family:var(--display);font-size:1.25rem;text-transform:uppercase}
[data-form-note].ok{color:var(--magenta-d)}

.info-card{background:var(--ink-3);border:3px solid var(--line-2);border-radius:var(--r-lg);padding:clamp(1.5rem,3vw,2.2rem)}
.info-card h3{font-size:1.7rem;text-transform:uppercase;color:#fff;margin-bottom:.3rem}
.info-row{display:flex;gap:.8rem;align-items:flex-start;padding:.9rem 0;border-bottom:2px solid var(--line)}
.info-row:last-child{border-bottom:none}
.info-ico{width:42px;height:42px;flex:none;border-radius:12px;display:grid;place-items:center;border:2.5px solid var(--ink);box-shadow:3px 3px 0 var(--ink)}
.info-ico.i-m{background:var(--magenta)}.info-ico.i-m svg{color:#fff}
.info-ico.i-c{background:var(--cyan)}
.info-ico.i-l{background:var(--lime)}
.info-ico svg{width:20px;height:20px;color:var(--ink)}
.info-row b{font-family:var(--display);font-weight:700;font-size:1.2rem;color:#fff;text-transform:uppercase}
.info-row span,.info-row a{display:block;color:var(--fog);font-size:.97rem}
.info-row a:hover{color:var(--cyan)}
.hours{margin-top:1rem}
.hours li{display:flex;justify-content:space-between;padding:.45rem 0;border-bottom:1px dashed var(--line);color:var(--fog);font-weight:500}
.hours li b{color:var(--lime);font-family:var(--display);font-weight:700;font-size:1.1rem}
.hours li.closed b{color:var(--magenta)}

.map-card{margin-top:1.4rem;border:3px solid var(--line-2);border-radius:var(--r-lg);overflow:hidden;background:var(--ink-2)}
.map-card svg{display:block;width:100%;height:auto}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink-2);border-top:3px solid var(--magenta);padding:clamp(2.8rem,5vw,4rem) 0 1.8rem;position:relative;overflow:hidden}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2rem}
.footer-brand .brand{margin-bottom:1rem}
.footer-brand p{color:var(--fog);max-width:34ch}
.footer-social{display:flex;gap:.6rem;margin-top:1.2rem}
.footer-social a{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;border:2.5px solid var(--line-2);color:var(--fog);transition:transform .25s var(--spring),background .2s,color .2s,border-color .2s}
.footer-social a:hover{transform:translateY(-4px) rotate(-6deg);background:var(--magenta);color:#fff;border-color:var(--magenta)}
.footer-social svg{width:19px;height:19px}
.footer-col h4{font-family:var(--display);font-weight:800;font-size:1.35rem;text-transform:uppercase;color:#fff;margin-bottom:1rem}
.footer-col ul{display:grid;gap:.6rem}
.footer-col a{color:var(--fog);font-weight:500;transition:color .2s,padding-left .2s}
.footer-col a:hover{color:var(--cyan);padding-left:5px}
.footer-bottom{margin-top:2.6rem;padding-top:1.5rem;border-top:2px solid var(--line);color:var(--fog-d);font-size:.86rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.disclaimer{margin-top:1rem;color:var(--fog-d);font-size:.8rem;max-width:90ch;line-height:1.5}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px) scale(.97);transition:opacity .6s var(--spring),transform .6s var(--spring)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.07s}
.reveal[data-d="2"]{transition-delay:.14s}
.reveal[data-d="3"]{transition-delay:.21s}
.reveal[data-d="4"]{transition-delay:.28s}
.reveal[data-d="5"]{transition-delay:.35s}

/* ---------- Page hero (interior) ---------- */
.page-hero{background:var(--grad-dusk);padding:clamp(3rem,6vw,5rem) 0 clamp(2.6rem,5vw,4rem);text-align:center;position:relative;overflow:hidden}
.page-hero h1{font-size:clamp(3rem,8vw,6rem);text-transform:uppercase;margin:1rem 0 .8rem}
.page-hero p{color:var(--fog);max-width:60ch;margin:0 auto;font-size:1.15rem}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:2.6rem}
  .hero-copy{text-align:center}
  .hero-copy h1{margin-inline:auto}
  .hero-tag{margin-inline:auto}
  .hero-actions,.hero-trust{justify-content:center}
  .split{grid-template-columns:1fr;gap:2.4rem}
  .split-media{order:-1}
  .cards,.svc-grid,.quotes,.post-grid{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr);gap:2.4rem 1.2rem}
  .pricing{grid-template-columns:1fr;max-width:460px;margin:0 auto}
  .featured{grid-template-columns:1fr}
  .featured-media{min-height:280px}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:740px){
  .nav-links,.nav-cta{
    position:absolute;top:calc(100% + 12px);left:0;right:0;
    flex-direction:column;align-items:stretch;gap:.5rem;
    background:var(--ink-2);border:3px solid var(--magenta);border-radius:20px;
    padding:1rem;box-shadow:var(--pop);
    opacity:0;visibility:hidden;transform:translateY(-12px);transition:.25s var(--spring);
  }
  .nav-cta{top:calc(100% + 12px)}
  .nav.open .nav-links{opacity:1;visibility:visible;transform:none}
  .nav.open .nav-cta{opacity:1;visibility:visible;transform:none;top:calc(100% + 290px)}
  .nav-links a{text-align:center;font-size:1.4rem}
  .nav-phone{justify-content:center}
  .nav-toggle{display:flex}
  .gallery{grid-template-columns:1fr}
}
@media (max-width:560px){
  .cards,.svc-grid,.quotes,.post-grid,.stats,.steps{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-copy h1{font-size:clamp(2.8rem,13vw,4rem)}
  .float-badge.fb1,.float-badge.fb2{position:static;display:inline-block;margin:.5rem .5rem 0 0;rotate:0deg}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .marquee-track{animation:none;transform:none}
}
