/* ============================================================
   SMITHSIDE JUNK REMOVAL — SITE STYLES
   ============================================================ */

:root{
  --neon:#39FF14;
  --electric:#00E65C;
  --forest:#0B5D1E;
  --deep:#031B0F;
  --lime:#66FF33;
  --toxic:#99FF00;
  --black:#000000;
  --charcoal:#111111;
  --soft-charcoal:#1a1a1a;
  --steel:#6E6E6E;
  --light-grey:#CFCFCF;
  --white:#FFFFFF;
  --burnt:#D96B1A;
  --gold:#F5A623;

  --shadow-sm:0 4px 12px rgba(0,0,0,.4);
  --shadow-md:0 12px 28px rgba(0,0,0,.5);
  --shadow-glow:0 0 24px rgba(57,255,20,.35);

  --radius-sm:4px;
  --radius-md:8px;
  --radius-lg:14px;

  --container:1240px;
  --nav-h:78px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

html{scroll-behavior:smooth;}
html,body{
  background:var(--charcoal);
  color:var(--white);
  font-family:'Inter',-apple-system,Segoe UI,Roboto,sans-serif;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{max-width:100%;display:block;}

a{color:inherit;text-decoration:none;}

button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit;}

::selection{background:var(--neon);color:var(--black);}

/* ===================== TYPOGRAPHY HELPERS ===================== */
.display{font-family:'Anton',Impact,sans-serif;font-weight:400;letter-spacing:.5px;text-transform:uppercase;line-height:.95;}
.bebas{font-family:'Bebas Neue',Impact,sans-serif;letter-spacing:1.5px;text-transform:uppercase;}
.stencil{font-family:'Black Ops One',Impact,sans-serif;letter-spacing:1px;text-transform:uppercase;}
.mono{font-family:'Oswald',sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:1.5px;}

.neon-text{
  color:var(--neon);
  text-shadow:0 0 8px rgba(57,255,20,.55),0 0 18px rgba(57,255,20,.35);
}

.eyebrow{
  display:inline-block;
  font-family:'Bebas Neue',sans-serif;
  font-size:13px;letter-spacing:5px;text-transform:uppercase;
  color:var(--neon);
  padding:6px 14px;
  border:1px solid rgba(57,255,20,.4);
  border-radius:2px;
  background:rgba(57,255,20,.06);
  margin-bottom:18px;
}

.section-title{
  font-family:'Anton',sans-serif;
  font-size:clamp(40px,6vw,72px);
  line-height:.95;
  text-transform:uppercase;
  letter-spacing:1px;
  margin-bottom:18px;
}
.section-title em{
  font-style:normal;
  background:linear-gradient(180deg, var(--neon) 0%, var(--electric) 60%, var(--forest) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 10px rgba(57,255,20,.4));
}

.section-lede{
  max-width:680px;
  font-size:16px;
  color:var(--light-grey);
  font-weight:300;
  line-height:1.75;
  margin-bottom:42px;
}

.stripe-divider{
  height:6px;
  background:repeating-linear-gradient(135deg,var(--neon) 0 8px,transparent 8px 16px);
  border-radius:2px;
}

/* ===================== LAYOUT ===================== */
.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 32px;
}
.section{padding:96px 0;position:relative;}
.section-dark{background:var(--charcoal);}
.section-deep{background:linear-gradient(180deg,#04130a 0%,var(--deep) 100%);}
.section-light{background:var(--soft-charcoal);}

.bg-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(57,255,20,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(57,255,20,.05) 1px, transparent 1px);
  background-size:32px 32px;
  mask-image:radial-gradient(ellipse at 50% 50%, #000 25%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 50%, #000 25%, transparent 80%);
  pointer-events:none;
  z-index:0;
}
.bg-glow-tl{
  position:absolute;top:-120px;left:-120px;
  width:520px;height:520px;
  background:radial-gradient(circle, rgba(57,255,20,.2) 0%, transparent 60%);
  filter:blur(40px);pointer-events:none;z-index:0;
}
.bg-glow-br{
  position:absolute;bottom:-160px;right:-120px;
  width:560px;height:560px;
  background:radial-gradient(circle, rgba(0,230,92,.18) 0%, transparent 60%);
  filter:blur(50px);pointer-events:none;z-index:0;
}
.section > .container{position:relative;z-index:1;}

/* ===================== BUTTONS ===================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:'Anton',sans-serif;font-size:16px;letter-spacing:1.5px;
  text-transform:uppercase;text-align:center;
  padding:16px 28px;border-radius:6px;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
  position:relative;overflow:hidden;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);}
.btn:active{transform:translateY(0);}

.btn-primary{
  background:var(--neon);
  color:var(--black);
  box-shadow:0 8px 20px rgba(57,255,20,.35), inset 0 -3px 0 rgba(0,0,0,.18);
}
.btn-primary:hover{
  background:var(--electric);
  box-shadow:0 14px 30px rgba(57,255,20,.5);
}
.btn-primary::after{
  content:'';position:absolute;top:0;left:-150%;width:60%;height:100%;
  background:linear-gradient(120deg, transparent, rgba(255,255,255,.5), transparent);
  transition:left .8s ease;
}
.btn-primary:hover::after{left:160%;}

.btn-accent{
  background:var(--burnt);
  color:var(--white);
  box-shadow:0 8px 20px rgba(217,107,26,.4);
}
.btn-accent:hover{background:#e8771f;box-shadow:0 14px 30px rgba(217,107,26,.55);}

.btn-ghost{
  background:transparent;
  color:var(--white);
  border:2px solid rgba(255,255,255,.25);
}
.btn-ghost:hover{
  border-color:var(--neon);
  color:var(--neon);
  box-shadow:0 0 24px rgba(57,255,20,.25);
}

.btn .ico{width:18px;height:18px;flex:0 0 auto;}

/* ===================== NAV ===================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--nav-h);
  background:rgba(10,10,10,.72);
  backdrop-filter:blur(18px) saturate(150%);
  -webkit-backdrop-filter:blur(18px) saturate(150%);
  border-bottom:1px solid rgba(57,255,20,.12);
  transition:background .3s ease, box-shadow .3s ease;
}
.nav.scrolled{
  background:rgba(8,8,8,.94);
  box-shadow:0 8px 30px rgba(0,0,0,.5);
}
.nav-inner{
  max-width:var(--container);
  height:100%;
  margin:0 auto;
  padding:0 32px;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-brand{
  display:flex;align-items:center;gap:14px;
}
.nav-brand img{
  height:48px;width:auto;
  filter:drop-shadow(0 0 12px rgba(57,255,20,.45));
  transition:transform .3s ease, filter .3s ease;
}
.nav-brand:hover img{transform:scale(1.05) rotate(-2deg);filter:drop-shadow(0 0 18px rgba(57,255,20,.7));}
.nav-brand-text{
  display:flex;flex-direction:column;line-height:1;
}
.nav-brand-text .top{
  font-family:'Anton',sans-serif;font-size:22px;color:var(--white);
  text-transform:uppercase;letter-spacing:1.5px;
}
.nav-brand-text .top em{font-style:normal;color:var(--neon);}
.nav-brand-text .sub{
  font-family:'Bebas Neue',sans-serif;font-size:11px;letter-spacing:3px;
  color:var(--steel);margin-top:3px;
}

.nav-links{
  display:flex;align-items:center;gap:6px;
}
.nav-links a.nav-link{
  font-family:'Bebas Neue',sans-serif;
  font-size:15px;letter-spacing:2.5px;
  color:var(--light-grey);
  text-transform:uppercase;
  padding:10px 16px;border-radius:4px;
  transition:color .25s ease, background .25s ease;
  position:relative;
}
.nav-links a.nav-link:hover{color:var(--neon);background:rgba(57,255,20,.08);}
.nav-links a.nav-link.active{color:var(--neon);}
.nav-links a.nav-link.active::after{
  content:'';position:absolute;left:16px;right:16px;bottom:5px;
  height:2px;background:var(--neon);
  box-shadow:0 0 8px var(--neon);
}

.nav-cta{
  margin-left:14px;
  background:var(--neon);
  color:var(--black);
  font-family:'Anton',sans-serif;font-size:14px;letter-spacing:1.5px;
  padding:12px 22px;border-radius:6px;
  text-transform:uppercase;
  transition:transform .25s ease, box-shadow .25s ease;
  box-shadow:0 6px 16px rgba(57,255,20,.35);
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(57,255,20,.5);}

.nav-toggle{
  display:none;
  width:44px;height:44px;
  border-radius:6px;
  align-items:center;justify-content:center;
  border:1px solid rgba(57,255,20,.3);
  background:rgba(57,255,20,.05);
}
.nav-toggle span{
  display:block;width:22px;height:2px;background:var(--neon);
  position:relative;transition:transform .3s ease, background .3s ease;
}
.nav-toggle span::before,.nav-toggle span::after{
  content:'';position:absolute;left:0;width:22px;height:2px;background:var(--neon);
  transition:transform .3s ease, top .3s ease;
}
.nav-toggle span::before{top:-7px;}
.nav-toggle span::after{top:7px;}
.nav-toggle.is-open span{background:transparent;}
.nav-toggle.is-open span::before{top:0;transform:rotate(45deg);}
.nav-toggle.is-open span::after{top:0;transform:rotate(-45deg);}

@media (max-width:960px){
  .nav-toggle{display:inline-flex;}
  .nav-links{
    position:fixed;top:var(--nav-h);left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:rgba(8,12,8,.98);
    backdrop-filter:blur(16px);
    border-bottom:1px solid rgba(57,255,20,.18);
    padding:18px 24px 28px;
    transform:translateY(-120%);opacity:0;pointer-events:none;
    transition:transform .35s ease, opacity .35s ease;
  }
  .nav-links.is-open{transform:translateY(0);opacity:1;pointer-events:auto;}
  .nav-links a.nav-link{
    padding:14px 8px;font-size:18px;border-bottom:1px solid rgba(255,255,255,.06);
  }
  .nav-links a.nav-link.active::after{display:none;}
  .nav-cta{margin:14px 0 0;display:flex;justify-content:center;font-size:16px;padding:14px;}
}

/* ===================== HERO ===================== */
.hero{
  position:relative;
  padding:calc(var(--nav-h) + 80px) 0 100px;
  overflow:hidden;
  background:radial-gradient(ellipse at 50% 30%,#0c2615 0%, #050d07 60%, #000 100%);
}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(57,255,20,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(57,255,20,.06) 1px, transparent 1px);
  background-size:36px 36px;
  mask-image:radial-gradient(ellipse at 60% 40%, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at 60% 40%, #000 30%, transparent 80%);
}
.hero::after{
  content:'';position:absolute;inset:0;
  background:
    conic-gradient(from 230deg at 80% 20%, transparent 0deg, rgba(57,255,20,.18) 8deg, transparent 16deg),
    conic-gradient(from 50deg at 15% 75%, transparent 0deg, rgba(102,255,51,.15) 8deg, transparent 16deg);
  mix-blend-mode:screen;opacity:.7;
}
.hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center;
}
.hero-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Bebas Neue',sans-serif;font-size:13px;letter-spacing:5px;
  color:var(--neon);
  padding:8px 16px;border:1px solid rgba(57,255,20,.5);border-radius:2px;
  background:rgba(57,255,20,.05);
  margin-bottom:24px;
}
.hero-tag::before{
  content:'';width:8px;height:8px;background:var(--neon);border-radius:50%;
  box-shadow:0 0 12px var(--neon);
  animation:pulse 1.6s infinite;
}
.hero-title{
  font-family:'Anton',sans-serif;
  font-size:clamp(54px,7.5vw,108px);
  line-height:.92;
  letter-spacing:.5px;
  text-transform:uppercase;
  color:var(--white);
  text-shadow:3px 3px 0 var(--forest), 6px 6px 0 var(--deep), 0 0 30px rgba(57,255,20,.18);
  margin-bottom:24px;
}
.hero-title em{
  font-style:normal;display:block;
  background:linear-gradient(180deg, var(--neon) 0%, var(--electric) 50%, var(--forest) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:none;
  filter:drop-shadow(0 0 22px rgba(57,255,20,.5));
}
.hero-sub{
  font-size:18px;color:var(--light-grey);font-weight:300;line-height:1.7;
  max-width:560px;margin-bottom:32px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:32px;}
.hero-trust{
  display:flex;flex-wrap:wrap;gap:22px;align-items:center;
  padding-top:24px;border-top:1px solid rgba(255,255,255,.08);
}
.hero-trust-item{display:flex;align-items:center;gap:10px;}
.hero-trust-item .ico{
  width:34px;height:34px;border-radius:50%;
  background:rgba(57,255,20,.1);
  border:1px solid rgba(57,255,20,.4);
  display:flex;align-items:center;justify-content:center;
  color:var(--neon);
}
.hero-trust-item .lbl{
  font-family:'Bebas Neue',sans-serif;font-size:13px;letter-spacing:2.5px;color:var(--white);
}
.hero-trust-item .val{font-size:11px;color:var(--steel);}

.hero-visual{
  position:relative;
  height:540px;
  border-radius:20px;
  overflow:hidden;
  border:1px solid rgba(57,255,20,.25);
  box-shadow:0 30px 80px rgba(0,0,0,.7), 0 0 50px rgba(57,255,20,.15);
}
.hero-visual img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(1.1) contrast(1.05);
  transition:transform 8s ease;
}
.hero-visual:hover img{transform:scale(1.06);}
.hero-visual::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(3,27,15,.85) 100%);
}
.hero-visual-badge{
  position:absolute;left:24px;bottom:24px;z-index:2;
  display:flex;align-items:center;gap:14px;
  padding:14px 20px;
  background:rgba(8,12,8,.85);
  backdrop-filter:blur(8px);
  border:1px solid var(--neon);
  border-radius:10px;
  box-shadow:0 0 28px rgba(57,255,20,.3);
}
.hero-visual-badge .num{
  font-family:'Anton',sans-serif;font-size:42px;color:var(--neon);line-height:1;
}
.hero-visual-badge .txt{
  font-family:'Bebas Neue',sans-serif;font-size:12px;letter-spacing:3px;color:var(--white);line-height:1.3;
}
.hero-visual-stickers{
  position:absolute;top:20px;right:20px;z-index:2;
  display:flex;flex-direction:column;gap:10px;
}
.hero-sticker{
  background:var(--burnt);color:var(--white);
  font-family:'Black Ops One',sans-serif;font-size:11px;letter-spacing:1px;
  padding:8px 14px;border-radius:4px;
  box-shadow:0 6px 14px rgba(217,107,26,.5);
  transform:rotate(3deg);
}
.hero-sticker.alt{background:var(--neon);color:var(--black);transform:rotate(-3deg);}

