
:root{
  --bg:#081008;
  --bg-soft:#0d160d;
  --panel:#111b11;
  --text:#eef7ee;
  --muted:#b8c9b8;
  --line:#223623;
  --green:#19d11a;
  --green-2:#42dd3e;
  --green-dark:#11990f;
  --green-soft:rgba(31,194,27,.12);
  --shadow:0 18px 45px rgba(0,0,0,.28);
  --radius:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',Arial,sans-serif;
  background:
    radial-gradient(circle at 10% 10%, rgba(31,194,27,.08), transparent 24%),
    radial-gradient(circle at 90% 15%, rgba(31,194,27,.06), transparent 22%),
    radial-gradient(circle at 50% 100%, rgba(31,194,27,.05), transparent 28%),
    linear-gradient(180deg, #0b110b 0%, #070b07 100%);
  color:var(--text);
  line-height:1.6;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{width:min(1160px, calc(100% - 32px)); margin:0 auto}
.center{text-align:center}
.stack > * + *{margin-top:14px}

.topbar{background:#060a06;border-bottom:1px solid var(--line);font-size:14px}
.topbar-inner{min-height:44px;display:flex;align-items:center;justify-content:space-between;gap:16px;color:var(--muted)}
.phone-link{color:#9df19b;font-weight:800;white-space:nowrap;position:relative}
.phone-link::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:linear-gradient(90deg, transparent, rgba(157,241,155,.9), transparent);animation:topbarGlow 2.4s ease-in-out infinite}

.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(8,12,8,.92); backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.04);
  box-shadow:0 10px 28px rgba(0,0,0,.25), inset 0 -1px 0 rgba(31,194,27,.12);
}
.header-inner{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;min-height:88px;
}
.brand{display:flex;align-items:center;gap:14px}
.logo{width:58px;height:58px;object-fit:contain;border-radius:16px;background:#fff;padding:4px;box-shadow:var(--shadow)}
.brand-text{display:flex;flex-direction:column}
.brand-text strong{font-size:18px;line-height:1.1}
.brand-text span{font-size:12px;color:var(--muted)}

.main-nav{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.main-nav > a,.nav-link-main,.nav-drop-toggle{
  font-weight:700;color:var(--text);background:none;border:none;font:inherit;cursor:pointer;
  padding:10px 14px;border-radius:999px;display:inline-flex;align-items:center
}
.main-nav > a:hover,.nav-link-main:hover,.nav-drop-toggle:hover{background:rgba(31,194,27,.08);color:#a4f2a2}
.nav-dropdown{position:relative;display:flex;align-items:center;gap:2px}
.nav-drop-toggle{padding:10px 10px}
.nav-dropdown-menu{
  position:absolute;top:calc(100% + 10px);left:0;min-width:270px;display:none;flex-direction:column;gap:6px;
  padding:12px;background:linear-gradient(180deg, rgba(22,30,22,.98), rgba(11,16,11,.98));
  border:1px solid rgba(80,130,80,.24);border-radius:18px;box-shadow:0 18px 45px rgba(0,0,0,.28)
}
.nav-dropdown.open .nav-dropdown-menu{display:flex}
.nav-dropdown-menu a{padding:10px 12px;border-radius:12px}
.nav-dropdown-menu a:hover{background:rgba(31,194,27,.1);color:#9df19b}

.header-socials,.footer-socials,.social-links{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.header-socials a,.footer-socials a,.social-links a{
  width:42px;height:42px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(31,194,27,.22);
  background:linear-gradient(180deg, rgba(20,28,20,.96), rgba(10,15,10,.96));
  color:var(--text); box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
  transition:.2s ease;
}
.header-socials a:hover,.footer-socials a:hover,.social-links a:hover{color:#9df19b;border-color:rgba(31,194,27,.4);transform:translateY(-1px)}
.menu-toggle{display:none;background:none;border:1px solid var(--line);color:var(--text);font-size:24px;border-radius:12px;padding:8px 12px}

.hero,.page-hero{position:relative;overflow:hidden}
.hero{min-height:80vh;display:grid;place-items:center}
.hero-bg,.hero-overlay,.page-banner-overlay{position:absolute;inset:0}
.hero-bg{background-position:center;background-size:cover;transform:scale(1.03);filter:saturate(.95) contrast(1.05)}
.hero-overlay,.page-banner-overlay{
  background:linear-gradient(90deg, rgba(4,8,4,.86) 0%, rgba(4,8,4,.56) 48%, rgba(4,8,4,.70) 100%), radial-gradient(circle at center, rgba(31,194,27,.08), transparent 55%);
}
.hero-content,.page-hero-content{position:relative;z-index:2}
.hero-content{padding:90px 0;max-width:760px}
.hero-panel,.page-hero-content{
  background:linear-gradient(180deg, rgba(8,12,8,.34), rgba(8,12,8,.18));
  border:1px solid rgba(31,194,27,.10);backdrop-filter:blur(4px);border-radius:26px;padding:36px;
  box-shadow:0 16px 38px rgba(0,0,0,.22)
}
.page-banner{min-height:360px;display:grid;place-items:end start;background-image:var(--page-banner);background-size:cover;background-position:center}
.page-hero-content{padding:100px 0 46px;max-width:760px;margin-bottom:26px}
.eyebrow,.section-tag{display:inline-flex;align-items:center;gap:8px;background:var(--green-soft);border:1px solid rgba(31,194,27,.22);color:#a1f29e;border-radius:999px;padding:9px 13px;font-size:13px;font-weight:800}
.hero h1,.page-hero h1{font-size:clamp(38px,6vw,68px);line-height:1.02;margin:18px 0 14px;max-width:12ch}
.hero p,.page-hero p{color:var(--muted);font-size:clamp(17px,2vw,20px);max-width:650px}
.hero-actions,.banner-actions,.zip-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}

.btn{
  display:inline-flex;justify-content:center;align-items:center;gap:10px;border:none;cursor:pointer;font:inherit;font-weight:800;
  border-radius:16px;padding:15px 22px;transition:transform .18s ease, box-shadow .18s ease, background .18s ease
}
.btn:hover{transform:translateY(-1px)}
.btn-primary,.btn-call,.nav-cta,.footer-cta,.contact-call,.floating-call{
  background:linear-gradient(180deg, var(--green-2), var(--green-dark));
  color:#051005 !important;
  box-shadow:0 14px 30px rgba(31,194,27,.24),0 0 0 1px rgba(31,194,27,.18),inset 0 1px 0 rgba(255,255,255,.14);
}
.btn-secondary{background:rgba(255,255,255,.03);border:1px solid var(--line);color:var(--text)}
.full{width:100%}

.cta-attention{position:relative;overflow:hidden;isolation:isolate;transition:transform .22s ease, box-shadow .22s ease}
.cta-attention:hover{transform:translateY(-2px) scale(1.01)}
.cta-text{position:relative;z-index:2}
.cta-shine{position:absolute;top:0;left:-34%;width:28%;height:100%;background:linear-gradient(90deg, transparent, rgba(255,255,255,.28), transparent);transform:skewX(-20deg);animation:ctaShine 3.2s ease-in-out infinite;z-index:1;pointer-events:none}
.pulse-ring::before{content:"";position:absolute;inset:-4px;border-radius:inherit;border:1px solid rgba(111,255,107,.28);opacity:0;transform:scale(.96);animation:pulseRing 2.2s ease-out infinite;pointer-events:none}
.nav-cta,.contact-call,.footer-cta{animation:ctaBreath 2.8s ease-in-out infinite}
@keyframes ctaShine{0%,72%{left:-35%;opacity:0}78%{opacity:.85}100%{left:120%;opacity:0}}
@keyframes pulseRing{0%{opacity:0;transform:scale(.94)}12%{opacity:.7}100%{opacity:0;transform:scale(1.12)}}
@keyframes topbarGlow{0%,100%{opacity:.35;transform:scaleX(.86)}50%{opacity:1;transform:scaleX(1)}}
@keyframes ctaBreath{0%,100%{box-shadow:0 14px 30px rgba(31,194,27,.20),0 0 0 1px rgba(31,194,27,.16),inset 0 1px 0 rgba(255,255,255,.12)}50%{box-shadow:0 18px 36px rgba(31,194,27,.30),0 0 0 1px rgba(31,194,27,.24),inset 0 1px 0 rgba(255,255,255,.18)}}

.section{padding:82px 0;position:relative;border-top:1px solid rgba(31,194,27,.06)}
.section::before,.site-footer::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg, transparent 0%, rgba(31,194,27,.035) 50%, transparent 100%);opacity:.55}
.section.alt{background:linear-gradient(180deg, rgba(17,26,17,.98), rgba(10,16,10,.98));border-bottom:1px solid rgba(255,255,255,.03)}
.section-heading{max-width:760px;margin:0 auto 28px}
.section-heading p{color:var(--muted)}

.cards{display:grid;gap:20px}
.cards-4{grid-template-columns:repeat(4,1fr)}
.cards-1{grid-template-columns:1fr}
.card,.team-card,.compare-card,.feature-panel,.banner-card,.contact-card.big,.estimate-form,.mini-card,.service-area-card{
  background:linear-gradient(180deg, rgba(22,30,22,.98), rgba(11,16,11,.98));
  border:1px solid rgba(80,130,80,.24);box-shadow:0 18px 45px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.03), inset 0 0 0 1px rgba(31,194,27,.05);border-radius:var(--radius);position:relative
}
.card,.team-card,.feature-panel,.banner-card,.contact-card.big,.estimate-form,.service-area-card{padding:28px}
.card::before,.team-card::before,.feature-panel::before,.banner-card::before,.contact-card.big::before,.estimate-form::before,.mini-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;background:linear-gradient(135deg, rgba(31,194,27,.06), transparent 35%),linear-gradient(315deg, rgba(255,255,255,.02), transparent 40%)
}
.split-intro,.form-layout,.contact-layout,.two-col,.service-detail-grid,.service-area-page{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:start}
.service-card{display:block;transition:.25s ease}
.service-card:hover,.team-card:hover,.banner-card:hover{transform:translateY(-4px);border-color:rgba(31,194,27,.4)}
.service-card::after{content:"";position:absolute;inset:auto 0 0 0;height:4px;background:linear-gradient(90deg, rgba(31,194,27,0) 0%, rgba(31,194,27,.85) 50%, rgba(31,194,27,0) 100%)}
.service-icon{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:rgba(31,194,27,.12);border:1px solid rgba(31,194,27,.22);color:#9cf49a;font-size:22px;margin-bottom:16px}
.icon-list{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:14px}
.icon-list li{display:flex;gap:14px;align-items:flex-start}
.icon-list i,.mini-card i,.contact-link i{color:#93ee8f;margin-top:4px}

.clean-slider,.slider{position:relative;overflow:hidden;background:transparent;height:520px;border-radius:22px}
.clean-slider::before,.slider::before{content:"";position:absolute;inset:0;background:rgba(11,15,12,.18);border-radius:22px;z-index:0}
.slide{position:absolute;inset:8px;width:calc(100% - 16px);height:calc(100% - 16px);object-fit:cover;object-position:center center;background:transparent;opacity:0;transition:opacity .7s ease;z-index:1;border-radius:18px}
.slide.active{opacity:1}

.team-grid{display:grid;gap:20px}
.team-grid-7{grid-template-columns:repeat(4,1fr)}
.team-card img{width:100%;height:320px;object-fit:cover;object-position:center top;border-radius:18px}
.slot-card{opacity:0;transform:translateY(-180px) scale(.92);filter:blur(8px)}
.slot-card.revealed{animation:slotDrop 1s cubic-bezier(.17,.89,.32,1.28) forwards}
.team-grid .slot-card:nth-child(1).revealed{animation-delay:.05s}
.team-grid .slot-card:nth-child(2).revealed{animation-delay:.12s}
.team-grid .slot-card:nth-child(3).revealed{animation-delay:.19s}
.team-grid .slot-card:nth-child(4).revealed{animation-delay:.26s}
.team-grid .slot-card:nth-child(5).revealed{animation-delay:.33s}
.team-grid .slot-card:nth-child(6).revealed{animation-delay:.40s}
.team-grid .slot-card:nth-child(7).revealed{animation-delay:.47s}
@keyframes slotDrop{0%{opacity:0;transform:translateY(-220px) scale(.85);filter:blur(10px)}35%{opacity:1;transform:translateY(18px) scale(1.02);filter:blur(1px)}55%{transform:translateY(-10px) scale(.99)}72%{transform:translateY(6px) scale(1.01)}100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease}
.reveal.revealed{opacity:1;transform:translateY(0)}

.estimate-form label{display:block;font-weight:700;margin-bottom:14px}
input,select,textarea{width:100%;margin-top:8px;background:#0b100b;border:1px solid var(--line);color:var(--text);border-radius:14px;padding:14px 15px;font:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:rgba(31,194,27,.45);box-shadow:0 0 0 3px rgba(31,194,27,.12)}
textarea{min-height:160px;resize:vertical}
.hidden-field{display:none}
.mini-card{display:flex;gap:16px;align-items:flex-start;padding:18px 20px}
.mini-card strong{display:block}.mini-card span{display:block;color:var(--muted)}
.contact-link{display:flex;align-items:center;gap:12px;font-weight:700}
.contact-call{padding:14px 16px;border-radius:18px}

.service-area-page{align-items:center}
.zip-result{margin-top:12px;color:var(--muted)} .zip-result.success{color:#9df19b} .zip-result.error{color:#ffd5b8}
.image-map-wrap,.florida-wrap{
  position:relative;overflow:hidden;width:min(430px,100%);margin:0 auto;display:flex;align-items:center;justify-content:center;
  border-radius:16px;border:1px solid rgba(31,194,27,.08);transition:box-shadow .28s ease,border-color .28s ease,filter .28s ease,background .28s ease;
}
.florida-map-image{
  width:100%;height:auto;display:block;background:transparent !important;
  opacity:.92;filter:brightness(1.04) contrast(1.02);
}
.image-map-wrap.active,.florida-wrap.active{
  border-color:rgba(76,255,71,.38);
  background:rgba(20,40,20,.18);
  box-shadow:0 0 24px rgba(31,194,27,.18), 0 0 55px rgba(31,194,27,.10), inset 0 0 55px rgba(76,255,71,.12);
}
.image-map-wrap.active .florida-map-image,.florida-wrap.active .florida-map-image{
  filter:hue-rotate(55deg) saturate(1.6) brightness(1.08) contrast(1.06);
  opacity:1;
}
.map-pin,.zip-chip-wrap{display:none !important}

.site-footer{border-top:1px solid var(--line);margin-top:40px;background:radial-gradient(circle at top left, rgba(31,194,27,.07), transparent 30%),linear-gradient(180deg, #090d09, #060906);position:relative}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:24px;padding:42px 0;align-items:start
}
.site-footer h3,.site-footer h4{margin:0 0 12px}
.site-footer p,.site-footer span,.site-footer a{color:var(--muted);display:block;margin-bottom:8px}
.site-footer a:hover{color:var(--green)}
.footer-badge-wrap{margin-top:18px;display:flex;justify-content:flex-start}
.footer-badge{width:105px;max-width:35vw;opacity:.95;filter:drop-shadow(0 10px 18px rgba(0,0,0,.45))}
.footer-bottom{border-top:1px solid var(--line);padding:16px;text-align:center;color:var(--muted);font-size:14px}
.floating-call{position:fixed;right:18px;bottom:18px;z-index:60;padding:14px 18px;border-radius:999px;font-weight:800;display:inline-flex;align-items:center;gap:10px}

@media (max-width:1100px){
  .cards-4{grid-template-columns:repeat(2,1fr)}
  .team-grid-7{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:980px){
  .split-intro,.form-layout,.contact-layout,.two-col,.service-detail-grid,.service-area-page{grid-template-columns:1fr}
  .header-inner{grid-template-columns:auto auto;gap:12px}
  .header-socials{justify-self:end}
  .main-nav{
    grid-column:1 / -1;position:absolute;left:16px;right:16px;top:calc(100% + 8px);display:none;flex-direction:column;align-items:stretch;
    background:#0d120d;border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:var(--shadow)
  }
  .main-nav.open{display:flex}
  .nav-dropdown{display:block}
  .nav-drop-toggle{padding:10px 12px}
  .nav-dropdown-menu{position:static;display:none;margin-top:8px;min-width:unset}
  .nav-dropdown.open .nav-dropdown-menu{display:flex}
  .menu-toggle{display:block}
}
@media (max-width:760px){
  .section{padding:42px 0}
  .container{width:min(100% - 20px, 1160px)}
  .topbar{font-size:12px}
  .topbar-inner{flex-direction:column;align-items:flex-start;padding:10px 0}
  .hero-panel,.page-hero-content{padding:24px;border-radius:20px}
  .hero{min-height:72vh}
  .hero h1,.page-hero h1{max-width:100%}
  .hero-actions,.banner-actions,.zip-row{flex-direction:column;align-items:stretch}
  .team-grid-7,.cards-4{grid-template-columns:1fr}
  .team-card img{height:280px}
  .clean-slider,.slider{height:300px;padding:8px;border-radius:18px}
  .slide{inset:8px;width:calc(100% - 16px);height:calc(100% - 16px);object-fit:contain}
  .header-socials a,.footer-socials a,.social-links a{width:36px;height:36px}
  .footer-grid{grid-template-columns:1fr;gap:10px;padding:28px 0}
  .site-footer h4{margin-top:8px}
  .footer-badge-wrap{justify-content:center}
  .floating-call{right:12px;bottom:12px;padding:12px 14px}
  .floating-call span{display:none}
  .image-map-wrap,.florida-wrap{width:min(320px,100%)}
}
@media (max-width:480px){
  .clean-slider,.slider{height:240px}
  .feature-panel,.banner-card,.contact-card.big,.estimate-form,.service-area-card,.card,.team-card{padding:20px}
}


.nav-cta{
  background:#19d11a !important;
  color:#041004 !important;
  border:2px solid #4cff47 !important;
  box-shadow:0 0 0 1px rgba(76,255,71,.18),0 10px 24px rgba(25,209,26,.34),0 0 18px rgba(25,209,26,.18) !important;
}
.nav-cta:hover{
  background:#23e024 !important;
  color:#041004 !important;
}
.site-header .nav-cta .cta-text{
  color:#041004 !important;
}

.image-map-wrap{position:relative}
.map-overlay-text{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%) scale(.92);
  width:min(82%,290px);
  text-align:center;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(7,12,7,.72);
  border:1px solid rgba(255,255,255,.08);
  color:#eef7ee;
  font-weight:700;
  line-height:1.35;
  box-shadow:0 16px 32px rgba(0,0,0,.22);
  opacity:0;
  pointer-events:none;
  transition:opacity .28s ease, transform .28s ease, background .28s ease, border-color .28s ease;
  backdrop-filter:blur(4px);
}
.map-overlay-text.show{
  opacity:1;
  transform:translate(-50%,-50%) scale(1);
}
.map-overlay-text.success{
  background:rgba(20,56,20,.74);
  border-color:rgba(76,255,71,.34);
  color:#dfffe0;
}
.map-overlay-text.error{
  background:rgba(42,20,20,.76);
  border-color:rgba(255,155,155,.26);
  color:#fff1f1;
}
@media (max-width:760px){
  .map-overlay-text{
    width:min(86%,250px);
    padding:12px 14px;
    font-size:14px;
  }
}


.section-heading.center{
  text-align:center;
}

.service-links,
.quick-service-links{
  display:flex;
  justify-content:center;
  align-items:center;
  flex-wrap:wrap;
  gap:12px;
  text-align:center;
}

.quick-service-links a,
.service-links a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.footer-credit{
  color:#9df19b;
  font-weight:700;
  margin-left:8px;
}

.mini-card .btn{
  margin-top:10px;
}


/* Cinergy green map tint override */
.florida-map-image,
.service-map img,
.map-image,
.area-map img {
  filter: brightness(0.88) saturate(1.25) hue-rotate(-32deg) contrast(1.12) !important;
  opacity: 0.96;
}

.area-map.served .florida-map-image,
.service-map.served img,
.area-map img.served {
  filter: brightness(1) saturate(1.45) hue-rotate(-36deg) contrast(1.1)
          drop-shadow(0 0 16px rgba(49, 201, 67, 0.55)) !important;
}


/* Homepage Google reviews section */
.reviews-home-section .section-heading{
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:20px;
  margin-top:24px;
}
.review-card{
  background:linear-gradient(180deg, rgba(22,30,22,.98), rgba(11,16,11,.98));
  border:1px solid rgba(80,130,80,.24);
  border-radius:24px;
  padding:24px;
  box-shadow:0 18px 45px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.03), inset 0 0 0 1px rgba(31,194,27,.05);
}
.review-stars{
  color:#7dff74;
  font-size:20px;
  letter-spacing:2px;
  margin-bottom:14px;
}
.review-card p{
  margin:0 0 14px;
  color:var(--text);
}
.review-card strong{
  color:#bfe8bf;
}
@media (max-width: 980px){
  .reviews-grid{
    grid-template-columns:1fr;
  }
}


/* Actual Google reviews section */
.reviews-home-section .section-heading{
  max-width:760px;
  margin-left:auto;
  margin-right:auto;
}
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:20px;
  margin-top:24px;
}
.review-card{
  background:linear-gradient(180deg, rgba(22,30,22,.98), rgba(11,16,11,.98));
  border:1px solid rgba(80,130,80,.24);
  border-radius:24px;
  padding:24px;
  box-shadow:0 18px 45px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.03), inset 0 0 0 1px rgba(31,194,27,.05);
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.review-card:hover{
  transform:translateY(-4px);
  border-color:rgba(31,194,27,.4);
}
.review-stars{
  color:#7dff74;
  font-size:20px;
  letter-spacing:2px;
  margin-bottom:14px;
}
.review-card p{
  margin:0 0 14px;
  color:var(--text);
}
.review-card strong{
  color:#bfe8bf;
}
.reviews-cta-wrap{
  display:flex;
  justify-content:center;
  margin-top:24px;
}

/* slide-in animation for reviews */
.review-slide{
  opacity:0;
  transform:translateX(-34px);
}
.review-slide.revealed{
  animation:reviewSlideIn .75s ease forwards;
}
.reviews-grid .review-slide:nth-child(2).revealed{animation-delay:.08s;}
.reviews-grid .review-slide:nth-child(3).revealed{animation-delay:.16s;}
.reviews-grid .review-slide:nth-child(4).revealed{animation-delay:.24s;}
.reviews-grid .review-slide:nth-child(5).revealed{animation-delay:.32s;}

@keyframes reviewSlideIn{
  0%{
    opacity:0;
    transform:translateX(-34px);
  }
  100%{
    opacity:1;
    transform:translateX(0);
  }
}

@media (max-width: 980px){
  .reviews-grid{
    grid-template-columns:1fr;
  }
}


/* Reviews slideshow upgrade */
.reviews-slideshow{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:16px;
  margin-top:24px;
}
.reviews-track-wrap{
  overflow:hidden;
  width:100%;
}
.reviews-track{
  display:flex;
  transition:transform .6s ease;
  will-change:transform;
}
.review-card{
  min-width:100%;
  margin:0;
  background:linear-gradient(180deg, rgba(22,30,22,.98), rgba(11,16,11,.98));
  border:1px solid rgba(80,130,80,.24);
  border-radius:26px;
  padding:28px;
  box-shadow:
    0 18px 45px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.03),
    inset 0 0 0 1px rgba(31,194,27,.05);
}
.review-card p{
  font-size:17px;
  line-height:1.72;
}
.review-card strong{
  display:inline-block;
  margin-top:6px;
}
.reviews-nav{
  width:46px;
  height:46px;
  border-radius:999px;
  border:1px solid rgba(31,194,27,.24);
  background:linear-gradient(180deg, rgba(20,28,20,.98), rgba(10,15,10,.98));
  color:#dff8df;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
  box-shadow:0 8px 18px rgba(0,0,0,.22);
}
.reviews-nav:hover{
  transform:translateY(-2px);
  border-color:rgba(76,255,71,.42);
  box-shadow:0 12px 24px rgba(31,194,27,.16);
}
.reviews-dots{
  display:flex;
  justify-content:center;
  gap:10px;
  margin-top:18px;
}
.review-dot{
  width:11px;
  height:11px;
  border-radius:999px;
  border:none;
  background:rgba(255,255,255,.18);
  cursor:pointer;
  transition:transform .2s ease, background .2s ease, box-shadow .2s ease;
}
.review-dot.active{
  background:#49e348;
  transform:scale(1.1);
  box-shadow:0 0 12px rgba(73,227,72,.28);
}
.review-slide{
  opacity:1 !important;
  transform:none !important;
  animation:none !important;
}
@media (max-width: 760px){
  .reviews-slideshow{
    grid-template-columns:1fr;
    gap:12px;
  }
  .reviews-nav{
    display:none;
  }
  .review-card{
    padding:22px;
  }
  .review-card p{
    font-size:16px;
    line-height:1.65;
  }
}


/* Auto-scrolling review marquee */
.reviews-marquee{
  display:block;
  overflow:hidden;
  position:relative;
  margin-top:24px;
}
.reviews-marquee .reviews-track-wrap{
  overflow:hidden;
  width:100%;
  mask-image: linear-gradient(to right, transparent, black 6%, black 94%, transparent);
  -webkit-mask-image: linear-gradient(to right, transparent, black 6%, black 94%, transparent);
}
.reviews-marquee .reviews-track{
  display:flex;
  gap:24px;
  width:max-content;
  animation:reviewMarquee 42s linear infinite;
  will-change:transform;
}
.reviews-marquee .review-card{
  min-width:420px;
  max-width:420px;
  opacity:1 !important;
  transform:none !important;
  animation:none !important;
}
.reviews-marquee:hover .reviews-track{
  animation-play-state:paused;
}
.reviews-nav,
.reviews-dots{
  display:none !important;
}

@keyframes reviewMarquee{
  from { transform: translateX(0); }
  to { transform: translateX(calc(-50% - 12px)); }
}

@media (max-width:760px){
  .reviews-marquee .review-card{
    min-width:85vw;
    max-width:85vw;
  }
  .reviews-marquee .reviews-track{
    gap:16px;
    animation-duration:30s;
  }
}


/* In-page estimate form status */
.form-status{
  margin-top:16px;
  padding:14px 16px;
  border-radius:16px;
  font-weight:700;
  display:none;
}
.form-status.pending,
.form-status.success,
.form-status.error{
  display:block;
}
.form-status.pending{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  color:#eef7ee;
}
.form-status.success{
  background:rgba(25,209,26,.12);
  border:1px solid rgba(76,255,71,.28);
  color:#dfffe0;
}
.form-status.error{
  background:rgba(120,26,26,.18);
  border:1px solid rgba(255,155,155,.24);
  color:#fff0f0;
}

/* Cleaner mobile header */
@media (max-width: 980px){
  .header-socials{
    display:none !important;
  }

  .header-inner{
    grid-template-columns: 1fr auto !important;
    align-items:center !important;
    gap:10px !important;
    min-height:74px !important;
    padding:10px 0 !important;
  }

  .brand{
    min-width:0;
    overflow:hidden;
    gap:10px !important;
  }

  .brand-text{
    min-width:0;
  }

  .brand-text strong{
    font-size:16px !important;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .brand-text span{
    display:none !important;
  }

  .logo{
    width:48px !important;
    height:48px !important;
    border-radius:12px !important;
  }

  .menu-toggle{
    display:inline-flex !important;
    align-items:center;
    justify-content:center;
    width:46px !important;
    height:46px !important;
    border-radius:12px !important;
    background:rgba(255,255,255,.03) !important;
  }

  .main-nav{
    left:10px !important;
    right:10px !important;
    top:calc(100% + 6px) !important;
    padding:12px !important;
    gap:6px !important;
    border-radius:16px !important;
  }

  .main-nav > a,
  .nav-link-main,
  .nav-drop-toggle,
  .nav-dropdown-menu a{
    width:100%;
    justify-content:space-between;
    padding:12px 14px !important;
    border-radius:12px !important;
  }

  .nav-dropdown{
    display:block !important;
  }

  .nav-dropdown-menu{
    position:static !important;
    margin-top:6px !important;
    padding:8px !important;
    border-radius:14px !important;
    min-width:unset !important;
  }

  .nav-cta{
    margin-top:6px;
    text-align:center;
    justify-content:center !important;
  }
}

@media (max-width: 760px){
  .topbar{
    display:none !important;
  }

  .site-header{
    background:rgba(8,12,8,.97) !important;
  }

  .header-inner{
    min-height:68px !important;
    gap:8px !important;
  }

  .logo{
    width:44px !important;
    height:44px !important;
  }

  .brand-text strong{
    font-size:15px !important;
  }
}


/* Footer socials styled to match header socials */
.footer-socials{
  display:flex;
  align-items:center;
  gap:12px;
}

.footer-socials a{
  width:42px;
  height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  background:rgba(31,194,27,.12);
  color:#49e348 !important;
  border:1px solid rgba(73,227,72,.24);
  box-shadow:0 10px 24px rgba(0,0,0,.18);
  transition:transform .22s ease, background .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.footer-socials a:hover{
  transform:translateY(-2px);
  background:rgba(31,194,27,.2);
  border-color:rgba(73,227,72,.45);
  box-shadow:0 12px 28px rgba(31,194,27,.22);
  color:#7dff74 !important;
}

.footer-socials a i{
  font-size:18px;
}


/* Desktop header cleanup: keep nav on one line */
.header-inner{
  grid-template-columns:auto minmax(0,1fr) auto !important;
}
.main-nav{
  flex-wrap:nowrap !important;
  gap:8px !important;
  justify-content:center !important;
  overflow:visible !important;
}
.main-nav > a, .nav-link-main, .nav-drop-toggle{
  font-size:14px;
  padding:9px 10px !important;
}
.nav-dropdown{
  flex-shrink:0;
}
.nav-cta{
  margin-left:8px;
  flex-shrink:0;
}
.nav-dropdown-menu{
  z-index:200 !important;
}
.site-header, .site-header .container{
  overflow:visible !important;
}

/* Services dropdown not covered by CTA */
.main-nav{
  position:relative;
}
.nav-dropdown-menu{
  top:calc(100% + 8px) !important;
}

/* Off-canvas mobile nav */
@media (max-width: 980px){
  body.nav-open{
    overflow:hidden;
  }

  .main-nav{
    position:fixed !important;
    top:0 !important;
    right:0 !important;
    left:auto !important;
    height:100dvh !important;
    width:min(86vw, 360px) !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    justify-content:flex-start !important;
    padding:88px 14px 18px !important;
    gap:8px !important;
    background:rgba(10,14,10,.98) !important;
    border-left:1px solid rgba(31,194,27,.18) !important;
    border-radius:0 !important;
    box-shadow:-24px 0 50px rgba(0,0,0,.35) !important;
    transform:translateX(100%);
    transition:transform .28s ease !important;
    overflow-y:auto !important;
    z-index:120 !important;
  }

  .main-nav.open{
    transform:translateX(0);
  }

  .main-nav > a,
  .nav-link-main,
  .nav-drop-toggle,
  .nav-dropdown-menu a{
    width:100%;
    justify-content:space-between;
    padding:13px 14px !important;
    border-radius:12px !important;
    text-align:left;
  }

  .nav-dropdown{
    display:block !important;
  }

  .nav-dropdown-menu{
    position:static !important;
    display:none;
    min-width:unset !important;
    margin-top:6px !important;
    padding:8px !important;
    border-radius:14px !important;
  }

  .nav-dropdown.open .nav-dropdown-menu{
    display:flex !important;
  }

  .header-socials{
    display:none !important;
  }
}
@media (max-width: 1200px){
  .header-socials{
    gap:8px;
  }
  .header-socials a{
    width:38px;
    height:38px;
  }
}

/* Uniform service image block */
.service-image-card{
  background:linear-gradient(180deg, rgba(22,30,22,.98), rgba(11,16,11,.98));
  border:1px solid rgba(80,130,80,.24);
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 18px 45px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.03), inset 0 0 0 1px rgba(31,194,27,.05);
}
.service-image-card img{
  width:100%;
  height:300px;
  object-fit:cover;
  object-position:center;
}
.service-image-caption{
  padding:12px 16px 16px;
  color:var(--muted);
  font-size:14px;
}
@media (max-width: 760px){
  .service-image-card img{
    height:220px;
  }
}

/* Keep service links centered */
.service-anchors{
  justify-content:center !important;
  text-align:center;
}


.service-detail-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:32px;
  align-items:start;
}

.service-right-column{
  display:flex;
  flex-direction:column;
  gap:20px;
}

.service-image-card{
  margin-top:0 !important;
}

@media (max-width: 980px){
  .service-detail-grid{
    grid-template-columns:1fr;
  }
}


/* Services overview layout to match requested screenshots */
.services-overview-intro{
  max-width: 860px;
}
.services-overview-intro p,
.services-after-buttons p{
  color: var(--muted);
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}
.service-button-grid{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:14px;
  margin-top:28px;
}
.service-page-btn{
  min-height:54px;
  text-align:center;
  white-space:nowrap;
}
.services-after-buttons{
  margin-top:26px;
  text-align:center;
}
.services-expect-grid{
  align-items:start;
}
@media (max-width: 980px){
  .service-page-btn{
    width:100%;
    white-space:normal;
  }
}


/* Home gallery button */
.gallery-button-wrap{
  display:flex;
  justify-content:center;
  margin-top:24px;
}

/* Completed work gallery */
.completed-work-slider{
  height:560px;
}
.completed-work-slider .slide{
  object-fit:cover;
}
@media (max-width: 760px){
  .completed-work-slider{
    height:300px;
  }
}


/* Dropdown interaction fix */
.nav-dropdown{
  position:relative;
}
.nav-dropdown .nav-dropdown-menu{
  z-index:300 !important;
}
.nav-dropdown.open .nav-dropdown-menu{
  display:flex !important;
  opacity:1 !important;
  pointer-events:auto !important;
  transform:translateY(0) !important;
}
.nav-drop-toggle,
.services-trigger{
  cursor:pointer;
}
.services-trigger{
  background:none;
  border:none;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.nav-dropdown.open .fa-angle-down{
  transform:rotate(180deg);
}
.nav-drop-toggle .fa-angle-down,
.services-trigger .fa-angle-down{
  transition:transform .2s ease;
}


/* Header spacing and interaction improvements */
.site-header{
  overflow: visible;
}
.header-inner{
  overflow: visible;
}

/* Desktop refinements */
@media (min-width: 981px){
  .header-inner{
    grid-template-columns: auto minmax(0,1fr) auto !important;
    gap: 14px !important;
  }

  .main-nav{
    flex-wrap: nowrap !important;
    gap: 6px !important;
    justify-content: center !important;
    overflow: visible !important;
  }

  .main-nav > a,
  .nav-link-main,
  .nav-drop-toggle,
  .services-trigger{
    padding: 8px 10px !important;
    font-size: 14px !important;
    white-space: nowrap;
  }

  .nav-dropdown{
    flex-shrink: 0;
  }

  .nav-cta{
    margin-left: 10px !important;
    white-space: nowrap;
    flex-shrink: 0;
  }

  .header-socials{
    gap: 8px !important;
    margin-left: 10px;
    flex-shrink: 0;
  }

  .header-socials a{
    width: 38px !important;
    height: 38px !important;
  }

  /* Better desktop dropdown UX: open on hover so users only need one click on a menu item */
  .nav-dropdown:hover .nav-dropdown-menu,
  .nav-dropdown:focus-within .nav-dropdown-menu,
  .nav-dropdown.open .nav-dropdown-menu{
    display: flex !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: translateY(0) !important;
  }

  .nav-dropdown-menu{
    top: calc(100% + 8px) !important;
  }
}

/* Small dynamic touches */
.main-nav > a,
.nav-link-main,
.services-trigger{
  position: relative;
}

.main-nav > a::after,
.nav-link-main::after,
.services-trigger::after{
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 6px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(76,255,71,.9), transparent);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .22s ease;
}

.main-nav > a:hover::after,
.nav-link-main:hover::after,
.services-trigger:hover::after{
  transform: scaleX(1);
}

.site-header::after{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(76,255,71,.35), transparent);
  pointer-events: none;
}




/* Restore original header layout with minor spacing fix */
@media (min-width: 981px){
  .header-inner{
    display:grid !important;
    grid-template-columns:auto 1fr auto !important;
    align-items:center !important;
    gap:18px !important;
    padding:12px 20px !important;
  }

  .main-nav{
    display:flex !important;
    justify-content:center !important;
    align-items:center !important;
    gap:18px !important;
    flex-wrap:nowrap !important;
  }

  .main-nav > a,
  .nav-link-main,
  .services-trigger{
    font-size:15px !important;
    white-space:nowrap;
  }

  .nav-cta{
    margin-right:12px !important;
  }

  .header-socials{
    display:flex !important;
    gap:10px !important;
    align-items:center !important;
  }

  .header-right,
  .header-actions{
    display:flex !important;
    align-items:center !important;
    gap:12px !important;
  }
}


/* Fix LinkedIn icon alignment in header */
@media (min-width: 981px){
  .header-socials{
    display:flex !important;
    flex-direction:row !important;
    flex-wrap:nowrap !important;
    align-items:center !important;
    justify-content:flex-end !important;
    gap:12px !important;
    min-width:150px !important;
  }

  .header-socials a{
    flex:0 0 auto !important;
    display:inline-flex !important;
  }
}


/* Move Cinergy logo/brand block further left */
@media (min-width: 981px){
  .header-inner{
    padding-left: 10px !important;
  }

  .brand,
  .site-brand,
  .header-brand{
    margin-left: 0 !important;
    padding-left: 0 !important;
    transform: translateX(-14px);
  }
}


/* Push logo farther left and give nav more separation */
@media (min-width: 981px){
  .brand,
  .site-brand,
  .header-brand{
    transform: translateX(-32px) !important;
    max-width: 320px;
  }

  .main-nav{
    margin-left: 28px !important;
  }
}


/* Dropdowns stay open while moving mouse */
.nav-dropdown{
  position:relative;
}

.nav-dropdown-menu{
  position:absolute;
  top:100%;
  left:0;
  min-width:280px;
  padding-top:14px;
  margin-top:0;
  z-index:9999;
}

.nav-dropdown::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:100%;
  height:18px;
}

@media (min-width: 981px){
  .nav-dropdown:hover .nav-dropdown-menu,
  .nav-dropdown:focus-within .nav-dropdown-menu,
  .nav-dropdown.open .nav-dropdown-menu{
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
    transform:translateY(0) !important;
    display:flex !important;
  }
}

/* Mobile header centered */
@media (max-width: 980px){
  .header-inner{
    display:grid !important;
    grid-template-columns:48px 1fr 48px !important;
    align-items:center !important;
    padding:14px 16px !important;
  }

  .menu-toggle{
    grid-column:1;
    justify-self:center;
    order:1;
  }

  .brand,
  .site-brand,
  .header-brand{
    grid-column:2;
    justify-self:center !important;
    text-align:center !important;
    transform:none !important;
    margin:0 auto !important;
  }

  .header-right,
  .header-socials,
  .nav-cta{
    display:none !important;
  }
}


/* Final mobile header alignment + stable dropdown hit area */
.nav-dropdown-menu{
  z-index: 10000 !important;
}
.nav-dropdown-menu a{
  display:block;
  width:100%;
}

/* Mobile header centered exactly */
@media (max-width: 980px){
  .site-header .header-inner{
    position: relative !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    min-height:78px !important;
    padding:14px 16px !important;
  }

  .site-header .menu-toggle{
    position:absolute !important;
    left:50% !important;
    top:50% !important;
    transform:translate(-50%, -50%) !important;
    z-index:70 !important;
    margin:0 !important;
  }

  .site-header .brand,
  .site-header .site-brand,
  .site-header .header-brand{
    position:relative !important;
    left:0 !important;
    right:0 !important;
    margin:0 auto !important;
    justify-content:center !important;
    text-align:center !important;
    transform:none !important;
    z-index:60 !important;
    max-width:260px;
  }

  .site-header .brand-text{
    text-align:center !important;
  }
}

/* Desktop dropdown hover bridge */
@media (min-width: 981px){
  .nav-dropdown{
    position:relative;
  }
  .nav-dropdown::after{
    content:"";
    position:absolute;
    left:0;
    right:0;
    top:100%;
    height:18px;
  }
  .nav-dropdown:hover .nav-dropdown-menu,
  .nav-dropdown:focus-within .nav-dropdown-menu,
  .nav-dropdown.open .nav-dropdown-menu{
    display:flex !important;
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
    transform:translateY(0) !important;
  }
}


/* Mobile: logo slightly left of centered hamburger */
@media (max-width: 980px){
  .site-header .header-inner{
    position: relative !important;
    min-height: 78px !important;
  }

  .site-header .menu-toggle{
    position:absolute !important;
    left:50% !important;
    top:50% !important;
    transform:translate(-50%, -50%) !important;
    z-index:70 !important;
  }

  .site-header .brand,
  .site-header .site-brand,
  .site-header .header-brand{
    position:absolute !important;
    left:calc(50% - 110px) !important;
    top:50% !important;
    transform:translateY(-50%) !important;
    margin:0 !important;
    max-width:220px !important;
    text-align:left !important;
    z-index:60 !important;
  }

  .site-header .brand-text{
    text-align:left !important;
  }
}


/* Final mobile header cleanup */
@media (max-width: 980px){
  .site-header{
    overflow: visible !important;
  }

  .site-header .header-inner{
    display: grid !important;
    grid-template-columns: auto 1fr auto !important;
    align-items: center !important;
    gap: 10px !important;
    min-height: 76px !important;
    padding: 12px 14px !important;
  }

  .site-header .menu-toggle{
    position: static !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    grid-column: 1 !important;
    justify-self: start !important;
    z-index: 70 !important;
    width: 42px !important;
    height: 42px !important;
    margin: 0 !important;
  }

  .site-header .brand,
  .site-header .site-brand,
  .site-header .header-brand{
    position: static !important;
    grid-column: 2 !important;
    justify-self: center !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    margin: 0 auto !important;
    max-width: 235px !important;
    width: auto !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
  }

  .site-header .brand-text{
    text-align: left !important;
  }

  .site-header .brand-text strong{
    font-size: 16px !important;
    line-height: 1.05 !important;
  }

  .site-header .brand-text span{
    font-size: 11px !important;
    line-height: 1.25 !important;
  }

  .site-header .logo{
    width: 46px !important;
    height: 46px !important;
  }

  .site-header .header-right,
  .site-header .header-socials,
  .site-header .nav-cta{
    display: none !important;
  }

  .main-nav{
    z-index: 120 !important;
  }
}

/* Cleaner dropdown interaction */
.nav-dropdown{
  position: relative;
}
.nav-dropdown-menu{
  z-index: 10000 !important;
}
.nav-dropdown.open .nav-dropdown-menu,
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu{
  display: flex !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translateY(0) !important;
}

.nav-dropdown-menu a{
  display: block !important;
  width: 100% !important;
}


/* Mobile header final alignment */
@media (max-width: 980px){
  .topbar{
    display:none !important;
  }

  .site-header{
    overflow: visible !important;
  }

  .site-header .header-inner{
    display:grid !important;
    grid-template-columns: 1fr auto !important;
    align-items:center !important;
    gap:12px !important;
    min-height:84px !important;
    padding:14px 16px !important;
  }

  .site-header .brand,
  .site-header .site-brand,
  .site-header .header-brand{
    grid-column:1 !important;
    justify-self:center !important;
    margin:0 auto !important;
    position:static !important;
    left:auto !important;
    right:auto !important;
    top:auto !important;
    transform:none !important;
    max-width:280px !important;
    width:100% !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    gap:12px !important;
    text-align:left !important;
  }

  .site-header .brand-text{
    display:flex !important;
    flex-direction:column !important;
    text-align:left !important;
  }

  .site-header .brand-text strong{
    font-size:18px !important;
    line-height:1.05 !important;
  }

  .site-header .brand-text span{
    font-size:11px !important;
    line-height:1.25 !important;
  }

  .site-header .logo{
    width:56px !important;
    height:56px !important;
    flex:0 0 auto !important;
  }

  .site-header .menu-toggle{
    grid-column:2 !important;
    justify-self:end !important;
    position:static !important;
    transform:none !important;
    width:52px !important;
    height:52px !important;
    margin:0 !important;
    border-radius:18px !important;
    z-index:130 !important;
  }

  .site-header .header-right,
  .site-header .header-socials,
  .site-header .nav-cta{
    display:none !important;
  }

  .main-nav{
    position:fixed !important;
    top:84px !important;
    right:12px !important;
    left:12px !important;
    width:auto !important;
    max-height:calc(100dvh - 96px) !important;
    overflow-y:auto !important;
    border-radius:20px !important;
    padding:14px !important;
    z-index:125 !important;
    display:none !important;
  }

  .main-nav.open{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:8px !important;
  }

  .main-nav > a,
  .nav-link-main,
  .nav-drop-toggle,
  .services-trigger{
    width:100% !important;
    justify-content:space-between !important;
    padding:13px 14px !important;
    border-radius:12px !important;
  }

  .nav-dropdown{
    display:block !important;
  }

  .nav-dropdown .nav-link-main{
    width:calc(100% - 52px) !important;
    display:inline-flex !important;
  }

  .nav-dropdown .nav-drop-toggle{
    width:48px !important;
    display:inline-flex !important;
    float:right !important;
  }

  .nav-dropdown-menu{
    position:static !important;
    min-width:unset !important;
    margin-top:8px !important;
    padding:8px !important;
    border-radius:14px !important;
    display:none !important;
    opacity:1 !important;
    visibility:visible !important;
    transform:none !important;
    pointer-events:auto !important;
  }

  .nav-dropdown.open .nav-dropdown-menu{
    display:flex !important;
    flex-direction:column !important;
  }
}


/* Better visibility for all individual service page hero photos */
.page-hero.page-banner,
.service-page-hero,
.page-banner{
    position: relative;
    background-size: cover !important;
    background-position: center center !important;
    overflow: hidden;
}

.page-hero.page-banner::before,
.service-page-hero::before,
.page-banner::before{
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
        90deg,
        rgba(0,0,0,.45) 0%,
        rgba(0,0,0,.20) 45%,
        rgba(0,0,0,.15) 100%
    );
    z-index: 1;
}

.page-hero.page-banner > *,
.service-page-hero > *,
.page-banner > *{
    position: relative;
    z-index: 2;
}

/* Make the hero card slightly lighter so the image shows through more */
.page-banner .glass-card,
.page-banner .hero-card,
.page-banner .hero-content{
    background: rgba(7,16,12,.42) !important;
    backdrop-filter: blur(10px) !important;
    border: 1px solid rgba(75,255,120,.18) !important;
}

/* Specific fixes for packout and roof tarp pages so the photos are less zoomed */
body.packout-page .page-banner,
body.packout-services-page .page-banner,
.packout-hero,
.page-banner.packout{
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-color: #06110b !important;
}

body.roof-tarp-page .page-banner,
body.tarp-page .page-banner,
.roof-tarp-hero,
.page-banner.roof-tarp{
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-color: #06110b !important;
}

/* Mobile keeps the images more visible */
@media (max-width: 900px){
    .page-hero.page-banner,
    .service-page-hero,
    .page-banner{
        background-position: center top !important;
    }

    body.packout-page .page-banner,
    body.packout-services-page .page-banner,
    body.roof-tarp-page .page-banner,
    body.tarp-page .page-banner{
        background-size: 100% auto !important;
    }
}


/* Services dropdown + homepage buttons */
.nav-dropdown{
  position:relative;
}
.nav-dropdown-menu{
  z-index:10000 !important;
}
.nav-dropdown-menu a{
  display:block;
  width:100%;
}
.nav-dropdown.open .nav-dropdown-menu{
  display:flex !important;
  opacity:1 !important;
  visibility:visible !important;
  pointer-events:auto !important;
  transform:translateY(0) !important;
}

.service-button-grid{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:14px;
  margin-top:28px;
}
.service-page-btn{
  min-height:54px;
  text-align:center;
  white-space:nowrap;
}

@media (min-width: 981px){
  .nav-dropdown::after{
    content:"";
    position:absolute;
    left:0;
    right:0;
    top:100%;
    height:18px;
  }
  .nav-dropdown:hover .nav-dropdown-menu,
  .nav-dropdown:focus-within .nav-dropdown-menu{
    display:flex !important;
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
    transform:translateY(0) !important;
  }
}

@media (max-width: 980px){
  .nav-dropdown.open .nav-dropdown-menu{
    display:flex !important;
    flex-direction:column !important;
  }
  .service-page-btn{
    width:100%;
    white-space:normal;
  }
}


/* Mobile dropdown row alignment fix */
@media (max-width: 980px){
  .main-nav .nav-dropdown{
    display:grid !important;
    grid-template-columns: 1fr 48px !important;
    align-items:center !important;
    gap:8px !important;
    width:100% !important;
  }

  .main-nav .nav-dropdown > .nav-link-main,
  .main-nav .nav-dropdown > .services-trigger{
    grid-column:1 !important;
    width:100% !important;
    min-height:48px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    padding:13px 14px !important;
    border-radius:12px !important;
    margin:0 !important;
  }

  .main-nav .nav-dropdown > .nav-drop-toggle{
    grid-column:2 !important;
    width:48px !important;
    min-width:48px !important;
    height:48px !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    padding:0 !important;
    border-radius:12px !important;
    margin:0 !important;
    float:none !important;
  }

  .main-nav .nav-dropdown > .nav-dropdown-menu{
    grid-column:1 / -1 !important;
    margin-top:6px !important;
  }

  /* Services uses one trigger button, keep arrow visually aligned right */
  .main-nav .services-trigger{
    justify-content:space-between !important;
  }
}


/* Polished mobile dropdown panel */
@media (max-width: 980px){
  .main-nav{
    background: linear-gradient(180deg, rgba(8,12,8,.98), rgba(10,16,10,.98)) !important;
    border: 1px solid rgba(76,255,71,.14) !important;
    box-shadow: 0 20px 40px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.03) !important;
    backdrop-filter: blur(14px) !important;
  }

  .main-nav > a,
  .main-nav .nav-link-main,
  .main-nav .services-trigger,
  .main-nav .nav-drop-toggle{
    background: rgba(255,255,255,.02) !important;
    border: 1px solid rgba(255,255,255,.04) !important;
    transition: background .2s ease, border-color .2s ease, transform .2s ease !important;
  }

  .main-nav > a:hover,
  .main-nav .nav-link-main:hover,
  .main-nav .services-trigger:hover,
  .main-nav .nav-drop-toggle:hover{
    background: rgba(76,255,71,.06) !important;
    border-color: rgba(76,255,71,.18) !important;
  }

  .main-nav .nav-dropdown-menu{
    background: rgba(5,10,7,.72) !important;
    border: 1px solid rgba(76,255,71,.10) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.02) !important;
  }

  .main-nav .nav-dropdown-menu a{
    padding: 12px 14px !important;
    border-radius: 10px !important;
  }

  .main-nav .nav-dropdown-menu a:hover{
    background: rgba(76,255,71,.08) !important;
  }

  .main-nav.open{
    animation: mobileMenuFadeIn .18s ease-out;
  }

  .main-nav .nav-dropdown.open > .nav-drop-toggle i,
  .main-nav .nav-dropdown.open > .services-trigger i{
    transform: rotate(180deg);
  }

  .main-nav .nav-drop-toggle i,
  .main-nav .services-trigger i{
    transition: transform .2s ease;
  }
}

