
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Barlow',sans-serif;background:#0d1f3c;color:#fff;overflow-x:hidden;}

:root{
  --navy:#0a1a36;
  --navy-mid:#1B3A6B;
  --navy-deep:#06122a;
  --orange:#E85D1A;
  --orange-hover:#C44A0A;
  --orange-light:#FF8347;
  --orange-glow:#FF7A2E;
  --white:#ffffff;
  --off-white:#f0f2f5;
  --text-dim:rgba(255,255,255,0.7);
  --shadow-deep:0 22px 60px rgba(7,18,36,0.45);
  --shadow-orange:0 10px 32px rgba(232,93,26,0.45);
}

a{text-decoration:none;color:inherit;}
img{display:block;max-width:100%;}
button{cursor:pointer;font-family:inherit;}
input,select,textarea{font-family:inherit;}

/* ─── DOT GRID PATTERN ─── */

/* ─── NAV ─── */
#main-nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(255,255,255,0.96);
  backdrop-filter:blur(16px);
  border-bottom:none;
  transition:all 0.3s;
  box-shadow:0 10px 30px rgba(7,18,36,0.08);
  isolation:isolate;
}
#main-nav::before{
  content:'';
  position:absolute;
  left:0;top:0;height:104px;
  width:calc((100vw - 1320px) / 2 + 410px);
  min-width:410px;
  max-width:460px;
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-mid) 100%);
  clip-path:polygon(0 0, 84% 0, 100% 100%, 0 100%);
  box-shadow:0 12px 32px rgba(7,18,36,0.35);
  z-index:0;
  pointer-events:none;
  transition:height 0.3s;
}

/* Section dividers */
#stats,
#services,
#gallery,
#storm-services,
#areas,
#contact,
#testimonials,
#footer{
  box-shadow:
    inset 0 1px rgba(255,255,255,0.08),
    inset 0 -1px rgba(0,0,0,0.18);
}

#about,
#social-proof,
#process,
#certs,
#cta-band{
  box-shadow:
    inset 0 1px rgba(10,26,54,0.08),
    inset 0 -1px rgba(10,26,54,0.08);
}

#stats::after,
#services::after,
#gallery::after,
#storm-services::after,
#areas::after,
#contact::after,
#testimonials::after{
  content:'';
  position:absolute;
  left:0;right:0;top:0;
  height:18px;
  background:linear-gradient(to bottom, rgba(232,93,26,0.08), transparent);
  pointer-events:none;
  z-index:1;
}

#about::before,
#process::before,
#social-proof::before,
#certs::before{
  content:'';
  position:absolute;
  left:0;right:0;top:0;
  height:14px;
  background:linear-gradient(to bottom, rgba(10,26,54,0.04), transparent);
  pointer-events:none;
  z-index:1;
}
.nav-inner{
  max-width:1320px;margin:0 auto;padding:0 40px;
  height:104px;display:flex;align-items:center;justify-content:space-between;gap:32px;
  transition:height 0.3s;
  position:relative;
}
.nav-logo{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  min-width:330px;
  filter:drop-shadow(0 6px 14px rgba(0,0,0,0.35));
  transition:transform 0.3s ease, filter 0.3s ease;
}
.nav-logo:hover{transform:translateY(-1px);}
.nav-logo img{height:74px;width:auto;transition:height 0.3s ease;}
.nav-center{display:flex;align-items:center;gap:28px;list-style:none;}
.nav-center,
.nav-right{
  position:relative;
  z-index:1;
}
.nav-center a{
  font-weight:700;font-size:13px;letter-spacing:0.08em;text-transform:uppercase;
  color:rgba(10,26,54,0.78);padding:4px 0;
  border-bottom:2px solid transparent;transition:all 0.2s;
}
.nav-center a:hover{color:var(--navy);border-bottom-color:var(--orange);}
.nav-right{display:flex;align-items:center;gap:16px;}
.nav-phone{
  display:flex;align-items:center;gap:8px;
  font-weight:700;font-size:15px;color:var(--navy);
}
.nav-phone svg{color:var(--orange);}
.btn-nav{
  background:var(--orange);color:#fff;
  padding:11px 24px;border:none;border-radius:3px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:16px;letter-spacing:0.06em;text-transform:uppercase;
  transition:background 0.2s,transform 0.15s,box-shadow 0.2s;
  white-space:nowrap;
  box-shadow:0 2px 12px rgba(232,93,26,0.4);
}
.btn-nav:hover{background:#C44A0A;transform:translateY(-1px);box-shadow:0 4px 18px rgba(232,93,26,0.55);}

/* ─── HERO — photo-forward, cleaner composition ─── */
/* ─── HERO — full-bleed photo, zoom-in parallax (no overlay text) ─── */
#hero{
  position:relative;
  height:78vh;
  min-height:520px;
  max-height:880px;
  overflow:hidden;
  background:var(--navy-deep);
  isolation:isolate;
}
.hero-frame{
  position:absolute;inset:0;
  overflow:hidden;
}
.hero-photo{
  position:absolute;
  /* Slight overscan so the scale-in zoom never reveals raw edges */
  inset:-3% -3%;
  background:url('uploads/Hero-Background%20-Image-web.jpg') center/cover no-repeat;
  filter:contrast(1.04) saturate(1.06);
  transform:scale(1);
  transform-origin:50% 55%;
  will-change:transform;
}
/* Soft top wash so the nav doesn't fight the sky, plus a subtle bottom feather
   so the photo seats into the white intro section without a harsh seam. */
.hero-photo::before{
  content:'';position:absolute;inset:0;
  background:
    linear-gradient(to bottom,
      rgba(6,18,42,0.30) 0%,
      transparent 20%,
      transparent 80%,
      rgba(255,255,255,0.10) 100%);
  pointer-events:none;
}

/* Slim scroll cue at the bottom-center of the photo */
.hero-scroll-cue{
  position:absolute;
  left:50%;bottom:28px;
  transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:6px;
  color:rgba(255,255,255,0.85);
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:11px;letter-spacing:0.28em;text-transform:uppercase;
  z-index:2;
  text-shadow:0 2px 10px rgba(0,0,0,0.45);
  pointer-events:none;
  animation:heroCueBob 2.4s ease-in-out infinite;
}
@keyframes heroCueBob{
  0%,100%{transform:translate(-50%,0);opacity:0.85;}
  50%   {transform:translate(-50%,6px);opacity:1;}
}

/* ─── HERO INTRO — editorial title-page below the photo ─── */
#hero-intro{
  background:
    /* soft warm radial in the upper center for atmosphere */
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(232,93,26,0.045) 0%, transparent 60%),
    /* faint navy wash at the bottom right to support the diagonal */
    radial-gradient(ellipse 60% 50% at 90% 100%, rgba(10,26,54,0.06) 0%, transparent 65%),
    /* base: cream-warm paper tone, not sterile white */
    linear-gradient(180deg, #faf8f4 0%, #ffffff 35%, #f7f5f0 100%);
  padding:clamp(72px, 9vw, 128px) 24px clamp(96px, 10vw, 144px);
  text-align:center;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
/* Faint navy dot texture floating top-left — quiet brand watermark */
#hero-intro::before{
  content:'';
  position:absolute;
  left:0;top:0;
  width:40%;height:55%;
  background-image:radial-gradient(circle, rgba(10,26,54,0.10) 1px, transparent 1px);
  background-size:24px 24px;
  -webkit-mask-image:linear-gradient(135deg, rgba(0,0,0,0.6) 0%, transparent 70%);
  mask-image:linear-gradient(135deg, rgba(0,0,0,0.6) 0%, transparent 70%);
  z-index:0;
  pointer-events:none;
}
/* Skewed orange accent on the right edge — echoes the nav's diagonal language */
#hero-intro .hi-accent{
  position:absolute;
  right:96px;top:64px;bottom:64px;
  width:3px;
  background:linear-gradient(to bottom, transparent, var(--orange) 25%, var(--orange) 75%, transparent);
  transform:skewX(-8deg);
  opacity:0.7;
  z-index:0;
  pointer-events:none;
  box-shadow:0 0 12px rgba(232,93,26,0.45);
}
/* Diagonal navy slice bottom-right — visually transitions into the orange marquee below */
#hero-intro .hi-corner{
  position:absolute;
  right:0;bottom:0;
  width:min(420px, 38vw);
  height:min(180px, 18vw);
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-mid) 100%);
  clip-path:polygon(100% 0, 100% 100%, 0 100%);
  opacity:0.92;
  z-index:0;
  pointer-events:none;
  box-shadow:-12px -12px 36px rgba(10,26,54,0.08);
}
/* Tiny orange notch on the diagonal cut — signature accent */
#hero-intro .hi-corner::after{
  content:'';
  position:absolute;
  left:0;top:0;
  width:120px;height:3px;
  background:var(--orange);
  transform:rotate(45deg) translate(28px, -20px);
  transform-origin:left top;
  box-shadow:0 0 18px rgba(232,93,26,0.55);
}
/* keep content above the decorations */
.hero-intro-inner{
  position:relative;
  z-index:1;
}
.hero-intro-inner{
  max-width:780px;
  margin:0 auto;
}
.hero-intro-eyebrow{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;
  font-size:13px;
  letter-spacing:0.24em;
  text-transform:uppercase;
  color:rgba(13,31,60,0.55);
  margin-bottom:28px;
}
.hero-intro-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  font-size:clamp(44px, 6.2vw, 96px);
  line-height:0.94;
  letter-spacing:-0.005em;
  text-transform:uppercase;
  color:var(--navy);
  margin:0;
  text-wrap:balance;
}
.hero-intro-title .hi-orange{ color:var(--orange); }
.hero-intro-rule{
  width:64px;height:4px;
  background:var(--orange);
  margin:36px auto 28px;
  border-radius:2px;
  box-shadow:0 4px 14px rgba(232,93,26,0.35);
}
.hero-intro-sub{
  font-size:clamp(15px, 1.3vw, 17px);
  line-height:1.65;
  color:rgba(13,31,60,0.72);
  max-width:580px;
  margin:0 auto 40px;
  font-weight:500;
}
.hero-intro-ctas{
  display:flex;
  gap:14px;
  justify-content:center;
  align-items:center;
  flex-wrap:wrap;
  margin-bottom:44px;
}
/* Light-background phone link variant — mirrors btn-ghost without the dark-bg assumptions */
.hi-btn-line{
  display:inline-flex;align-items:center;
  padding:14px 30px;border-radius:3px;
  border:2px solid var(--navy);
  color:var(--navy);
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:18px;letter-spacing:0.06em;text-transform:uppercase;
  transition:border-color 0.2s, background 0.2s, color 0.2s, transform 0.15s;
}
.hi-btn-line:hover{
  border-color:var(--orange);
  background:rgba(232,93,26,0.06);
  color:var(--navy);
  transform:translateY(-2px);
}
.hero-intro-meta{
  list-style:none;
  margin:0;padding:0;
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:18px 32px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;
  font-size:12px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:rgba(13,31,60,0.55);
}
.hero-intro-meta li{
  display:flex;align-items:center;gap:9px;
}
.hero-intro-meta li::before{
  content:'';
  width:6px;height:6px;
  background:var(--orange);
  border-radius:50%;
  display:inline-block;
  box-shadow:0 0 8px rgba(232,93,26,0.5);
}
.btn-primary{
  background:linear-gradient(135deg, var(--orange-light) 0%, var(--orange) 50%, var(--orange-hover) 100%);
  color:#fff;border:none;
  padding:17px 38px;border-radius:3px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:19px;letter-spacing:0.06em;text-transform:uppercase;
  transition:transform 0.18s ease, box-shadow 0.25s ease, filter 0.2s ease;
  display:inline-flex;align-items:center;gap:8px;
  box-shadow:
    0 10px 28px rgba(232,93,26,0.45),
    0 2px 0 rgba(255,255,255,0.18) inset,
    0 -3px 0 rgba(0,0,0,0.18) inset;
  position:relative;
}
.btn-primary:hover{
  filter:brightness(1.08);
  transform:translateY(-2px);
  box-shadow:
    0 14px 36px rgba(232,93,26,0.6),
    0 2px 0 rgba(255,255,255,0.22) inset,
    0 -3px 0 rgba(0,0,0,0.18) inset;
}
.btn-ghost{
  background:rgba(255,255,255,0.06);color:#fff;
  border:2px solid rgba(255,255,255,0.92);
  padding:15px 34px;border-radius:3px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:19px;letter-spacing:0.06em;text-transform:uppercase;
  transition:border-color 0.2s,background 0.2s,color 0.2s,box-shadow 0.2s,transform 0.15s;
  backdrop-filter:blur(4px);
  box-shadow:0 8px 22px rgba(0,0,0,0.25);
}
.btn-ghost:hover{
  border-color:var(--orange);
  background:rgba(232,93,26,0.18);
  color:#fff;
  transform:translateY(-2px);
  box-shadow:0 12px 30px rgba(0,0,0,0.35), 0 0 0 1px var(--orange) inset;
}
/* ─── SERVICE BANNER MARQUEE ─── */
#service-banner{
  position:relative;z-index:3;
  background:var(--orange);
  overflow:hidden;
  padding:0;
  border-top:3px solid rgba(255,255,255,0.15);
  border-bottom:3px solid rgba(255,255,255,0.15);
}
/* fade edges */
#service-banner::before,
#service-banner::after{
  content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