@media (max-width:900px){
  .hero{padding:calc(var(--nav-h) + 40px) 0 60px;}
  .hero-grid{grid-template-columns:1fr;gap:42px;}
  .hero-visual{height:380px;}
}

/* Floating lightning bolt animation */
.float-bolt{
  position:absolute;
  font-size:80px;color:var(--neon);
  opacity:.18;
  filter:drop-shadow(0 0 18px var(--neon));
  pointer-events:none;
  animation:float 6s ease-in-out infinite;
}

/* ===================== PAGE BANNER (non-home pages) ===================== */
.page-banner{
  position:relative;
  padding:calc(var(--nav-h) + 70px) 0 80px;
  background:radial-gradient(ellipse at 30% 50%, #0c2615 0%, #050d07 60%, #000 100%);
  overflow:hidden;
  border-bottom:1px solid rgba(57,255,20,.2);
}
.page-banner::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(57,255,20,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(57,255,20,.05) 1px, transparent 1px);
  background-size:30px 30px;
  mask-image:radial-gradient(ellipse at 50% 50%, #000 25%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 50%, #000 25%, transparent 80%);
}
.page-banner .container{position:relative;z-index:2;}
.page-banner h1{
  font-family:'Anton',sans-serif;
  font-size:clamp(48px,7vw,92px);
  line-height:.95;
  text-transform:uppercase;
  letter-spacing:1px;
  margin-bottom:18px;
}
.page-banner h1 em{
  font-style:normal;
  background:linear-gradient(180deg, var(--neon) 0%, var(--electric) 60%, var(--forest) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 12px rgba(57,255,20,.45));
}
.page-banner p{
  font-size:17px;color:var(--light-grey);max-width:680px;line-height:1.7;
}
.crumbs{
  display:flex;gap:10px;align-items:center;
  font-family:'Bebas Neue',sans-serif;font-size:12px;letter-spacing:3px;color:var(--steel);
  margin-bottom:18px;
}
.crumbs a:hover{color:var(--neon);}
.crumbs .sep{color:var(--neon);}

/* ===================== CARDS ===================== */
.card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:22px;
}
.card-grid.cols-3{grid-template-columns:repeat(3,1fr);}
.card-grid.cols-4{grid-template-columns:repeat(4,1fr);}
@media (max-width:900px){
  .card-grid.cols-3,.card-grid.cols-4{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:600px){
  .card-grid.cols-3,.card-grid.cols-4{grid-template-columns:1fr;}
}

.svc-card{
  position:relative;
  background:linear-gradient(160deg, var(--soft-charcoal) 0%, #0c0c0c 100%);
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  overflow:hidden;
  transition:transform .35s ease, border-color .35s ease, box-shadow .35s ease;
}
.svc-card:hover{
  transform:translateY(-8px);
  border-color:rgba(57,255,20,.45);
  box-shadow:0 20px 50px rgba(0,0,0,.6), 0 0 30px rgba(57,255,20,.18);
}
.svc-card .img{
  height:200px;position:relative;overflow:hidden;
}
.svc-card .img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease;}
.svc-card:hover .img img{transform:scale(1.1);}
.svc-card .img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(0,0,0,.85) 100%);
}
.svc-card .badge{
  position:absolute;top:14px;left:14px;z-index:2;
  background:rgba(8,12,8,.85);
  border:1px solid var(--neon);
  color:var(--neon);
  font-family:'Bebas Neue',sans-serif;font-size:11px;letter-spacing:2.5px;
  padding:5px 11px;border-radius:3px;
}
.svc-card .body{
  padding:24px 26px 28px;
}
.svc-card h3{
  font-family:'Anton',sans-serif;
  font-size:24px;text-transform:uppercase;letter-spacing:.5px;
  color:var(--white);
  margin-bottom:10px;
}
.svc-card p{
  font-size:14px;color:var(--light-grey);line-height:1.65;
  margin-bottom:18px;font-weight:300;
}
.svc-card .more{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Bebas Neue',sans-serif;font-size:13px;letter-spacing:3px;
  color:var(--neon);
  transition:gap .25s ease;
}
.svc-card .more:hover{gap:14px;}
.svc-card .more::after{content:'→';font-family:Inter,sans-serif;font-size:16px;}