@keyframes mobileMenuFadeIn{
  from{
    opacity: 0;
    transform: translateY(-8px);
  }
  to{
    opacity: 1;
    transform: translateY(0);
  }
}


/* Make About and Services rows match on mobile */
@media (max-width: 980px){
  .main-nav .nav-dropdown{
    display:grid !important;
    grid-template-columns: 1fr 48px !important;
    align-items:center !important;
    gap:8px !important;
    width:100% !important;
  }

  .main-nav .nav-dropdown > .nav-link-main,
  .main-nav .nav-dropdown > .services-trigger{
    grid-column:1 !important;
    width:100% !important;
    min-height:48px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    padding:13px 14px !important;
    margin:0 !important;
    border-radius:12px !important;
  }

  .main-nav .nav-dropdown > .nav-drop-toggle{
    grid-column:2 !important;
    width:48px !important;
    min-width:48px !important;
    height:48px !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    padding:0 !important;
    margin:0 !important;
    float:none !important;
    border-radius:12px !important;
  }

  .main-nav .nav-dropdown > .nav-dropdown-menu{
    grid-column:1 / -1 !important;
    margin-top:6px !important;
    width:100% !important;
  }

  /* Services should no longer space its arrow inside the main button on mobile */
  .main-nav .services-trigger{
    justify-content:flex-start !important;
  }

  .main-nav .services-trigger i{
    display:none !important;
  }
}