#service-banner::before{left:0;background:linear-gradient(to right,var(--orange),transparent);}
#service-banner::after{right:0;background:linear-gradient(to left,var(--orange),transparent);}

.marquee-track{
  display:flex;align-items:center;
  height:76px;
  width:max-content;
  animation:marqueeScroll 28s linear infinite;
}
.marquee-track:hover{animation-play-state:paused;}

@keyframes marqueeScroll{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

.marquee-item{
  display:inline-flex;align-items:center;gap:16px;
  padding:0 36px;
  white-space:nowrap;
  border-right:2px solid rgba(255,255,255,0.22);
}
.marquee-item:last-child{border-right:none;}
.marquee-item-label{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:24px;
  text-transform:uppercase;color:#fff;
  letter-spacing:0.04em;line-height:1;
}
.marquee-item-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,0.5);flex-shrink:0;
}
.marquee-item-sub{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:600;font-size:13px;
  text-transform:uppercase;letter-spacing:0.1em;
  color:rgba(255,255,255,0.65);
}

.gaf-badge{
  width:48px;height:48px;
  object-fit:contain;flex-shrink:0;
  display:block;
}
.gaf-label{
  font-weight:700;font-size:13px;letter-spacing:0.08em;
  text-transform:uppercase;color:#fff;
  line-height:1.3;
}

/* ─── STATS ─── */
#stats{
  background:var(--navy-mid);
  padding:52px 0 48px;
  position:relative;overflow:hidden;
}
#stats::before{
  content:'';position:absolute;right:0;top:0;bottom:0;width:200px;
  background:linear-gradient(to right, transparent, rgba(232,93,26,0.12));
}
.stats-grid{
  max-width:1320px;margin:0 auto;padding:0 40px;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;
}
.stat-item{
  text-align:center;padding:20px 24px;
  border-right:1px solid rgba(255,255,255,0.1);
  position:relative;
}
.stat-item:last-child{border-right:none;}
.stat-num{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:58px;line-height:1;
  color:var(--orange);
  letter-spacing:-0.02em;
}
.stat-sup{font-size:28px;vertical-align:super;}
.stat-label{
  font-size:12px;font-weight:700;letter-spacing:0.1em;
  text-transform:uppercase;color:rgba(255,255,255,0.6);
  margin-top:6px;
}
.stat-sub{
  font-size:11px;color:rgba(255,255,255,0.3);
  margin-top:3px;font-style:italic;letter-spacing:0.03em;
}

/* ─── ABOUT STRIP ─── */
#about{
  background:var(--off-white);
  position:relative;overflow:hidden;
}
.about-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:640px;
  max-width:1400px;
  margin:0 auto;
}
.about-photo-col{
  position:relative;overflow:hidden;
}
.about-photo-col img{
  width:100%;height:100%;
  object-fit:cover;display:block;
  min-height:580px;
}
.about-photo-badge{
  position:absolute;top:32px;left:32px;
  background:var(--orange);color:#fff;
  padding:9px 18px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:13px;letter-spacing:0.08em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;
  box-shadow:0 4px 20px rgba(232,93,26,0.5);
}
.about-photo-stat-bar{
  position:absolute;bottom:0;left:0;right:0;
  background:rgba(10,26,54,0.9);
  backdrop-filter:blur(8px);
  display:flex;align-items:center;
  padding:20px 28px;
  gap:0;
}
.about-stat{flex:1;text-align:center;}
.about-stat-num{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:26px;color:var(--orange);
  letter-spacing:0.02em;line-height:1;
}
.about-stat-lbl{
  font-size:11px;color:rgba(255,255,255,0.6);
  font-weight:600;letter-spacing:0.06em;text-transform:uppercase;
  margin-top:4px;
}
.about-stat-divider{
  width:1px;height:40px;
  background:rgba(255,255,255,0.15);
  flex-shrink:0;
}
.about-text-col{
  padding:80px 64px 80px 72px;
  display:flex;flex-direction:column;justify-content:center;
  background:var(--off-white);
}
.about-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:700;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--orange);margin-bottom:18px;
}
.about-tag::before{content:'';display:block;width:28px;height:2px;background:var(--orange);}
.about-h2{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:clamp(44px,4vw,68px);
  line-height:0.93;text-transform:uppercase;
  color:var(--navy);margin-bottom:24px;
}
.about-h2 span{color:var(--orange);}
.about-p{
  font-size:16px;line-height:1.78;color:#3a3a3a;
  margin-bottom:18px;
  text-wrap:pretty;
}
.about-p strong{color:var(--navy);font-weight:700;}
.about-owner-note{
  background:#fff;
  border-left:4px solid var(--orange);
  padding:16px 20px;
  margin:24px 0 24px;
  font-size:15px;font-style:italic;color:#555;line-height:1.65;
  box-shadow:0 2px 12px rgba(0,0,0,0.06);
}
.about-owner-note cite{
  display:block;margin-top:10px;
  font-style:normal;font-weight:700;font-size:13px;
  color:var(--navy);letter-spacing:0.04em;text-transform:uppercase;
}
.about-trust-row{
  display:flex;flex-wrap:wrap;gap:10px 24px;
  margin-bottom:28px;
}
.about-trust-item{
  display:inline-flex;align-items:center;gap:7px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:14px;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--navy);
}
.about-trust-item svg{color:var(--orange);flex-shrink:0;}
.about-btn{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--navy);color:#fff;
  padding:14px 32px;border-radius:3px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:17px;letter-spacing:0.06em;text-transform:uppercase;
  transition:background 0.2s;align-self:flex-start;
}
.about-btn:hover{background:var(--orange);}

/* ─── SERVICES ─── */
#services{
  background:var(--navy);
  padding:96px 0 100px;
  position:relative;overflow:hidden;
}

.services-geo-br{
  position:absolute;right:-20px;bottom:-20px;
  width:200px;height:200px;
  border:3px solid rgba(232,93,26,0.2);
  transform:rotate(15deg);
}
.section-head{
  max-width:1320px;margin:0 auto;padding:0 40px;
  margin-bottom:52px;
}
.section-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:700;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--orange);margin-bottom:14px;
}
.section-tag::before{content:'';display:block;width:28px;height:2px;background:var(--orange);}
.section-h2{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:clamp(48px,5vw,80px);
  line-height:0.92;text-transform:uppercase;color:#fff;
}
.section-h2 span{color:var(--orange);}
.section-sub{
  font-size:16px;color:rgba(255,255,255,0.5);
  margin-top:14px;max-width:480px;line-height:1.6;
  font-weight:400;
}
.section-tag--dark{color:var(--orange);}
.section-h2--dark{color:var(--navy);}

/* Services: varied card heights to break perfect grid symmetry */
.services-grid{
  max-width:1320px;margin:0 auto;padding:0 40px;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  grid-template-rows:auto;
  gap:8px;
  align-items:start;
}
.svc-card{
  position:relative;overflow:hidden;
  cursor:pointer;
  background:var(--navy-mid);
}
/* Intentionally different heights — feels designed, not generated */
.svc-card:nth-child(odd){ height:500px; }
.svc-card:nth-child(even){ height:460px; margin-top:32px; }

.svc-card img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.6s ease;
  filter:brightness(0.72) saturate(0.85);
}
.svc-card:hover img{transform:scale(1.06);filter:brightness(0.85) saturate(1);}
.svc-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top, rgba(10,26,54,0.97) 0%, rgba(10,26,54,0.35) 50%, transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:28px 28px 32px;transition:background 0.3s;
}
.svc-card:hover .svc-overlay{
  background:linear-gradient(to top, rgba(10,26,54,0.99) 0%, rgba(10,26,54,0.5) 55%, transparent 100%);
}
.svc-num{
  position:absolute;top:16px;right:20px;
  font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:72px;
  line-height:1;color:rgba(255,255,255,0.18);
  text-shadow:0 2px 8px rgba(0,0,0,0.4);
  pointer-events:none;
}
.svc-icon-bar{
  width:36px;height:3px;background:var(--orange);
  margin-bottom:14px;
  transition:width 0.3s;
}
.svc-card:hover .svc-icon-bar{width:56px;}
.svc-name{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:38px;text-transform:uppercase;
  color:#fff;line-height:1;margin-bottom:10px;
}
.svc-desc{
  font-size:14px;color:rgba(255,255,255,0.75);
  line-height:1.6;margin-bottom:14px;
}
.svc-card:hover .svc-desc{color:rgba(255,255,255,0.9);}
.svc-tags{
  display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;
}
.svc-tag{
  font-size:11px;font-weight:700;letter-spacing:0.07em;text-transform:uppercase;
  color:rgba(255,255,255,0.5);
  border:1px solid rgba(255,255,255,0.15);
  padding:3px 9px;border-radius:2px;
}
.svc-link{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:14px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--orange);
  opacity:0;transform:translateY(6px);
  transition:opacity 0.3s,transform 0.3s;
}
.svc-card:hover .svc-link{opacity:1;transform:translateY(0);}