.svc-card .accent-edge{
  position:absolute;top:0;left:0;height:3px;width:0;
  background:var(--neon);
  transition:width .5s ease;
  box-shadow:0 0 8px var(--neon);
}
.svc-card:hover .accent-edge{width:100%;}

/* ===================== STATS ===================== */
.stats-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
@media (max-width:800px){.stats-row{grid-template-columns:repeat(2,1fr);}}
.stat{
  text-align:left;
  background:linear-gradient(160deg, rgba(57,255,20,.05) 0%, transparent 100%);
  border:1px solid rgba(57,255,20,.18);
  border-left:3px solid var(--neon);
  border-radius:10px;
  padding:24px 22px;
  position:relative;overflow:hidden;
}
.stat::after{
  content:'';position:absolute;top:0;right:0;width:100px;height:100px;
  background:radial-gradient(circle, rgba(57,255,20,.18) 0%, transparent 65%);
  pointer-events:none;
}
.stat .v{
  font-family:'Anton',sans-serif;font-size:54px;line-height:1;color:var(--neon);
  text-shadow:0 0 20px rgba(57,255,20,.4);
}
.stat .v small{font-size:30px;color:var(--white);text-shadow:none;}
.stat .l{
  margin-top:6px;
  font-family:'Bebas Neue',sans-serif;font-size:13px;letter-spacing:3px;color:var(--light-grey);
}