/* Match Services caret styling with About on mobile */
@media (max-width: 980px){
  .main-nav .services-trigger{
    justify-content:flex-start !important;
    position:relative !important;
    padding-right:44px !important;
  }

  .main-nav .services-trigger i{
    display:inline-block !important;
    position:absolute !important;
    right:14px !important;
    top:50% !important;
    transform:translateY(-50%) !important;
    transition:transform .2s ease !important;
  }

  .main-nav .nav-dropdown.open > .services-trigger i{
    transform:translateY(-50%) rotate(180deg) !important;
  }
}

/* Improve hero photo visibility on service pages */
.page-hero.page-banner,
.page-banner{
  background-size:cover !important;
  background-position:center center !important;
  position:relative;
  overflow:hidden;
}

.page-banner-overlay{
  background:
    linear-gradient(90deg, rgba(3,8,6,.28) 0%, rgba(4,10,7,.16) 38%, rgba(4,10,7,.14) 100%) !important;
}

.page-hero-content{
  position:relative;
  z-index:2;
}

.page-hero-content .section-tag,
.page-hero-content h1,
.page-hero-content p{
  text-shadow:0 2px 18px rgba(0,0,0,.28);
}

/* Make the hero card more transparent so photos show through better */
.page-hero-content,
.page-banner .glass-card,
.page-banner .hero-card,
.page-banner .hero-content{
  background:rgba(8,16,12,.30) !important;
  backdrop-filter:blur(8px) !important;
  -webkit-backdrop-filter:blur(8px) !important;
  border:1px solid rgba(76,255,71,.14) !important;
  box-shadow:0 14px 34px rgba(0,0,0,.18) !important;
}

