
:root{
  --navy:#0A1F3D; --navy-deep:#050E1F; --navy-mid:#15315A;
  --red:#D72831; --red-deep:#9F1A24;
  --cream:#FAF7F0; --white:#fff;
  --charcoal:#1A1A1A; --steel:#5C6B7A; --steel-light:#D9DEE4;
  --gold:#F4C300;
  --r-sm:6px; --r-md:12px; --r-lg:20px; --r-xl:28px; --r-full:999px;
  --shadow-sm:0 1px 2px rgba(10,31,61,.06);
  --shadow-md:0 6px 16px rgba(10,31,61,.08);
  --shadow-lg:0 16px 40px rgba(10,31,61,.12);
  --shadow-xl:0 32px 64px rgba(10,31,61,.16);
  --shadow-red:0 12px 32px rgba(215,40,49,.25);
  --font-display:'Anton',Impact,sans-serif;
  --font-head:'Plus Jakarta Sans',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip;max-width:100%}
/* Scroll-reveal ("lazy slide") — only active once JS adds body.reveal-on, so it
   fails safe (no JS = everything visible). Disabled for reduced-motion users. */
@media(prefers-reduced-motion:no-preference){
  body.reveal-on .reveal{opacity:0;transform:translateY(28px);transition:opacity .6s cubic-bezier(.22,.61,.36,1),transform .6s cubic-bezier(.22,.61,.36,1);will-change:opacity,transform}
  body.reveal-on .reveal.is-visible{opacity:1;transform:none}
  body.reveal-on .reveal.reveal-delay-1{transition-delay:.08s}
  body.reveal-on .reveal.reveal-delay-2{transition-delay:.16s}
  body.reveal-on .reveal.reveal-delay-3{transition-delay:.24s}
}
body{font-family:var(--font-body);font-size:17px;line-height:1.6;color:var(--charcoal);background:var(--cream);-webkit-font-smoothing:antialiased;overflow-x:clip;max-width:100%}
/* Skip-to-content link (keyboard a11y, hidden until focused) */
.skip-link{position:absolute;top:-100px;left:8px;background:var(--navy);color:#fff;padding:10px 16px;z-index:9999;border-radius:0 0 8px 8px;font-weight:700;text-decoration:none;transition:top .15s}
.skip-link:focus{top:0;outline:3px solid var(--gold);outline-offset:2px}
/* Visible focus rings for keyboard users (a11y win) */
:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:6px}
/* Hero trust-badges row (small, dense, professional) */
.hero-trust-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.85);backdrop-filter:blur(6px);border:1px solid rgba(10,31,61,.12);padding:6px 12px;border-radius:999px;font-size:13px;font-weight:700;color:var(--navy);box-shadow:var(--shadow-sm)}
.hero-badge::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 2px rgba(244,195,0,.25);flex-shrink:0}
.hero-badge.hero-badge-red::before{background:var(--red);box-shadow:0 0 0 2px rgba(215,40,49,.25)}
/* Form inline error (replaces native tooltip) */
.form-row.has-error input,.form-row.has-error select,.form-row.has-error textarea{border-color:var(--red);box-shadow:0 0 0 3px rgba(215,40,49,.12)}
.form-error-msg{display:none;color:var(--red);font-size:12px;font-weight:600;margin-top:4px}
.form-row.has-error .form-error-msg{display:block}
/* Visually hidden text — read by screen readers AND search crawlers, invisible to sighted users */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.container{max-width:1280px;margin:0 auto;padding:0 24px}
@media(min-width:900px){.container{padding:0 64px}}
.section{padding:56px 0}
@media(min-width:600px){.section{padding:72px 0}}
@media(min-width:900px){.section{padding:120px 0}}