/* ===================== PROCESS ===================== */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
@media (max-width:900px){.process{grid-template-columns:repeat(2,1fr);}}
@media (max-width:520px){.process{grid-template-columns:1fr;}}
.step{
  position:relative;
  background:var(--soft-charcoal);
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  padding:30px 26px 26px;
  transition:transform .3s ease, border-color .3s ease;
}
.step:hover{transform:translateY(-6px);border-color:rgba(57,255,20,.4);}
.step .n{
  font-family:'Anton',sans-serif;
  font-size:64px;line-height:1;color:var(--neon);
  text-shadow:0 0 22px rgba(57,255,20,.45);
  opacity:.9;
}
.step h3{
  font-family:'Anton',sans-serif;font-size:22px;
  text-transform:uppercase;letter-spacing:1px;
  color:var(--white);margin:6px 0 10px;
}
.step p{font-size:14px;color:var(--light-grey);line-height:1.65;font-weight:300;}

/* ===================== REVIEWS ===================== */
.review-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
}
@media (max-width:900px){.review-grid{grid-template-columns:1fr;}}
.review-card{
  background:linear-gradient(160deg, #1a1a1a 0%, #0c0c0c 100%);
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  padding:30px 28px;
  position:relative;
  transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.review-card:hover{
  transform:translateY(-6px);
  border-color:rgba(57,255,20,.4);
  box-shadow:0 16px 40px rgba(0,0,0,.5), 0 0 24px rgba(57,255,20,.15);
}
.review-card .stars{
  display:flex;gap:3px;color:var(--gold);font-size:18px;margin-bottom:14px;
}
.review-card blockquote{
  font-size:15.5px;color:var(--white);line-height:1.7;font-weight:300;
  margin-bottom:22px;
  font-style:italic;
}
.review-card blockquote::before{content:'“';color:var(--neon);font-size:30px;line-height:0;margin-right:4px;}
.review-card .who{
  display:flex;align-items:center;gap:14px;
  padding-top:18px;border-top:1px solid rgba(255,255,255,.06);
}
.review-card .who .av{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg, var(--neon), var(--forest));
  color:var(--black);
  display:flex;align-items:center;justify-content:center;
  font-family:'Anton',sans-serif;font-size:20px;
}
.review-card .who .nm{font-family:'Bebas Neue',sans-serif;letter-spacing:2px;color:var(--white);font-size:15px;}
.review-card .who .meta{font-size:11.5px;color:var(--steel);font-family:'Oswald',sans-serif;letter-spacing:1px;}
.review-card::before{
  content:'';position:absolute;top:0;left:30px;width:60px;height:3px;
  background:var(--neon);border-radius:0 0 3px 3px;
  box-shadow:0 0 10px var(--neon);
}

/* ===================== CTA BANNER ===================== */
.cta-banner{
  position:relative;
  padding:80px 56px;
  background:linear-gradient(115deg, var(--deep) 0%, #061508 60%, #000 100%);
  border:1px solid var(--neon);
  border-radius:22px;
  overflow:hidden;
  display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center;
  box-shadow:0 30px 70px rgba(0,0,0,.5), 0 0 40px rgba(57,255,20,.18);
}
.cta-banner::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 100% 0%, rgba(57,255,20,.22) 0%, transparent 55%),
    repeating-linear-gradient(135deg, rgba(57,255,20,.04) 0 8px, transparent 8px 16px);
  pointer-events:none;
}
.cta-banner > *{position:relative;z-index:1;}
.cta-banner h2{
  font-family:'Anton',sans-serif;
  font-size:clamp(34px,4vw,52px);
  text-transform:uppercase;letter-spacing:1px;line-height:1;
  margin-bottom:14px;
}
.cta-banner h2 em{font-style:normal;color:var(--neon);text-shadow:0 0 18px rgba(57,255,20,.5);}
.cta-banner p{font-size:16px;color:var(--light-grey);max-width:520px;margin-bottom:8px;}
.cta-banner .actions{display:flex;flex-direction:column;gap:14px;}
.cta-banner .ph{
  font-family:'Anton',sans-serif;font-size:38px;color:var(--neon);
  text-shadow:0 0 18px rgba(57,255,20,.4);
  display:flex;align-items:center;gap:14px;
}
.cta-banner .ph::before{content:'⚡';}
@media (max-width:900px){
  .cta-banner{grid-template-columns:1fr;padding:50px 28px;}
}