/* Better framing for service page hero images */
@media (min-width: 981px){
  .page-hero.page-banner,
  .page-banner{
    min-height:480px !important;
  }
}

@media (max-width: 980px){
  .page-hero.page-banner,
  .page-banner{
    background-position:center center !important;
  }

  .page-hero-content,
  .page-banner .glass-card,
  .page-banner .hero-card,
  .page-banner .hero-content{
    background:rgba(8,16,12,.34) !important;
  }
}

/* Less zoom for packout and roof tarp hero photos */
body[class*="packout"] .page-banner,
body[class*="roof"] .page-banner,
body[class*="tarp"] .page-banner{
  background-size:contain !important;
  background-repeat:no-repeat !important;
  background-color:#081008 !important;
}


/* Make service page hero content card more transparent */
.container.page-hero-content{
  background: rgba(8, 16, 12, 0.16) !important;
  border: 1px solid rgba(76,255,71,0.10) !important;
  backdrop-filter: blur(5px) !important;
  -webkit-backdrop-filter: blur(5px) !important;
  box-shadow: 0 10px 28px rgba(0,0,0,0.12) !important;
}

@media (max-width: 980px){
  .container.page-hero-content{
    background: rgba(8, 16, 12, 0.20) !important;
  }
}


/* Make About and Services mobile rows match exactly */
@media (max-width: 980px){
  .main-nav .nav-dropdown{
    display:grid !important;
    grid-template-columns: 1fr 48px !important;
    align-items:center !important;
    gap:8px !important;
    width:100% !important;
  }

  .main-nav .nav-dropdown > .nav-link-main,
  .main-nav .nav-dropdown > .services-trigger{
    grid-column:1 !important;
    width:100% !important;
    min-height:48px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    padding:13px 14px !important;
    margin:0 !important;
    border-radius:12px !important;
    position:relative !important;
  }

  .main-nav .nav-dropdown > .nav-drop-toggle{
    grid-column:2 !important;
    width:48px !important;
    min-width:48px !important;
    height:48px !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    padding:0 !important;
    margin:0 !important;
    float:none !important;
    border-radius:12px !important;
  }

  /* Services should use the same right-side arrow button layout as About */
  .main-nav .services-trigger{
    padding-right:14px !important;
  }

  .main-nav .services-trigger i{
    display:none !important;
  }

  .main-nav .nav-dropdown > .nav-dropdown-menu{
    grid-column:1 / -1 !important;
    margin-top:6px !important;
    width:100% !important;
  }
}


/* === Final navigation cleanup === */
:root{
  --nav-row-radius: 12px;
  --nav-row-height: 48px;
  --nav-border-soft: rgba(255,255,255,.06);
  --nav-border-accent: rgba(76,255,71,.18);
  --nav-bg-soft: rgba(255,255,255,.02);
  --nav-bg-hover: rgba(76,255,71,.08);
  --nav-panel-bg: rgba(5,10,7,.88);
}

.main-nav .nav-dropdown{
  position: relative;
}

.main-nav .nav-link-main,
.main-nav .nav-drop-toggle{
  transition: background .2s ease, border-color .2s ease, color .2s ease, transform .2s ease;
}