/* ─── SOCIAL PROOF STRIP ─── */
#social-proof{
  background:#fff;
  border-top:1px solid #e8eaed;
  border-bottom:1px solid #e8eaed;
  padding:28px 0;
}
.sp-inner{
  max-width:1320px;margin:0 auto;padding:0 40px;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;flex-wrap:wrap;
}
.sp-review{
  display:flex;align-items:center;gap:14px;
}
.sp-stars{
  display:flex;gap:3px;
}
.sp-review-text span{color:#888;font-weight:400;margin-left:4px;}
.sp-divider{width:1px;height:32px;background:#ddd;flex-shrink:0;}
.sp-trust{
  display:flex;align-items:center;gap:8px;
  font-size:13px;color:#555;font-weight:600;
}
.sp-trust-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--orange);flex-shrink:0;
}

/* ─── HOW IT WORKS ─── */
#process{
  background:var(--off-white);
  padding:96px 0 100px;
  position:relative;overflow:hidden;
}
.process-stripe{
  position:absolute;left:0;top:0;bottom:0;width:50%;
  background:url('uploads/WhatsApp Image 2026-04-17 at 12.18.47 PM (2).jpeg') center/cover no-repeat;
  opacity:0.06;
}
.process-inner{
  max-width:1320px;margin:0 auto;padding:0 40px;
  position:relative;z-index:1;
}
.process-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:64px;align-items:start;
  margin-top:52px;
}
.process-steps{display:flex;flex-direction:column;gap:0;}
.step{
  display:flex;gap:20px;
  padding:24px 0 28px;
  border-bottom:1px solid rgba(0,0,0,0.07);
  position:relative;
}
.step:last-child{border-bottom:none;}
.step-num-wrap{
  flex-shrink:0;
  width:48px;height:48px;
  background:var(--navy);
  border-radius:3px;
  display:flex;align-items:center;justify-content:center;
  position:relative;
  box-shadow:0 4px 12px rgba(10,26,54,0.18);
}
.step-num{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:24px;color:#fff;
}
.step-num-wrap::after{
  content:'';position:absolute;left:50%;bottom:-28px;
  transform:translateX(-50%);
  width:1px;height:28px;
  background:rgba(27,58,107,0.2);
}
.step:last-child .step-num-wrap::after{display:none;}
.step-body{padding-top:4px;}
.step-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:22px;text-transform:uppercase;
  color:var(--navy);margin-bottom:6px;letter-spacing:0.02em;
}
.step-desc{
  font-size:15px;color:#555;line-height:1.65;
  text-wrap:pretty;
}
.step-detail{
  margin-top:8px;
  font-size:13px;color:var(--orange);font-weight:700;
  letter-spacing:0.04em;text-transform:uppercase;
}
.process-photo-stack{
  display:grid;grid-template-columns:1fr 1fr;
  grid-template-rows:260px 260px;
  gap:4px;
}
.process-photo{overflow:hidden;position:relative;}
.process-photo img{width:100%;height:100%;object-fit:cover;}
.process-photo:first-child{grid-column:1/3;}
.process-badge{
  position:absolute;bottom:0;left:0;right:0;
  background:var(--orange);
  padding:14px 20px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:16px;text-transform:uppercase;
  letter-spacing:0.06em;color:#fff;
  display:flex;align-items:center;justify-content:space-between;
}

/* ─── GALLERY ─── */
#gallery{
  background:var(--navy);
  padding:100px 0;
  position:relative;
}
.gallery-dot-tr{
  position:absolute;right:0;top:0;
  width:260px;height:200px;
  background-image:none;
  background-size:18px 18px;pointer-events:none;
}
.gallery-grid{
  max-width:1320px;margin:0 auto;padding:0 40px;
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  grid-template-rows:280px 240px;
  gap:4px;
  margin-top:52px;
}
.g-item{overflow:hidden;position:relative;background:#1B3A6B;}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s;}
.g-item:hover img{transform:scale(1.04);}
.g-item-tall{grid-row:1/3;}
.g-item-wide{grid-column:2/4;}
.g-label{display:none;}
.gallery-cta{
  max-width:1320px;margin:32px auto 0;padding:0 40px;
  text-align:center;
}

/* ─── STORM / EMERGENCY SERVICES ─── */
#storm-services{
  background:#060f1e;
  position:relative;
  overflow:hidden;
}
.storm-bg-photo{
  position:absolute;inset:0;
  z-index:0;
  background:#060f1e;
}
.storm-bg-video{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
.storm-bg-video{
  position:absolute;
  inset:0;
  opacity:0.58;
  filter:brightness(1.06) contrast(1.04);
}
.storm-photo-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(90deg, rgba(6,15,30,0.86) 0%, rgba(6,15,30,0.76) 26%, rgba(6,15,30,0.48) 48%, rgba(6,15,30,0.16) 72%, rgba(6,15,30,0.08) 100%),
    linear-gradient(180deg, rgba(6,15,30,0.16) 0%, rgba(6,15,30,0.18) 40%, rgba(6,15,30,0.4) 72%, rgba(6,15,30,0.82) 100%);
}
.storm-inner{
  max-width:1320px;margin:0 auto;padding:80px 40px 0;
  position:relative;z-index:1;
}
.storm-content{
  max-width:680px;
}
.storm-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--orange);margin-bottom:20px;
}
.storm-h2{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:clamp(48px,5vw,80px);
  line-height:0.92;text-transform:uppercase;
  color:#fff;margin-bottom:20px;
}
.storm-h2 span{color:var(--orange);}
.storm-sub{
  font-size:16px;line-height:1.7;
  color:rgba(255,255,255,0.6);
  margin-bottom:40px;
  max-width:480px;
  text-wrap:pretty;
}
.storm-items{
  display:grid;grid-template-columns:1fr 1fr;
  gap:0;
  border-top:1px solid rgba(255,255,255,0.1);
}
.storm-item{
  display:flex;gap:20px;
  padding:28px 28px 28px 0;
  border-bottom:1px solid rgba(255,255,255,0.1);
  border-right:1px solid rgba(255,255,255,0.1);
}
.storm-item:nth-child(even){
  padding-left:28px;padding-right:0;
  border-right:none;
}
.storm-item-num{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:36px;
  color:rgba(232,93,26,0.3);
  line-height:1;flex-shrink:0;
  width:44px;
}
.storm-item-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:17px;text-transform:uppercase;
  letter-spacing:0.04em;color:#fff;
  margin-bottom:6px;line-height:1.1;
}
.storm-item-desc{
  font-size:14px;line-height:1.6;
  color:rgba(255,255,255,0.5);
}
/* Call bar */
.storm-call-bar{
  position:relative;z-index:1;
  margin-top:72px;
  background:var(--orange);
}
.storm-call-inner{
  max-width:1320px;margin:0 auto;padding:28px 40px;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;flex-wrap:wrap;
}
.storm-call-hed{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:22px;text-transform:uppercase;
  letter-spacing:0.04em;color:#fff;line-height:1.1;
}
.storm-call-sub{
  font-size:14px;color:rgba(255,255,255,0.8);
  margin-top:4px;
}
.storm-call-btn{
  display:inline-flex;align-items:center;gap:10px;
  background:#fff;color:var(--orange);
  padding:14px 32px;border-radius:3px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:19px;letter-spacing:0.06em;text-transform:uppercase;
  white-space:nowrap;transition:background 0.18s,color 0.18s;
  flex-shrink:0;
}
.storm-call-btn:hover{background:var(--navy);color:#fff;}

@media (prefers-reduced-motion: reduce){
  .storm-bg-video{display:none;}
}

/* ─── AREAS ─── */
#areas{
  background:
    linear-gradient(rgba(10,26,54,0.88), rgba(6,14,29,0.92)),
    url('uploads/WhatsApp Image 2026-04-17 at 12.24.04 PM.jpeg') center/cover no-repeat;
  padding:60px 0 40px;
  position:relative;overflow:hidden;
  min-height:780px;
}
#areas::before{
  content:'';
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 18% 22%, rgba(232,93,26,0.18) 1px, transparent 1.6px),
    linear-gradient(90deg, rgba(10,26,54,0.56), rgba(10,26,54,0.16) 45%, rgba(10,26,54,0.34));
  background-size:18px 18px, auto;
  opacity:0.7;
  pointer-events:none;
}
.areas-geo{display:none;}
.areas-inner{max-width:1320px;margin:0 auto;padding:0 40px;position:relative;z-index:1;}
.areas-header{text-align:center;}
#areas .section-h2{
  font-size:clamp(48px,5vw,80px);
  line-height:0.92;
  color:#fff;
  margin:0;
}
#areas .section-h2 span{color:inherit;}
.areas-subtitle{
  max-width:880px;
  margin:18px auto 0;
  color:rgba(255,255,255,0.62);
  font-size:16px;
  line-height:1.75;
  font-weight:400;
  text-wrap:pretty;
}

/* Map + chips side by side */
.areas-layout{
  display:grid;
  grid-template-columns:minmax(480px, 610px) minmax(560px, 1fr);
  gap:78px;
  align-items:center;
  margin-top:110px;
}
.areas-list-col{
  padding:0;
}
.areas-list-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  font-size:22px;
  line-height:1.05;
  letter-spacing:0.04em;
  text-transform:uppercase;
  color:#fff;
  text-align:center;
  background:rgba(10,26,54,0.96);
  padding:34px 27px 24px;
}
.map-wrap{
  position:relative;
}
.map-wrap::after{display:none;}
#areas #service-map{
  width:100%;
  height:610px;
  position:relative;
}
#areas #service-map svg{
  filter:drop-shadow(0 14px 0 rgba(0,0,0,0.22)) drop-shadow(0 18px 18px rgba(0,0,0,0.32));
}
#areas #service-map .city-dots,
#areas #service-map .county-labels{
  display:none;
}
/* Hide old HTML legend — legend lives inside SVG now */
.map-legend{display:none;}
.map-legend-dot{display:none;}