/* ===================== FOOTER ===================== */
.footer{
  background:linear-gradient(180deg, #050d07 0%, #000 100%);
  border-top:1px solid rgba(57,255,20,.18);
  padding:70px 0 30px;
  position:relative;
}
.footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:6px;
  background:repeating-linear-gradient(135deg,var(--neon) 0 8px,transparent 8px 16px);
  opacity:.7;
}
.footer-grid{
  display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:42px;margin-bottom:48px;
}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;}}
.footer-brand img{height:64px;margin-bottom:14px;filter:drop-shadow(0 0 16px rgba(57,255,20,.45));}
.footer-brand p{color:var(--light-grey);font-size:14px;line-height:1.7;font-weight:300;max-width:340px;}
.footer h4{
  font-family:'Anton',sans-serif;font-size:18px;text-transform:uppercase;letter-spacing:1.5px;
  color:var(--white);margin-bottom:18px;
  display:flex;align-items:center;gap:8px;
}
.footer h4::before{content:'';width:18px;height:2px;background:var(--neon);}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer ul a{
  color:var(--light-grey);font-size:14px;
  transition:color .25s ease, padding-left .25s ease;
}
.footer ul a:hover{color:var(--neon);padding-left:6px;}
.footer .contact-line{
  display:flex;align-items:center;gap:10px;color:var(--light-grey);font-size:14px;margin-bottom:10px;
}
.footer .contact-line .ico{color:var(--neon);width:16px;flex:0 0 16px;}
.footer .contact-line a:hover{color:var(--neon);}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:26px;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;
  font-family:'Bebas Neue',sans-serif;font-size:12px;letter-spacing:3px;color:var(--steel);
}
.footer-bottom .accent{color:var(--neon);}

/* ===================== ABOUT PAGE ===================== */
.about-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:center;}
@media (max-width:900px){.about-grid{grid-template-columns:1fr;}}
.about-img{
  position:relative;border-radius:20px;overflow:hidden;
  border:1px solid rgba(57,255,20,.25);
  box-shadow:0 30px 60px rgba(0,0,0,.5), 0 0 30px rgba(57,255,20,.15);
}
.about-img img{width:100%;height:560px;object-fit:cover;}
.about-img .stamp{
  position:absolute;left:24px;bottom:24px;
  background:rgba(8,12,8,.85);backdrop-filter:blur(8px);
  border:1px solid var(--neon);border-radius:10px;
  padding:14px 18px;
  display:flex;align-items:center;gap:14px;
}
.about-img .stamp .v{font-family:'Anton',sans-serif;font-size:34px;color:var(--neon);line-height:1;}
.about-img .stamp .l{font-family:'Bebas Neue',sans-serif;font-size:11px;letter-spacing:2.5px;color:var(--white);line-height:1.3;}
.about-text p{font-size:16px;color:var(--light-grey);line-height:1.85;margin-bottom:18px;font-weight:300;}
.about-text p strong{color:var(--white);font-weight:600;}

.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
@media (max-width:900px){.values-grid{grid-template-columns:1fr;}}
.value{
  background:var(--soft-charcoal);
  border:1px solid rgba(255,255,255,.06);
  border-left:3px solid var(--neon);
  border-radius:10px;
  padding:28px 26px;
  transition:transform .3s ease, border-color .3s ease;
}
.value:hover{transform:translateY(-6px);}
.value .ico{
  width:54px;height:54px;border-radius:12px;
  background:rgba(57,255,20,.1);border:1px solid rgba(57,255,20,.3);
  display:flex;align-items:center;justify-content:center;
  color:var(--neon);font-size:24px;
  margin-bottom:18px;
}
.value h3{
  font-family:'Anton',sans-serif;font-size:22px;text-transform:uppercase;letter-spacing:1px;
  color:var(--white);margin-bottom:10px;
}
.value p{color:var(--light-grey);font-size:14px;line-height:1.7;font-weight:300;}

/* ===================== SERVICES PAGE ===================== */
.svc-detail{
  display:grid;grid-template-columns:1fr 1.1fr;gap:50px;align-items:center;
  padding:60px 0;border-bottom:1px solid rgba(255,255,255,.07);
}
.svc-detail:nth-child(even){grid-template-columns:1.1fr 1fr;}
.svc-detail:nth-child(even) .svc-detail-img{order:2;}
.svc-detail:nth-child(even) .svc-detail-text{order:1;}
@media (max-width:900px){
  .svc-detail,.svc-detail:nth-child(even){grid-template-columns:1fr;}
  .svc-detail:nth-child(even) .svc-detail-img,
  .svc-detail:nth-child(even) .svc-detail-text{order:initial;}
}
.svc-detail-img{
  position:relative;height:380px;
  border-radius:20px;overflow:hidden;
  border:1px solid rgba(57,255,20,.2);
  box-shadow:0 24px 60px rgba(0,0,0,.55);
}
.svc-detail-img img{width:100%;height:100%;object-fit:cover;transition:transform 8s ease;}
.svc-detail-img:hover img{transform:scale(1.08);}
.svc-detail-img .num{
  position:absolute;top:18px;right:18px;
  background:rgba(8,12,8,.85);border:1px solid var(--neon);color:var(--neon);
  font-family:'Anton',sans-serif;font-size:22px;
  padding:6px 14px;border-radius:6px;
}
.svc-detail-text h3{
  font-family:'Anton',sans-serif;font-size:clamp(34px,4vw,46px);text-transform:uppercase;
  letter-spacing:1px;line-height:.98;margin-bottom:14px;
}
.svc-detail-text h3 em{font-style:normal;color:var(--neon);}
.svc-detail-text p{font-size:16px;color:var(--light-grey);line-height:1.8;margin-bottom:18px;font-weight:300;}
.svc-detail-text ul{
  display:grid;grid-template-columns:1fr 1fr;gap:10px 24px;
  list-style:none;margin-bottom:24px;
}
.svc-detail-text ul li{
  display:flex;align-items:flex-start;gap:10px;
  color:var(--white);font-size:14px;
}
.svc-detail-text ul li::before{
  content:'⚡';color:var(--neon);
  filter:drop-shadow(0 0 6px var(--neon));
}