.main-nav .nav-drop-toggle{
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.main-nav .nav-drop-toggle i{
  transition: transform .2s ease;
}

.main-nav .nav-dropdown.open > .nav-drop-toggle i,
.main-nav .nav-dropdown.open > .services-trigger i{
  transform: rotate(180deg);
}

@media (min-width: 981px){
  .main-nav .nav-dropdown{
    display: inline-flex;
    align-items: center;
    gap: 8px;
  }

  .main-nav .nav-link-main{
    display: inline-flex;
    align-items: center;
  }

  .main-nav .nav-drop-toggle{
    width: 38px;
    height: 38px;
    border-radius: 10px;
    border: 1px solid transparent;
    background: transparent;
    color: inherit;
    cursor: pointer;
  }

  .main-nav .nav-drop-toggle:hover,
  .main-nav .nav-dropdown:hover > .nav-drop-toggle{
    background: var(--nav-bg-hover);
    border-color: var(--nav-border-accent);
  }

  .main-nav .nav-dropdown-menu{
    top: calc(100% + 12px);
  }
}

@media (max-width: 980px){
  .main-nav > a,
  .main-nav .nav-dropdown > .nav-link-main,
  .main-nav .nav-dropdown > .nav-drop-toggle{
    border: 1px solid var(--nav-border-soft) !important;
    background: var(--nav-bg-soft) !important;
  }

  .main-nav .nav-dropdown{
    display: grid !important;
    grid-template-columns: minmax(0,1fr) var(--nav-row-height) !important;
    align-items: center !important;
    gap: 8px !important;
    width: 100% !important;
  }

  .main-nav .nav-dropdown > .nav-link-main{
    grid-column: 1 !important;
    width: 100% !important;
    min-height: var(--nav-row-height) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    padding: 13px 14px !important;
    margin: 0 !important;
    border-radius: var(--nav-row-radius) !important;
  }

  .main-nav .nav-dropdown > .nav-drop-toggle{
    grid-column: 2 !important;
    width: var(--nav-row-height) !important;
    min-width: var(--nav-row-height) !important;
    height: var(--nav-row-height) !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: var(--nav-row-radius) !important;
    float: none !important;
  }

  .main-nav > a:hover,
  .main-nav .nav-dropdown > .nav-link-main:hover,
  .main-nav .nav-dropdown > .nav-drop-toggle:hover{
    background: var(--nav-bg-hover) !important;
    border-color: var(--nav-border-accent) !important;
  }

  .main-nav .nav-dropdown > .nav-dropdown-menu{
    grid-column: 1 / -1 !important;
    width: 100% !important;
    margin-top: 6px !important;
    padding: 8px !important;
    border-radius: 14px !important;
    background: var(--nav-panel-bg) !important;
    border: 1px solid rgba(76,255,71,.12) !important;
  }

  .main-nav .nav-dropdown-menu a{
    border-radius: 10px !important;
  }
}


/* --- Services dropdown refactor to match About --- */
.nav-dropdown-services .nav-link-main{
  display:flex;
  align-items:center;
}

.nav-dropdown-services .services-drop-toggle{
  margin-left:10px;
}

@media (max-width: 980px){
  .nav-dropdown{
    display:grid;
    grid-template-columns:1fr 58px;
    gap:10px;
    align-items:center;
  }

  .nav-dropdown > .nav-link-main{
    width:100%;
    padding:18px 20px;
    border-radius:16px;
    border:1px solid rgba(75,255,75,.14);
    background:rgba(8,12,8,.92);
  }

  .nav-dropdown > .nav-drop-toggle{
    width:58px;
    height:58px;
    border-radius:16px;
    border:1px solid rgba(75,255,75,.14);
    background:rgba(8,12,8,.92);
    display:flex;
    align-items:center;
    justify-content:center;
  }

  .nav-dropdown-services .nav-drop-toggle i,
  .nav-dropdown-about .nav-drop-toggle i{
    transition:transform .25s ease;
  }

  .nav-dropdown.open .nav-drop-toggle i{
    transform:rotate(180deg);
  }
}


/* Services label only (no clickable page link) */
.nav-link-label{
  cursor: default;
  user-select: none;
  color: #fff;
  text-decoration: none;
}


/* --- Recommended polish upgrade --- */
.hero-overlay{
  background:
    linear-gradient(90deg, rgba(3,8,4,.78) 0%, rgba(4,8,4,.56) 42%, rgba(4,8,4,.34) 100%),
    linear-gradient(180deg, rgba(0,0,0,.16), rgba(0,0,0,.26));
}
.hero-panel{
  backdrop-filter: blur(8px);
  background: rgba(6, 10, 7, 0.28);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 28px;
  max-width: 760px;
}
.trust-strip{
  background: #0b120d;
  border-top: 1px solid rgba(75,255,75,.08);
  border-bottom: 1px solid rgba(75,255,75,.08);
}
.trust-strip-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:14px;
  padding: 18px 0;
}
.trust-pill{
  display:flex;
  align-items:center;
  gap:12px;
  padding:16px 18px;
  border-radius:18px;
  border:1px solid rgba(75,255,75,.14);
  background: rgba(255,255,255,.02);
  color:#f3f5f4;
}
.trust-pill i,
.process-number,
.before-after-label,
.quick-list li::marker{
  color:#6ff05d;
}
.before-after-shell{max-width: 980px;}
.before-after-card{
  padding:22px;
  border-radius:28px;
  background: rgba(255,255,255,.02);
  border:1px solid rgba(75,255,75,.12);
}
.before-after-frame{
  position:relative;
  overflow:hidden;
  border-radius:24px;
  aspect-ratio: 16 / 9;
  background:#061009;
}
.before-after-img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.after-clip{
  position:absolute;
  inset:0;
  width:52%;
  overflow:hidden;
  border-right:2px solid rgba(255,255,255,.8);
}
.after-clip img{width:100%; height:100%; object-fit:cover;}
.before-after-handle{
  position:absolute;
  top:0;
  left:52%;
  transform:translateX(-50%);
  width:4px;
  height:100%;
  background: rgba(255,255,255,.82);
  box-shadow: 0 0 0 10px rgba(111,240,93,.14);
}
.before-after-label{
  position:absolute;
  top:16px;
  padding:8px 12px;
  border-radius:999px;
  background: rgba(6,10,7,.72);
  color:#fff;
  font-weight:700;
  font-size:.88rem;
}
.before-label{left:16px;}
.after-label{right:16px;}
.before-after-range{
  width:100%;
  margin-top:18px;
}
.process-grid,
.faq-grid,
.quick-grid,
.city-grid{
  display:grid;
  gap:18px;
}
.process-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
.faq-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
.service-faq-grid{grid-template-columns:repeat(2,minmax(0,1fr)); margin-top:18px;}
.quick-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
.city-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
.process-card,
.faq-card,
.quick-card,
.city-card{
  display:block;
  padding:24px;
  border-radius:24px;
  border:1px solid rgba(75,255,75,.12);
  background: rgba(255,255,255,.02);
  color:inherit;
  text-decoration:none;
}
.process-number{
  display:inline-flex;
  margin-bottom:16px;
  font-weight:800;
  font-size:1.4rem;
}
.quick-list,
.process-mini{
  margin: 16px 0 0;
  padding-left: 20px;
}
.quick-list li,
.process-mini li{margin-bottom: 10px;}
.faq-heading{margin-top:34px;}
.floating-estimate{
  position:fixed;
  right:24px;
  bottom:95px;
  z-index:90;
  padding:14px 18px;
  border-radius:999px;
  background:#ffffff;
  color:#0b110d;
  font-weight:700;
  text-decoration:none;
  box-shadow: 0 16px 38px rgba(0,0,0,.28);
}
.floating-estimate:hover{transform:translateY(-1px);}
@media (max-width: 980px){
  .trust-strip-grid,
  .process-grid,
  .faq-grid,
  .quick-grid,
  .city-grid,
  .service-faq-grid{
    grid-template-columns:1fr;
  }
  .hero-panel{
    background: rgba(6,10,7,.36);
  }
  .floating-estimate{
    right:20px;
    bottom:86px;
    padding:12px 16px;
    font-size:.92rem;
  }
}


/* --- Before/After multi-card upgrade --- */
.before-after-gallery{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 20px;
}
.before-after-card{
  position: relative;
}
.before-after-note{
  margin-top: 14px;
  color: rgba(255,255,255,.74);
  font-size: .95rem;
}
.before-after-template-card{
  padding: 24px;
  border-radius: 28px;
  background: rgba(255,255,255,.02);
  border:1px solid rgba(75,255,75,.12);
}
.before-after-code-sample{
  margin-top: 16px;
  padding: 16px;
  overflow-x: auto;
  white-space: pre;
  border-radius: 18px;
  background: rgba(6,10,7,.78);
  border: 1px solid rgba(75,255,75,.12);
  color: #e9f6ea;
  font-size: .84rem;
  line-height: 1.45;
}
.before-after-frame{
  isolation: isolate;
}
.after-clip{
  transition: width .12s linear, box-shadow .18s ease;
  box-shadow: inset 0 0 0 rgba(111,240,93,0);
}
.after-clip.is-active{
  box-shadow: inset 0 0 90px rgba(111,240,93,.18);
}
.after-label{
  transition: color .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
  border: 1px solid transparent;
}
.before-after-card.after-highlighted .after-label{
  color: #6ff05d;
  border-color: rgba(111,240,93,.45);
  background: rgba(6,10,7,.88);
  box-shadow: 0 0 24px rgba(111,240,93,.18);
}
.before-after-card.after-highlighted .before-after-handle{
  box-shadow: 0 0 0 10px rgba(111,240,93,.18), 0 0 26px rgba(111,240,93,.24);
}
@media (max-width: 980px){
  .before-after-gallery{
    grid-template-columns: 1fr;
  }
}


/* Homepage final cleanup */
.before-after-gallery{
  grid-template-columns: repeat(3, minmax(0,1fr));
  align-items: stretch;
}
.before-after-card{
  height: 100%;
}
.before-after-note{
  text-align: left;
}
@media (max-width: 1200px){
  .before-after-gallery{
    grid-template-columns: 1fr;
  }
}


/* --- Final visual polish pass --- */
:root{
  --cinergy-green-bright: #6ff05d;
  --cinergy-green-glow: rgba(111, 240, 93, 0.34);
  --cinergy-green-soft: rgba(111, 240, 93, 0.16);
  --cinergy-border-strong: rgba(111, 240, 93, 0.28);
}

.section-tag{
  border: 1px solid var(--cinergy-border-strong);
  box-shadow: 0 0 0 1px rgba(111,240,93,0.05) inset, 0 0 24px rgba(111,240,93,0.10);
}

.process-card,
.faq-card,
.quick-card,
.city-card,
.before-after-card,
.trust-pill,
.service-image-card,
.feature-panel,
.banner-card,
.contact-card,
.info-card,
.review-card{
  border: 1px solid var(--cinergy-border-strong);
  box-shadow:
    0 0 0 1px rgba(111,240,93,0.04) inset,
    0 12px 34px rgba(0,0,0,0.24);
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease, background .22s ease;
}

.process-card:hover,
.faq-card:hover,
.quick-card:hover,
.city-card:hover,
.before-after-card:hover,
.trust-pill:hover,
.service-image-card:hover,
.feature-panel:hover,
.banner-card:hover,
.contact-card:hover,
.info-card:hover,
.review-card:hover{
  transform: translateY(-4px);
  border-color: rgba(111, 240, 93, 0.46);
  box-shadow:
    0 0 0 1px rgba(111,240,93,0.07) inset,
    0 0 30px rgba(111,240,93,0.12),
    0 16px 40px rgba(0,0,0,0.28);
}

.before-after-frame,
.hero-panel,
.nav-dropdown > .nav-link-main,
.nav-dropdown > .nav-drop-toggle{
  box-shadow:
    0 0 0 1px rgba(111,240,93,0.04) inset,
    0 0 22px rgba(111,240,93,0.08);
}

.before-after-label{
  border: 1px solid rgba(255,255,255,0.08);
}

.before-after-card.after-highlighted .after-label{
  color: var(--cinergy-green-bright);
  border-color: rgba(111,240,93,0.52);
  box-shadow:
    0 0 0 1px rgba(111,240,93,0.08) inset,
    0 0 26px rgba(111,240,93,0.20);
}

.btn,
.floating-estimate,
.floating-call,
.btn-call,
.btn-primary{
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}

.btn:hover,
.floating-estimate:hover,
.floating-call:hover,
.btn-call:hover,
.btn-primary:hover{
  transform: translateY(-2px);
  filter: brightness(1.02);
}

.btn-call,
.cta-attention{
  box-shadow:
    0 0 0 1px rgba(111,240,93,0.12) inset,
    0 0 24px rgba(111,240,93,0.22),
    0 12px 28px rgba(0,0,0,0.24);
}

.before-after-note{
  color: rgba(255,255,255,0.82);
  font-weight: 500;
}

.site-header{
  border-bottom: 1px solid rgba(111,240,93,0.14);
  box-shadow: 0 10px 28px rgba(0,0,0,0.18);
}

.section.alt{
  background:
    radial-gradient(circle at top center, rgba(111,240,93,0.06), transparent 38%),
    linear-gradient(180deg, rgba(4,10,6,0.98), rgba(3,8,5,1));
}

@media (max-width: 980px){
  .process-card:hover,
  .faq-card:hover,
  .quick-card:hover,
  .city-card:hover,
  .before-after-card:hover,
  .trust-pill:hover,
  .service-image-card:hover,
  .feature-panel:hover,
  .banner-card:hover,
  .contact-card:hover,
  .info-card:hover,
  .review-card:hover{
    transform: none;
  }
}


/* Full-width header update */
.site-header,
.topbar{
  width: 100%;
  max-width: 100%;
  margin: 0;
  left: 0;
  right: 0;
}

.topbar{
  padding-left: 0;
  padding-right: 0;
}

.topbar .container,
.site-header .container,
.header-inner{
  max-width: 1500px;
  width: 100%;
}

.site-header{
  position: relative;
}

.site-header::before{
  content: "";
  position: absolute;
  inset: 0;
  width: 100vw;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(3,10,5,0.98), rgba(2,8,4,0.98));
  z-index: -1;
  border-top: 1px solid rgba(111,240,93,0.10);
  border-bottom: 1px solid rgba(111,240,93,0.14);
}

.topbar::before{
  content: "";
  position: absolute;
  inset: 0;
  width: 100vw;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(2,8,4,0.98);
  z-index: -1;
  border-bottom: 1px solid rgba(111,240,93,0.12);
}

@media (min-width: 1200px){
  .site-header .container,
  .topbar .container{
    padding-left: 34px;
    padding-right: 34px;
  }
}


.topbar .container{
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
}

.topbar-center-text{
  justify-self: center;
  text-align: center;
  color: rgba(255,255,255,0.92);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  white-space: nowrap;
}

@media (max-width: 980px){
  .topbar .container{
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .topbar-center-text{
    order: -1;
    white-space: normal;
    font-size: 0.82rem;
    padding: 0 12px;
  }
}


/* Header spacing cleanup */
.topbar .container{
  grid-template-columns: auto 1fr auto;
  column-gap: 28px;
}

.topbar-center-text{
  justify-self: start;
  padding-left: 42px;
}

.topbar .phone-link,
.topbar .topbar-phone,
.topbar a[href^="tel:"]{
  justify-self: end;
  margin-right: 28px;
}

.site-header .brand,
.site-header .logo-wrap,
.site-header .site-brand{
  margin-left: 26px;
}

/* Reduce hero blur and make photos more visible */
.hero-panel,
.page-hero-content,
.page-banner .page-hero-content{
  backdrop-filter: blur(4px);
  background: rgba(6, 10, 7, 0.18);
}

.hero-overlay,
.page-banner-overlay{
  background:
    linear-gradient(90deg, rgba(3,8,4,.62) 0%, rgba(4,8,4,.38) 45%, rgba(4,8,4,.18) 100%),
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.18));
}

.page-banner .page-hero-content{
  border: 1px solid rgba(111,240,93,0.14);
  box-shadow:
    0 0 0 1px rgba(111,240,93,0.04) inset,
    0 10px 30px rgba(0,0,0,0.18);
}


/* Better spacing for logo / brand block */
.header-inner{
  padding-left: 34px;
  padding-right: 34px;
}

.brand{
  margin-left: 24px;
}

@media (max-width: 980px){
  .header-inner{
    padding-left: 18px;
    padding-right: 18px;
  }

  .brand{
    margin-left: 10px;
  }
}


/* Move brand block closer to Home button */
.header-inner{
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
}

.brand{
  margin-left: 34px;
  margin-right: 72px;
}

.primary-nav,
.site-nav,
.nav-links{
  margin-left: 0;
}

@media (max-width: 980px){
  .brand{
    margin-right: 24px;
  }
}


/* Better spacing for certification text */
.license-group{
  display: flex;
  align-items: center;
  gap: 18px;
  color: rgba(255,255,255,0.82);
  font-size: 0.92rem;
  white-space: nowrap;
}

.license-divider{
  width: 1px;
  height: 14px;
  background: rgba(111,240,93,0.28);
  display: inline-block;
}

@media (max-width: 980px){
  .license-group{
    flex-direction: column;
    gap: 4px;
    white-space: normal;
    text-align: center;
  }

  .license-divider{
    display: none;
  }
}


/* Align logo block under beginning of topbar text */
.topbar .container,
.header-inner{
  max-width: 1500px;
  margin: 0 auto;
}

.brand{
  margin-left: 78px;
  margin-right: 72px;
}

@media (max-width: 980px){
  .brand{
    margin-left: 10px;
  }
}


/* Fill empty space between logo and navigation */
.header-inner{
  display: flex;
  align-items: center;
}