.eyebrow{font:600 13px/1 var(--font-body);letter-spacing:.18em;text-transform:uppercase;color:var(--red);display:inline-block;margin-bottom:18px}
.eyebrow.on-dark{color:var(--gold)}
.eyebrow.on-red{color:#fff;opacity:.92}
.h-mega{font:400 44px/1 var(--font-display);letter-spacing:.005em;text-transform:uppercase;color:var(--navy)}
.h-mega .accent{color:var(--red)}
@media(min-width:500px){.h-mega{font-size:56px}}
@media(min-width:900px){.h-mega{font-size:96px}}
.h-display{font:800 36px/1.05 var(--font-head);letter-spacing:-.02em}
@media(min-width:900px){.h-display{font-size:64px}}
.h-section{font:800 28px/1.15 var(--font-head);letter-spacing:-.02em;margin-bottom:14px;color:var(--navy)}
@media(min-width:600px){.h-section{font-size:34px;margin-bottom:18px}}
@media(min-width:900px){.h-section{font-size:52px}}
.h-section.on-dark{color:#fff}
.lead{font:500 18px/1.55 var(--font-body);color:var(--steel);max-width:680px}
.lead.on-dark{color:#cbd6e2}
@media(min-width:900px){.lead{font-size:20px}}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:18px 32px;border:0;border-radius:var(--r-md);font:700 15px/1 var(--font-body);letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--red);color:#fff;box-shadow:var(--shadow-red)}
.btn-primary:hover{background:var(--red-deep)}
.btn-secondary{background:var(--navy);color:#fff}
.btn-secondary:hover{background:var(--navy-deep)}
.btn-outline{background:transparent;color:var(--navy);border:2px solid var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-light{background:#fff;color:var(--red);box-shadow:var(--shadow-xl)}
.btn-light:hover{background:var(--cream);color:var(--red-deep)}
.btn-lg{padding:22px 40px;font-size:16px}
/* Tap feedback for touch devices */
@media(hover:none){.btn:active{transform:scale(.96);transition:transform .1s}}
@media(hover:none){.service-card:active,.review-card:active,.why-card:active{transform:scale(.99)}}
/* Smooth-scroll offset for sticky header */
section[id]{scroll-margin-top:90px}
/* Mobile video sizing — let before/after read clearly side-by-side */
@media(max-width:599px){.promise-video video{max-height:340px;object-fit:cover}}


/* Topbar */
.topbar{background:var(--navy-deep);color:#cbd6e2;padding:10px 0;font-size:13px}
.topbar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;text-align:left}
.topbar .topbar-phone{display:block}
.topbar .stars{color:var(--gold);letter-spacing:2px;margin-right:6px}
.topbar a{font-weight:700;color:#fff}
.topbar a:hover{color:var(--gold)}
/* Hide topbar on mobile — matches subpages; frees vertical space + kills horizontal overflow.
   Trust signals (5.0 Google / Insured / 1-Year Warranty) still appear in the hero trust row. */
@media(max-width:639px){.topbar{display:none}}

/* Header — fits all 5 nav links + brand + phone + CTA on one line at 1200px+ */
.header{position:sticky;top:0;z-index:100;background:rgba(250,247,240,.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--steel-light)}
.header .container{display:flex;align-items:center;justify-content:space-between;padding-top:12px;padding-bottom:12px;gap:16px}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.brand img{width:60px;height:60px;border-radius:50%;background:transparent;filter:drop-shadow(0 4px 10px rgba(10,31,61,.18));transition:transform .25s}
.brand:hover img{transform:scale(1.04) rotate(-2deg)}
@media(min-width:1200px){.brand img{width:68px;height:68px}}
@media(max-width:600px){.brand img{width:60px;height:60px}}
.brand-text{font:800 18px/1 var(--font-head);color:var(--navy)}
.brand-text small{display:block;font:600 10px/1 var(--font-body);color:var(--red);letter-spacing:.16em;text-transform:uppercase;margin-top:5px}
@media(min-width:1200px){.brand-text{font-size:20px}.brand-text small{font-size:11px}}
@media(max-width:600px){.brand-text{font-size:17px}.brand-text small{font-size:10px}}
@media(max-width:430px){.brand-text small{display:none}.brand img{width:56px;height:56px}}
@media(max-width:430px){.header .container{gap:10px}.header-cta .btn{padding:12px 16px;font-size:13px}}
.nav{display:none}
@media(min-width:1200px){.nav{display:flex;gap:18px;align-items:center}}
.nav a{font-weight:600;color:var(--charcoal);font-size:14.5px;transition:color .15s;white-space:nowrap}
.nav a:hover{color:var(--red)}
.header-cta{display:flex;align-items:center;gap:10px;flex-shrink:0;flex-wrap:nowrap;white-space:nowrap}
.header-cta .btn{flex-shrink:0;white-space:nowrap;padding:11px 16px;font-size:14.5px}
.header-phone{display:none;font:700 16px/1 var(--font-body);color:var(--navy);white-space:nowrap;flex-shrink:0}
@media(min-width:1200px){.header-phone{display:inline-block}}
/* Hamburger menu (mobile only) */
.hamburger{display:none;width:44px;height:44px;background:transparent;border:0;padding:0;cursor:pointer;align-items:center;justify-content:center;flex-shrink:0;border-radius:8px;transition:background .2s}
.hamburger:active{background:rgba(10,31,61,.08)}
.hamburger span{display:block;width:24px;height:2.5px;background:var(--navy);border-radius:2px;position:relative;transition:transform .25s,opacity .25s}
.hamburger span::before,.hamburger span::after{content:"";position:absolute;left:0;width:24px;height:2.5px;background:var(--navy);border-radius:2px;transition:transform .25s}
.hamburger span::before{top:-7px}
.hamburger span::after{top:7px}
.hamburger.open span{background:transparent}
.hamburger.open span::before{transform:translateY(7px) rotate(45deg)}
.hamburger.open span::after{transform:translateY(-7px) rotate(-45deg)}
@media(max-width:999px){.hamburger{display:flex}}
/* On phones/tablets the hamburger is the menu — hide the redundant header CTA button so the hamburger isn't pushed off-screen (hero + sticky call bar still carry the CTA) */
@media(max-width:899px){.header-cta .btn{display:none}}
.mobile-nav{position:fixed;top:0;left:0;right:0;background:var(--cream);z-index:99;padding:80px 24px 32px;transform:translateY(-100%);transition:transform .3s ease;box-shadow:0 20px 40px rgba(10,31,61,.18);display:flex;flex-direction:column;gap:4px}
.mobile-nav.open{transform:translateY(0)}
.mobile-nav a{font:700 18px/1.4 var(--font-head);color:var(--navy);padding:16px 18px;border-radius:var(--r-md);transition:background .15s,color .15s;border-bottom:1px solid var(--steel-light)}
.mobile-nav a:active{background:var(--red);color:#fff}
.mobile-nav a:last-child{border-bottom:0}
.mobile-nav-cta{margin-top:14px;background:var(--red);color:#fff !important;text-align:center;border:0 !important;border-radius:var(--r-md) !important}
.mobile-nav-cta:active{background:var(--red-deep) !important}


/* Hero — PORTRAIT video (the techs were filmed vertically, so portrait keeps them at
   natural proportions). Mobile = video full-bleed with text overlaid at the bottom.
   >=920px = side-by-side split (text on navy left, portrait video framed at right). */
.hero{position:relative;background:var(--navy);overflow:hidden}
.hero::after{content:none}
/* MOBILE base: portrait video fills the hero. The phone screen is portrait too, so the
   video covers with almost no crop -> the technicians stay at true proportions. */
.hero-visual{position:absolute;inset:0;z-index:0;margin:0;padding:0}
.hero-visual video,.hero-visual img{width:100%;height:100%;object-fit:cover;object-position:center 30%;display:block}
/* Navy gradient: clear at the top (you see the techs), dark at the bottom (text reads on top) */
.hero-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(8,19,40,.15) 0%,rgba(8,19,40,.28) 42%,rgba(8,19,40,.86) 76%,var(--navy) 100%)}
.hero-fx{display:none}
.hero .container{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;min-height:82vh;padding-top:40px;padding-bottom:34px}
.hero-content{width:100%;max-width:640px;text-shadow:0 2px 16px rgba(0,8,24,.55)}
/* Corner shield badge */
.hero-shield{position:absolute;top:14px;right:14px;width:74px;aspect-ratio:1;z-index:3;animation:floatA 5s ease-in-out infinite .3s}
.hero-shield img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 10px 22px rgba(0,0,0,.5))}
@keyframes floatA{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* White text */
.hero h1{margin:0 0 14px;color:#fff}
.hero h1 .accent{color:#ff5a60}
.hero .lead{margin-bottom:22px;color:rgba(255,255,255,.94);font-size:15.5px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}
@media(max-width:599px){.hero-ctas{flex-direction:column}.hero-ctas .btn{width:100%}}
.hero .btn-outline{border-color:rgba(255,255,255,.6);color:#fff;background:rgba(8,19,40,.35)}
.hero .btn-outline:hover{background:#fff;color:var(--navy);border-color:#fff}
.hero-trust{display:flex;flex-wrap:wrap;gap:10px 20px;color:rgba(255,255,255,.9);font:600 13px/1.4 var(--font-body);padding-top:16px;border-top:1px solid rgba(255,255,255,.18)}
.hero-trust span{display:inline-flex;align-items:center;gap:7px}
.hero-trust svg{width:18px;height:18px;color:var(--gold);flex-shrink:0}

/* Eyebrow (retained for safety; not used on the home hero) */
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:7px 16px;background:rgba(215,40,49,.1);color:var(--red);border-radius:var(--r-full);font:700 12px/1 var(--font-body);letter-spacing:.16em;text-transform:uppercase;margin-bottom:24px}
.hero-eyebrow .pulse{width:8px;height:8px;border-radius:50%;background:var(--red);animation:pulse 1.6s ease-out infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(215,40,49,.7)}70%{box-shadow:0 0 0 10px rgba(215,40,49,0)}100%{box-shadow:0 0 0 0 rgba(215,40,49,0)}}
@media(prefers-reduced-motion:reduce){.hero-eyebrow .pulse{animation:none}}

/* DESKTOP (>=920px): the portrait video is CENTERED and its edges are FEATHERED into the
   navy (no hard panel) so it blends like the mobile hero; the text overlays the left. */
@media(min-width:920px){
  /* SPEED LINES: navy stage + a soft spotlight behind the centered clip. The diagonal
     brand streaks live in ::after, confined to the LOGO (right) side only.
     (To revert: restore the blurred-backdrop ::before and remove this ::after.) */
  .hero::before{content:"";position:absolute;inset:0;z-index:0;
    background:
      url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E"),
      radial-gradient(closest-side at 50% 47%,rgba(130,160,220,.16),transparent 76%),
      linear-gradient(120deg,#0a1730 0%,#0B1E3F 52%,#0e2450 100%);
    background-size:180px 180px,auto,auto;background-repeat:repeat,no-repeat,no-repeat}
  /* PREMIUM HERO FX (right/logo side, behind the shield): a soft drifting aurora glow,
     whisper-soft light rays, and a slow specular sheen. Refined and high-end, not loud. */
  .hero-fx{display:block;position:absolute;top:0;bottom:0;right:0;width:42%;z-index:1;pointer-events:none;overflow:hidden;
    -webkit-mask-image:linear-gradient(to bottom,transparent,#000 18%,#000 82%,transparent),linear-gradient(to right,transparent,#000 42%);
    -webkit-mask-composite:source-in;
    mask-image:linear-gradient(to bottom,transparent,#000 18%,#000 82%,transparent),linear-gradient(to right,transparent,#000 42%);
    mask-composite:intersect}
  /* Soft aurora (brand-tone glows) + two whisper-soft light rays, gently drifting */
  .hero-fx::after{content:"";position:absolute;inset:-40%;
    background:
      linear-gradient(118deg,transparent 43%,rgba(255,255,255,.07) 50%,transparent 57%),
      linear-gradient(118deg,transparent 62%,rgba(255,255,255,.05) 67%,transparent 72%),
      radial-gradient(42% 34% at 70% 26%,rgba(200,32,46,.30),transparent 72%),
      radial-gradient(50% 40% at 36% 74%,rgba(22,56,120,.55),transparent 74%),
      radial-gradient(30% 24% at 84% 64%,rgba(244,195,0,.16),transparent 72%);
    filter:blur(24px);
    animation:auroraDrift 17s ease-in-out infinite;will-change:transform}
  /* Slow, soft specular sheen sweeping across — a premium light pass */
  .hero-fx::before{content:"";position:absolute;top:-25%;bottom:-25%;left:0;width:60%;z-index:1;
    background:linear-gradient(116deg,transparent 40%,rgba(255,255,255,.22) 50%,transparent 60%);
    filter:blur(10px);mix-blend-mode:screen;transform:translateX(-180%);
    animation:sheen 9s ease-in-out infinite;will-change:transform}
  @keyframes auroraDrift{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-3%,3.5%) scale(1.07)}}
  @keyframes sheen{0%,68%{transform:translateX(-180%);opacity:0}74%{opacity:1}90%{transform:translateX(250%);opacity:.9}100%{transform:translateX(250%);opacity:0}}
  /* Video centered; the shield sits in the open space to its right */
  .hero-visual{inset:0;width:auto;display:flex;align-items:center;justify-content:center;padding:0}
  /* Bigger solid core, thinner feathered edges -> the clip reads sharp, still blends */
  .hero-visual video,.hero-visual img{width:auto;height:100%;max-height:none;aspect-ratio:9/16;
    object-fit:cover;border-radius:0;box-shadow:none;
    -webkit-mask-image:linear-gradient(to right,transparent 0,#000 15%,#000 85%,transparent 100%),linear-gradient(to bottom,transparent 0,#000 7%,#000 91%,transparent 100%);
    -webkit-mask-composite:source-in;
    mask-image:linear-gradient(to right,transparent 0,#000 15%,#000 85%,transparent 100%),linear-gradient(to bottom,transparent 0,#000 7%,#000 91%,transparent 100%);
    mask-composite:intersect}
  /* Navy holds the text on the left, fades right so the streaks + clip read clearly */
  .hero-scrim{display:block;background:
    linear-gradient(to right,var(--navy) 0%,rgba(11,30,63,.82) 26%,rgba(11,30,63,.22) 56%,transparent 80%),
    radial-gradient(135% 130% at 50% 50%,transparent 60%,rgba(4,10,24,.5) 100%)}
  .hero .container{flex-direction:row;align-items:center;justify-content:flex-start;
    min-height:clamp(560px,66vh,660px);padding-top:48px;padding-bottom:56px}
  .hero-content{max-width:430px;text-shadow:0 2px 18px rgba(0,8,24,.6)}
  .hero h1{margin:0 0 20px;font-size:clamp(44px,4vw,60px);line-height:1.04}
  .hero .lead{margin-bottom:28px;font-size:18px;color:rgba(255,255,255,.92);max-width:340px}
  .hero-ctas{margin-bottom:26px}
  .hero-trust{border-top:none;padding-top:0;font-size:14px;color:rgba(255,255,255,.85)}
  .hero-trust svg{color:var(--gold)}
  /* Big shield, vertically centered in the open space to the RIGHT of the centered video.
     margin-based vertical centering leaves the float animation (translateY) free to run. */
  .hero-shield{top:50%;left:81%;right:auto;margin:0;transform:translate(-50%,-50%);width:clamp(210px,19vw,300px);animation:none}
  .hero-shield img{position:relative;z-index:1;animation:floatA 5s ease-in-out infinite .3s;filter:drop-shadow(0 16px 34px rgba(0,0,0,.6))}
  /* Soft brand glow behind the shield so it reads as lit / premium */
  .hero-shield::before{content:"";position:absolute;inset:-22%;z-index:0;
    background:radial-gradient(closest-side,rgba(255,205,80,.24),rgba(200,32,46,.10) 52%,transparent 76%);
    filter:blur(26px);animation:shieldGlow 5.5s ease-in-out infinite}
  @keyframes shieldGlow{0%,100%{opacity:.6;transform:scale(.95)}50%{opacity:1;transform:scale(1.08)}}
}
/* Hero stats live in the trust strip directly below the hero on every screen size */

/* Trust strip */
.trust-strip{background:var(--navy);color:#fff;padding:24px 0}
@media(min-width:900px){.trust-strip{padding:36px 0}}
.trust-strip .container{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;text-align:center}
@media(min-width:900px){.trust-strip .container{gap:24px}}
.trust-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:0 4px}
.trust-num{font:400 28px/1 var(--font-display);color:#fff}
@media(min-width:600px){.trust-num{font-size:36px}}
@media(min-width:900px){.trust-num{font-size:44px}}
.trust-item.gold .trust-num{color:var(--gold)}
.trust-label{font:600 11px/1.25 var(--font-body);letter-spacing:.1em;text-transform:uppercase;color:#cbd6e2}
@media(min-width:600px){.trust-label{font-size:13px;letter-spacing:.14em}}
@media(min-width:900px){.trust-label{font-size:12px}}

.section-head{max-width:780px;margin-bottom:36px}
@media(min-width:900px){.section-head{margin-bottom:56px}}
.section-head.center{text-align:center;margin-left:auto;margin-right:auto}
.section-head .lead{margin-left:auto;margin-right:auto}

/* Services — compact 4-up grid on desktop, scene-specific photo per card */
.services-grid{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:600px){.services-grid{grid-template-columns:1fr 1fr;gap:20px}}
@media(min-width:1100px){.services-grid{grid-template-columns:repeat(4,1fr);gap:20px}}
.service-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column;border:1px solid transparent}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--steel-light)}
.service-photo{aspect-ratio:4/3;background:linear-gradient(135deg,var(--navy-mid),var(--navy));position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
@media(min-width:1100px){.service-photo{aspect-ratio:5/4}}
.service-photo::before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 40 40'%3E%3Cpath d='M0 20h40M20 0v40' stroke='%23fff' stroke-width='.4' opacity='.06'/%3E%3C/svg%3E");pointer-events:none}
.service-photo .photo-placeholder{position:relative;text-align:center;padding:24px;color:rgba(255,255,255,.55);font:600 11px/1.5 var(--font-body);letter-spacing:.16em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:14px}
.service-photo .photo-placeholder svg{width:42px;height:42px;color:rgba(255,255,255,.35)}
.service-photo::after{content:"";position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(180deg,transparent,rgba(10,31,61,.4));pointer-events:none}

/* Real-photo variant — premium image treatment */
.service-photo-real{background:#0a1f3d}
.service-real-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .6s ease}
/* Per-card object-position tuning so each photo's subject lands in the visible frame */
.service-real-img.pos-roller{object-position:center 25%}
.service-real-img.pos-track{object-position:center 40%}
.service-real-img.pos-lock{object-position:center center}
.service-real-img.pos-restoration{object-position:center 60%}
.service-card:hover .service-real-img{transform:scale(1.06)}
.service-photo-real::after{content:"";position:absolute;bottom:0;left:0;right:0;top:auto;height:55%;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.7) 100%);pointer-events:none;z-index:1}
.service-photo-real::before{display:none}
.service-photo-caption{position:absolute;bottom:16px;left:0;right:0;z-index:2;display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;text-align:center;padding:0 16px}
.caption-pill{display:inline-flex;align-items:center;gap:7px;background:rgba(215,40,49,.95);backdrop-filter:blur(6px);color:#fff;padding:6px 14px;border-radius:var(--r-full);font:700 11px/1 var(--font-body);letter-spacing:.14em;text-transform:uppercase;box-shadow:0 6px 16px rgba(0,0,0,.35);white-space:nowrap}
.caption-pill::before{content:"●";font-size:12px;color:var(--gold)}
.caption-line{font:600 13px/1.3 var(--font-body);color:rgba(255,255,255,.95);text-shadow:0 2px 10px rgba(0,0,0,.7);letter-spacing:.02em}
.service-tag{position:absolute;top:14px;left:50%;transform:translateX(-50%);display:inline-flex;align-items:center;gap:7px;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);color:#fff;padding:7px 14px;border-radius:var(--r-full);font:700 11px/1 var(--font-body);letter-spacing:.16em;text-transform:uppercase;z-index:2;white-space:nowrap}
.service-tag::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold)}
.service-body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.service-body h3{font:800 19px/1.2 var(--font-head);color:var(--navy);margin:0}
@media(min-width:1100px){.service-body h3{font-size:18px}}
.service-body .desc{color:var(--steel);font-size:14px;line-height:1.55;flex:1}
.service-body .learn{font:700 12.5px/1 var(--font-body);color:var(--red);display:inline-flex;align-items:center;gap:7px;align-self:flex-start;text-transform:uppercase;letter-spacing:.08em;margin-top:4px;transition:gap .2s}
.service-card:hover .learn{gap:11px}

/* Promise — text-centered with before/after videos blending in from sides */
.promise{background:linear-gradient(135deg,var(--red),#a01a23);color:#fff;padding:64px 0;position:relative;overflow:hidden}
@media(min-width:900px){.promise{padding:88px 0}}
.promise::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent 0 30px,rgba(255,255,255,.05) 30px 31px);pointer-events:none;z-index:0}
.promise::after{content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(244,195,0,.18),transparent 70%);pointer-events:none;z-index:0}
.promise .container{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:center;max-width:1280px;grid-template-areas:"vid-before vid-after" "body body"}
@media(min-width:900px){.promise .container{grid-template-columns:240px 1fr 240px;gap:40px;grid-template-areas:"vid-before body vid-after"}}
@media(min-width:1100px){.promise .container{grid-template-columns:280px 1fr 280px;gap:56px}}

.promise-video.before{grid-area:vid-before}
.promise-video.after{grid-area:vid-after}
.promise-body{grid-area:body}

.promise-video{position:relative;border-radius:var(--r-md);overflow:hidden;box-shadow:0 16px 32px rgba(0,0,0,.4);width:100%}
@media(min-width:900px){.promise-video{border-radius:var(--r-lg);box-shadow:0 24px 48px rgba(0,0,0,.4);max-width:280px;margin:0 auto}}
.promise-video video{width:100%;height:auto;display:block}
.promise-video::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(135deg,rgba(215,40,49,.22) 0%,transparent 35%,transparent 65%,rgba(160,26,35,.32) 100%)}
@media(min-width:900px){
  .promise-video.before video{-webkit-mask-image:linear-gradient(to right,black 60%,transparent 100%);mask-image:linear-gradient(to right,black 60%,transparent 100%)}
  .promise-video.after video{-webkit-mask-image:linear-gradient(to left,black 60%,transparent 100%);mask-image:linear-gradient(to left,black 60%,transparent 100%)}
}
.promise-video-label{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);padding:7px 18px;border-radius:var(--r-full);font:800 11px/1 var(--font-body);letter-spacing:.2em;text-transform:uppercase;z-index:2;backdrop-filter:blur(6px);box-shadow:0 4px 14px rgba(0,0,0,.35);white-space:nowrap}
.promise-video.before .promise-video-label{background:rgba(0,0,0,.78);color:#fff;border:1px solid rgba(255,255,255,.15)}
.promise-video.after .promise-video-label{background:var(--gold);color:var(--navy);border:1px solid rgba(0,0,0,.1)}

.promise-body{text-align:center}
.promise-eyebrow{font:700 13px/1 var(--font-body);letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;display:inline-flex;align-items:center;gap:12px}
.promise-eyebrow::before,.promise-eyebrow::after{content:"";width:30px;height:2px;background:var(--gold)}
.promise h2{font:800 34px/1.1 var(--font-head);color:#fff;margin-bottom:16px}
@media(min-width:900px){.promise h2{font-size:48px;letter-spacing:-.01em}}
@media(min-width:1100px){.promise h2{font-size:54px}}
.promise p{font-size:17px;color:rgba(255,255,255,.94);max-width:580px;margin:0 auto 28px}
@media(min-width:900px){.promise p{font-size:18px}}
.promise-features{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 24px;margin:0 auto;max-width:560px;font:600 14px/1.3 var(--font-body);text-align:left}
@media(min-width:700px){.promise-features{grid-template-columns:repeat(3,1fr)}}
.promise-features li{display:flex;align-items:center;gap:10px}
.promise-features li::before{content:"✓";display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.2);font-weight:800;font-size:13px;flex-shrink:0}

/* Mobile: videos sit side-by-side ABOVE the text in a single row, then text below */
@media(max-width:899px){.promise-body{margin-top:8px}}

/* Process */
.process{background:linear-gradient(180deg,var(--cream),#f4ede0)}
.steps{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(min-width:600px){.steps{gap:20px}}
@media(min-width:1100px){.steps{grid-template-columns:repeat(4,1fr);gap:24px}}
.step{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.step:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.step-image{position:relative;aspect-ratio:1/1;background:linear-gradient(180deg,#f7f2e6,#ede4d2);overflow:hidden}
.step-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center}
.step-num{position:absolute;top:10px;left:10px;width:30px;height:30px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font:800 13px/1 var(--font-head);box-shadow:var(--shadow-md);z-index:2}
@media(min-width:600px){.step-num{top:14px;left:14px;width:38px;height:38px;font-size:16px}}
.step-body{padding:14px 14px 18px}
@media(min-width:600px){.step-body{padding:24px 24px 30px}}
.step-body h3{font:800 15px/1.25 var(--font-head);color:var(--navy);margin:0 0 6px}
@media(min-width:600px){.step-body h3{font-size:21px;margin-bottom:8px}}
.step-body p{color:var(--steel);font-size:12.5px;line-height:1.5}
@media(min-width:600px){.step-body p{font-size:15px}}

/* Why */
.why{background:var(--white)}
.why-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:600px){.why-grid{grid-template-columns:1fr 1fr;gap:18px}}
@media(min-width:1000px){.why-grid{grid-template-columns:repeat(3,1fr);gap:20px}}
.why-card{padding:24px 22px;border:1px solid var(--steel-light);border-radius:var(--r-lg);background:var(--cream);transition:border-color .2s,box-shadow .2s,transform .2s;display:flex;flex-direction:column;gap:8px}
.why-card:hover{border-color:var(--navy);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.why-icon{width:42px;height:42px;border-radius:12px;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:6px;flex-shrink:0}
.why-icon svg{width:22px;height:22px}
.why-card h3{font:800 17px/1.25 var(--font-head);color:var(--navy);margin:0}
.why-card p{color:var(--steel);font-size:14px;line-height:1.5;margin:0}

/* Service Area — truck Speedy + city list */
.service-area{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.service-area::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 600px at 100% 0%,rgba(215,40,49,.18),transparent 65%);pointer-events:none}
.service-area .container{position:relative;display:grid;grid-template-columns:1fr;gap:32px;align-items:center}
@media(min-width:900px){.service-area .container{grid-template-columns:1fr 1fr;gap:48px}}
.service-area h2{color:#fff;font:800 30px/1.1 var(--font-head)}
@media(min-width:600px){.service-area h2{font-size:36px}}
@media(min-width:900px){.service-area h2{font-size:52px}}
.service-area .lead{color:#cbd6e2;margin:14px 0 24px;font-size:15px}
@media(min-width:600px){.service-area .lead{font-size:17px;margin:18px 0 32px}}
.cities{display:grid;grid-template-columns:repeat(2,1fr);gap:6px 12px;max-width:520px;margin-bottom:24px}
@media(min-width:600px){.cities{grid-template-columns:repeat(3,1fr);gap:8px 16px;margin-bottom:32px}}
.cities li{font:600 13px/1.5 var(--font-body);color:#cbd6e2;display:flex;align-items:center;gap:7px}
@media(min-width:600px){.cities li{font-size:14px}}
.cities li::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--gold);flex-shrink:0}
.service-area-image{position:relative;aspect-ratio:1/1;min-height:340px;max-width:380px;width:100%;margin:0 auto;border-radius:var(--r-lg);overflow:hidden;background:linear-gradient(180deg,#fff5e0,#ffd9b3);box-shadow:0 20px 40px rgba(0,0,0,.35),0 0 0 3px rgba(244,195,0,.18)}
@media(min-width:900px){.service-area-image{max-width:none;min-height:520px;border-radius:var(--r-xl);box-shadow:0 30px 60px rgba(0,0,0,.4),0 0 0 4px rgba(244,195,0,.18)}}
.service-area-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* Meet Speedy */
.meet-speedy{background:var(--cream);color:var(--charcoal);position:relative;overflow:hidden}
.meet-speedy::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 500px at 0% 50%,rgba(244,195,0,.18),transparent 60%);pointer-events:none}
.meet-speedy .container{position:relative;display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:900px){.meet-speedy .container{grid-template-columns:1fr 1fr}}
.meet-speedy h2{color:var(--navy);font:800 32px/1.1 var(--font-head)}
@media(min-width:600px){.meet-speedy h2{font-size:40px}}
@media(min-width:900px){.meet-speedy h2{font-size:56px}}
.meet-speedy .lead{color:var(--steel);margin:14px 0 24px}
.speedy-quotes{display:grid;grid-template-columns:1fr;gap:10px;margin-top:24px}
.speedy-quote{background:#fff;border-left:4px solid var(--red);padding:14px 18px;border-radius:0 var(--r-md) var(--r-md) 0;font:500 14px/1.5 var(--font-body);box-shadow:var(--shadow-sm);color:var(--charcoal)}
@media(min-width:600px){.speedy-quote{padding:18px 22px;font-size:15px}}
.speedy-portrait{position:relative;display:flex;justify-content:center;align-items:center;min-height:280px;padding:20px 0}
@media(min-width:900px){.speedy-portrait{min-height:480px;padding:0}}
.speedy-portrait img{width:100%;max-width:280px;border-radius:50%;box-shadow:0 20px 50px rgba(10,31,61,.22),0 0 0 5px var(--gold),0 0 0 12px rgba(244,195,0,.2),0 0 0 20px rgba(244,195,0,.08);position:relative;z-index:2;animation:floatGently 6s ease-in-out infinite;object-fit:cover;aspect-ratio:1}
@media(min-width:900px){.speedy-portrait img{max-width:440px;box-shadow:0 30px 80px rgba(10,31,61,.25),0 0 0 6px var(--gold),0 0 0 14px rgba(244,195,0,.22),0 0 0 24px rgba(244,195,0,.08)}}
.speedy-portrait::before{content:"";position:absolute;inset:8% 6% auto 6%;aspect-ratio:1;background:radial-gradient(circle,rgba(244,195,0,.25) 0%,rgba(215,40,49,.12) 40%,transparent 70%);border-radius:50%;z-index:1;animation:pulseGlow 4s ease-in-out infinite}
.speech-bubble{position:absolute;top:8%;right:-2%;background:var(--navy);color:#fff;padding:14px 22px;border-radius:24px 24px 24px 4px;font:800 17px/1.2 var(--font-head);box-shadow:var(--shadow-xl);z-index:3;animation:bubbleIn 1s ease .6s both,bubbleBounce 3s ease-in-out 1.6s infinite}
.speech-bubble::after{content:"";position:absolute;bottom:-12px;left:18px;width:0;height:0;border:12px solid transparent;border-top-color:var(--navy);border-bottom:0;border-left-width:6px}
@keyframes floatGently{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes pulseGlow{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.06);opacity:1}}
@keyframes bubbleIn{from{opacity:0;transform:translateY(-10px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes bubbleBounce{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-6px) rotate(2deg)}}
@media(max-width:899px){.speech-bubble{right:0;font-size:14px;padding:10px 16px}}

/* Reviews */
.reviews{background:var(--white)}
.reviews-head{display:grid;grid-template-columns:1fr;gap:24px;align-items:center;margin-bottom:36px}
@media(min-width:900px){.reviews-head{grid-template-columns:1fr 1fr;gap:32px;margin-bottom:56px}}
.reviews-google{display:flex;justify-content:center;align-items:center}
.reviews-google img{max-width:220px;width:100%;filter:drop-shadow(0 14px 28px rgba(10,31,61,.18))}
@media(min-width:600px){.reviews-google img{max-width:280px}}
@media(min-width:900px){.reviews-google img{max-width:340px;filter:drop-shadow(0 20px 40px rgba(10,31,61,.18))}}
.reviews-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:600px){.reviews-grid{gap:20px}}
@media(min-width:700px){.reviews-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1100px){.reviews-grid{grid-template-columns:repeat(3,1fr);gap:24px}}
.review-card{background:var(--cream);padding:22px;border-radius:var(--r-lg);border:1px solid var(--steel-light);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;gap:12px}
@media(min-width:600px){.review-card{padding:28px;gap:14px}}
.review-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.review-stars{color:var(--gold);font-size:18px;letter-spacing:2px}
.review-quote{font:500 16px/1.55 var(--font-body);color:var(--charcoal);flex:1}
.review-meta{display:flex;align-items:center;gap:10px;padding-top:14px;border-top:1px solid var(--steel-light)}
.review-avatar{width:40px;height:40px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font:800 16px/1 var(--font-head);flex-shrink:0}
.review-name{font:700 14px/1.2 var(--font-body);color:var(--navy)}
.review-detail{font:500 12px/1.2 var(--font-body);color:var(--steel)}

/* FAQ */
.faq{background:var(--cream);position:relative;overflow:hidden}
.faq-grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:start}
@media(min-width:900px){.faq-grid{grid-template-columns:1fr 1.4fr;gap:48px}}
.faq-image{position:relative;max-width:240px;margin:0 auto}
@media(min-width:900px){.faq-image{position:sticky;top:120px;max-width:none;margin:0}}
.faq-image img{width:100%;border-radius:var(--r-lg);box-shadow:var(--shadow-lg)}
.faq-list{display:flex;flex-direction:column;gap:10px}
@media(min-width:600px){.faq-list{gap:14px}}
.faq-item{background:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid transparent;transition:border-color .2s}
.faq-item[open]{border-color:var(--red)}
.faq-item summary{padding:16px 18px;font:700 14.5px/1.35 var(--font-head);color:var(--navy);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:14px;list-style:none}
@media(min-width:600px){.faq-item summary{padding:22px 24px;font-size:17px}}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font:300 24px/1 var(--font-display);color:var(--red);transition:transform .2s;flex-shrink:0}
@media(min-width:600px){.faq-item summary::after{font-size:28px}}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{padding:0 18px 18px;color:var(--steel);font-size:13.5px;line-height:1.55}
@media(min-width:600px){.faq-item p{padding:0 24px 22px;font-size:15px}}

/* ============================================================================
   FINAL CTA — full-bleed navy/red gradient closing banner (homepage + site-wide)
   ============================================================================ */
.final-cta{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 45%,var(--red-deep) 100%);
  color:#fff;
  padding:80px 0;
  position:relative;
  overflow:hidden;
  margin-top:0
}
.final-cta::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 82% 18%,rgba(244,195,0,.14),transparent 55%);
  pointer-events:none
}
.final-cta .container{position:relative;z-index:2}
.final-cta-grid{display:grid;gap:36px;grid-template-columns:1fr;align-items:center}
@media(min-width:880px){.final-cta-grid{grid-template-columns:1.05fr 1fr;gap:56px}}
/* Left column: centered as a unit for visual balance with right action card */
.final-cta-grid > div:first-child{text-align:center;display:flex;flex-direction:column;align-items:center}
.final-cta-shield{
  display:block;
  width:110px;
  height:110px;
  margin:0 auto 22px;
  filter:drop-shadow(0 10px 24px rgba(0,0,0,.4))
}
@media(min-width:880px){.final-cta-shield{width:130px;height:130px;margin-bottom:24px}}
.final-cta-eyebrow{
  display:inline-block;
  font:700 12px/1 var(--font-body);
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--gold);
  background:rgba(244,195,0,.15);
  padding:8px 14px;
  border-radius:var(--r-full);
  margin-bottom:16px
}
.final-cta-grid > div:first-child .final-cta-sub{margin-left:auto;margin-right:auto}
.final-cta-grid > div:first-child .final-cta-trust{justify-content:center}
.final-cta h2{
  color:#fff;
  font:800 38px/1.05 var(--font-display);
  text-transform:uppercase;
  letter-spacing:-.3px;
  margin-bottom:14px
}
@media(min-width:900px){.final-cta h2{font-size:54px}}
.final-cta h2 .accent{color:var(--gold)}
.final-cta-sub{
  font-size:18px;
  color:rgba(255,255,255,.85);
  margin-bottom:22px;
  max-width:52ch;
  line-height:1.55
}
.final-cta-trust{display:flex;gap:18px;flex-wrap:wrap;font-size:14px;color:rgba(255,255,255,.78)}
.final-cta-trust span{display:inline-flex;align-items:center;gap:6px;font-weight:600}
.final-cta-trust svg{width:16px;height:16px;color:var(--gold);flex-shrink:0}
.final-cta-action{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.16);
  border-radius:var(--r-lg);
  padding:32px;
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  text-align:center
}
@media(max-width:639px){.final-cta-action{padding:24px}}
.final-cta-phone-label{
  font:700 12px/1 var(--font-body);
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.6);
  margin-bottom:10px
}
.final-cta-phone{
  display:block;
  font:800 44px/1 var(--font-display);
  color:#fff;
  letter-spacing:-.5px;
  margin-bottom:10px;
  transition:color .15s
}
@media(min-width:680px){.final-cta-phone{font-size:56px}}
.final-cta-phone:hover,.final-cta-phone:focus{color:var(--gold)}
.final-cta-callback{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:14px;
  color:rgba(255,255,255,.78);
  margin-bottom:22px
}
.final-cta-callback::before{
  content:"";
  width:9px;
  height:9px;
  background:#22c55e;
  border-radius:50%;
  box-shadow:0 0 0 0 rgba(34,197,94,.7);
  animation:final-cta-pulse 2s infinite
}
@keyframes final-cta-pulse{
  0%{box-shadow:0 0 0 0 rgba(34,197,94,.65)}
  70%{box-shadow:0 0 0 10px rgba(34,197,94,0)}
  100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}
}
@media(prefers-reduced-motion:reduce){.final-cta-callback::before{animation:none}}
.final-cta-action .btn{
  width:100%;
  background:var(--red);
  color:#fff;
  padding:18px 24px;
  font-size:18px;
  min-height:56px;
  box-shadow:0 12px 28px rgba(215,40,49,.4)
}
.final-cta-action .btn:hover{
  background:#fff;
  color:var(--red);
  transform:translateY(-1px);
  box-shadow:0 16px 36px rgba(0,0,0,.25)
}
.final-cta-signoff{
  margin-top:20px;
  font-size:13px;
  color:rgba(255,255,255,.55);
  letter-spacing:.3px
}
@media(max-width:599px){
  .final-cta{padding:56px 0}
  .final-cta h2{font-size:32px}
  .final-cta-phone{font-size:40px}
}

/* Footer */
.footer{background:var(--navy-deep);color:#cbd6e2;padding:48px 0 80px}
@media(min-width:600px){.footer{padding:60px 0 24px}}
@media(min-width:900px){.footer{padding:72px 0 24px}}
.footer .container{display:grid;grid-template-columns:1fr 1fr;gap:24px 16px}
@media(min-width:500px){.footer .container{grid-template-columns:1fr 1fr;gap:32px 20px}}
@media(min-width:700px){.footer .container{grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}}
.foot-brand{display:flex;flex-direction:column;gap:14px;grid-column:1 / -1}
@media(min-width:700px){.foot-brand{grid-column:auto}}
.foot-brand-logo{display:flex;align-items:center;gap:14px}
.foot-brand-logo img{width:64px;height:64px;border-radius:50%;background:transparent;filter:drop-shadow(0 8px 16px rgba(0,0,0,.4))}
@media(min-width:600px){.foot-brand-logo img{width:72px;height:72px}}
.foot-brand-logo span{font:800 20px/1 var(--font-head);color:#fff}
.foot-brand-logo span small{display:block;font:600 11px/1 var(--font-body);color:var(--gold);letter-spacing:.18em;text-transform:uppercase;margin-top:6px}
.foot-brand p{font-size:14px;line-height:1.6}
.footer-social{display:flex;gap:12px;margin-top:14px}
.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);color:#fff;transition:background .15s,transform .15s}
.footer-social a:hover{background:var(--gold);color:var(--navy);transform:translateY(-2px)}
.footer-social svg{width:20px;height:20px;fill:currentColor}
.foot-col h4{font:800 12px/1 var(--font-head);color:#fff;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
@media(min-width:600px){.foot-col h4{font-size:14px;letter-spacing:.1em;margin-bottom:18px}}
.foot-col ul{display:flex;flex-direction:column;gap:8px}
@media(min-width:600px){.foot-col ul{gap:10px}}
.foot-col a{font-size:13px;color:#9ca8b6;transition:color .15s}
@media(min-width:600px){.foot-col a{font-size:14px}}
.foot-col a:hover{color:#fff}
.foot-bottom{margin-top:32px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:6px;text-align:center;font-size:13px;color:#7a8593}
@media(min-width:600px){.foot-bottom{margin-top:56px;padding-top:24px;gap:8px;font-size:12px}}
@media(min-width:700px){.foot-bottom{flex-direction:row;justify-content:space-between;text-align:left}}

/* Modal */
.modal-backdrop{position:fixed;inset:0;background:rgba(10,31,61,.65);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:200;padding:24px}
.modal-backdrop.open{display:flex}
.modal{background:#fff;border-radius:var(--r-xl);max-width:520px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:modalIn .25s ease}
@keyframes modalIn{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.modal-head{padding:24px 28px 18px;display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--steel-light)}
.modal-head img{width:60px;height:60px;border-radius:50%;flex-shrink:0;object-fit:cover}
.modal-head h3{font:800 22px/1.2 var(--font-head);color:var(--navy)}
.modal-head p{font-size:13px;color:var(--steel);margin-top:2px}
.modal-close{margin-left:auto;width:44px;height:44px;border-radius:50%;background:var(--cream);border:0;font:300 22px/1 var(--font-display);color:var(--steel);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.modal-close:hover{background:var(--steel-light);color:var(--charcoal)}
.modal-body{padding:24px 28px 28px}
.form-row{margin-bottom:14px}
.form-row label{display:block;font:700 13px/1 var(--font-body);color:var(--charcoal);margin-bottom:6px;letter-spacing:.04em;text-transform:uppercase}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:12px 14px;border:1.5px solid var(--steel-light);border-radius:var(--r-md);background:#fff;font:400 16px/1.4 var(--font-body);color:var(--charcoal);transition:border-color .15s ease,box-shadow .15s ease}
.form-row textarea{min-height:80px;resize:vertical;font-family:inherit}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:0;border-color:var(--red);box-shadow:0 0 0 3px rgba(215,40,49,.15)}
.modal-success{display:none;text-align:center;padding:24px}
.modal-success.show{display:block}
.modal-success img{width:120px;height:120px;border-radius:50%;margin:0 auto 24px;box-shadow:0 12px 32px rgba(10,31,61,.18);animation:successPop .5s cubic-bezier(.2,1.4,.4,1) both}
@keyframes successPop{0%{opacity:0;transform:scale(.4)}100%{opacity:1;transform:scale(1)}}
.modal-success h3{font:800 24px/1.2 var(--font-head);color:var(--navy);margin-bottom:10px}
.modal-success p{color:var(--steel);font-size:15px;margin-bottom:24px}

/* Sticky mobile call — full-width bottom bar (better conversion than floating pill) */
.sticky-call{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(180deg,var(--red),var(--red-deep));color:#fff;padding:16px 24px;font:800 15px/1 var(--font-body);text-transform:uppercase;letter-spacing:.1em;box-shadow:0 -10px 28px rgba(215,40,49,.32),0 -1px 0 rgba(255,255,255,.15) inset;z-index:90;display:flex;align-items:center;justify-content:center;gap:10px;white-space:nowrap}
.sticky-call::before{content:"";width:8px;height:8px;border-radius:50%;background:#fff;box-shadow:0 0 0 0 rgba(255,255,255,.7);animation:stickyDot 1.6s ease-out infinite}
@keyframes stickyDot{0%{box-shadow:0 0 0 0 rgba(255,255,255,.7)}70%{box-shadow:0 0 0 12px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
.sticky-call:active{filter:brightness(.92)}
body{padding-bottom:calc(64px + env(safe-area-inset-bottom))}
@media(min-width:900px){.sticky-call{display:none}body{padding-bottom:0}}

/* Floating WhatsApp button (FAB) — sits above sticky-call on mobile */
.fab-wa{position:fixed;right:14px;bottom:calc(74px + env(safe-area-inset-bottom));z-index:88;width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(37,211,102,.45);transition:transform .15s,box-shadow .15s}
.fab-wa:hover{transform:scale(1.06);box-shadow:0 12px 32px rgba(37,211,102,.55);color:#fff}
.fab-wa:active{transform:scale(.98)}
.fab-wa svg{width:30px;height:30px;fill:currentColor}
@media(min-width:900px){.fab-wa{bottom:24px;width:60px;height:60px}.fab-wa svg{width:32px;height:32px}}

/* === MOBILE SCROLL-DENSITY OVERHAUL (v3.5) === */
@media(max-width:899px){
  /* #5 — Tighter section padding (saves ~3 screen-heights cumulatively) */
  .section{padding:36px 0}
  .promise{padding:40px 0}
  .trust-strip{padding:18px 0}
  .section-head{margin-bottom:22px}

  /* === HERO — portrait video full-bleed, text overlaid at the bottom (see _home.css base) === */
  .hero-content{max-width:100%;padding:0}
  /* Trust strip — separated by a light divider on the dark hero */
  .hero-trust{
    font-size:12.5px;gap:10px 16px;
    justify-content:flex-start;
  }

  /* === DESIGN HIERARCHY: STORY moments BIG, INFO moments compact === */

  /* STORY — Process steps as 1:1 squares (matches services card photos for visual rhythm) */
  .step-image{aspect-ratio:1/1}
  .step-image img{padding:10px}
  /* Bigger numbered badge on mobile so it's tappable and visible */
  .step-num{width:34px;height:34px;font-size:14px;top:10px;left:10px}
  /* Tighter step body to balance the bigger image */
  .step-body{padding:14px 14px 16px}
  .step-body h3{font-size:15px;line-height:1.2;margin-bottom:4px}
  .step-body p{font-size:12.5px;line-height:1.45}

  /* STORY — Service Area truck = BRAND IDENTITY moment, must be commanding */
  .service-area-image{aspect-ratio:4/3;min-height:0;max-width:none;width:100%}

  /* STORY — Meet Speedy portrait = THE character moment, generous portrait */
  .speedy-portrait{min-height:320px;padding:16px 0}
  .speedy-portrait img{max-width:300px}

  /* TRUST SIGNAL — FAQ image matches Reviews 5-stars badge size */
  .faq-image{max-width:220px}

  /* TRUST SIGNAL — Reviews 5-stars badge, medium-prominent */
  .reviews-google img{max-width:220px}

  /* STORY — Promise videos: side-by-side, blended into red bg, slightly bigger */
  .promise .container{
    grid-template-columns:1fr 1fr;
    grid-template-areas:"vid-before vid-after" "body body";
    gap:10px;
    padding:0 12px;
  }
  /* Transparent bg = letterbox blends into red. object-fit:cover crops to fill so
     no black bars at all — each video fills its rectangle clean. */
  .promise-video{
    width:100%;
    max-width:none;
    margin:0;
    aspect-ratio:3/4;
    background:transparent;
    border-radius:var(--r-md);
    box-shadow:0 14px 30px rgba(0,0,0,.38);
    overflow:hidden;
  }
  .promise-video video{
    width:100%;height:100%;
    max-height:none;
    object-fit:cover;
    display:block;
  }
  /* Disable the desktop diagonal blend overlay on mobile (was causing dark band) */
  .promise-video::after{display:none}
  .promise-video-label{
    font-size:11.5px;padding:7px 16px;letter-spacing:.18em;
    bottom:12px;
  }

  /* #2 — Service cards become horizontal swipe carousel */
  .services-grid{
    display:flex;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    gap:14px;
    padding:4px 24px 18px;
    margin:0 -24px;
    grid-template-columns:none;
    touch-action:pan-x pan-y;
  }
  /* Make the entire service card tappable on mobile (not just the link) */
  .service-card{cursor:pointer;-webkit-tap-highlight-color:rgba(215,40,49,.12)}
  .service-card .learn{cursor:pointer;display:inline-flex;padding:6px 0}
  .services-grid::-webkit-scrollbar{display:none}
  .services-grid > .service-card{
    flex:0 0 82%;
    scroll-snap-align:start;
    min-width:82%;
  }
  .services-grid > .service-card:last-child{margin-right:24px}

  /* #2b — Why grid: 2-column on small mobile (was 1-col) for more density */
  .why-grid{grid-template-columns:1fr 1fr;gap:10px}
  .why-card{padding:16px 14px;gap:6px}
  .why-icon{width:34px;height:34px;border-radius:9px;margin-bottom:2px}
  .why-icon svg{width:18px;height:18px}
  .why-card h3{font-size:14.5px;line-height:1.2}
  .why-card p{font-size:12.5px;line-height:1.45}

  /* #2c — Reviews: stay 1-col but more compact */
  .review-card{padding:18px}
  .review-quote{font-size:14.5px;line-height:1.5}

  /* #7 — FAQ: swipe-hint indicator on services */
  /* Subtle "swipe —" hint dot above services on mobile */

  /* (Process step body rules now defined above with the 1:1 squares block) */

  /* Service body: tighter */
  .service-body{padding:18px 18px 20px}
  .service-body h3{font-size:18px}
  .service-body .desc{font-size:13.5px}

  /* Swipe hint above the carousel — visible only on mobile */
  .swipe-hint{display:block;text-align:center;font:600 11.5px/1 var(--font-body);color:var(--steel);letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px;animation:swipeFade 2.4s ease-in-out infinite}
}
@media(min-width:900px){.swipe-hint{display:none}}
@keyframes swipeFade{0%,100%{opacity:.5}50%{opacity:1}}

/* Extra-small phones (—430px): keep proportional, slight reduction */
@media(max-width:430px){
  .hero-shield{width:66px;top:14px;right:14px}
  .speedy-portrait img{max-width:260px}
  .speedy-portrait{min-height:280px}
  .reviews-google img{max-width:200px}
  .faq-image{max-width:200px}
  .why-grid{gap:8px}
  .why-card{padding:14px 12px}
}

/* === MOBILE BEST-PRACTICES POLISH === */
/* Respect users who prefer reduced motion (iOS accessibility setting) */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
    scroll-behavior:auto !important;
  }
}
/* Touch tap target minimum 44px (WCAG / Apple HIG) — already covered, safety net */
@media(hover:none){
  .btn{min-height:44px}
  a,button{touch-action:manipulation}
}
/* Prevent layout shift from images while loading (CLS optimization) */
img{max-width:100%}
/* Hardware-accelerate animations on mobile for 60fps */
.hero-visual video,.speedy-portrait img{will-change:transform}
/* Safe-area padding for iPhone notch/home indicator */
.sticky-call{padding-bottom:calc(16px + env(safe-area-inset-bottom))}
.topbar{padding-top:calc(8px + env(safe-area-inset-top))}
@media(min-width:600px){.topbar{padding-top:calc(10px + env(safe-area-inset-top))}}

/* Protect our media — block drag / selection / iOS long-press "Save" on images and videos site-wide */
img,video{-webkit-user-drag:none;-khtml-user-drag:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}