/* ===================== CONTACT PAGE ===================== */
.contact-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:start;
}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;}}
.contact-info{
  display:flex;flex-direction:column;gap:18px;
}
.contact-card{
  display:flex;gap:18px;align-items:flex-start;
  padding:26px 24px;
  background:linear-gradient(160deg, var(--soft-charcoal) 0%, #0c0c0c 100%);
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  transition:transform .3s ease, border-color .3s ease;
}
.contact-card:hover{transform:translateX(4px);border-color:rgba(57,255,20,.4);}
.contact-card .ico{
  width:54px;height:54px;border-radius:14px;flex:0 0 54px;
  background:rgba(57,255,20,.1);border:1px solid rgba(57,255,20,.4);
  display:flex;align-items:center;justify-content:center;
  color:var(--neon);
}
.contact-card h4{
  font-family:'Anton',sans-serif;font-size:20px;text-transform:uppercase;letter-spacing:1px;
  color:var(--white);margin-bottom:6px;
}
.contact-card p,.contact-card a{
  color:var(--light-grey);font-size:14px;line-height:1.6;
}
.contact-card a:hover{color:var(--neon);}
.contact-card a.big{
  font-family:'Anton',sans-serif;color:var(--neon);font-size:24px;letter-spacing:1px;
  text-shadow:0 0 12px rgba(57,255,20,.4);
}

.contact-form{
  background:linear-gradient(160deg, var(--soft-charcoal) 0%, #050d07 100%);
  border:1px solid rgba(57,255,20,.25);
  border-radius:18px;
  padding:36px 34px;
  box-shadow:0 30px 60px rgba(0,0,0,.5);
  position:relative;overflow:hidden;
}
.contact-form::before{
  content:'';position:absolute;top:-100px;right:-100px;width:280px;height:280px;
  background:radial-gradient(circle, rgba(57,255,20,.18) 0%, transparent 60%);
  pointer-events:none;
}
.contact-form h3{
  font-family:'Anton',sans-serif;font-size:30px;text-transform:uppercase;letter-spacing:1px;
  margin-bottom:8px;
}
.contact-form h3 em{font-style:normal;color:var(--neon);}
.contact-form .sub{font-size:14px;color:var(--light-grey);margin-bottom:24px;}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;position:relative;z-index:1;}
.field label{
  font-family:'Bebas Neue',sans-serif;font-size:12px;letter-spacing:3px;color:var(--neon);
}
.field input,.field select,.field textarea{
  font-family:'Inter',sans-serif;font-size:15px;color:var(--white);
  background:rgba(0,0,0,.4);
  border:1px solid rgba(255,255,255,.12);
  border-radius:8px;padding:14px 16px;
  transition:border-color .25s ease, background .25s ease, box-shadow .25s ease;
  width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--neon);
  background:rgba(57,255,20,.04);
  box-shadow:0 0 0 3px rgba(57,255,20,.15);
}
.field textarea{min-height:130px;resize:vertical;font-family:inherit;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
@media (max-width:520px){.field-row{grid-template-columns:1fr;}}
.form-success{
  display:none;text-align:center;padding:24px;
  border:1px solid var(--neon);border-radius:10px;
  background:rgba(57,255,20,.08);
}
.form-success.show{display:block;animation:fadeIn .5s ease;}
.form-success .ico{font-size:38px;margin-bottom:8px;}
.form-success h4{font-family:'Anton',sans-serif;font-size:24px;color:var(--neon);text-transform:uppercase;}
.form-success p{font-size:14px;color:var(--light-grey);margin-top:6px;}

/* ===================== REVIEWS PAGE ===================== */
.review-summary{
  display:grid;grid-template-columns:.7fr 1.3fr;gap:42px;align-items:center;
  background:linear-gradient(115deg, var(--deep) 0%, #061508 100%);
  border:1px solid rgba(57,255,20,.3);
  border-radius:20px;
  padding:42px;
  margin-bottom:60px;
  position:relative;overflow:hidden;
}
.review-summary::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 100% 0%, rgba(57,255,20,.18) 0%, transparent 55%);
  pointer-events:none;
}
.review-summary > *{position:relative;z-index:1;}
@media (max-width:800px){.review-summary{grid-template-columns:1fr;text-align:center;}}
.rating-big{
  display:flex;flex-direction:column;align-items:flex-start;
}
.rating-big .num{
  font-family:'Anton',sans-serif;font-size:120px;line-height:1;color:var(--neon);
  text-shadow:0 0 22px rgba(57,255,20,.4);
}
.rating-big .stars{color:var(--gold);font-size:22px;letter-spacing:2px;margin-top:4px;}
.rating-big .meta{font-family:'Bebas Neue',sans-serif;letter-spacing:3px;color:var(--white);font-size:13px;margin-top:8px;}
@media (max-width:800px){.rating-big{align-items:center;}}
.review-bars .bar{
  display:grid;grid-template-columns:60px 1fr 50px;gap:14px;align-items:center;margin-bottom:10px;
}
.review-bars .bar .lbl{font-family:'Bebas Neue',sans-serif;color:var(--white);letter-spacing:2px;font-size:13px;}
.review-bars .bar .track{
  height:8px;background:rgba(255,255,255,.08);border-radius:6px;overflow:hidden;
}
.review-bars .bar .fill{
  height:100%;background:linear-gradient(90deg, var(--electric), var(--neon));
  border-radius:6px;
  width:0;transition:width 1.4s cubic-bezier(.2,.8,.2,1);
}
.review-bars .bar .pct{font-family:'Oswald',sans-serif;font-size:13px;color:var(--steel);text-align:right;}

/* ===================== ANIMATIONS ===================== */
@keyframes pulse{
  0%,100%{box-shadow:0 0 4px var(--neon),0 0 12px var(--neon);transform:scale(1);}
  50%{box-shadow:0 0 12px var(--neon),0 0 24px var(--neon);transform:scale(1.15);}
}
@keyframes float{
  0%,100%{transform:translateY(0) rotate(-8deg);}
  50%{transform:translateY(-22px) rotate(-2deg);}
}
@keyframes fadeIn{
  from{opacity:0;transform:translateY(20px);}
  to{opacity:1;transform:none;}
}
@keyframes glowPulse{
  0%,100%{filter:drop-shadow(0 0 12px rgba(57,255,20,.4));}
  50%{filter:drop-shadow(0 0 26px rgba(57,255,20,.7));}
}
@keyframes shimmer{
  0%{background-position:-200% center;}
  100%{background-position:200% center;}
}
@keyframes slideIn{
  from{opacity:0;transform:translateX(-30px);}
  to{opacity:1;transform:none;}
}