/* SVG map loading skeleton */
.map-skeleton{
  width:100%;height:100%;
  background:rgba(255,255,255,0.05);
  display:flex;align-items:center;justify-content:center;
}
.map-sk-inner{
  width:70%;height:60%;
  background:linear-gradient(90deg,#1B3A6B 25%,#2b4d80 50%,#1B3A6B 75%);
  background-size:200% 100%;
  animation:mapSkeletonShimmer 1.5s infinite;
  border-radius:4px;
}
@keyframes mapSkeletonShimmer{
  0%{background-position:200% 0;}
  100%{background-position:-200% 0;}
}
.map-error{
  padding:24px;color:rgba(255,255,255,0.5);
  font-family:'Barlow Condensed',sans-serif;font-size:15px;text-align:center;
}
.map-error a{color:var(--orange);}

/* SVG map tooltip */

.smt-name{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:18px;text-transform:uppercase;
  color:#fff;letter-spacing:0.04em;line-height:1;
}
.smt-sub{
  font-size:11px;color:rgba(255,255,255,0.5);
  font-weight:600;margin-top:4px;
  letter-spacing:0.06em;text-transform:uppercase;
}
.smt-cta{
  display:inline-block;margin-top:8px;
  background:var(--orange);color:#fff;
  padding:5px 14px;border-radius:3px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:13px;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;
  text-decoration:none;transition:background 0.2s;
}
.smt-cta:hover{background:#C44A0A;}

/* HQ dot pulse ring animation */

@keyframes hqPulse{
  0%{r:10;opacity:0.5;}
  70%{r:20;opacity:0;}
  100%{r:10;opacity:0;}
}

.areas-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
  background:rgba(10,26,54,0.96);
  padding:0 27px 26px;
}
.area-chip{
  background:rgba(255,255,255,0.12);
  border:0;
  border-top:2px solid var(--orange);
  border-radius:0;
  padding:0 26px;
  min-height:72px;
  display:flex;
  align-items:center;
  gap:26px;
  font-family:'Barlow',sans-serif;
  font-weight:600;font-size:17px;letter-spacing:0;text-transform:none;
  color:#fff;
  text-align:left;
  transition:all 0.18s;cursor:pointer;
  user-select:none;
  white-space:normal;
}
.area-chip:nth-child(n+7){display:none;}
.area-chip-icon{color:rgba(255,255,255,0.27);width:42px;height:20px;flex:0 0 42px;}
.area-chip span{flex:1;}
.area-chip-arrow{color:rgba(232,93,26,0.95);width:24px;height:24px;flex:0 0 24px;}
.area-chip:hover{background:rgba(232,93,26,0.28);color:#fff;}
.area-chip.active{background:rgba(232,93,26,0.42);color:#fff;box-shadow:none;}
.areas-cta-row{
  display:flex;
  margin-top:28px;
  justify-content:flex-start;
  padding-left:95px;
}

.areas-view-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:28px;
  min-width:418px;
  min-height:80px;
  background:var(--orange);
  color:#fff;
  border:1px solid var(--orange-light);
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  font-size:18px;
  letter-spacing:0.06em;
  line-height:1;
  text-transform:uppercase;
  transition:background 0.18s,transform 0.18s;
}
.areas-view-btn:hover{background:#C44A0A;transform:translateY(-1px);}

@media(max-width:900px){
  #areas{padding:48px 0 44px;min-height:auto;}
  .areas-layout{grid-template-columns:1fr;gap:34px;margin-top:46px;}
  .areas-subtitle{font-size:16px;max-width:720px;}
  #areas #service-map{height:380px;}
  .areas-grid{grid-template-columns:1fr;}
  .areas-cta-row{padding-left:0;justify-content:center;}
}
@media(max-width:480px){
  #areas .section-h2{font-size:clamp(36px,10vw,56px);}
  .areas-subtitle{font-size:16px;}
  .areas-list-title{font-size:20px;padding:28px 20px 20px;}
  .areas-grid{grid-template-columns:1fr;padding:0 20px 20px;gap:12px;}
  .area-chip{min-height:62px;font-size:15px;padding:0 18px;gap:14px;}
  .area-chip-icon{width:28px;flex-basis:28px;}
  .areas-view-btn{min-width:0;width:100%;font-size:16px;min-height:68px;gap:18px;}
}

/* ─── MID-PAGE CTA BAND ─── */
#cta-band{
  background:var(--orange);
  padding:52px 0;
  position:relative;overflow:hidden;
}
#cta-band::before{
  content:'';position:absolute;inset:0;
  background-image:none;
  background-size:20px 20px;
}
.cta-band-inner{
  max-width:1320px;margin:0 auto;padding:0 40px;
  display:flex;align-items:center;justify-content:space-between;
  gap:32px;flex-wrap:wrap;
  position:relative;z-index:1;
}
.cta-band-hed{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:clamp(32px,3vw,48px);
  text-transform:uppercase;color:#fff;line-height:1;
  margin-bottom:6px;letter-spacing:-0.01em;
}
.cta-band-sub{
  font-size:16px;color:rgba(255,255,255,0.8);
  font-weight:500;
}
.btn-cta-band{
  background:#fff;color:var(--orange);
  padding:16px 36px;border:none;border-radius:3px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:20px;letter-spacing:0.05em;text-transform:uppercase;
  white-space:nowrap;flex-shrink:0;
  transition:background 0.2s,transform 0.15s;
  box-shadow:0 4px 20px rgba(0,0,0,0.15);
}
.btn-cta-band:hover{background:#f0f2f5;transform:translateY(-2px);}

/* ─── CONTACT ─── */
#contact{
  background:var(--navy);
  padding:100px 0;
  position:relative;overflow:hidden;
}

.contact-stripe{
  position:absolute;right:0;top:0;bottom:0;
  width:44%;
  background:url('uploads/WhatsApp Image 2026-04-17 at 12.18.46 PM (2).jpeg') center/cover no-repeat;
  opacity:0.1;
}
.contact-inner{
  max-width:1320px;margin:0 auto;padding:0 40px;
  display:grid;grid-template-columns:1fr 480px;
  gap:80px;align-items:start;
  position:relative;z-index:1;
}
.contact-left .section-h2{margin-bottom:18px;}
.contact-desc{
  font-size:16px;color:rgba(255,255,255,0.6);
  line-height:1.75;margin-bottom:36px;max-width:400px;
  text-wrap:pretty;
}
.contact-details{display:flex;flex-direction:column;gap:18px;margin-bottom:32px;}
.cdet{display:flex;align-items:flex-start;gap:14px;}
.cdet-icon{
  width:44px;height:44px;background:var(--orange);border-radius:3px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;
  box-shadow:0 4px 12px rgba(232,93,26,0.3);
}
.cdet-lbl{font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:3px;}
.cdet-val{font-size:16px;font-weight:600;color:#fff;}
.socials{display:flex;gap:10px;margin-top:4px;}
.social-btn{
  width:40px;height:40px;border-radius:3px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.55);
  transition:all 0.2s;
}
.social-btn:hover{background:var(--orange);border-color:var(--orange);color:#fff;}

/* Contact form card */
.contact-card{
  background:var(--navy-mid);
  border:1px solid rgba(255,255,255,0.08);
  border-top:3px solid var(--orange);
  border-radius:4px;
  padding:36px 36px 40px;
  box-shadow:0 24px 64px rgba(0,0,0,0.35);
}
.contact-card-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:28px;text-transform:uppercase;
  color:#fff;margin-bottom:4px;letter-spacing:0.02em;
}
.contact-card-sub{
  font-size:13px;color:rgba(255,255,255,0.4);
  margin-bottom:24px;
}
.cf{
  width:100%;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:3px;
  padding:12px 15px;
  color:#fff;font-size:15px;
  margin-bottom:10px;outline:none;
  transition:border-color 0.2s,background 0.2s;
}
.cf::placeholder{color:rgba(255,255,255,0.3);}
.cf:focus{border-color:var(--orange);background:rgba(255,255,255,0.07);}
select.cf option{background:#1B3A6B;}
textarea.cf{resize:none;}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.cf-submit{
  width:100%;background:var(--orange);color:#fff;border:none;
  border-radius:3px;padding:16px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:20px;letter-spacing:0.06em;text-transform:uppercase;
  margin-top:8px;transition:background 0.2s,box-shadow 0.2s,transform 0.15s;
  box-shadow:0 4px 20px rgba(232,93,26,0.4);
}
.cf-submit:hover{background:#C44A0A;box-shadow:0 8px 28px rgba(232,93,26,0.55);transform:translateY(-1px);}
.cf-privacy{
  font-size:12px;color:rgba(255,255,255,0.3);
  text-align:center;margin-top:12px;line-height:1.5;
}

/* ─── FOOTER ─── */
#footer{
  background:var(--navy-mid);
  border-top:4px solid var(--orange);
  padding:60px 0 0;
}
.footer-inner{
  max-width:1320px;margin:0 auto;padding:0 40px;
  display:grid;grid-template-columns:300px 1fr 1fr 180px;
  gap:60px;padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.footer-logo{margin-bottom:16px;}
.footer-logo img{
  height:64px;
  width:auto;
  max-width:100%;
  display:block;
  object-fit:contain;
  object-position:left center;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,0.35));
}
.footer-tagline{font-size:13px;color:rgba(255,255,255,0.5);line-height:1.65;}
.footer-col-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:15px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--orange);margin-bottom:18px;
}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-links a{font-size:14px;color:rgba(255,255,255,0.55);transition:color 0.2s;}
.footer-links a:hover{color:#fff;}
.footer-phone-big{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:22px;color:var(--orange);
  display:block;margin-bottom:8px;
}
.footer-bottom{
  max-width:1320px;margin:0 auto;padding:20px 40px;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;
}
.footer-copy{font-size:12px;color:rgba(255,255,255,0.35);}

/* ─── CERTS BAND ─── */
#certs{
  background:var(--off-white);
  padding:32px 0;
  border-top:3px solid var(--orange);
}
.certs-inner{
  max-width:1320px;margin:0 auto;padding:0 40px;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:24px;
}
.cert-pill{
  display:flex;align-items:center;gap:12px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:15px;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--navy);
}
.cert-icon-sq{
  width:38px;height:38px;background:var(--navy);border-radius:3px;
  display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;
}

/* ─── SCROLL ANIMATIONS ─── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
.anim{animation:fadeUp 0.6s ease both;}
.anim-d1{animation-delay:0.05s;}
.anim-d2{animation-delay:0.15s;}
.anim-d3{animation-delay:0.28s;}
.anim-d4{animation-delay:0.42s;}
.anim-d5{animation-delay:0.56s;}

/* Motion.dev — hover transition only activates AFTER entrance animation completes */
/* .motion-ready is added by JS clear() — prevents CSS transition firing during setup */
.svc-card.motion-ready {
  transition: transform 0.38s cubic-bezier(0.16,1,0.3,1),
              box-shadow 0.38s cubic-bezier(0.16,1,0.3,1);
}
.svc-card.motion-ready:hover {
  transform: translateY(-10px);
  box-shadow: 0 24px 60px rgba(0,0,0,0.45);
}

/* Gallery item clipping for image zoom */
.g-item, .gf-item { overflow: hidden; }