.brand{
  margin-left: 78px;
  margin-right: 18px;
  display: flex;
  align-items: center;
  min-width: 360px;
}

.brand-text{
  margin-left: 14px;
  max-width: 250px;
}

.site-nav,
.primary-nav,
.nav-links{
  margin-left: 12px;
}

@media (max-width: 980px){
  .brand{
    min-width: auto;
    margin-left: 10px;
    margin-right: 10px;
  }

  .brand-text{
    max-width: none;
  }
}


/* Actual brand shift into empty header space */
.header-inner{
  display:flex;
  align-items:center;
  padding-left: 0;
}

.brand{
  margin-left: 120px !important;
  margin-right: 36px !important;
  min-width: 430px;
}

.brand-text{
  margin-left: 18px;
}

@media (max-width: 980px){
  .brand{
    margin-left: 14px !important;
    min-width: auto;
  }
}


/* Desktop header fit cleanup */
@media (min-width: 981px){
  .header-inner{
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:24px;
    padding-left:24px !important;
    padding-right:24px !important;
  }

  .brand{
    margin-left:0 !important;
    margin-right:24px !important;
    min-width:0 !important;
    flex:0 1 330px;
    display:flex;
    align-items:center;
  }

  .brand .logo,
  .logo{
    flex:0 0 auto;
  }

  .brand-text{
    margin-left:12px !important;
    max-width:220px !important;
  }

  .brand-text strong{
    display:block;
    font-size:1rem;
    line-height:1.05;
  }

  .brand-text span{
    display:block;
    font-size:.72rem;
    line-height:1.35;
  }

  .site-nav,
  .primary-nav,
  .nav-links{
    flex:1 1 auto;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    min-width:0;
    margin-left:0 !important;
  }

  .site-nav a,
  .primary-nav a,
  .nav-links a,
  .nav-link-main{
    font-size:.95rem;
    white-space:nowrap;
  }

  .nav-dropdown{
    gap:6px !important;
  }

  .nav-drop-toggle{
    width:38px;
    height:38px;
  }

  .header-actions,
  .header-cta,
  .header-right{
    flex:0 0 auto;
    display:flex;
    align-items:center;
    gap:14px;
    min-width:0;
  }

  .btn-call,
  .header-actions .btn,
  .header-cta .btn{
    padding:14px 22px !important;
    font-size:.95rem;
    white-space:nowrap;
  }

  .social-links,
  .header-socials,
  .social-icons{
    display:flex !important;
    align-items:center;
    gap:10px;
    flex:0 0 auto;
  }

  .social-links a,
  .header-socials a,
  .social-icons a{
    width:42px;
    height:42px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex:0 0 auto;
  }
}

/* Wider screens can breathe a little more */
@media (min-width: 1200px){
  .header-inner{
    gap:28px;
    padding-left:30px !important;
    padding-right:30px !important;
  }

  .brand{
    flex-basis:360px;
    margin-right:28px !important;
  }

  .brand-text{
    max-width:235px !important;
  }

  .site-nav,
  .primary-nav,
  .nav-links{
    gap:14px;
  }
}


/* Trust section refinements */
.trust-strip-heading{
  margin-bottom: 18px;
}
.trust-contact-section{
  padding-bottom: 22px;
}
.contact-cta-band{
  margin-top: 22px;
  padding: 28px;
  border-radius: 26px;
  border: 1px solid rgba(111,240,93,0.22);
  background: linear-gradient(180deg, rgba(9,14,10,0.98), rgba(6,10,7,0.98));
  box-shadow: 0 16px 38px rgba(0,0,0,0.22), 0 0 24px rgba(111,240,93,0.08);
  text-align: center;
}
.contact-cta-band h3{
  margin-bottom: 10px;
}
.contact-cta-band .banner-actions{
  justify-content: center;
  margin-top: 16px;
}

/* County buttons */
.county-button-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:18px;
}
.county-button{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:70px;
  padding:18px 20px;
  border-radius:20px;
  border:1px solid rgba(111,240,93,0.24);
  background: linear-gradient(180deg, rgba(10,16,11,0.98), rgba(5,9,6,0.98));
  color:#f3f6f4;
  text-decoration:none;
  font-weight:700;
  letter-spacing:.01em;
  box-shadow: 0 12px 30px rgba(0,0,0,0.22), 0 0 24px rgba(111,240,93,0.08);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.county-button:hover{
  transform: translateY(-3px);
  border-color: rgba(111,240,93,0.46);
  box-shadow: 0 16px 38px rgba(0,0,0,0.26), 0 0 30px rgba(111,240,93,0.16);
}

/* Service trust block */
.service-trust-section{
  padding-top: 18px;
  padding-bottom: 6px;
}
.service-trust-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:14px;
}
.service-trust-pill{
  display:flex;
  align-items:center;
  gap:12px;
  padding:16px 18px;
  border-radius:18px;
  border:1px solid rgba(111,240,93,0.18);
  background: rgba(255,255,255,.02);
  box-shadow: 0 10px 28px rgba(0,0,0,.18), 0 0 18px rgba(111,240,93,.06);
}
.service-trust-pill i{
  color:#6ff05d;
}

/* Small performance-friendly image rules */
img{
  max-width:100%;
  height:auto;
}
.completed-work-grid img,
.before-after-gallery img,
.service-image-card img,
.review-card img{
  content-visibility: auto;
}

@media (max-width: 980px){
  .county-button-grid,
  .service-trust-grid{
    grid-template-columns: 1fr;
  }
}


/* Final county + header cleanup */
:root{
  --header-bg: linear-gradient(180deg, rgba(4,10,6,0.98), rgba(3,8,5,0.98));
  --topbar-bg: rgba(2,8,4,0.98);
  --green-strong: rgba(111,240,93,0.42);
  --green-mid: rgba(111,240,93,0.24);
  --green-soft: rgba(111,240,93,0.10);
}

.topbar{
  position: relative;
  background: var(--topbar-bg);
  border-bottom: 1px solid var(--green-soft);
}

.topbar .container{
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto minmax(190px, 1fr);
  align-items: center;
  gap: 18px;
  max-width: 1500px;
  margin: 0 auto;
  padding: 10px 28px;
}

.license-group{
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  white-space: normal;
  line-height: 1.3;
  font-size: 0.88rem;
}

.topbar-center-text{
  justify-self: center;
  text-align: center;
  font-size: 0.92rem;
  font-weight: 700;
  color: rgba(255,255,255,0.94);
  letter-spacing: 0.01em;
}

.topbar a[href^="tel:"],
.topbar .phone-link,
.topbar .topbar-phone{
  justify-self: end;
  white-space: nowrap;
  font-weight: 700;
}

.site-header{
  position: sticky;
  top: 0;
  z-index: 120;
  background: var(--header-bg);
  backdrop-filter: saturate(130%) blur(8px);
  border-bottom: 1px solid rgba(111,240,93,0.14);
  box-shadow: 0 14px 34px rgba(0,0,0,0.18);
}

.header-inner{
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 22px;
  max-width: 1500px;
  margin: 0 auto;
  padding: 16px 28px !important;
}

.brand{
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 0 !important;
  flex: 0 1 340px;
  min-width: 0 !important;
}

.logo{
  width: 68px;
  height: 68px;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid rgba(111,240,93,0.18);
  box-shadow: 0 0 22px rgba(111,240,93,0.08);
}

.brand-text{
  margin: 0 !important;
  min-width: 0;
}

.brand-text strong{
  display: block;
  font-size: 1.03rem;
  line-height: 1.05;
}

.brand-text span{
  display: block;
  margin-top: 4px;
  font-size: 0.76rem;
  line-height: 1.28;
  color: rgba(255,255,255,0.72);
}

.site-nav,
.primary-nav,
.nav-links{
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin: 0 !important;
}

.site-nav > a,
.primary-nav > a,
.nav-links > a,
.nav-link-main{
  white-space: nowrap;
  font-size: 0.94rem;
}

.nav-dropdown{
  display: inline-flex;
  align-items: center;
  gap: 6px !important;
}

.nav-drop-toggle{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(111,240,93,0.16);
  background: rgba(255,255,255,0.02);
}

.header-actions,
.header-cta,
.header-right{
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 0 0 auto;
}

.btn-call,
.header-actions .btn,
.header-cta .btn{
  padding: 13px 18px !important;
  font-size: 0.9rem;
  white-space: nowrap;
  border-radius: 14px;
}

.social-links,
.header-socials,
.social-icons{
  display: flex !important;
  align-items: center;
  gap: 8px;
}

.social-links a,
.header-socials a,
.social-icons a{
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  border: 1px solid rgba(111,240,93,0.14);
  background: rgba(255,255,255,0.02);
}

.county-button-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 18px;
}

.county-button{
  min-height: 74px;
  font-size: 0.98rem;
  text-align: center;
  padding: 18px 16px;
  border-radius: 18px;
}

.section-heading.center p:empty{
  display: none;
}

@media (max-width: 1180px){
  .topbar .container{
    grid-template-columns: 1fr;
    gap: 8px;
    text-align: center;
  }

  .license-group,
  .topbar-center-text,
  .topbar a[href^="tel:"],
  .topbar .phone-link,
  .topbar .topbar-phone{
    justify-self: center;
  }

  .header-inner{
    gap: 16px;
    padding: 14px 18px !important;
  }

  .brand{
    flex-basis: 280px;
  }

  .brand-text span{
    font-size: 0.72rem;
  }

  .site-nav,
  .primary-nav,
  .nav-links{
    gap: 9px;
  }

  .site-nav > a,
  .primary-nav > a,
  .nav-links > a,
  .nav-link-main{
    font-size: 0.88rem;
  }

  .btn-call,
  .header-actions .btn,
  .header-cta .btn{
    padding: 12px 14px !important;
    font-size: 0.86rem;
  }
}

@media (max-width: 980px){
  .topbar .container{
    padding: 10px 14px;
  }

  .header-inner{
    padding: 12px 14px !important;
  }

  .brand{
    flex: 1 1 auto;
  }

  .logo{
    width: 60px;
    height: 60px;
  }

  .county-button-grid{
    grid-template-columns: 1fr;
  }
}


/* Mobile floating CTA cleanup */
@media (max-width: 980px){
  .floating-estimate,
  .floating-call{
    position: fixed;
    left: 14px;
    right: 14px;
    width: auto;
    max-width: none;
    border-radius: 16px;
    text-align: center;
    justify-content: center;
    padding: 14px 18px;
    font-size: 0.95rem;
    line-height: 1.2;
  }

  .floating-estimate{
    bottom: 82px;
  }

  .floating-call{
    bottom: 18px;
  }

  body{
    padding-bottom: 150px;
  }
}

@media (max-width: 640px){
  .floating-estimate,
  .floating-call{
    left: 12px;
    right: 12px;
    padding: 13px 16px;
    font-size: 0.92rem;
    min-height: 52px;
    box-shadow: 0 12px 28px rgba(0,0,0,0.24);
  }

  .floating-estimate{
    bottom: 78px;
  }

  .floating-call{
    bottom: 14px;
  }

  body{
    padding-bottom: 145px;
  }
}


/* --- Final header smoothing pass --- */
@media (min-width: 981px){
  .header-inner{
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:18px !important;
    padding:14px 22px !important;
  }

  .brand{
    flex:0 1 300px !important;
    gap:12px !important;
    margin:0 !important;
    min-width:0 !important;
  }

  .logo{
    width:62px !important;
    height:62px !important;
    border-radius:14px !important;
  }

  .brand-text{
    margin:0 !important;
    max-width:210px !important;
  }

  .brand-text strong{
    font-size:0.98rem !important;
    line-height:1.02 !important;
    margin-bottom:3px !important;
  }

  .brand-text span{
    font-size:0.70rem !important;
    line-height:1.22 !important;
  }

  .site-nav,
  .primary-nav,
  .nav-links{
    flex:1 1 auto !important;
    justify-content:center !important;
    gap:10px !important;
    margin:0 !important;
    min-width:0 !important;
  }

  .site-nav > a,
  .primary-nav > a,
  .nav-links > a,
  .nav-link-main{
    font-size:0.93rem !important;
    white-space:nowrap !important;
  }

  .nav-dropdown{
    gap:5px !important;
  }

  .nav-drop-toggle{
    width:36px !important;
    height:36px !important;
    border-radius:11px !important;
  }

  .header-actions,
  .header-cta,
  .header-right{
    display:flex !important;
    align-items:center !important;
    gap:10px !important;
    flex:0 0 auto !important;
  }

  .btn-call,
  .header-actions .btn,
  .header-cta .btn{
    padding:12px 16px !important;
    font-size:0.88rem !important;
    border-radius:14px !important;
  }

  .social-links,
  .header-socials,
  .social-icons{
    display:flex !important;
    align-items:center !important;
    gap:8px !important;
  }

  .social-links a,
  .header-socials a,
  .social-icons a{
    width:38px !important;
    height:38px !important;
    border-radius:12px !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    border:1px solid rgba(111,240,93,0.16) !important;
    background:rgba(255,255,255,0.02) !important;
    box-shadow:0 0 0 1px rgba(111,240,93,0.03) inset !important;
  }
}

/* counties section tidy */
.county-button-grid{
  grid-template-columns: repeat(3, minmax(0,1fr)) !important;
}
.county-button{
  min-height:72px !important;
  font-size:0.98rem !important;
  font-weight:700 !important;
}

@media (max-width: 980px){
  .county-button-grid{
    grid-template-columns:1fr !important;
  }
}


/* About page copy section */
.about-intro-copy{
  padding-top: 22px;
  padding-bottom: 10px;
}
.about-copy-grid{
  display:grid;
  grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
  gap: 26px;
  align-items:start;
}
.about-copy-grid p{
  margin-bottom: 16px;
}
@media (max-width: 980px){
  .about-copy-grid{
    grid-template-columns: 1fr;
    gap: 14px;
  }
}


/* --- Mobile logo text smoothing + topbar/header spacing fix --- */
.topbar .container{
  display:grid;
  grid-template-columns: auto 1fr auto;
  align-items:center;
  gap:16px;
  max-width:1500px;
  margin:0 auto;
  padding:10px 22px;
}

.topbar-center-text{
  justify-self:start;
  text-align:left;
  white-space:nowrap;
  font-size:0.92rem;
  font-weight:700;
}

.topbar-inline-divider{
  display:inline-block;
  margin-left:12px;
  margin-right:2px;
  color:rgba(111,240,93,0.45);
}

.license-group{
  justify-self:start;
  display:flex;
  align-items:center;
  gap:14px;
  white-space:nowrap;
  flex-wrap:nowrap;
  font-size:0.9rem;
}

.license-divider{
  color:rgba(111,240,93,0.5);
  font-weight:700;
}

.topbar a[href^="tel:"],
.topbar .phone-link,
.topbar .topbar-phone{
  justify-self:end;
  white-space:nowrap;
  margin-left:12px;
}

@media (min-width: 981px){
  .header-inner{
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:16px !important;
    padding:14px 22px !important;
  }

  .brand{
    flex:0 1 295px !important;
    gap:12px !important;
    margin:0 !important;
  }

  .site-nav,
  .primary-nav,
  .nav-links{
    flex:1 1 auto !important;
    justify-content:flex-start !important;
    margin-left:18px !important;
    gap:10px !important;
    min-width:0 !important;
  }

  .header-actions,
  .header-cta,
  .header-right{
    margin-left:auto !important;
    gap:10px !important;
  }
}