/* Reveal-on-scroll */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease, transform .8s ease;}
.reveal.in{opacity:1;transform:none;}
.reveal.delay-1{transition-delay:.08s;}
.reveal.delay-2{transition-delay:.16s;}
.reveal.delay-3{transition-delay:.24s;}
.reveal.delay-4{transition-delay:.32s;}

/* Lightning bolt floating decorations */
.deco-bolt{
  position:absolute;color:var(--neon);
  filter:drop-shadow(0 0 14px var(--neon));opacity:.18;
  pointer-events:none;
  animation:float 6s ease-in-out infinite;
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;}
}

/* ===================== HOMEPAGE SLIDER (marquee) ===================== */
.slider-section{
  padding:90px 0 100px;
  background:linear-gradient(180deg,var(--charcoal) 0%, #050d07 100%);
  position:relative;overflow:hidden;
}
.slider-section .bg-grid{position:absolute;inset:0;}

/* Marquee runs full-bleed (edge-to-edge) for visual impact */
.slider-wrap{
  position:relative;
  width:100%;
  /* fade the edges so slides melt in/out */
  -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
          mask-image:linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
  overflow:hidden;
}

.slider-stage{
  position:relative;
  overflow:hidden;
  padding:8px 0;
}

.slider-track{
  display:flex;
  gap:18px;
  width:max-content;
  animation:marquee 60s linear infinite;
  will-change:transform;
}
.slider-track:hover,
.slider-stage.is-paused .slider-track{animation-play-state:paused;}

@keyframes marquee{
  from{transform:translateX(0);}
  to  {transform:translateX(-50%);}   /* duplicates create seamless loop */
}

/* Slide sizing — 5 / 4 / 2 across the visible area */
.slider-slide{
  --visible:5;
  flex:0 0 calc((100vw - 18px * (var(--visible) - 1)) / var(--visible) - 36px / var(--visible));
  position:relative;
  aspect-ratio:4/3;
  border-radius:14px;overflow:hidden;
  background:#000;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 14px 30px rgba(0,0,0,.45);
  transition:transform .35s ease, border-color .35s ease, box-shadow .35s ease;
}
.slider-slide:hover{
  transform:translateY(-6px) scale(1.02);
  border-color:rgba(57,255,20,.5);
  box-shadow:0 22px 50px rgba(0,0,0,.55), 0 0 26px rgba(57,255,20,.22);
  z-index:2;
}

@media (max-width:1100px){
  .slider-slide{--visible:4;}
}
@media (max-width:700px){
  .slider-slide{--visible:2;}
  .slider-track{gap:12px;animation-duration:45s;}
}

.slider-slide img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .8s ease, filter .35s ease;
}
.slider-slide:hover img{transform:scale(1.08);filter:saturate(1.15) contrast(1.05);}

.slider-slide::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(3,27,15,.85) 100%);
  pointer-events:none;
}

.slider-caption{
  position:absolute;left:14px;right:14px;bottom:14px;z-index:2;
}
.slider-caption .tag{
  display:inline-block;
  font-family:'Bebas Neue',sans-serif;font-size:10px;letter-spacing:2.5px;
  color:var(--neon);
  padding:3px 9px;border:1px solid var(--neon);border-radius:3px;
  background:rgba(8,12,8,.75);backdrop-filter:blur(4px);
  margin-bottom:8px;
}
.slider-caption h3{
  font-family:'Anton',sans-serif;font-size:16px;
  text-transform:uppercase;letter-spacing:.5px;line-height:1.05;
  color:var(--white);
  text-shadow:1px 1px 0 var(--deep);
}
@media (max-width:700px){
  .slider-caption h3{font-size:13px;}
  .slider-caption .tag{font-size:9px;letter-spacing:2px;padding:2px 7px;}
}

/* Slider header */
.slider-head{
  text-align:center;
  margin-bottom:42px;
}

/* ===================== PHONE BAR (sticky bottom on mobile) ===================== */
.mobile-call-bar{
  display:none;
  position:fixed;left:12px;right:12px;bottom:12px;z-index:90;
  background:var(--neon);color:var(--black);
  font-family:'Anton',sans-serif;font-size:18px;letter-spacing:1px;
  padding:14px 18px;border-radius:12px;
  text-align:center;text-transform:uppercase;
  box-shadow:0 14px 30px rgba(57,255,20,.45);
}
@media (max-width:640px){.mobile-call-bar{display:block;}}

/* utilities */
.text-center{text-align:center;}
.mt-0{margin-top:0;}
.mb-0{margin-bottom:0;}
.mt-32{margin-top:32px;}
.mb-32{margin-bottom:32px;}

/* ============================================================
   MOBILE RESPONSIVE FIXES
   ============================================================ */

/* The .why-grid class is used inline on Home (1fr 1.4fr) and
   About-Owner (.9fr 1.1fr) but had no media-query rule.
   Force it to a single column on tablets and below. */
@media (max-width:900px){
  .why-grid{
    grid-template-columns:1fr !important;
    gap:40px !important;
  }
}

/* Tighter container & nav padding on phones */
@media (max-width:640px){
  .container{padding:0 18px;}
  .nav-inner{padding:0 18px;}
  .section{padding:64px 0;}
}
@media (max-width:420px){
  .container{padding:0 14px;}
  .nav-inner{padding:0 14px;}
  .section{padding:48px 0;}
}

/* HERO — keep text + visual readable on phones */
@media (max-width:640px){
  .hero{padding:calc(var(--nav-h) + 28px) 0 56px;}
  .hero-title{font-size:clamp(40px,11vw,72px);}
  .hero-sub{font-size:15.5px;line-height:1.65;margin-bottom:24px;}
  .hero-actions{gap:10px;margin-bottom:26px;}
  .hero-actions .btn{flex:1 1 100%;justify-content:center;white-space:normal;padding:14px 18px;font-size:15px;}
  .hero-trust{gap:14px;padding-top:18px;}
  .hero-trust-item{flex:1 1 calc(50% - 14px);}
  .hero-visual{height:300px;}
  .hero-visual-badge{padding:10px 14px;left:14px;bottom:14px;gap:10px;}
  .hero-visual-badge .num{font-size:30px;}
  .hero-visual-badge .txt{font-size:10px;letter-spacing:2px;}
  .hero-visual-stickers{top:14px;right:14px;gap:8px;}
  .hero-sticker{font-size:10px;padding:6px 10px;}
}