/* NAV scrolled — compact */
#main-nav.scrolled{background:rgba(255,255,255,0.98);box-shadow:0 8px 24px rgba(7,18,36,0.12);}
#main-nav.scrolled::before{height:84px;}
#main-nav.scrolled .nav-inner{height:84px;}
#main-nav.scrolled .nav-logo img{height:62px;}

/* ─── HAMBURGER ─── */
.hamburger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  background:none;border:none;padding:6px;cursor:pointer;
  width:38px;height:38px;flex-shrink:0;
}
.hamburger span{
  display:block;width:24px;height:2px;
  background:var(--navy);border-radius:2px;
  transition:all 0.3s;transform-origin:center;
}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ─── MOBILE MENU ─── */
.mobile-menu{
  display:none;
  flex-direction:column;gap:4px;
  padding:16px 24px 24px;
  background:rgba(255,255,255,0.98);
  border-top:1px solid rgba(10,26,54,0.08);
  box-shadow:0 14px 28px rgba(7,18,36,0.08);
  position:relative;
  z-index:1;
}
.mobile-menu.open{display:flex;}
.mobile-links{list-style:none;display:flex;flex-direction:column;gap:0;}
.mobile-links a{
  display:block;padding:14px 0;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:20px;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--navy);
  border-bottom:1px solid rgba(10,26,54,0.07);
  transition:color 0.2s;
}
.mobile-links a:hover{color:var(--orange);}
.mobile-phone{
  display:flex;align-items:center;gap:10px;
  color:var(--navy);font-weight:700;font-size:18px;
  margin:16px 0 12px;
}
.mobile-phone svg{color:var(--orange);}
.mobile-cta{width:100%;text-align:center;}

/* ════════════════════════════════════
   RESPONSIVE BREAKPOINTS
════════════════════════════════════ */

/* ─── TABLET: 1024px ─── */
@media(max-width:1024px){
  /* Nav */
  #main-nav::before{width:380px;min-width:380px;max-width:380px;clip-path:polygon(0 0, 86% 0, 100% 100%, 0 100%);}
  .nav-center{display:none;}
  .nav-phone{display:none;}
  .btn-nav{display:none;}
  .hamburger{display:flex;}

  /* Hero — tablet sizing handled in base + 768 query */

  /* Banner */
  .banner-label{font-size:38px;}
  .banner-service-item{font-size:16px;padding:0 16px;}

  /* Stats */
  .stats-grid{padding:0 28px;}
  .stat-num{font-size:44px;}

  /* About */
  .about-inner{grid-template-columns:1fr;}
  .about-photo-col img{min-height:420px;}
  .about-photo-stat-bar{position:static;background:var(--navy);}
  .about-text-col{padding:56px 40px;}

  /* Services */
  .section-head{padding:0 28px;}
  .services-grid{padding:0 28px;grid-template-columns:1fr 1fr;gap:10px;}

  /* Process */
  .process-inner{padding:0 28px;}
  .process-grid{grid-template-columns:1fr;gap:40px;}
  .process-photo-stack{grid-template-columns:1fr 1fr;grid-template-rows:220px 220px;}
  .process-photo:first-child{grid-column:1/3;}

  /* Gallery */
  .gallery-grid{padding:0 28px;grid-template-columns:1fr 1fr;grid-template-rows:220px 200px 200px;}
  .g-item-tall{grid-column:1;grid-row:1/3;}
  .g-item-wide{grid-column:auto;grid-row:auto;}

  /* Storm services */
  .storm-inner{padding:64px 28px 0;}
  .storm-items{grid-template-columns:1fr;}
  .storm-item{border-right:none !important;padding-left:0 !important;padding-right:0 !important;}
  .storm-call-inner{padding:28px;}

  /* Areas */
  .areas-inner{padding:0 28px;}

  /* Contact */
  .contact-inner{grid-template-columns:1fr;gap:48px;padding:0 28px;}
  .contact-stripe{display:none;}

  /* Certs */
  .certs-inner{padding:0 28px;gap:16px;}
  .cert-pill{font-size:13px;}

  /* Social proof + CTA band */
  .sp-inner{padding:0 28px;flex-wrap:wrap;gap:14px;}
  .sp-divider{display:none;}
  .cta-band-inner{padding:0 28px;flex-direction:column;align-items:flex-start;gap:24px;}

  /* Services card heights — reset on tablet, uniform aspect for clean 2x2 */
  .svc-card,
  .svc-card:nth-child(odd),
  .svc-card:nth-child(even){ height:auto; margin-top:0; aspect-ratio:4/5; }

  /* Footer */
  .footer-inner{grid-template-columns:1fr 1fr;gap:40px;padding:0 28px 48px;}
  .footer-bottom{padding:20px 28px;}
}

/* ─── MOBILE: 768px ─── */
@media(max-width:768px){
  /* Mobile nav — two-row layout: large logo on row 1, hamburger + CTA on row 2.
     Navy panel covers the entire mobile header (no diagonal cut). */
  #main-nav::before{
    width:100%;min-width:100%;max-width:100%;
    height:100%;
    clip-path:none;
  }
  #main-nav.scrolled::before{height:100%;}
  .nav-inner{
    flex-direction:column;
    height:auto;
    padding:14px 20px 12px;
    gap:12px;
    align-items:stretch;
  }
  #main-nav.scrolled .nav-inner{height:auto;padding:10px 20px 10px;}
  .nav-logo{
    min-width:0;
    width:100%;
    justify-content:center;
    filter:drop-shadow(0 4px 12px rgba(0,0,0,0.4));
  }
  .nav-logo img{height:90px;}
  #main-nav.scrolled .nav-logo img{height:64px;}
  /* Row 2: hamburger left, Free Inspections button right */
  .nav-right{
    width:100%;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
  }
  .nav-phone{display:none;}
  .btn-nav{
    display:inline-flex;
    align-items:center;justify-content:center;
    flex:1;
    padding:11px 18px;
    font-size:14px;
    letter-spacing:0.07em;
  }
  .hamburger{
    display:flex;
    flex-shrink:0;
    background:rgba(255,255,255,0.06);
    border:1px solid rgba(255,255,255,0.18);
    border-radius:3px;
  }
  .hamburger span{background:#fff;}

  /* Hero — shorter on mobile so the headline/CTAs below come into view sooner */
  #hero{ height:62vh; min-height:420px; }
  .hero-scroll-cue{ display:none; }
  /* Hero intro: stack CTAs full-width for thumbs */
  .hero-intro-ctas{ flex-direction:column; align-items:stretch; gap:10px; margin-bottom:36px; }
  .hero-intro-ctas .btn-primary,
  .hero-intro-ctas .hi-btn-line{ width:100%; justify-content:center; }
  .hero-intro-meta{ gap:12px 22px; font-size:11px; }
  /* The skewed orange accent line cuts through the centered content on narrow screens — hide it
     and shrink the navy corner so it doesn't crowd the meta row */
  #hero-intro .hi-accent{ display:none; }
  #hero-intro .hi-corner{ width:140px; height:80px; }

  /* Banner */
  .marquee-item-label{font-size:20px;}
  .marquee-item{padding:0 24px;}

  /* Stats */
  .stats-grid{grid-template-columns:1fr 1fr;padding:0 20px;}
  .stat-item{border-right:none;border-bottom:1px solid rgba(255,255,255,0.1);}
  .stat-item:nth-child(odd){border-right:1px solid rgba(255,255,255,0.1);}
  .stat-item:nth-last-child(-n+2){border-bottom:none;}
  .stat-num{font-size:40px;}

  /* About */
  .about-h2{font-size:clamp(38px,9vw,56px);}
  .about-text-col{padding:48px 28px;}
  .about-photo-col img{min-height:360px;}

  /* Services */
  .section-head{padding:0 20px;}
  .services-grid{padding:0 20px;grid-template-columns:1fr;gap:14px;}

  /* Process */
  .process-inner{padding:0 20px;}
  .process-photo-stack{grid-template-columns:1fr;grid-template-rows:220px 180px 180px;}
  .process-photo:first-child{grid-column:1;}

  /* Gallery */
  .gallery-grid{
    padding:0 20px;
    grid-template-columns:1fr 1fr;
    grid-template-rows:200px 180px 180px;
  }
  .g-item-tall{grid-column:1;grid-row:1/3;}
  .g-item-wide{grid-column:auto;grid-row:auto;}

  /* Certs */
  .certs-inner{
    padding:0 20px;
    flex-direction:column;gap:12px;
    align-items:flex-start;
  }

  /* Social proof + CTA band */
  #social-proof{padding:20px 0;}
  .sp-inner{padding:0 20px;flex-direction:column;align-items:flex-start;gap:12px;}
  .sp-divider{display:none;}
  #cta-band{padding:40px 0;}
  .cta-band-inner{padding:0 20px;flex-direction:column;align-items:flex-start;gap:20px;}
  .btn-cta-band{width:100%;text-align:center;}

  /* About owner note */
  .about-owner-note{margin:20px 0 24px;}

  /* Services — all single col, uniform height on mobile, no nth-child overlap */
  .svc-card,
  .svc-card:nth-child(odd),
  .svc-card:nth-child(even){ height:340px; margin-top:0; aspect-ratio:auto; grid-column:auto; }

  /* Storm services */
  .storm-inner{padding:48px 20px 0;}
  .storm-h2{font-size:clamp(40px,10vw,64px);}
  .storm-call-inner{padding:24px 20px;flex-direction:column;align-items:flex-start;}
  .storm-call-btn{width:100%;justify-content:center;}

  /* Areas */
  .areas-inner{padding:0 20px;}
  .areas-cta-row{flex-direction:column;align-items:center;padding-left:0;}

  /* Contact */
  .contact-inner{padding:0 20px;}
  .contact-card{padding:28px 20px;}
  .cf-row{grid-template-columns:1fr;}

  /* Footer */
  .footer-inner{
    grid-template-columns:1fr;gap:32px;
    padding:0 20px 40px;
  }
  .footer-bottom{padding:20px 20px;flex-direction:column;gap:8px;text-align:center;}
}

/* ─── SMALL MOBILE: 480px ─── */
@media(max-width:480px){
  /* Inherit the two-row mobile header from 768px; just refine sizes */
  .nav-logo img{height:74px;}
  #main-nav.scrolled .nav-logo img{height:56px;}
  .btn-nav{padding:10px 14px;font-size:13px;}
  .section-h2{font-size:clamp(36px,10vw,56px);}

  /* Banner */
  .marquee-item-label{font-size:18px;}
  .marquee-item{padding:0 18px;}
  .marquee-item-sub{display:none;}

  /* Stats */
  .stat-num{font-size:36px;}
  .stat-sub{display:none;}

  /* About */
  .about-h2{font-size:clamp(34px,10vw,48px);}
  .about-text-col{padding:32px 20px;}
  .about-photo-stat-bar{gap:0;padding:16px 20px;}
  .about-stat-num{font-size:22px;}

  /* Gallery - single column */
  .gallery-grid{
    grid-template-columns:1fr;
    grid-template-rows:repeat(5, 200px);
  }
  .g-item-tall{grid-column:1;grid-row:auto;}
  .g-item-wide{grid-column:1;grid-row:auto;}

  /* Process photos - single col */
  .process-photo-stack{
    grid-template-rows:200px 160px 160px;
  }

  /* Certs hide on very small */
  .cert-pill:nth-child(n+4){display:none;}

  /* Areas chips smaller */
  .area-chip{font-size:15px;padding:0 18px;}

  /* Footer */
  .footer-phone-big{font-size:20px;}
}