@media (max-width: 1200px){
  .topbar .container{
    grid-template-columns:1fr;
    gap:6px;
    text-align:center;
  }

  .topbar-center-text,
  .license-group,
  .topbar a[href^="tel:"],
  .topbar .phone-link,
  .topbar .topbar-phone{
    justify-self:center;
    text-align:center;
  }

  .topbar-center-text{
    white-space:normal;
  }

  .license-group{
    white-space:normal;
    flex-wrap:wrap;
    justify-content:center;
  }

  .topbar-inline-divider{
    margin-left:8px;
  }
}

@media (max-width: 980px){
  .header-inner{
    display:grid !important;
    grid-template-columns:auto 1fr auto !important;
    align-items:center !important;
    gap:12px !important;
    padding:12px 14px !important;
  }

  .brand{
    display:grid !important;
    grid-template-columns:56px minmax(0,1fr) !important;
    align-items:center !important;
    gap:10px !important;
    margin:0 !important;
    min-width:0 !important;
  }

  .logo{
    width:56px !important;
    height:56px !important;
    border-radius:14px !important;
  }

  .brand-text{
    min-width:0 !important;
    max-width:none !important;
    overflow:visible !important;
  }

  .brand-text strong{
    font-size:0.88rem !important;
    line-height:1.04 !important;
    white-space:nowrap !important;
    letter-spacing:-0.01em;
  }

  .brand-text span{
    font-size:0.52rem !important;
    line-height:1.18 !important;
    white-space:normal !important;
    max-width:150px !important;
  }

  .site-nav,
  .primary-nav,
  .nav-links{
    display:none !important;
  }
}

@media (max-width: 640px){
  .header-inner{
    gap:10px !important;
    padding:10px 12px !important;
  }

  .brand{
    grid-template-columns:52px minmax(0,1fr) !important;
    gap:9px !important;
  }

  .logo{
    width:52px !important;
    height:52px !important;
  }

  .brand-text strong{
    font-size:0.84rem !important;
  }

  .brand-text span{
    font-size:0.50rem !important;
    max-width:138px !important;
  }
}


/* --- Final requested topbar / header / mobile brand fixes --- */
.topbar .container{
  display:grid !important;
  grid-template-columns: auto auto 1fr auto !important;
  align-items:center !important;
  gap: 12px !important;
  max-width: 1500px !important;
  margin: 0 auto !important;
  padding: 10px 20px !important;
}

.topbar-center-text{
  justify-self:start !important;
  text-align:left !important;
  white-space:nowrap !important;
  font-size:0.91rem !important;
  font-weight:700 !important;
  line-height:1.2 !important;
}

.topbar-inline-divider{
  display:inline-block !important;
  margin-left:8px !important;
  color:rgba(111,240,93,0.45) !important;
  font-weight:700 !important;
}

.license-group{
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  white-space:nowrap !important;
  flex-wrap:nowrap !important;
  font-size:0.89rem !important;
  line-height:1.2 !important;
}

.license-divider{
  color:rgba(111,240,93,0.5) !important;
  font-weight:700 !important;
}

.topbar a[href^="tel:"],
.topbar .phone-link,
.topbar .topbar-phone{
  justify-self:end !important;
  white-space:nowrap !important;
  margin-left:8px !important;
  font-weight:700 !important;
}

@media (min-width: 981px){
  .header-inner{
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:14px !important;
    padding:14px 20px !important;
  }

  .brand{
    flex:0 1 280px !important;
    gap:10px !important;
    margin:0 !important;
    min-width:0 !important;
  }

  .logo{
    width:60px !important;
    height:60px !important;
  }

  .brand-text{
    max-width:195px !important;
  }

  .brand-text strong{
    font-size:0.96rem !important;
  }

  .brand-text span{
    font-size:0.68rem !important;
  }

  .site-nav,
  .primary-nav,
  .nav-links{
    flex:1 1 auto !important;
    justify-content:flex-start !important;
    margin-left:8px !important;
    gap:9px !important;
    min-width:0 !important;
  }

  .header-actions,
  .header-cta,
  .header-right{
    margin-left:auto !important;
    gap:8px !important;
  }

  .social-links a,
  .header-socials a,
  .social-icons a{
    width:36px !important;
    height:36px !important;
  }
}

@media (max-width: 1200px){
  .topbar .container{
    grid-template-columns:1fr !important;
    gap:4px !important;
    text-align:center !important;
  }

  .topbar-center-text,
  .license-group,
  .topbar a[href^="tel:"],
  .topbar .phone-link,
  .topbar .topbar-phone{
    justify-self:center !important;
    text-align:center !important;
  }

  .topbar-center-text,
  .license-group{
    white-space:normal !important;
  }

  .license-group{
    justify-content:center !important;
    flex-wrap:wrap !important;
  }
}

@media (max-width: 980px){
  .header-inner{
    display:grid !important;
    grid-template-columns:auto 1fr auto !important;
    align-items:center !important;
    gap:10px !important;
    padding:10px 12px !important;
  }

  .brand{
    display:grid !important;
    grid-template-columns:50px minmax(0,1fr) !important;
    align-items:center !important;
    gap:8px !important;
    margin:0 !important;
    min-width:0 !important;
  }

  .logo{
    width:50px !important;
    height:50px !important;
    border-radius:12px !important;
  }

  .brand-text{
    min-width:0 !important;
    max-width:none !important;
    overflow:visible !important;
  }

  .brand-text strong{
    font-size:0.80rem !important;
    line-height:1.02 !important;
    white-space:nowrap !important;
    letter-spacing:-0.01em !important;
    padding-bottom:2px !important;
  }

  .brand-text span{
    font-size:0.48rem !important;
    line-height:1.16 !important;
    white-space:normal !important;
    max-width:126px !important;
  }

  .site-nav,
  .primary-nav,
  .nav-links{
    display:none !important;
  }
}

@media (max-width: 640px){
  .header-inner{
    gap:8px !important;
    padding:9px 10px !important;
  }

  .brand{
    grid-template-columns:46px minmax(0,1fr) !important;
    gap:7px !important;
  }

  .logo{
    width:46px !important;
    height:46px !important;
  }

  .brand-text strong{
    font-size:0.76rem !important;
    padding-bottom:3px !important;
  }

  .brand-text span{
    font-size:0.46rem !important;
    max-width:118px !important;
  }
}


/* Match desktop header spacing to approved layout */
@media (min-width: 981px){
  .header-inner{
    padding:14px 22px !important;
    gap:18px !important;
  }

  .brand{
    flex:0 0 330px !important;
    max-width:330px !important;
  }

  .site-nav,
  .primary-nav,
  .nav-links{
    justify-content:flex-start !important;
    margin-left:34px !important;
    gap:18px !important;
    flex:1 1 auto !important;
  }

  .site-nav > a,
  .primary-nav > a,
  .nav-links > a,
  .nav-link-main{
    font-size:0.94rem !important;
  }

  .header-actions,
  .header-cta,
  .header-right{
    margin-left:18px !important;
    gap:14px !important;
  }

  .btn-call,
  .header-actions .btn,
  .header-cta .btn{
    margin-right:10px !important;
    padding:12px 20px !important;
  }

  .social-links,
  .header-socials,
  .social-icons{
    gap:12px !important;
  }
}


/* Center the top bar content on desktop */
@media (min-width: 981px){
  .topbar .container{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    gap:18px !important;
    padding:10px 24px !important;
  }

  .topbar-center-text,
  .license-group,
  .topbar a[href^="tel:"],
  .topbar .phone-link,
  .topbar .topbar-phone{
    justify-self:auto !important;
    text-align:center !important;
    margin:0 !important;
  }

  .license-group{
    gap:10px !important;
  }
}


/* Final desktop alignment adjustment requested */
@media (min-width: 981px){
  .header-inner{
    padding-left:48px !important;
    padding-right:26px !important;
    gap:20px !important;
  }

  .brand{
    flex:0 0 355px !important;
    max-width:355px !important;
    margin-left:18px !important;
  }

  .site-nav,
  .primary-nav,
  .nav-links{
    margin-left:58px !important;
    justify-content:flex-start !important;
    gap:18px !important;
  }

  .header-actions,
  .header-cta,
  .header-right{
    margin-left:auto !important;
  }
}


/* Rebalanced desktop header so the whole composition feels centered */
@media (min-width: 981px){
  .site-header{
    position: relative;
  }

  .header-inner{
    max-width: 1420px !important;
    margin: 0 auto !important;
    padding: 14px 32px !important;
    display: grid !important;
    grid-template-columns: 300px minmax(0,1fr) auto !important;
    align-items: center !important;
    column-gap: 28px !important;
  }

  .brand{
    margin: 0 0 0 18px !important;
    max-width: 300px !important;
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    justify-self: start !important;
  }

  .logo{
    width: 60px !important;
    height: 60px !important;
  }

  .brand-text{
    max-width: 210px !important;
    margin: 0 !important;
  }

  .brand-text strong{
    font-size: 0.98rem !important;
    line-height: 1.04 !important;
  }

  .brand-text span{
    font-size: 0.69rem !important;
    line-height: 1.22 !important;
  }

  .site-nav,
  .primary-nav,
  .nav-links{
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 16px !important;
    margin: 0 !important;
    min-width: 0 !important;
    justify-self: center !important;
  }

  .site-nav > a,
  .primary-nav > a,
  .nav-links > a,
  .nav-link-main{
    font-size: 0.95rem !important;
    white-space: nowrap !important;
  }

  .nav-dropdown{
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
  }

  .nav-drop-toggle{
    width: 36px !important;
    height: 36px !important;
  }

  .header-actions,
  .header-cta,
  .header-right{
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    justify-self: end !important;
    margin: 0 8px 0 0 !important;
  }

  .btn-call,
  .header-actions .btn,
  .header-cta .btn{
    padding: 12px 18px !important;
    font-size: 0.9rem !important;
    margin: 0 !important;
  }

  .social-links,
  .header-socials,
  .social-icons{
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin: 0 !important;
  }

  .social-links a,
  .header-socials a,
  .social-icons a{
    width: 38px !important;
    height: 38px !important;
  }
}

/* Make the top bar feel centered with the header width */
@media (min-width: 981px){
  .topbar .container{
    max-width: 1420px !important;
    margin: 0 auto !important;
    padding-left: 32px !important;
    padding-right: 32px !important;
  }
}


/* Tighten desktop header spacing further */
@media (min-width: 981px){
  .header-inner{
    max-width: 1380px !important;
    padding: 14px 26px !important;
    grid-template-columns: 270px minmax(0,1fr) auto !important;
    column-gap: 18px !important;
  }

  .brand{
    max-width: 270px !important;
    margin-left: 8px !important;
    gap: 10px !important;
  }

  .logo{
    width: 56px !important;
    height: 56px !important;
  }

  .brand-text{
    max-width: 190px !important;
  }

  .brand-text strong{
    font-size: 0.95rem !important;
  }

  .brand-text span{
    font-size: 0.66rem !important;
  }

  .site-nav,
  .primary-nav,
  .nav-links{
    gap: 13px !important;
    justify-content: flex-start !important;
    padding-left: 6px !important;
  }

  .header-actions,
  .header-cta,
  .header-right{
    gap: 10px !important;
    margin-right: 0 !important;
  }

  .btn-call,
  .header-actions .btn,
  .header-cta .btn{
    padding: 11px 17px !important;
    font-size: 0.88rem !important;
  }

  .social-links,
  .header-socials,
  .social-icons{
    gap: 8px !important;
  }

  .social-links a,
  .header-socials a,
  .social-icons a{
    width: 36px !important;
    height: 36px !important;
  }
}


/* Reduce oversized gap between logo block and Home so both sides feel balanced */
@media (min-width: 981px){
  .header-inner{
    grid-template-columns: 245px minmax(0,1fr) auto !important;
    column-gap: 10px !important;
    max-width: 1360px !important;
  }

  .brand{
    max-width: 245px !important;
    margin-left: 6px !important;
    gap: 9px !important;
  }

  .brand-text{
    max-width: 170px !important;
  }

  .site-nav,
  .primary-nav,
  .nav-links{
    padding-left: 0 !important;
    margin-left: -18px !important;
    gap: 13px !important;
    justify-content: flex-start !important;
  }
}


/* Tighten the logo-to-Home gap one more step */
@media (min-width: 981px){
  .header-inner{
    grid-template-columns: 228px minmax(0,1fr) auto !important;
    column-gap: 6px !important;
    max-width: 1345px !important;
    padding-left: 22px !important;
    padding-right: 22px !important;
  }

  .brand{
    max-width: 228px !important;
    margin-left: 2px !important;
    gap: 8px !important;
  }

  .logo{
    width: 54px !important;
    height: 54px !important;
  }

  .brand-text{
    max-width: 158px !important;
  }

  .brand-text strong{
    font-size: 0.92rem !important;
  }

  .brand-text span{
    font-size: 0.63rem !important;
  }

  .site-nav,
  .primary-nav,
  .nav-links{
    margin-left: -30px !important;
    padding-left: 0 !important;
    gap: 12px !important;
    justify-content: flex-start !important;
  }

  .header-actions,
  .header-cta,
  .header-right{
    gap: 9px !important;
  }
}


/* Requested fresh updates */
.page-banner-overlay{
  background: linear-gradient(180deg, rgba(0,0,0,0.10) 0%, rgba(0,0,0,0.14) 100%) !important;
}

.about-hero-fit,
.about-tpa-hero-fit,
.areas-hero-fit,
.estimates-hero-fit,
.contact-hero-fit{
  background-repeat: no-repeat !important;
  background-position: center center !important;
  background-size: contain !important;
  background-color: #091009 !important;
  min-height: 540px !important;
}

@media (max-width: 980px){
  .about-hero-fit,
  .about-tpa-hero-fit,
  .areas-hero-fit,
  .estimates-hero-fit,
  .contact-hero-fit{
    min-height: 300px !important;
    background-size: contain !important;
    background-position: center center !important;
  }
}

/* Completed work grid + lightbox */
.completed-work-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:18px;
  margin-top: 26px;
}
.completed-card{
  padding:0;
  border:none;
  border-radius:22px;
  overflow:hidden;
  cursor:pointer;
  text-align:left;
  background:linear-gradient(180deg, rgba(12,18,12,.98), rgba(8,12,8,.98));
  border:1px solid rgba(111,240,93,.16);
  box-shadow:0 12px 34px rgba(0,0,0,.22);
}
.completed-card img{
  width:100%;
  height:320px;
  object-fit:contain;
  background:#050905;
  padding:10px;
}
.completed-card span{
  display:block;
  padding:12px 16px 16px;
  font-weight:700;
}
.lightbox{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.9);
  z-index:3000;
  padding:24px;
}
.lightbox.open{display:flex;}
.lightbox-image{
  max-width:min(1200px,90vw);
  max-height:84vh;
  object-fit:contain;
  border-radius:18px;
  background:#050905;
}
.lightbox-close{
  position:absolute;
  top:18px;
  right:18px;
  width:50px;
  height:50px;
  border:none;
  border-radius:999px;
  background:rgba(20,20,20,.92);
  color:#fff;
  font-size:2rem;
  cursor:pointer;
}
.lightbox-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:54px;
  height:54px;
  border:none;
  border-radius:999px;
  background:rgba(20,20,20,.88);
  color:#fff;
  font-size:2rem;
  cursor:pointer;
}
.lightbox-prev{left:18px;}
.lightbox-next{right:18px;}
.lightbox-counter{
  position:absolute;
  bottom:18px;
  left:50%;
  transform:translateX(-50%);
  padding:10px 16px;
  border-radius:999px;
  background:rgba(20,20,20,.80);
  color:#fff;
  font-weight:700;
}
@media (max-width: 980px){
  .completed-work-grid{grid-template-columns:1fr;}
  .completed-card img{height:260px;}
  .lightbox-nav{width:46px;height:46px;font-size:1.6rem;}
  .lightbox-prev{left:10px;}
  .lightbox-next{right:10px;}
}