/* PAGE BANNER */
@media (max-width:640px){
  .page-banner{padding:calc(var(--nav-h) + 32px) 0 48px;}
  .page-banner h1{font-size:clamp(36px,10vw,64px);}
  .page-banner p{font-size:15px;}
}

/* SECTION TITLES — phones get a smaller minimum */
@media (max-width:480px){
  .section-title{font-size:clamp(30px,9vw,52px);}
  .section-lede{font-size:15px;}
  .eyebrow{font-size:12px;letter-spacing:4px;padding:5px 12px;}
}

/* CARDS / SERVICE PREVIEWS */
@media (max-width:480px){
  .svc-card .img{height:180px;}
  .svc-card .body{padding:20px 20px 24px;}
  .svc-card h3{font-size:21px;}
}

/* STATS */
@media (max-width:520px){
  .stats-row{gap:12px;}
  .stat{padding:18px 16px;}
  .stat .v{font-size:40px;}
  .stat .v small{font-size:22px;}
  .stat .l{font-size:11.5px;letter-spacing:2px;}
}

/* PROCESS */
@media (max-width:480px){
  .step{padding:22px 18px;}
  .step .n{font-size:48px;}
  .step h3{font-size:19px;}
}

/* REVIEW CARD / SUMMARY */
@media (max-width:640px){
  .review-card{padding:24px 22px;}
  .review-card blockquote{font-size:14.5px;}
  .review-summary{padding:28px 22px;gap:24px;}
  .rating-big .num{font-size:80px;}
  .rating-big .stars{font-size:18px;}
  .review-bars .bar{grid-template-columns:46px 1fr 38px;gap:10px;}
}

/* CTA BANNER */
@media (max-width:640px){
  .cta-banner{padding:38px 22px;border-radius:16px;}
  .cta-banner h2{font-size:clamp(26px,7vw,38px);}
  .cta-banner p{font-size:14.5px;}
  .cta-banner .ph{font-size:28px;gap:10px;}
  .cta-banner .actions .btn{font-size:14px;padding:14px 18px;}
}
@media (max-width:380px){
  .cta-banner .ph{font-size:24px;}
}

/* ABOUT IMAGE / OWNER CARD */
@media (max-width:900px){
  .about-img img{height:420px;}
}
@media (max-width:520px){
  .about-img img{height:280px;}
  .about-img .stamp{padding:10px 14px;left:14px;bottom:14px;gap:10px;}
  .about-img .stamp .v{font-size:26px;}
  .about-img .stamp .l{font-size:10px;letter-spacing:2px;}
  .about-text p{font-size:15px;line-height:1.75;}
}

/* CONTACT INFO + FORM */
@media (max-width:640px){
  .contact-card{padding:20px 18px;gap:14px;}
  .contact-card .ico{width:44px;height:44px;flex:0 0 44px;border-radius:10px;}
  .contact-card h4{font-size:18px;}
  .contact-card a.big{font-size:22px;}
  .contact-form{padding:26px 20px;border-radius:14px;}
  .contact-form h3{font-size:24px;}
  .field input,.field select,.field textarea{font-size:14.5px;padding:12px 14px;}
}

/* SERVICE DETAILS */
@media (max-width:640px){
  .svc-detail{padding:42px 0;gap:28px;}
  .svc-detail-img{height:240px;}
  .svc-detail-text h3{font-size:clamp(28px,8vw,38px);}
  .svc-detail-text ul{grid-template-columns:1fr;gap:8px 16px;margin-bottom:20px;}
  .svc-detail-text p{font-size:15px;line-height:1.7;}
}

/* GENERIC BUTTON SHRINK ON TINY DEVICES */
@media (max-width:380px){
  .btn{font-size:14px;padding:13px 16px;letter-spacing:1px;}
}

/* FOOTER spacing */
@media (max-width:640px){
  .footer{padding:50px 0 24px;}
  .footer-grid{gap:30px;margin-bottom:34px;}
  .footer-brand img{height:54px;}
  .footer-bottom{font-size:11px;letter-spacing:2px;}
}

/* NAV brand on tiny screens — prevent it crowding the toggle */
@media (max-width:420px){
  .nav-brand img{height:40px;}
  .nav-brand-text .top{font-size:18px;letter-spacing:1px;}
  .nav-brand-text .sub{font-size:9.5px;letter-spacing:2px;}
  .nav-brand{gap:10px;}
}

/* MOBILE CALL BAR — give the page room so it never covers footer text */
@media (max-width:640px){
  body{padding-bottom:78px;}
  .mobile-call-bar{font-size:16px;padding:13px 16px;}
}
@media (max-width:380px){
  .mobile-call-bar{font-size:14px;padding:12px 14px;letter-spacing:.5px;}
}

/* ABOUT — Owner card on phones: shrink the giant avatar/circle and details */
@media (max-width:520px){
  .why-grid > .reveal > div[style*="width:160px"]{
    width:120px !important;height:120px !important;
    font-size:60px !important;margin-bottom:16px !important;
  }
}

/* About-page Brandon block — large phone number can overflow */
@media (max-width:480px){
  .why-grid a[href^="tel:"][style*="font-size:38px"]{font-size:28px !important;}
  .why-grid h3[style*="font-size:36px"]{font-size:26px !important;}
}

/* SERVICES tier cards — tighten on phones */
@media (max-width:480px){
  .card-grid > div[style*="padding:34px 28px"]{padding:26px 22px !important;}
  .card-grid > div[style*="padding:34px 28px"] > div[style*="font-size:48px"]{font-size:36px !important;}
  .card-grid > div[style*="padding:34px 28px"] > div[style*="font-size:38px"]{font-size:30px !important;}
}

/* FAQ — tighten the inline-styled details blocks on phones */
@media (max-width:480px){
  details[style*="padding:18px 22px"]{padding:14px 16px !important;}
  details summary[style*="font-size:20px"]{font-size:17px !important;}
}

/* SERVICE PILLS — keep single line wrap clean */
@media (max-width:480px){
  .section[style*="padding:42px 0"] a[class="bebas"]{
    font-size:11.5px !important;padding:8px 14px !important;letter-spacing:2px !important;
  }
}

/* Slider caption tighter on tiny phones */
@media (max-width:380px){
  .slider-caption h3{font-size:12px;}
  .slider-caption .tag{font-size:8.5px;letter-spacing:1.5px;}
}