/* ════════════════════════════════════════════════════════
   ENHANCEMENTS — GRAIN · PROGRESS · REVEAL · ANIMATE
════════════════════════════════════════════════════════ */

/* GRAIN — removes flat-AI feel, adds material depth */
body::before {
  content:'';
  position:fixed;inset:0;
  z-index:9999;
  pointer-events:none;
  opacity:0.026;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:160px 160px;
}

/* SCROLL PROGRESS */
#scroll-progress {
  position:fixed;top:0;left:0;
  height:3px;width:0;
  background:var(--orange);
  z-index:2000;
  box-shadow:0 0 10px rgba(232,93,26,0.55);
  transition:width 0.06s linear;
}

/* ─── SCROLL REVEAL SYSTEM ─── */
[data-reveal] {
  opacity:0;
  transition:opacity 0.72s cubic-bezier(0.22,1,0.36,1),
             transform 0.72s cubic-bezier(0.22,1,0.36,1);
}
[data-reveal="up"]    { transform:translateY(52px); }
[data-reveal="left"]  { transform:translateX(-52px); }
[data-reveal="right"] { transform:translateX(52px); }
[data-reveal="scale"] { transform:scale(0.88); }
[data-reveal].is-visible { opacity:1;transform:none; }

/* Section tag line — animates in on reveal */
.section-tag::before,
.about-tag::before {
  width:0;
  transition:width 0.55s ease;
}
[data-reveal].is-visible .section-tag::before,
[data-reveal].is-visible .about-tag::before { width:28px; }

/* ─── ENHANCED HERO ENTRY ─── */
@keyframes fadeUpHeavy {
  from { opacity:0;transform:translateY(32px); }
  to   { opacity:1;transform:translateY(0); }
}
.anim { animation:fadeUpHeavy 0.65s cubic-bezier(0.22,1,0.36,1) both; }

/* Hero orange line slides in after load */

/* ─── MARQUEE ENTRANCE ─── */
@keyframes marqueeSlideUp {
  from { transform:translateY(100%);opacity:0; }
  to   { transform:translateY(0);opacity:1; }
}
#service-banner {
  animation:marqueeSlideUp 0.5s 0.55s cubic-bezier(0.22,1,0.36,1) both;
}

/* ─── ENHANCED SERVICE CARD HOVER ─── */
.svc-card::after {
  content:'';
  position:absolute;inset:0;
  border:2px solid var(--orange);
  opacity:0;
  transition:opacity 0.28s;
  pointer-events:none;
  z-index:3;
}
.svc-card:hover::after { opacity:1; }

/* ─── FORM FOCUS RING ─── */
.cf:focus {
  box-shadow:0 0 0 3px rgba(232,93,26,0.18);
}

/* ─── COUNTER NUMBERS ─── */
.stat-num { font-variant-numeric:tabular-nums; }

/* ─── HERO PARALLAX ─── */
.hero-photo { will-change:transform; }

/* ═══════════════════════════════
   TESTIMONIALS SECTION
═══════════════════════════════ */
#testimonials {
  background:var(--off-white);
  padding:96px 0 100px;
  position:relative;overflow:hidden;
}
#testimonials::after {
  content:'';
  position:absolute;
  right:-80px;bottom:-80px;
  width:380px;height:380px;
  border:44px solid rgba(10,26,54,0.06);
  border-radius:50%;
  pointer-events:none;
}

.testi-stars { display:flex;gap:3px;margin-bottom:14px; }

.testi-text  { font-size:15px;line-height:1.78;color:#3d3d3d;margin-bottom:20px; }

/* ═══════════════════════════════
   BACK TO TOP
═══════════════════════════════ */
#back-to-top {
  position:fixed;bottom:28px;right:28px;
  z-index:950;
  width:46px;height:46px;
  background:var(--navy-mid);
  border:1px solid rgba(255,255,255,0.14);
  border-radius:3px;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.65);
  cursor:pointer;
  transition:opacity 0.3s, transform 0.3s, background 0.2s, color 0.2s;
  opacity:0;pointer-events:none;
  transform:translateY(10px);
  box-shadow:0 4px 20px rgba(0,0,0,0.3);
}
#back-to-top.visible { opacity:1;pointer-events:all;transform:translateY(0); }
#back-to-top:hover   { background:var(--orange);border-color:var(--orange);color:#fff; }

/* ─── RESPONSIVE UPDATES ─── */
@media(max-width:1024px) {
  .testi-grid { grid-template-columns:1fr;gap:16px; }
  .testimonials-inner { padding:0 28px; }
}
@media(max-width:768px) {
  #testimonials { padding:72px 0 80px; }
  .testimonials-inner { padding:0 20px; }
}

/* ════════════════════════════════════════════════════════
   SUBPAGE SHARED STYLES
════════════════════════════════════════════════════════ */

/* ─── SUBPAGE HERO ─── */
.page-hero {
  background:var(--navy);
  padding:160px 0 88px;
  position:relative;overflow:hidden;
  min-height:400px;display:flex;align-items:center;
}
.page-hero-photo {
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:0.18;z-index:0;
}
.page-hero-photo::before {
  content:'';position:absolute;inset:0;
  background:linear-gradient(to right, var(--navy) 0%, rgba(10,26,54,0.55) 60%, var(--navy) 100%);
}
.page-hero-inner {
  max-width:1320px;margin:0 auto;padding:0 40px;
  position:relative;z-index:2;width:100%;
}

.page-hero-h1 {
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:clamp(52px,6vw,88px);
  line-height:0.92;text-transform:uppercase;color:#fff;
  margin-bottom:20px;text-wrap:balance;
}
.page-hero-h1 span{color:var(--orange);}
.page-hero-h1 .line-outline{-webkit-text-stroke:2px #fff;color:transparent;}
.page-hero-sub {
  font-size:17px;color:rgba(255,255,255,0.72);
  max-width:480px;line-height:1.65;margin-bottom:32px;font-weight:500;
}
.page-hero-ctas{display:flex;gap:14px;flex-wrap:wrap;}
.page-hero-badges {
  display:flex;gap:24px;flex-wrap:wrap;margin-top:36px;
}
.page-hero-geo{
  position:absolute;right:-40px;top:0;bottom:0;
  width:380px;background:var(--navy-mid);
  transform:skewX(-8deg);transform-origin:top right;z-index:1;
}
.page-hero-geo2{
  position:absolute;right:220px;top:0;bottom:0;
  width:6px;background:var(--orange);
  transform:skewX(-8deg);opacity:0.6;z-index:1;
}

/* ─── SERVICE BREAKDOWN ─── */
.breakdown-section {
  background:var(--off-white);
  padding:96px 0 100px;
  position:relative;overflow:hidden;
}
.breakdown-inner {
  max-width:1320px;margin:0 auto;padding:0 40px;
}
.breakdown-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;margin-top:52px;
}

.breakdown-card {
  background:#fff;
  border:1px solid #e4e7ec;
  border-top:3px solid var(--orange);
  padding:32px 26px 28px;
  position:relative;
  box-shadow:0 2px 14px rgba(0,0,0,0.05);
  transition:transform 0.25s ease,box-shadow 0.25s ease;
}
.breakdown-card:hover{transform:translateY(-5px);box-shadow:0 14px 40px rgba(0,0,0,0.1);}
.breakdown-icon {
  width:48px;height:48px;
  background:var(--navy);border-radius:3px;
  display:flex;align-items:center;justify-content:center;
  color:var(--orange);margin-bottom:16px;flex-shrink:0;
}
.breakdown-title {
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:22px;text-transform:uppercase;
  color:var(--navy);margin-bottom:10px;letter-spacing:0.02em;
}
.breakdown-desc {font-size:14px;color:#555;line-height:1.72;}
.breakdown-features {
  margin-top:14px;display:flex;flex-direction:column;gap:7px;
}
.breakdown-feature {
  display:flex;align-items:center;gap:9px;
  font-size:13px;color:#444;font-weight:500;
}
.breakdown-feature::before{
  content:'';width:12px;height:2px;background:var(--orange);flex-shrink:0;
}

/* ─── WHY US (dark bg) ─── */
.why-section {
  background:var(--navy);
  padding:96px 0 100px;
  position:relative;overflow:hidden;
}
.why-inner {
  max-width:1320px;margin:0 auto;padding:0 40px;
  display:grid;grid-template-columns:1fr 1fr;
  gap:72px;align-items:center;
}
.why-points{display:flex;flex-direction:column;gap:0;}
.why-point {
  display:flex;gap:18px;
  padding:22px 0;
  border-bottom:1px solid rgba(255,255,255,0.07);
}
.why-point:last-child{border-bottom:none;padding-bottom:0;}
.why-num {
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:44px;
  color:var(--orange);line-height:1;
  flex-shrink:0;width:52px;
}
.why-title {
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:20px;text-transform:uppercase;
  color:#fff;margin-bottom:6px;letter-spacing:0.02em;
}
.why-desc{font-size:14px;color:rgba(255,255,255,0.6);line-height:1.72;}
.why-photo{position:relative;}
.why-photo img{width:100%;height:480px;object-fit:cover;display:block;}
.why-photo-badge{
  position:absolute;bottom:0;left:0;right:0;
  background:rgba(10,26,54,0.88);padding:14px 20px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:14px;text-transform:uppercase;
  letter-spacing:0.06em;color:rgba(255,255,255,0.9);
  display:flex;align-items:center;gap:10px;
}
.why-photo-badge::before{content:'';width:16px;height:2px;background:var(--orange);flex-shrink:0;}

/* ─── PAGE PROCESS (light bg) ─── */
.page-process {
  background:var(--off-white);
  padding:96px 0 100px;
  position:relative;overflow:hidden;
}
.page-process-inner{max-width:1320px;margin:0 auto;padding:0 40px;}
.page-process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:52px;}
.pp-step{
  padding:28px 24px;
  border-right:1px solid rgba(0,0,0,0.08);
  position:relative;
}
.pp-step:last-child{border-right:none;}
.pp-num{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:60px;line-height:1;
  color:var(--orange);letter-spacing:-0.02em;margin-bottom:12px;
}
.pp-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:20px;text-transform:uppercase;
  color:var(--navy);margin-bottom:8px;letter-spacing:0.02em;
}
.pp-desc{font-size:14px;color:#555;line-height:1.7;}

/* ─── GALLERY FULL (subpage) ─── */

.gallery-full-grid {
  max-width:1320px;margin:32px auto 0;padding:0 40px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:4px;
}
.gf-item {
  position:relative;overflow:hidden;
  height:300px;background:var(--navy-mid);cursor:pointer;
}
.gf-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.5s;filter:brightness(0.78);
}
.gf-item:hover img{transform:scale(1.06);filter:brightness(0.95);}