/* Service page small lower-left label only */
.service-hero-label{
  position:absolute;
  left:34px;
  bottom:28px;
  z-index:5;
  max-width:460px;
  padding:14px 18px;
  border-radius:18px;
  background:rgba(6,12,9,.55);
  border:1px solid rgba(111,240,93,.18);
  box-shadow:0 14px 40px rgba(0,0,0,.26);
  color:#fff;
  font-weight:800;
  font-size:clamp(1.2rem,2.5vw,2rem);
  line-height:1.1;
  backdrop-filter: blur(4px);
}
@media (max-width: 980px){
  .service-hero-label{
    left:14px;
    right:14px;
    bottom:18px;
    max-width:none;
    font-size:1.2rem;
    padding:12px 14px;
  }
}


.completed-info-grid{
  display:grid;
  grid-template-columns:1.5fr .9fr;
  gap:20px;
  margin:36px 0 34px;
}

.completed-info-card,
.completed-stat-card{
  border-radius:28px;
  border:1px solid rgba(78,255,97,.12);
  background:linear-gradient(180deg, rgba(5,12,8,.96), rgba(3,8,5,.98));
  box-shadow:0 18px 50px rgba(0,0,0,.24);
}

.completed-info-text{
  padding:28px;
}

.completed-info-text h3{
  margin:0 0 18px;
  font-size:2rem;
}

.completed-info-text p{
  margin:0;
  font-size:1.15rem;
  line-height:1.7;
  color:rgba(255,255,255,.92);
}

.completed-info-side{
  display:flex;
  flex-direction:column;
  gap:18px;
}

.completed-stat-card{
  padding:34px 20px;
  text-align:center;
}

.completed-stat-card strong{
  display:block;
  color:#71ff65;
  font-size:2.5rem;
  line-height:1;
  margin-bottom:10px;
}

.completed-stat-card span{
  font-size:1.25rem;
  color:rgba(255,255,255,.9);
}

@media (max-width: 900px){
  .completed-info-grid{
    grid-template-columns:1fr;
  }
}


/* Completed work page tuned to match desired layout */
.completed-work-intro-wrap{
  padding-top: 22px;
  padding-bottom: 24px;
}
.completed-work-intro-shell{
  display:flex;
  justify-content:center;
}
.completed-work-intro-card{
  width:min(980px, 100%);
  padding:30px 34px;
  border-radius:28px;
  border:1px solid rgba(78,255,97,.12);
  background:linear-gradient(180deg, rgba(5,12,8,.96), rgba(3,8,5,.98));
  box-shadow:0 18px 50px rgba(0,0,0,.24);
}
.completed-work-intro-card h2{
  margin:14px 0 14px;
  font-size:clamp(2rem, 3vw, 3rem);
  line-height:1.1;
}
.completed-work-intro-card p{
  margin:0;
  max-width:1000px;
  font-size:1.18rem;
  line-height:1.7;
  color:rgba(255,255,255,.92);
}

.completed-work-section{
  padding-top: 34px;
}
.completed-work-section .section-heading{
  max-width: 980px;
  margin: 0 auto 24px;
}
.completed-work-section .section-heading h2{
  font-size:clamp(2rem, 2.7vw, 3rem);
  margin:14px 0 14px;
}
.completed-work-section .section-heading p{
  max-width: 980px;
  margin: 0 auto;
  font-size:1.1rem;
  line-height:1.65;
  color:rgba(255,255,255,.9);
}

.completed-info-grid{
  display:grid;
  grid-template-columns:1.45fr .9fr;
  gap:20px;
  margin:34px 0 36px;
  align-items:stretch;
}
.completed-info-card,
.completed-stat-card{
  border-radius:28px;
  border:1px solid rgba(78,255,97,.10);
  background:linear-gradient(180deg, rgba(5,12,8,.96), rgba(3,8,5,.98));
  box-shadow:0 18px 50px rgba(0,0,0,.22);
}
.completed-info-text{
  padding:28px;
  min-height: 320px;
}
.completed-info-text h3{
  margin:0 0 18px;
  font-size:1.95rem;
  line-height:1.12;
}
.completed-info-text p{
  margin:0;
  font-size:1.12rem;
  line-height:1.72;
  color:rgba(255,255,255,.92);
}
.completed-info-side{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.completed-stat-card{
  padding:28px 20px;
  text-align:center;
  min-height: 96px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.completed-stat-card strong{
  display:block;
  color:#71ff65;
  font-size:2.15rem;
  line-height:1;
  margin-bottom:10px;
}
.completed-stat-card span{
  font-size:1.15rem;
  color:rgba(255,255,255,.9);
}

@media (max-width: 900px){
  .completed-work-intro-card{
    padding:22px 20px;
  }
  .completed-work-intro-card h2{
    font-size:2rem;
  }
  .completed-work-intro-card p,
  .completed-work-section .section-heading p,
  .completed-info-text p{
    font-size:1rem;
  }
  .completed-info-grid{
    grid-template-columns:1fr;
  }
  .completed-info-text{
    min-height:auto;
  }
}


/* Interior pages: show full hero artwork without cropping */
.page-hero.page-banner{
  position: relative;
  overflow: hidden;
}

.page-hero.page-banner.about-full-fit,
.page-hero.page-banner.about-tpa-full-fit,
.page-hero.page-banner.areas-full-fit,
.page-hero.page-banner.estimates-full-fit,
.page-hero.page-banner.contact-full-fit{
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
  background-color: #091009 !important;
}

.about-full-fit,
.about-tpa-full-fit,
.areas-full-fit,
.estimates-full-fit,
.contact-full-fit{
  min-height: 520px !important;
}

@media (max-width: 980px){
  .about-full-fit,
  .about-tpa-full-fit,
  .areas-full-fit,
  .estimates-full-fit,
  .contact-full-fit{
    min-height: 320px !important;
    background-size: contain !important;
    background-position: center center !important;
  }
}

/* Matching interior info boxes */
.interior-intro-wrap{
  padding-top: 26px;
  padding-bottom: 24px;
}
.interior-intro-shell{
  display:flex;
  justify-content:center;
}
.interior-intro-card{
  width:min(980px, 100%);
  padding:30px 34px;
  border-radius:28px;
  border:1px solid rgba(78,255,97,.12);
  background:linear-gradient(180deg, rgba(5,12,8,.96), rgba(3,8,5,.98));
  box-shadow:0 18px 50px rgba(0,0,0,.24);
}
.interior-intro-card h2{
  margin:14px 0 14px;
  font-size:clamp(2rem, 3vw, 3rem);
  line-height:1.1;
}
.interior-intro-card p{
  margin:0;
  max-width:1000px;
  font-size:1.18rem;
  line-height:1.7;
  color:rgba(255,255,255,.92);
}

@media (max-width: 900px){
  .interior-intro-card{
    padding:22px 20px;
  }
  .interior-intro-card h2{
    font-size:2rem;
  }
  .interior-intro-card p{
    font-size:1rem;
  }
}


/* SEO accessibility helper */
.sr-only {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}


/* April 2026 update: crisper service heroes, dedicated completed work hero, larger before/after */
.page-hero.page-banner:not(.about-full-fit):not(.about-tpa-full-fit):not(.areas-full-fit):not(.estimates-full-fit):not(.contact-full-fit):not(.completed-work-full-fit){
  min-height: 500px !important;
  background-size: cover !important;
  background-position: center 34% !important;
}

.page-banner-overlay{
  background:
    linear-gradient(90deg, rgba(4,8,6,.52) 0%, rgba(4,8,6,.26) 42%, rgba(4,8,6,.14) 100%) !important,
    linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.12)) !important;
}

.container.page-hero-content{
  background: rgba(8, 16, 12, 0.10) !important;
  backdrop-filter: blur(2px) !important;
  -webkit-backdrop-filter: blur(2px) !important;
  box-shadow: 0 10px 28px rgba(0,0,0,0.10) !important;
}

.completed-work-full-fit{
  min-height: 520px !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  background-color: #091009 !important;
}

.before-after-shell{
  max-width: 1320px !important;
}
.before-after-gallery{
  grid-template-columns: repeat(3, minmax(0,1fr)) !important;
  gap: 24px !important;
}
.before-after-card{
  padding: 24px !important;
}
.before-after-frame{
  aspect-ratio: 4 / 3 !important;
  min-height: 340px !important;
}
.before-after-note{
  font-size: 1rem !important;
}

@media (max-width: 1200px){
  .before-after-gallery{
    grid-template-columns: 1fr !important;
  }
  .before-after-frame{
    min-height: 280px !important;
  }
  .page-hero.page-banner:not(.about-full-fit):not(.about-tpa-full-fit):not(.areas-full-fit):not(.estimates-full-fit):not(.contact-full-fit):not(.completed-work-full-fit){
    min-height: 400px !important;
    background-position: center center !important;
  }
  .completed-work-full-fit{
    min-height: 360px !important;
    background-size: cover !important;
  }
}


/* April 2026 final polish: homepage CTA copy, completed work hero, bigger before/after */
.completed-work-full-fit .page-banner-overlay{
  background: linear-gradient(90deg, rgba(5,10,7,.22) 0%, rgba(5,10,7,.10) 42%, rgba(5,10,7,.12) 100%) !important;
}
.completed-work-full-fit .service-hero-label{
  left: 34px;
  bottom: 28px;
}
.completed-work-full-fit .page-hero-content{
  display:none !important;
}

/* Keep service heroes crisp and less muddy */
.page-hero.page-banner:not(.about-full-fit):not(.about-tpa-full-fit):not(.areas-full-fit):not(.estimates-full-fit):not(.contact-full-fit):not(.completed-work-full-fit){
  background-size: cover !important;
  background-position: center center !important;
  min-height: 500px !important;
}
.page-hero.page-banner:not(.about-full-fit):not(.about-tpa-full-fit):not(.areas-full-fit):not(.estimates-full-fit):not(.contact-full-fit):not(.completed-work-full-fit)::before{
  background: linear-gradient(90deg, rgba(0,0,0,.30) 0%, rgba(0,0,0,.16) 45%, rgba(0,0,0,.12) 100%) !important;
}

/* Restore larger original-feel before/after cards */
.before-after-shell{
  max-width: 1500px !important;
}
.before-after-gallery{
  grid-template-columns: repeat(3, minmax(0,1fr)) !important;
  gap: 20px !important;
}
.before-after-card{
  padding: 14px !important;
}
.before-after-frame{
  aspect-ratio: 16 / 9 !important;
  min-height: 0 !important;
}
.before-after-range{
  margin-top: 14px !important;
}
.before-after-note{
  margin-top: 12px !important;
}
@media (max-width: 1200px){
  .before-after-gallery{
    grid-template-columns: 1fr !important;
  }
  .completed-work-full-fit .service-hero-label{
    left: 14px;
    right: 14px;
    bottom: 18px;
  }
}


/* April 16 targeted hero fixes */
.hero-water-damage{
  background-size: contain !important;
  background-position: center center !important;
  background-repeat:no-repeat !important;
  background-color:#0a0f0b !important;
  min-height: 500px !important;
}
.hero-biohazard{
  background-size: auto 100% !important;
  background-position: left center !important;
  background-repeat:no-repeat !important;
  background-color:#0a0f0b !important;
  min-height: 500px !important;
}
@media (max-width: 980px){
  .hero-water-damage,
  .hero-biohazard{
    background-size: cover !important;
    background-position: center center !important;
    min-height: 360px !important;
  }
}
.completed-card span{
  display:block !important;
  color:#f4f7f4 !important;
  background:rgba(5,10,7,.92) !important;
  font-weight:700 !important;
  font-size:1rem !important;
  line-height:1.35 !important;
  min-height:60px !important;
}


.footer-satisfaction-wrap{
  margin-top:18px;
  display:flex;
  justify-content:flex-start;
  align-items:center;
}
.footer-satisfaction-badge{
  width:118px;
  max-width:42vw;
  height:auto;
  display:block;
  filter:drop-shadow(0 10px 18px rgba(0,0,0,.35));
}



/* Match service page hero sizing/layout to the About / Contact style while keeping each page's own image */
.page-banner{
  min-height: 480px !important;
  display: grid !important;
  place-items: end start !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}

.page-hero-content{
  padding: 100px 0 46px !important;
  max-width: 760px !important;
  margin-bottom: 26px !important;
}

/* Service pages only: keep same hero dimensions as the other inner pages */
body.service-page .page-banner{
  min-height: 480px !important;
  background-size: cover !important;
  background-position: center center !important;
}

@media (max-width: 980px){
  .page-banner,
  body.service-page .page-banner{
    min-height: 360px !important;
    background-position: center center !important;
  }
}

/* === MOBILE + CSS CLEANUP PATCH === */

/* Prevent horizontal scrolling */
html, body {
  overflow-x: hidden;
  max-width: 100%;
}

/* Consistent hero sizing across pages */
.page-hero,
.service-hero,
.about-hero,
.contact-hero {
  min-height: 420px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 120px 20px 80px;
}

.page-hero-content {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}

/* Cleaner transparent hero card */
.page-hero-content,
.service-hero-content {
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(6px);
  border-radius: 20px;
  padding: 32px;
}

/* Mobile nav fixes */
@media (max-width: 768px) {
  .nav-links,
  .mobile-menu {
    width: 100%;
    flex-direction: column;
    gap: 12px;
  }

  .dropdown-menu {
    position: static;
    width: 100%;
    box-shadow: none;
    border-radius: 12px;
    margin-top: 8px;
  }

  .page-hero,
  .service-hero,
  .about-hero,
  .contact-hero {
    min-height: 320px;
    padding: 100px 16px 56px;
  }

  .page-hero-content,
  .service-hero-content {
    padding: 22px;
    border-radius: 16px;
  }

  .page-hero-content h1,
  .service-hero-content h1 {
    font-size: 2rem;
    line-height: 1.1;
  }

  .page-hero-content p,
  .service-hero-content p {
    font-size: 1rem;
  }

  .btn,
  .button,
  .cta-button {
    width: 100%;
    justify-content: center;
  }

  .card-grid,
  .services-grid,
  .gallery-grid,
  .review-grid {
    grid-template-columns: 1fr !important;
    gap: 20px;
  }

  .card,
  .service-card,
  .review-card {
    padding: 20px;
  }
}