.gf-item.gf-hidden{display:none;}

/* ─── FAQ ACCORDION ─── */
.faq-section{
  background:var(--off-white);padding:80px 0 88px;
}
.faq-inner{max-width:820px;margin:0 auto;padding:0 40px;}
.faq-list{margin-top:48px;display:flex;flex-direction:column;gap:0;}
.faq-item{border-bottom:1px solid #ddd;}
.faq-item:first-child{border-top:1px solid #ddd;}
.faq-question{
  width:100%;background:none;border:none;text-align:left;
  padding:20px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;
  cursor:pointer;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:20px;text-transform:uppercase;
  color:var(--navy);letter-spacing:0.02em;transition:color 0.2s;
}
.faq-question:hover{color:var(--orange);}
.faq-icon{
  width:26px;height:26px;border-radius:50%;
  background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:18px;line-height:1;
  transition:background 0.2s,transform 0.3s;
  font-family:monospace;
}
.faq-item.open .faq-icon{background:var(--orange);transform:rotate(45deg);}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.4s ease;}
.faq-item.open .faq-answer{max-height:300px;}
.faq-answer-inner{
  padding:0 40px 22px 0;
  font-size:15px;color:#555;line-height:1.78;
}

/* ─── ABOUT PAGE ─── */

.values-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;margin-top:52px;
}
.value-card{
  padding:36px 24px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-top:3px solid var(--orange);
  text-align:center;
  transition:background 0.2s;
}
.value-card:hover{background:rgba(255,255,255,0.07);}
.value-icon{
  width:52px;height:52px;margin:0 auto 16px;
  background:rgba(232,93,26,0.14);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--orange);
}
.value-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:18px;text-transform:uppercase;
  color:#fff;margin-bottom:8px;
}
.value-desc{font-size:13px;color:rgba(255,255,255,0.55);line-height:1.65;}

/* ─── NAV ACTIVE PAGE ─── */
.nav-active{color:#fff !important;border-bottom-color:var(--orange) !important;}

/* ─── SUBPAGE RESPONSIVE ─── */
@media(max-width:1024px){
  .page-hero-inner{padding:0 28px;}
  .breakdown-inner{padding:0 28px;}
  .breakdown-grid{grid-template-columns:1fr 1fr;gap:16px;}
  .breakdown-grid-4{grid-template-columns:1fr 1fr;}
  .why-inner{grid-template-columns:1fr;gap:48px;padding:0 28px;}
  .page-process-inner{padding:0 28px;}
  .page-process-grid{grid-template-columns:1fr 1fr;gap:0;}
  .gallery-filters{padding:40px 28px 0;}
  .gallery-full-grid{grid-template-columns:1fr 1fr;padding:0 28px;}
  .faq-inner{padding:0 28px;}
  .about-story-inner{grid-template-columns:1fr;gap:48px;padding:0 28px;}
  .about-values-inner{padding:0 28px;}
  .values-grid{grid-template-columns:1fr 1fr;gap:16px;}
  .page-hero-geo,.page-hero-geo2{display:none;}
}
@media(max-width:768px){
  .page-hero{padding:200px 0 60px;min-height:320px;}
  .page-hero-inner{padding:0 20px;}
  .page-hero-h1{font-size:clamp(44px,10vw,68px);}
  .breakdown-grid,.breakdown-grid-4{grid-template-columns:1fr;}
  .breakdown-inner{padding:0 20px;}
  .why-inner{padding:0 20px;}
  .why-photo img{height:320px;}
  .page-process-inner{padding:0 20px;}
  .page-process-grid{grid-template-columns:1fr 1fr;}
  .pp-step{border-right:none;border-bottom:1px solid rgba(0,0,0,0.08);}
  .pp-step:nth-child(odd){border-right:1px solid rgba(0,0,0,0.08);}
  .gallery-filters{padding:32px 20px 0;}
  .gallery-full-grid{grid-template-columns:1fr 1fr;padding:0 20px;}
  .gf-item{height:200px;}
  .faq-inner{padding:0 20px;}
  .about-story-inner{padding:0 20px;}
  .about-values-inner{padding:0 20px;}
  .values-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:480px){
  .gallery-full-grid{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:1fr;}
  .page-process-grid{grid-template-columns:1fr;}
  .pp-step{border-right:none;}
}

/* ════════════════════════════════════════════════════════
   CONTACT PAGE
════════════════════════════════════════════════════════ */

/* Light-bg form overrides */
.contact-form .cf {
  background:#fff;
  border:1.5px solid #d8dce4;
  color:var(--navy);
  margin-bottom:0;
}
.contact-form .cf::placeholder{color:#aaa;}
.contact-form .cf:focus{border-color:var(--orange);background:#fff;box-shadow:0 0 0 3px rgba(232,93,26,0.12);}
.contact-form select.cf option{background:#fff;color:var(--navy);}

.cf-group{display:flex;flex-direction:column;gap:6px;}
.cf-label{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:13px;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--navy);
}
.contact-form .cf-row{gap:16px;margin-bottom:16px;}
.contact-form .cf-group{margin-bottom:16px;}

/* Contact info sidebar cards */
.contact-info-card{
  display:flex;align-items:flex-start;gap:18px;
  background:#fff;border-radius:8px;
  padding:22px 20px;
  border:1px solid #e8e8e8;
  border-left:4px solid var(--orange);
  box-shadow:0 2px 12px rgba(0,0,0,0.05);
}
.contact-info-icon{
  width:44px;height:44px;flex-shrink:0;
  background:var(--navy);border-radius:3px;
  display:flex;align-items:center;justify-content:center;
  color:var(--orange);
}
.contact-info-label{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:12px;letter-spacing:0.1em;text-transform:uppercase;
  color:#888;margin-bottom:3px;
}
.contact-info-value{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:20px;color:var(--navy);
  display:block;text-decoration:none;
  transition:color 0.2s;
}
a.contact-info-value:hover{color:var(--orange);}
.contact-info-note{font-size:13px;color:#888;margin-top:2px;}

/* Service area chips (static, light bg) */
.area-chip-static{
  display:inline-block;
  background:#fff;
  border:1.5px solid #d8dce4;
  border-radius:2px;
  padding:5px 12px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:13px;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--navy);
}

/* ── CONTACT PAGE RESPONSIVE ── */
@media(max-width:1024px){
  .contact-2col{grid-template-columns:1fr !important;}
}
@media(max-width:768px){
  .contact-2col{padding:0 20px !important;}
}

/* ════════════════════════════════════════════════════════
   GALLERY PAGE FILTER TABS
════════════════════════════════════════════════════════ */

/* Gallery full grid on light bg */
#gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:4px;
}
#gallery-grid .gf-item .g-label{display:none;}
#gallery-grid .gf-item:hover .g-label{display:none;}

@media(max-width:1024px){
  #gallery-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  #gallery-grid{grid-template-columns:1fr 1fr;}
  .gallery-filter-tabs{gap:6px;}
  .gf-tab{padding:8px 16px;font-size:13px;}
}
@media(max-width:480px){
  #gallery-grid{grid-template-columns:1fr;}
}

/* ════════════════════════════════════════════════════════
   ABOUT PAGE — inline grid responsive patch
════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .about-2col{grid-template-columns:1fr !important;padding:0 28px !important;}
  .certs-3-col{grid-template-columns:1fr 1fr !important;padding:0 28px !important;}
}
@media(max-width:768px){
  .about-2col{padding:0 20px !important;}
  .certs-3-col{grid-template-columns:1fr !important;padding:0 20px !important;}
}

/* ════════════════════════════════════════════════════════
   LIGHTBOX
════════════════════════════════════════════════════════ */
#lightbox{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity 0.25s ease;
}
#lightbox.open{opacity:1;pointer-events:all;}
#lb-backdrop{
  position:absolute;inset:0;
  background:rgba(5,12,26,0.94);
  backdrop-filter:blur(6px);
}
#lb-img-wrap{
  position:relative;z-index:1;
  max-width:90vw;max-height:88vh;
  display:flex;align-items:center;justify-content:center;
}
#lb-img{
  max-width:90vw;max-height:85vh;
  object-fit:contain;
  border-radius:3px;
  box-shadow:0 24px 80px rgba(0,0,0,0.7);
  opacity:0;transition:opacity 0.2s ease;
  display:block;
}
#lb-spinner{
  position:absolute;
  width:36px;height:36px;
  border:3px solid rgba(255,255,255,0.15);
  border-top-color:#D4622A;
  border-radius:50%;
  animation:lbSpin 0.7s linear infinite;
  display:none;
}
@keyframes lbSpin{ to{transform:rotate(360deg);} }
#lb-close{
  position:absolute;top:20px;right:24px;z-index:2;
  background:rgba(255,255,255,0.1);border:1.5px solid rgba(255,255,255,0.2);
  color:#fff;font-size:28px;line-height:1;
  width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.2s;cursor:pointer;
}
#lb-close:hover{background:var(--orange);border-color:var(--orange);}
#lb-prev,#lb-next{
  position:absolute;top:50%;transform:translateY(-50%);z-index:2;
  background:rgba(255,255,255,0.1);border:1.5px solid rgba(255,255,255,0.2);
  color:#fff;font-size:36px;line-height:1;
  width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.2s;cursor:pointer;
}
#lb-prev{left:20px;}
#lb-next{right:20px;}
#lb-prev:hover,#lb-next:hover{background:var(--orange);border-color:var(--orange);}
#lb-counter{
  position:absolute;bottom:20px;left:50%;transform:translateX(-50%);z-index:2;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:14px;letter-spacing:0.1em;
  color:rgba(255,255,255,0.5);
}
@media(max-width:600px){
  #lb-prev{left:8px;width:44px;height:44px;font-size:28px;}
  #lb-next{right:8px;width:44px;height:44px;font-size:28px;}
  #lb-close{top:12px;right:12px;}
}

/* ════════════════════════════════════════════════════════
   FORM VALIDATION STATES
════════════════════════════════════════════════════════ */
.cf-invalid{
  border-color:#e53e3e !important;
  box-shadow:0 0 0 3px rgba(229,62,62,0.18) !important;
}
.cf-err{
  font-size:12px;color:#fc8181;font-weight:600;
  margin-top:4px;margin-bottom:2px;
  letter-spacing:0.02em;
}
.cf-success{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;
  padding:56px 32px;gap:16px;min-height:320px;
}
.cf-success-icon{
  width:72px;height:72px;border-radius:50%;
  background:rgba(232,93,26,0.15);
  border:2px solid var(--orange);
  display:flex;align-items:center;justify-content:center;
  color:var(--orange);margin-bottom:8px;
}
.cf-success-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:32px;
  text-transform:uppercase;color:#fff;letter-spacing:0.04em;
}
.cf-success-sub{
  font-size:15px;color:rgba(255,255,255,0.65);
  line-height:1.6;max-width:320px;
}

/* ════════════════════════════════════════════════════════
   REDUCED MOTION — respect user OS preference
════════════════════════════════════════════════════════ */
@media(prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
  }
  .marquee-track{animation:none;width:100%;flex-wrap:wrap;height:auto;padding:12px 0;}
  html{scroll-behavior:auto;}
}

/* ════════════════════════════════════════════════════════
   GAF LOGO IN STATS
════════════════════════════════════════════════════════ */
.stat-gaf{display:flex;align-items:center;justify-content:center;padding:4px 0;}
.stat-gaf img{width:56px;height:56px;object-fit:contain;}

/* ════════════════════════════════════════════════════════
   GALLERY ZOOM HOVER CUE
════════════════════════════════════════════════════════ */
.g-item,.gf-item{position:relative;overflow:hidden;}
.g-item::after,.gf-item::after{
  content:'';
  position:absolute;inset:0;
  background:rgba(10,26,54,0);
  transition:background 0.25s;
  pointer-events:none;
  z-index:1;
}
.g-item:hover::after,.gf-item:hover::after{
  background:rgba(10,26,54,0.32);
}
/* Zoom circle using before pseudo on the item */
.g-item::before,.gf-item::before{
  content:'';
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%) scale(0.6);
  z-index:2;
  width:52px;height:52px;border-radius:50%;
  background:rgba(255,255,255,0.95)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%230d1f3c' stroke-width='2.5' stroke-linecap='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3Cline x1='11' y1='8' x2='11' y2='14'/%3E%3Cline x1='8' y1='11' x2='14' y2='11'/%3E%3C/svg%3E")
    center/22px no-repeat;
  opacity:0;
  transition:opacity 0.25s,transform 0.25s;
  pointer-events:none;
}
.g-item:hover::before,.gf-item:hover::before{
  opacity:1;transform:translate(-50%,-50%) scale(1);
}

/* ════════════════════════════════════════════════════════
   SOCIAL PROOF — bolder stars
════════════════════════════════════════════════════════ */
.sp-star{color:#f4a40a;font-size:22px;line-height:1;text-shadow:0 1px 4px rgba(244,164,10,0.3);}
.sp-review-text{font-size:15px;font-weight:700;color:#222;}

/* ════════════════════════════════════════════════════════
   FLOATING MOBILE CALL BUTTON
════════════════════════════════════════════════════════ */
.mobile-call-fab{
  display:none;
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  z-index:1100;
  background:var(--orange);color:#fff;
  border-radius:100px;
  padding:14px 28px;
  align-items:center;gap:10px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:18px;letter-spacing:0.06em;text-transform:uppercase;
  box-shadow:0 8px 32px rgba(232,93,26,0.55),0 2px 8px rgba(0,0,0,0.3);
  transition:transform 0.2s,box-shadow 0.2s;
  white-space:nowrap;
  text-decoration:none;
}
.mobile-call-fab:active{transform:translateX(-50%) scale(0.96);}
@media(max-width:768px){
  .mobile-call-fab{display:flex;}
  /* Push back-to-top up so it doesn't overlap */
  #back-to-top{bottom:84px;}
}

/* ════════════════════════════════════════
   COMPARISON PAGE STYLES (2l-vs-*.html)
══════════════════════════════════════════ */

/* Verdict band — sits right under the page-hero */

/* Section wrapper for the table + deep-dive sections */

/* The comparison table itself */

/* Status pills inside cells */

/* Deep-dive sections — alternating dark/light */

.cmp-deep--alt{background:var(--navy);color:#fff;}
.cmp-deep--alt .section-h2--dark{color:#fff;}
.cmp-deep--alt .section-tag{color:var(--orange-light);}
.cmp-deep--alt .section-tag::before{background:var(--orange-light);}

.cmp-deep-inner--reverse{grid-template-columns:0.8fr 1.2fr;}
.cmp-deep-inner--reverse .cmp-deep-text{order:2;}
.cmp-deep-inner--reverse .cmp-deep-card{order:1;}

.cmp-deep--alt .cmp-deep-text p{color:rgba(255,255,255,0.82);}
.cmp-deep--alt .cmp-deep-text strong{color:var(--orange-light);}

/* Deep-dive card — checklist sidebar */

.cmp-deep-card--light{
  background:linear-gradient(135deg, #fff 0%, var(--off-white) 100%);
  color:var(--navy);
  box-shadow:0 22px 60px rgba(7,18,36,0.12);
  border-top-color:var(--orange);
}
.cmp-deep-card--light .cmp-deep-card-num{color:rgba(13,31,60,0.10);}
.cmp-deep-card--light .cmp-deep-list li{color:rgba(13,31,60,0.82);border-bottom-color:rgba(13,31,60,0.08);}
.cmp-deep-card--light .cmp-deep-list li::before{color:var(--orange);}

/* Best-for split */

.cmp-bestfor-card--2l{
  border-top-color:var(--orange);
  background:linear-gradient(180deg, #fff 0%, rgba(232,93,26,0.04) 100%);
  box-shadow:0 22px 60px rgba(232,93,26,0.18), 0 2px 6px rgba(7,18,36,0.08);
}
.cmp-bestfor-card--2l::after{
  content:'Recommended if it fits you';
  position:absolute;top:-14px;right:24px;
  background:var(--orange);color:#fff;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;
  padding:5px 14px;border-radius:2px;
  box-shadow:0 6px 16px rgba(232,93,26,0.4);
}

.cmp-bestfor-card--other .cmp-bestfor-eyebrow{color:rgba(13,31,60,0.55);}

/* Methodology disclosure */

/* ── Comparison page responsive ── */
@media(max-width:1024px){
  .cmp-deep-inner,
  .cmp-deep-inner--reverse{grid-template-columns:1fr;gap:40px;padding:0 28px;}
  .cmp-deep-inner--reverse .cmp-deep-text{order:0;}
  .cmp-deep-inner--reverse .cmp-deep-card{order:0;}
  .cmp-section-inner,.cmp-bestfor-inner,.cmp-verdict-inner{padding:0 28px;}
  .cmp-bestfor-grid{grid-template-columns:1fr;}
}
@media(max-width:768px){
  .cmp-section{padding:64px 0 56px;}
  .cmp-deep{padding:64px 0;}
  .cmp-bestfor{padding:64px 0;}
  .cmp-verdict{padding:48px 0;}
  .cmp-verdict-inner,.cmp-section-inner,.cmp-bestfor-inner{padding:0 20px;}
  .cmp-deep-inner,.cmp-deep-inner--reverse{padding:0 20px;}
  .cmp-verdict-body{font-size:17px;}
  .cmp-verdict-pick{font-size:15px;}

  /* Stack the table into per-criterion cards on mobile */
  .cmp-table-wrap{box-shadow:none;border:none;background:transparent;}
  .cmp-table thead{display:none;}
  .cmp-table,
  .cmp-table tbody,
  .cmp-table tr,
  .cmp-table th,
  .cmp-table td{display:block;width:100%;}
  .cmp-table tr{
    background:#fff;border-radius:4px;
    margin-bottom:14px;
    box-shadow:0 6px 18px rgba(7,18,36,0.08);
    overflow:hidden;
    border:1px solid rgba(13,31,60,0.08);
  }
  .cmp-table tbody th{
    background:var(--navy);color:#fff;
    font-family:'Barlow Condensed',sans-serif;
    font-weight:800;font-size:13px;letter-spacing:0.1em;text-transform:uppercase;
    padding:12px 16px;width:auto;
  }
  .cmp-table tbody td{
    padding:12px 16px;
    font-size:14px;
    border-bottom:1px solid rgba(13,31,60,0.06);
    border-left:none;
  }
  .cmp-table tbody td:first-of-type{
    border-left:none;
    background:rgba(232,93,26,0.05);
  }
  .cmp-table tbody td:first-of-type::before{
    content:'2L Home Improvement';
    display:block;
    font-family:'Barlow Condensed',sans-serif;
    font-weight:800;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
    color:var(--orange);margin-bottom:6px;
  }
  .cmp-table tbody td:last-of-type::before{
    content:'Alan Kunsman Roofing';
    display:block;
    font-family:'Barlow Condensed',sans-serif;
    font-weight:800;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
    color:rgba(13,31,60,0.5);margin-bottom:6px;
  }
}

/* ════════════════════════════════════════
   PAGE LOADER (full-screen, fades on load)
══════════════════════════════════════════ */
.page-loader{
  position:fixed;inset:0;z-index:99999;
  background:
    radial-gradient(ellipse at center, var(--navy-mid) 0%, var(--navy-deep) 70%, #04091c 100%),
    var(--navy-deep);
  display:flex;align-items:center;justify-content:center;
  opacity:1;visibility:visible;
  transition:opacity 0.55s ease, visibility 0s linear 0.55s;
}
.page-loader.is-loaded{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
}
.page-loader-inner{
  display:flex;flex-direction:column;align-items:center;gap:32px;
  padding:0 24px;
  animation: pl-breathe 2.2s ease-in-out infinite;
}
.page-loader-logo{
  width:320px;height:auto;max-width:64vw;
  filter:drop-shadow(0 12px 28px rgba(0,0,0,0.55));
}
.page-loader-bar{
  width:220px;height:3px;
  background:rgba(255,255,255,0.08);
  border-radius:2px;overflow:hidden;
  position:relative;
}
.page-loader-bar::before{
  content:'';
  position:absolute;left:0;top:0;bottom:0;width:55%;
  background:linear-gradient(90deg,
    transparent 0%,
    var(--orange) 30%,
    var(--orange-light) 50%,
    var(--orange) 70%,
    transparent 100%);
  border-radius:2px;
  box-shadow:0 0 16px rgba(232,93,26,0.55);
  animation: pl-slide 1.4s cubic-bezier(0.4,0,0.6,1) infinite;
}
.page-loader-text{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:11px;letter-spacing:0.32em;text-transform:uppercase;
  color:rgba(255,255,255,0.45);
}
@keyframes pl-breathe{
  0%,100%{ transform:scale(1);   opacity:1;   }
  50%    { transform:scale(1.02); opacity:0.92; }
}
@keyframes pl-slide{
  0%   { transform:translateX(-100%); }
  100% { transform:translateX(280%);  }
}
@media (prefers-reduced-motion: reduce){
  .page-loader-inner{animation:none;}
  .page-loader-bar::before{
    animation:none;
    transform:none;
    left:0;width:100%;
    background:var(--orange);
  }
  .page-loader{transition:opacity 0.2s ease, visibility 0s linear 0.2s;}
}
