:root{
  --brand-navy:#10263f;
  --brand-aqua:#00bcd4;
  --brand-aqua-2:#26c6da;
  --brand-surface:#f5f7fa;
  --brand-text:#1e1e1e;
  --bg:var(--brand-surface);
  --text:var(--brand-text);
  --muted:#4a5568;
  --line:#dde3ea;
  --accent:var(--brand-aqua);
  --accent-2:var(--brand-aqua-2);
  --dark:var(--brand-navy);
  --card:#ffffff;
  --font-body:'Inter',system-ui,Segoe UI,Arial,sans-serif;
  --font-head:'Poppins',system-ui,Segoe UI,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--font-body);background:var(--brand-surface);color:var(--text);line-height:1.65}
h1,h2,h3{font-family:var(--font-head);text-align:center;font-weight:700}
.section > p,.section .muted{text-align:center}
.container{max-width:1200px;margin:0 auto;padding:0 18px}
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,255,255,.96);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(14px);
  transition:background .28s ease,border-color .28s ease,box-shadow .28s ease;
  will-change:transform;
}
.site-header:not(.site-header--transparent) .brand--logo-lockup img{
  filter:contrast(1.18) saturate(1.08) drop-shadow(0 0.5px 0 rgba(15,23,42,.25));
}
body.has-hero-header .site-header.site-header--transparent{
  position:fixed;
  top:0;
  left:0;
  right:0;
  background:transparent;
  border-bottom:1px solid rgba(255,255,255,.12);
  box-shadow:none;
}
body.has-hero-header .site-header.site-header--transparent.site-header--solid{
  background:rgba(16,38,63,.96);
  border-bottom-color:rgba(255,255,255,.12);
  box-shadow:0 10px 30px rgba(0,0,0,.2);
}
/* After scroll: nav was reverting to dark gray on navy (unreadable). Force light chrome. */
body.has-hero-header .site-header.site-header--transparent.site-header--solid .brand,
body.has-hero-header .site-header.site-header--transparent.site-header--solid .brand-wordmark,
body.has-hero-header .site-header.site-header--transparent.site-header--solid .brand-wordmark-light{
  color:#fff;
}
body.has-hero-header .site-header.site-header--transparent.site-header--solid .nav-main a{
  color:rgba(255,255,255,.92);
}
body.has-hero-header .site-header.site-header--transparent.site-header--solid .nav-main a:hover,
body.has-hero-header .site-header.site-header--transparent.site-header--solid .nav-main a:focus-visible{
  color:var(--brand-aqua);
}
body.has-hero-header .site-header.site-header--transparent.site-header--solid .nav-main a.active{
  color:#fff;
  box-shadow:0 2px 0 var(--brand-aqua);
}
body.has-hero-header .site-header.site-header--transparent.site-header--solid .btn-nav-call{
  border-color:rgba(255,255,255,.45);
  color:#fff;
  background:rgba(255,255,255,.1);
}
body.has-hero-header .site-header.site-header--transparent.site-header--solid .btn-nav-quote{
  box-shadow:0 8px 24px rgba(0,0,0,.28);
}
body.has-hero-header .site-header.site-header--transparent:not(.site-header--solid){
  background:rgba(24,26,30,.92);
  border-bottom-color:rgba(255,255,255,.1);
  backdrop-filter:blur(14px);
}
body.has-hero-header .site-header.site-header--transparent.site-header--solid .menu-toggle{
  border-color:rgba(255,255,255,.5);
  background:rgba(255,255,255,.12);
  color:#fff;
}
body.has-hero-header .site-header.site-header--transparent{
  z-index:150;
}
.header-shell{
  display:flex;
  align-items:center;
  gap:14px;
  padding:10px 16px;
  max-width:1200px;
  margin:0 auto;
}
.header-right{
  display:flex;
  flex:1;
  align-items:center;
  justify-content:flex-end;
  gap:12px 18px;
  min-width:0;
  flex-wrap:wrap;
}
.brand{
  text-decoration:none;
  color:var(--brand-navy);
  font-weight:700;
  font-size:14px;
  letter-spacing:.02em;
  display:flex;
  align-items:center;
  gap:12px;
  flex-shrink:0;
}
.brand img{height:48px;width:auto;display:block;object-fit:contain}
.brand--logo-lockup img{height:clamp(44px,5.2vw,56px)}
.brand-wordmark{display:none;font-family:var(--font-head)}
@media(min-width:900px){
  .brand-wordmark{display:inline;line-height:1.1}
  .brand-wordmark-light{font-weight:600;opacity:.88}
}
.site-header--transparent:not(.site-header--solid) .brand{color:#fff}
.site-header--transparent:not(.site-header--solid) .brand-wordmark,
.site-header--transparent:not(.site-header--solid) .brand-wordmark-light{color:#fff}
.nav-main{
  display:flex;
  flex:0 1 auto;
  justify-content:flex-end;
  align-items:center;
  flex-wrap:wrap;
  gap:6px 14px;
  padding:0 8px;
}
.nav-main a{
  color:#334155;
  text-decoration:none;
  white-space:nowrap;
  font-size:13px;
  font-weight:600;
  padding:6px 4px;
  border-radius:6px;
}
.nav-main a:hover,.nav-main a:focus-visible{color:var(--brand-aqua)}
.nav-main a.active{color:var(--brand-navy);box-shadow:0 2px 0 var(--brand-aqua)}
.site-header--transparent:not(.site-header--solid) .nav-main a{color:rgba(255,255,255,.9)}
.site-header--transparent:not(.site-header--solid) .nav-main a:hover{color:#fff}
.site-header--transparent:not(.site-header--solid) .nav-main a.active{color:#fff;box-shadow:0 2px 0 var(--brand-aqua)}
.header-cta-group{display:flex;align-items:center;gap:10px;flex-shrink:0}
.btn-nav-call{
  padding:10px 16px;
  border-radius:999px;
  font-weight:700;
  font-size:13px;
  text-decoration:none;
  border:1px solid rgba(16,38,63,.25);
  color:var(--brand-navy);
  background:#fff;
  transition:transform .28s cubic-bezier(0.22,1,0.36,1),box-shadow .28s cubic-bezier(0.22,1,0.36,1),border-color .28s cubic-bezier(0.22,1,0.36,1),background .28s cubic-bezier(0.22,1,0.36,1);
}
.btn-nav-quote{
  padding:10px 18px;
  border-radius:999px;
  font-weight:700;
  font-size:13px;
  text-decoration:none;
  background:linear-gradient(135deg,var(--brand-aqua),var(--brand-aqua-2));
  color:#fff;
  border:0;
  box-shadow:0 8px 22px rgba(0,188,212,.35);
  transition:transform .28s cubic-bezier(0.22,1,0.36,1),box-shadow .28s cubic-bezier(0.22,1,0.36,1),filter .28s cubic-bezier(0.22,1,0.36,1);
}
.btn-nav-quote:hover{
  filter:brightness(1.06);
}
.site-header--transparent:not(.site-header--solid) .btn-nav-call{
  border:1px solid rgba(255,255,255,.55);
  color:#fff;
  background:rgba(10,10,12,.82);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.site-header--transparent:not(.site-header--solid) .btn-nav-call:hover{
  background:rgba(18,18,22,.92);
  border-color:rgba(255,255,255,.65);
}
.site-header--transparent:not(.site-header--solid) .btn-nav-quote{
  box-shadow:0 8px 24px rgba(0,0,0,.25);
}
.btn-nav-call:hover,.btn-nav-quote:hover{transform:translateY(-3px)}
.menu-toggle{
  display:none;
  margin-left:auto;
  border:1px solid rgba(16,38,63,.2);
  background:#fff;
  border-radius:10px;
  padding:9px 14px;
  font-weight:700;
  font-size:13px;
  color:var(--brand-navy);
  cursor:pointer;
}
.site-header--transparent:not(.site-header--solid) .menu-toggle{
  border-color:rgba(255,255,255,.5);
  background:rgba(255,255,255,.12);
  color:#fff;
}
.content{padding:0 0 92px}
main.content:not(:has(.hero--home)){
  padding-bottom:68px;
}
main.content:has(.hero--home){
  padding-bottom:58px;
}
.content > *{max-width:none;margin-inline:0;padding-inline:clamp(16px,3.2vw,42px)}
.content > .hero.hero--image,
.content > .hero.hero--video,
.content > .hero.hero--spa{
  padding-inline:0;
}
.content > .services-page{
  padding-inline:0;
}
.services-page > *:not(.hero):not(.full-bleed){
  padding-inline:clamp(16px,3.2vw,42px);
}
.hero-trust-chip{
  display:inline-flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
  margin:22px auto 0;
  padding:12px 20px;
  border-radius:14px;
  background:rgba(2,6,23,.45);
  border:1px solid rgba(255,255,255,.2);
  max-width:520px;
}
.hero-trust-chip img{height:22px;width:auto}
.hero-trust-chip span{font-size:14px;font-weight:600;color:#fef9c3}
.hero--video.hero--home .hero-content--stacked{
  min-height:min(86vh,920px);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding-bottom:clamp(28px,5vh,56px);
}
body.has-hero-header .hero--video.hero--home .hero-content--stacked{
  padding-top:clamp(96px,14vh,140px);
}
.hero--video.hero--home .hero-content-main{
  flex:1;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.hero--video.hero--home .hero-content-main .pill{
  color:rgba(255,255,255,.94);
  letter-spacing:.2em;
}
.hero--video.hero--home .hero-title-home{
  font-size:clamp(2.1rem,4.6vw,3.45rem);
  line-height:1.12;
  margin:12px 0;
}
.hero--video.hero--home .hero-title-home br{display:block}
.hero-trust-chip--prominent{
  flex-direction:column;
  align-items:center;
  gap:10px;
  margin:clamp(14px,2.5vh,24px) auto clamp(12px,2vh,20px);
  padding:16px clamp(18px,3vw,28px) 18px;
  max-width:400px;
  width:100%;
  position:relative;
  z-index:3;
  background:rgba(2,6,23,.72);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.18);
  border-radius:16px;
  box-shadow:0 16px 40px rgba(0,0,0,.35);
}
.hero-trust-chip--prominent .hero-star-row{
  display:flex;
  align-items:flex-end;
  justify-content:center;
  gap:4px 10px;
  line-height:1;
}
.hero-star-gold{
  font-size:clamp(1.35rem,3.2vw,1.85rem);
  color:#fbbf24;
  text-shadow:0 0 12px rgba(250,204,21,.55),0 0 22px rgba(245,158,11,.35);
}
.hero-star-gold--center{
  font-size:clamp(1.75rem,4vw,2.35rem);
  transform:translateY(-4px);
}
.hero-trust-caption{
  font-size:14px;
  font-weight:600;
  color:#fff;
  letter-spacing:.02em;
  text-align:center;
}
.quick-services-strip{
  background:#fff;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:22px 0;
}
.quick-services-inner{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px 8px;
  max-width:1100px;
  margin:0 auto;
}
.quick-service-link{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  text-decoration:none;
  color:var(--brand-navy);
  font-weight:700;
  font-size:12px;
  letter-spacing:.04em;
  text-transform:uppercase;
  padding:10px 14px;
  min-width:104px;
  border-radius:12px;
  transition:background .2s ease,color .2s ease;
}
.quick-service-link:hover{background:var(--brand-surface);color:var(--brand-aqua)}
.quick-service-ring{
  width:44px;
  height:44px;
  border-radius:50%;
  border:2px solid var(--brand-navy);
  opacity:.85;
}
.home-about{
  padding:38px 0;
}
.home-about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
  max-width:1120px;
  margin:0 auto;
  align-items:center;
}
.home-about-copy h2{text-align:left;font-size:clamp(1.6rem,2.8vw,2.35rem);margin:0 0 14px;color:var(--brand-navy)}
.home-about-copy p{text-align:left;color:var(--muted);margin:0 0 14px}
.home-about-list{list-style:none;margin:16px 0;padding:0}
.home-about-list li{
  padding:8px 0 8px 32px;
  position:relative;
  font-weight:600;
  color:var(--brand-text);
  text-align:left;
}
.home-about-list li::before{
  content:'';
  position:absolute;
  left:0;
  top:50%;
  transform:translateY(-50%);
  width:20px;
  height:20px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--brand-aqua),var(--brand-aqua-2));
  box-shadow:0 2px 8px rgba(0,188,212,.35);
}
.home-about-media img{
  width:100%;
  border-radius:16px;
  box-shadow:0 20px 50px rgba(16,38,63,.18);
  object-fit:cover;
  min-height:280px;
}
.reviews-section-home{padding:38px 0}
.reviews-section-home h2{font-size:clamp(1.6rem,2.6vw,2.2rem);color:var(--brand-navy)}
.home-services-head{margin-bottom:18px}
.home-service-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.home-service-card{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  min-height:300px;
  text-decoration:none;
  color:#fff;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:22px 18px;
  box-shadow:0 14px 36px rgba(15,23,42,.2);
  transition:transform .32s cubic-bezier(0.22,1,0.36,1),box-shadow .32s cubic-bezier(0.22,1,0.36,1);
}
.home-service-card:hover{transform:translateY(-5px);box-shadow:0 24px 52px rgba(15,23,42,.3)}
.home-service-card::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(2,6,23,.12) 0%,transparent 32%,rgba(16,38,63,.5) 62%,rgba(16,38,63,.92) 100%);
  z-index:0;
}
.home-service-card-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center 42%;
  z-index:-1;
}
.home-service-card h3,.home-service-card p{position:relative;z-index:2;margin:0;text-align:left}
.home-service-card h3{font-size:1.05rem;letter-spacing:.06em;text-transform:uppercase}
.home-service-card p{
  font-size:13px;
  opacity:.94;
  margin-top:8px;
  line-height:1.45;
  min-height:4.35em;
  max-width:36ch;
}
.home-service-more{
  display:inline-block;
  margin-top:10px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  color:var(--brand-aqua);
  position:relative;
  z-index:1;
}
.gallery-masonry{
  columns:3;
  column-gap:14px;
  max-width:1200px;
  margin:0 auto;
}
.gallery-masonry img{
  width:100%;
  margin-bottom:14px;
  border-radius:14px;
  display:block;
  break-inside:avoid;
  cursor:pointer;
  box-shadow:0 10px 28px rgba(15,23,42,.15);
  transition:transform .2s ease;
}
.gallery-masonry img:hover{transform:scale(1.02)}
.home-area-split{
  display:grid;
  grid-template-columns:1fr 1.05fr;
  gap:36px;
  max-width:1100px;
  margin:0 auto;
  align-items:center;
}
.home-area-split h2{text-align:left;color:var(--brand-navy)}
.home-area-split p,.home-area-split .muted{text-align:left}
.home-area-map img{width:100%;border-radius:16px;border:1px solid var(--line);box-shadow:0 14px 36px rgba(15,23,42,.1)}
.final-cta-premium{
  text-align:center;
  padding:38px clamp(16px,3vw,32px);
  background:linear-gradient(135deg,#10263f 0%,#0a1929 100%);
  color:#fff;
  border-radius:0;
}
.final-cta-premium h2{color:#fff;margin:0 0 12px;font-size:clamp(1.75rem,3vw,2.5rem)}
.final-cta-premium .muted{color:#cbd5e1;margin-bottom:16px}
.final-cta-premium .btn-navy{
  background:#fff;
  color:var(--brand-navy);
  border:0;
  box-shadow:0 8px 24px rgba(0,0,0,.15);
}
.final-cta-premium .btn-navy:hover{filter:none;background:#f0fdfa}
.trust-micro-strip{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
  padding:10px 0 2px;
}
.trust-micro-strip img{height:20px;width:auto}
@media(max-width:900px){
  .home-about-grid,.home-area-split{grid-template-columns:1fr}
  .home-about-copy h2,.home-about-copy p,.home-about-list li{text-align:center}
  .home-about-list li{padding-left:0}
  .home-about-list li::before{display:none}
  .home-service-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .gallery-masonry{columns:2}
  .footer-expanded{grid-template-columns:1fr 1fr}
  .footer-brand-col{grid-column:1/-1}
  .home-float-bar{grid-template-columns:repeat(3,minmax(0,1fr))}
  .home-trust-stats-grid{grid-template-columns:1fr}
  .home-trust-col .section-eyebrow,.home-trust-heading,.home-trust-lead,.home-trust-list li{text-align:center}
  .home-trust-list li{justify-content:center}
  .home-trust-cta{text-align:center}
  .home-trust-visual{padding-right:0;min-height:0}
  .home-trust-stats .home-stat-box{
    position:relative;
    top:auto;
    right:auto;
    transform:none;
    width:100%;
    max-width:440px;
    margin:-32px auto 0;
  }
  .home-gallery-bento{
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto;
  }
  .home-gallery-cell--1{grid-column:1 / -1;grid-row:1;min-height:220px}
  .home-gallery-cell--2{grid-column:1;grid-row:2}
  .home-gallery-cell--3{grid-column:2;grid-row:2}
  .home-gallery-cell--4{grid-column:1;grid-row:3}
  .home-gallery-cell--5{grid-column:2;grid-row:3}
}
@media(max-width:640px){
  .home-service-grid{grid-template-columns:1fr}
  .gallery-masonry{columns:1}
  .home-float-wrap{margin-top:-24px;padding-bottom:24px}
  .home-float-bar{grid-template-columns:repeat(2,minmax(0,1fr));padding:18px 12px;gap:8px 6px}
  .home-float-label{font-size:10px}
  .home-gallery-bento{grid-template-columns:1fr}
  .home-gallery-cell--1,.home-gallery-cell--2,.home-gallery-cell--3,.home-gallery-cell--4,.home-gallery-cell--5{
    grid-column:1;
    grid-row:auto;
    min-height:200px;
  }
}
.contact-two-col{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:28px;
  max-width:1120px;
  margin:0 auto;
  align-items:start;
}
.contact-hp{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.contact-form-success{color:#0f5132;background:#d1e7dd;border:1px solid #badbcc;border-radius:10px;padding:12px 14px;margin:0 0 14px;font-weight:600}
.contact-form-error{color:#842029;background:#f8d7da;border:1px solid #f5c2c7;border-radius:10px;padding:12px 14px;margin:0 0 14px;font-weight:600}
.contact-form-grid{display:grid;gap:12px}
.contact-form-grid input,.contact-form-grid textarea{
  width:100%;
  padding:14px 16px;
  border:1px solid var(--line);
  border-radius:12px;
  font-size:1rem;
  background:#fff;
}
.contact-form-grid textarea{resize:vertical;min-height:140px}
.contact-form-panel h2{text-align:left}
.contact-aside{display:flex;flex-direction:column;gap:16px}
.contact-aside-block{text-align:left}
.contact-aside-cta{margin-top:8px;display:inline-block}
.contact-aside-block h3{margin:0 0 8px;font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-navy)}
.contact-aside-block p{margin:0}
.contact-big-link{font-size:1.35rem;font-weight:800;color:var(--brand-navy);text-decoration:none}
.contact-big-link:hover{color:var(--brand-aqua)}
.contact-map-wrap{
  max-width:960px;
  margin:0 auto;
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 14px 36px rgba(15,23,42,.1);
  background:#e8edf4;
}
.contact-map-wrap img{
  width:100%;
  height:auto;
  display:block;
  vertical-align:top;
  object-fit:contain;
  object-position:center;
}
.contact-map-wrap.contact-map-wrap--circle{
  width:min(640px,92vw);
  max-width:640px;
  margin:16px auto 0;
  aspect-ratio:1/1;
  border-radius:50%;
  overflow:hidden;
  border:4px solid var(--brand-navy);
  box-shadow:0 20px 50px rgba(15,23,42,.2);
  background:#dbeafe;
}
.contact-map-wrap.contact-map-wrap--circle img{
  width:100%;
  height:100%;
  min-height:100%;
  object-fit:contain;
  object-position:center center;
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media(max-width:900px){
  .contact-two-col{grid-template-columns:1fr}
}
.hero{color:#fff;border-radius:0;box-shadow:none;margin-top:0}
.hero:not(.hero--video):not(.hero--spa):not(.hero--image){
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:30px;
  background:linear-gradient(135deg,#10263f 0%,#0a1929 52%,#0d2138 100%);
  padding:56px clamp(16px,3.2vw,42px);
}
.hero:not(.hero--video):not(.hero--spa):not(.hero--image){
  align-items:center;
  max-width:1200px;
  margin-left:auto;
  margin-right:auto;
  padding:clamp(48px,7vw,64px) clamp(16px,3.2vw,42px);
}
.hero h1{font-size:clamp(2rem,4vw,3.2rem);line-height:1.08;margin:12px 0;color:#fff}
.hero .muted{color:#cbd5e1}
.hero > div{text-align:center}
.hero:not(.hero--video):not(.hero--spa):not(.hero--image) > div{max-width:34rem;justify-self:start}
.hero:not(.hero--video):not(.hero--spa):not(.hero--image) img{width:100%;height:380px;object-fit:cover;border-radius:18px;box-shadow:0 20px 50px rgba(2,6,23,.45)}
@media(min-width:901px){
  .hero:not(.hero--video):not(.hero--spa):not(.hero--image) > div{text-align:left}
  .hero:not(.hero--video):not(.hero--spa):not(.hero--image) .btn-row{justify-content:flex-start}
}
.hero-media{border-radius:18px;overflow:hidden;box-shadow:0 20px 50px rgba(2,6,23,.45);min-height:380px}
.hero-media video{width:100%;height:100%;min-height:380px;display:block;object-fit:cover}
.hero--video{
  position:relative;
  display:block;
  min-height:74vh;
  overflow:hidden;
  padding:0;
  background:#031226;
}
.hero--video.hero--home{
  min-height:min(90vh,980px);
}
.hero--video .hero-bg-media{
  position:absolute;
  inset:0;
}
.hero--video .hero-bg-media video{
  width:100%;
  height:100%;
  min-height:100%;
  object-fit:cover;
  object-position:center center;
  display:block;
}
.hero--video .hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(115deg,rgba(2,6,23,.82) 12%,rgba(2,6,23,.56) 52%,rgba(2,6,23,.74) 100%);
}
.hero--video.hero--home .hero-overlay{
  background:
    linear-gradient(180deg,rgba(2,6,23,.42) 0%,rgba(8,23,42,.58) 45%,rgba(2,6,23,.72) 100%),
    linear-gradient(115deg,rgba(16,38,63,.62) 0%,rgba(2,6,23,.4) 48%,rgba(8,23,42,.66) 100%);
}
.hero.hero--video.hero--home{
  padding-bottom:clamp(72px,12vh,140px);
}
.hero--video.hero--home .hero-content .muted{color:#e8f0fa}
.hero--video.hero--home .btn-secondary-outline{
  background:rgba(8,10,14,.72);
  color:#fff;
  border:1px solid rgba(255,255,255,.55);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.hero--video.hero--home .btn-secondary-outline{
  transition:transform .28s cubic-bezier(0.22,1,0.36,1),background .28s cubic-bezier(0.22,1,0.36,1),border-color .28s cubic-bezier(0.22,1,0.36,1);
}
.hero--video.hero--home .btn-secondary-outline:hover{
  background:rgba(20,24,32,.88);
  border-color:rgba(255,255,255,.7);
  transform:translateY(-3px);
}
.hero--video .hero-content{
  position:relative;
  z-index:2;
  max-width:980px;
  margin:0 auto;
  padding:clamp(70px,11vh,130px) clamp(16px,3.2vw,42px);
  text-align:center;
}
body.has-hero-header .hero--video .hero-content{
  padding-top:clamp(100px,15vh,150px);
}
.hero-accent{color:#5eead4}
.hero--image{
  position:relative;
  display:block;
  min-height:74vh;
  overflow:hidden;
  padding:0;
  background:#031226;
}
.hero--image .hero-bg-media{
  position:absolute;
  inset:0;
}
.hero--image .hero-bg-media img{
  width:100%;
  height:100%;
  min-height:74vh;
  object-fit:cover;
  object-position:center 42%;
  display:block;
}
.hero--image .hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(115deg,rgba(2,6,23,.85) 10%,rgba(2,6,23,.5) 50%,rgba(2,6,23,.78) 100%);
}
.hero--image .hero-content{
  position:relative;
  z-index:2;
  max-width:980px;
  margin:0 auto;
  padding:clamp(70px,11vh,130px) clamp(16px,3.2vw,42px);
  text-align:center;
}
body.has-hero-header .hero--image .hero-content{
  padding-top:clamp(100px,15vh,150px);
}
.hero--image.hero--immersive{
  min-height:min(96vh,980px);
}
.hero--image.hero--immersive .hero-bg-media img{
  min-height:min(96vh,980px);
  object-position:center 40%;
}
.hero--image.hero--immersive .hero-overlay{
  background:
    linear-gradient(180deg,rgba(2,6,23,.5) 0%,rgba(8,23,42,.62) 42%,rgba(2,6,23,.78) 100%),
    linear-gradient(115deg,rgba(16,38,63,.72) 0%,rgba(2,6,23,.45) 48%,rgba(8,23,42,.7) 100%);
}
.hero-content--immersive{
  display:flex;
  justify-content:center;
  align-items:center;
  padding-bottom:clamp(56px,12vh,120px) !important;
}
.hero-content-immersive-inner{
  max-width:760px;
  margin:0 auto;
  text-align:center;
}
.hero-title-immersive{
  margin:12px 0 14px;
  font-size:clamp(2.1rem,4.8vw,3.5rem);
  line-height:1.06;
  font-weight:700;
  color:#fff;
  font-family:var(--font-head);
  letter-spacing:-.02em;
}
.hero-lead-immersive{
  margin:0 auto 22px;
  max-width:48ch;
  font-size:clamp(1.02rem,1.9vw,1.2rem);
  line-height:1.55;
  color:#e2e8f0 !important;
}
.hero--image.hero--immersive .hero-content .muted{color:#e2e8f0}
.hero-immersive-trust-row{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:8px 6px;
  margin-top:clamp(18px,3.5vh,28px);
  padding:12px 20px;
  border-radius:999px;
  background:rgba(2,6,23,.5);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 12px 36px rgba(0,0,0,.22);
  font-size:12px;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#f1f5f9;
  max-width:100%;
}
.hero-immersive-trust-row span[role="listitem"]{padding:2px 4px}
.hero-immersive-trust-sep{
  width:5px;
  height:5px;
  border-radius:50%;
  background:rgba(94,234,212,.85);
  flex-shrink:0;
}
.hero--image .btn-navy,.hero--image.hero--immersive .btn-navy{
  background:rgba(16,38,63,.88);
  border:1px solid rgba(255,255,255,.35);
  color:#fff;
}
.hero--image .btn-secondary-outline,.hero--image.hero--immersive .btn-secondary-outline{
  background:rgba(8,10,14,.72);
  color:#fff;
  border:1px solid rgba(255,255,255,.55);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  transition:transform .28s cubic-bezier(0.22,1,0.36,1),background .28s cubic-bezier(0.22,1,0.36,1),border-color .28s cubic-bezier(0.22,1,0.36,1);
}
.hero--image .btn-secondary-outline:hover,.hero--image.hero--immersive .btn-secondary-outline:hover{
  background:rgba(20,24,32,.88);
  border-color:rgba(255,255,255,.7);
  transform:translateY(-3px);
}
.hero--image .btn.ghost,.hero--image.hero--immersive .btn.ghost{
  border-color:#a8d8ff;
  color:#fff;
}
main.content:has(.hero--immersive){
  padding-bottom:58px;
}
.services-offering-card:hover{
  box-shadow:0 22px 52px rgba(15,23,42,.14);
}
.services-mid-cta-inner{
  box-shadow:0 20px 52px rgba(15,23,42,.1);
  border-color:#dbe3ec;
}
.services-section-head a{
  color:var(--brand-navy);
  font-weight:700;
  text-decoration:underline;
  text-decoration-color:rgba(0,188,212,.45);
  text-underline-offset:3px;
}
.services-section-head a:hover{color:var(--brand-aqua)}
.services-inline-links a{color:var(--brand-navy);font-weight:700;text-decoration:underline;text-underline-offset:3px}
.services-inline-links a:hover{color:var(--brand-aqua)}
.services-inline-links{text-align:center;margin-top:18px;font-size:14px}
@media(max-width:900px){
  .hero--image.hero--immersive{min-height:min(88vh,860px)}
  .hero--image.hero--immersive .hero-bg-media img{min-height:min(88vh,860px)}
  .hero-immersive-trust-row{font-size:11px;padding:10px 14px}
}
@media(max-width:640px){
  .hero-title-immersive{font-size:clamp(1.75rem,6.5vw,2.35rem)}
  .hero--image.hero--immersive .btn-row{flex-direction:column;width:100%;max-width:360px;margin:0 auto}
  .hero--image.hero--immersive .btn-row .btn{width:100%;text-align:center;min-height:48px;display:flex;align-items:center;justify-content:center}
}
.btn-primary-glow{
  transition:transform .3s cubic-bezier(0.22,1,0.36,1),box-shadow .3s cubic-bezier(0.22,1,0.36,1),filter .3s cubic-bezier(0.22,1,0.36,1);
}
.btn-primary-glow:hover{
  transform:translateY(-3px);
  box-shadow:0 20px 44px rgba(0,188,212,.5);
}
.btn-secondary-outline-light{
  background:transparent;
  color:#fff;
  border:2px solid rgba(255,255,255,.75);
  box-shadow:none;
}
.btn-secondary-outline-light:hover{
  background:rgba(255,255,255,.1);
  transform:translateY(-2px);
}
.home-float-wrap{
  position:relative;
  z-index:6;
  margin-top:clamp(-40px,-3.2vw,-26px);
  padding:0 18px 32px;
  pointer-events:none;
}
.home-float-wrap .container{pointer-events:auto}
.home-float-bar{
  position:relative;
  z-index:7;
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:10px 8px;
  align-items:start;
  background:#fff;
  border-radius:24px;
  padding:22px 18px;
  box-shadow:0 22px 50px rgba(15,23,42,.14);
  border:1px solid rgba(226,232,240,.95);
}
.home-float-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:var(--brand-navy);
  text-align:center;
  font-weight:700;
  font-size:11px;
  line-height:1.25;
  letter-spacing:.04em;
  text-transform:uppercase;
  padding:6px 4px;
  border-radius:12px;
  transition:color .28s cubic-bezier(0.22,1,0.36,1),background .28s cubic-bezier(0.22,1,0.36,1),transform .28s cubic-bezier(0.22,1,0.36,1);
}
.home-float-item:hover{
  color:var(--brand-aqua);
  background:rgba(0,188,212,.06);
  transform:translateY(-3px);
}
.home-float-icon{
  width:44px;
  height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--brand-navy);
}
.home-float-icon svg{width:28px;height:28px;display:block}
.home-float-label{max-width:11em}
.section-eyebrow{
  text-align:center;
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--brand-aqua);
  margin:0 0 12px;
  font-family:var(--font-body);
}
.section-eyebrow--on-dark{color:#7dd3fc}
.home-services-block .section-eyebrow{margin-bottom:6px}
.home-services-block .home-services-head h2{margin-top:0}
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .55s ease,transform .55s ease;
  transition-delay:60ms;
}
.reveal.reveal--visible{
  opacity:1;
  transform:none;
}
@media (prefers-reduced-motion: reduce){
  .reveal,.reveal.reveal--visible{
    opacity:1;
    transform:none;
    transition:none;
  }
}
.reviews-section-home--premium.band{
  background:#e8eaef;
  border-top-color:#d9dde5;
  border-bottom-color:#d9dde5;
}
.reviews-section-inner--premium{
  max-width:1120px;
  margin:0 auto;
}
.reviews-section-title--premium{
  text-align:center;
  font-size:clamp(1.35rem,2.4vw,2rem);
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--brand-aqua);
  font-weight:700;
  margin:0 0 10px;
}
.reviews-section-lead--premium{
  text-align:center;
  max-width:52ch;
  margin:0 auto 18px;
}
.trustindex-wrapper--premium{
  margin-top:8px;
  background:#fff;
  border:0;
  border-radius:20px;
  padding:clamp(12px,2vw,22px);
  box-shadow:0 16px 40px rgba(15,23,42,.08);
}
.home-service-card-icon{
  position:absolute;
  left:18px;
  bottom:118px;
  width:52px;
  height:52px;
  border-radius:50%;
  background:var(--brand-navy);
  color:var(--brand-aqua);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:3;
  border:2px solid rgba(255,255,255,.35);
  box-shadow:0 10px 24px rgba(0,0,0,.28);
}
.home-service-card-icon svg{width:26px;height:26px;display:block}
.home-service-arrow{margin-left:4px}
.home-gallery-showcase{
  background:linear-gradient(180deg,#060f1a 0%,#10263f 55%,#0d2138 100%);
  color:#e2e8f0;
  padding:38px 0 28px;
  margin-top:38px;
  border-top:1px solid rgba(255,255,255,.06);
}
.home-gallery-showcase-head{text-align:center;max-width:720px;margin:0 auto}
.home-gallery-showcase-head h2{
  color:#fff;
  margin:0 0 12px;
  font-size:clamp(1.6rem,2.8vw,2.35rem);
}
.home-gallery-sub{color:#cbd5e1;margin:0}
.home-gallery-bento-wrap{max-width:1120px;margin:0 auto}
.home-gallery-bento{
  display:grid;
  grid-template-columns:1.25fr 1fr 1fr;
  grid-template-rows:minmax(170px,1fr) minmax(170px,1fr);
  gap:14px;
  margin-top:22px;
}
.home-gallery-cell{
  position:relative;
  overflow:hidden;
  border-radius:16px;
  min-height:150px;
  box-shadow:0 14px 36px rgba(0,0,0,.35);
}
.home-gallery-cell--1{grid-column:1;grid-row:1 / span 2}
.home-gallery-cell--2{grid-column:2;grid-row:1}
.home-gallery-cell--3{grid-column:3;grid-row:1}
.home-gallery-cell--4{grid-column:2;grid-row:2}
.home-gallery-cell--5{grid-column:3;grid-row:2}
.home-gallery-cell img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  min-height:160px;
  cursor:pointer;
  transition:transform .4s cubic-bezier(0.22,1,0.36,1);
}
.home-gallery-cell img:hover{transform:scale(1.035)}
.home-gallery-cta{text-align:center;margin:16px 0 0}
.home-trust-stats{
  background:#f1f5f9;
  padding:34px 0 38px;
  margin-top:34px;
  border-top:1px solid #e2e8f0;
  border-bottom:1px solid #e2e8f0;
}
.home-trust-stats-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1.18fr);
  gap:40px 12px;
  align-items:center;
  max-width:1180px;
  margin:0 auto;
}
.home-trust-visual{
  position:relative;
  padding-right:clamp(8px,4vw,52px);
  min-height:220px;
}
.home-trust-map-panel{
  background:#fff;
  border-radius:18px;
  padding:14px 14px 18px;
  box-shadow:0 22px 50px rgba(15,23,42,.1);
  border:1px solid #e2e8f0;
}
.home-trust-map-panel img{
  width:100%;
  display:block;
  border-radius:14px;
  vertical-align:middle;
}
.home-trust-stats .home-stat-box{
  position:absolute;
  right:0;
  top:50%;
  transform:translateY(-50%);
  width:min(300px,48%);
  margin:0;
}
.home-trust-col .section-eyebrow{text-align:left;margin-bottom:8px}
.home-trust-heading{
  text-align:left;
  color:var(--brand-navy);
  margin:0 0 10px;
  font-size:clamp(1.45rem,2.4vw,2rem);
}
.home-trust-lead{text-align:left;margin:0 0 6px}
.home-trust-list{
  list-style:none;
  margin:18px 0 0;
  padding:0;
  display:grid;
  gap:14px;
}
.home-trust-list li{
  display:flex;
  gap:12px;
  align-items:flex-start;
  text-align:left;
  font-weight:600;
  color:var(--brand-text);
  font-size:15px;
}
.home-trust-ico{
  flex-shrink:0;
  width:28px;
  height:28px;
  color:var(--brand-aqua);
  margin-top:1px;
}
.home-trust-ico svg{display:block;width:26px;height:26px}
.home-trust-cta{margin-top:22px}
.home-stat-box{
  background:linear-gradient(155deg,#10263f 0%,#071525 100%);
  color:#f1f5f9;
  padding:28px 24px;
  border-radius:18px;
  box-shadow:0 20px 48px rgba(2,6,23,.35);
  border:1px solid rgba(255,255,255,.08);
}
.home-stat-line{
  font-size:15px;
  line-height:1.45;
  margin-bottom:16px;
  color:#e2e8f0;
}
.home-stat-line:last-child{margin-bottom:0}
.home-stat-line strong{
  display:block;
  font-size:1.35rem;
  font-family:var(--font-head);
  color:#fff;
  letter-spacing:.02em;
  margin-bottom:4px;
}
.home-stat-stars .home-stat-star-icons{display:block;margin-top:8px}
.home-stat-stars img{height:22px;width:auto}
.btn-navy{
  background:var(--brand-navy);
  color:#fff;
  border:1px solid rgba(255,255,255,.25);
  box-shadow:0 12px 28px rgba(16,38,63,.35);
  transition:transform .28s cubic-bezier(0.22,1,0.36,1),filter .28s cubic-bezier(0.22,1,0.36,1),box-shadow .28s cubic-bezier(0.22,1,0.36,1);
}
.btn-navy:hover{filter:brightness(1.08);transform:translateY(-3px)}
.hero--video .btn-navy,.hero--spa .btn-navy{
  background:rgba(16,38,63,.88);
  border:1px solid rgba(255,255,255,.35);
}
.hero--video .hero-content .muted{
  color:#d7e6f6;
}
.hero--video .btn.ghost{
  border-color:#a8d8ff;
  color:#fff;
}
.hero:not(.hero--video):not(.hero--spa):not(.hero--image) .btn-navy{
  background:rgba(16,38,63,.88);
  border:1px solid rgba(255,255,255,.35);
  color:#fff;
}
.hero:not(.hero--video):not(.hero--spa):not(.hero--image) .btn-secondary-outline{
  background:rgba(8,10,14,.72);
  color:#fff;
  border:1px solid rgba(255,255,255,.55);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  transition:transform .28s cubic-bezier(0.22,1,0.36,1),background .28s cubic-bezier(0.22,1,0.36,1),border-color .28s cubic-bezier(0.22,1,0.36,1);
}
.hero:not(.hero--video):not(.hero--spa):not(.hero--image) .btn-secondary-outline:hover{
  background:rgba(20,24,32,.88);
  border-color:rgba(255,255,255,.7);
  transform:translateY(-3px);
}
.hero:not(.hero--video):not(.hero--spa):not(.hero--image) .btn.ghost{
  border-color:#a8d8ff;
  color:#fff;
}
.hero--spa{
  position:relative;
  display:block;
  min-height:68vh;
  overflow:hidden;
  padding:0;
  background:#031226;
}
.hero--spa .hero-bg-media{
  position:absolute;
  inset:0;
}
.hero--spa .hero-bg-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 28%;
  display:block;
}
.hero--spa .hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(118deg,rgba(2,6,23,.88) 0%,rgba(2,6,23,.45) 48%,rgba(2,6,23,.82) 100%);
}
.hero--spa .hero-content{
  position:relative;
  z-index:2;
  max-width:920px;
  margin:0 auto;
  padding:clamp(64px,10vh,120px) clamp(16px,3.2vw,42px);
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:0;
}
body.has-hero-header .hero--spa .hero-content{
  padding-top:clamp(96px,14vh,138px);
}
.hero--spa .hero-content .muted{color:#dbeafe}
.hero--spa .btn.ghost{border-color:#a8d8ff;color:#fff}
.hero--spa .btn-secondary-outline{
  background:rgba(8,10,14,.72);
  color:#fff;
  border:1px solid rgba(255,255,255,.55);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  transition:transform .28s cubic-bezier(0.22,1,0.36,1),background .28s cubic-bezier(0.22,1,0.36,1),border-color .28s cubic-bezier(0.22,1,0.36,1);
}
.hero--spa .btn-secondary-outline:hover{
  background:rgba(20,24,32,.88);
  border-color:rgba(255,255,255,.7);
  transform:translateY(-3px);
}
.hero--spa .pill{margin:0 0 16px}
.hero-title-spa{
  margin:0 0 14px;
  line-height:1.12;
  font-size:clamp(1.65rem,3.6vw,2.75rem);
}
.hero-title-spa-sub{
  display:block;
  margin-top:10px;
  font-size:clamp(1.05rem,2.1vw,1.4rem);
  font-weight:600;
  letter-spacing:-.01em;
}
.hero-dealer-lockup{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  margin:0 0 22px;
  padding:14px 22px 16px;
  background:rgba(255,255,255,.94);
  border-radius:14px;
  box-shadow:0 12px 40px rgba(2,6,23,.35);
  border:1px solid rgba(255,255,255,.65);
}
.garden-leisure-logo{
  width:min(168px,52vw);
  height:auto;
  display:block;
}
.hero-dealer-caption{
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:700;
  color:#0f172a;
  opacity:.78;
}
.spa-why-section{margin-top:44px}
.spa-why-split{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:40px;
  max-width:1120px;
  margin:0 auto;
  align-items:start;
}
.spa-why-copy h2{text-align:left;margin:0 0 14px;font-size:clamp(1.35rem,2.2vw,1.9rem);line-height:1.2}
.spa-why-copy h3{text-align:left;margin:26px 0 10px;font-size:1.2rem;color:#0f172a}
.spa-why-copy h4{text-align:left;margin:20px 0 8px;font-size:1.05rem;color:#0c4a6e}
.spa-why-copy p{text-align:left;color:var(--muted);margin:0 0 12px}
.spa-dealer-list{margin:0 0 6px;padding-left:1.2rem}
.spa-dealer-list li{margin:8px 0;font-weight:600;color:#0f172a}
.spa-benefits{margin:0;padding-left:1.15rem}
.spa-benefits li{margin:6px 0}
.spa-brand-panel{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:40px 28px;
  text-align:center;
  box-shadow:0 16px 44px rgba(15,23,42,.08);
  position:sticky;
  top:88px;
}
.spa-brand-panel-logo{width:min(300px,88%);height:auto;margin:0 auto 14px;display:block}
.spa-brand-panel .small{color:var(--muted);max-width:32ch;margin:0 auto}
.spa-products-band{
  background:#f1f5f9;
  border-top:1px solid #e2e8f0;
  border-bottom:1px solid #e2e8f0;
  padding:34px 0 40px;
}
.spa-section-eyebrow{
  text-align:center;
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  font-weight:800;
  color:var(--brand-aqua);
  margin:0 0 10px;
  font-family:var(--font-body);
}
.spa-products-band h2{margin-bottom:8px}
/* Compound selector beats later `.card` base so dark spa tiles keep contrast (was white card + light text). */
.card.spa-model-card--dark{
  background:linear-gradient(160deg,#3d4556 0%,#232a36 42%,#171c28 100%);
  color:#f1f5f9;
  border:1px solid #4b5563;
  box-shadow:0 14px 36px rgba(15,23,42,.22);
  padding:16px 14px 20px;
}
.card.spa-model-card--dark h3{color:#fff;margin:2px 0 8px;font-size:1.12rem}
.card.spa-model-card--dark .spa-model-thumb--dark{
  background:#0f172a;
  border-radius:12px;
  overflow:hidden;
  margin:0 0 12px;
  border:1px solid #64748b;
}
.card.spa-model-card--dark .spa-model-thumb--dark img{
  width:100%;
  height:200px;
  object-fit:cover;
  object-position:center;
  display:block;
}
.card.spa-model-card--dark .spa-model-specs{text-align:left;margin:0 auto 4px;padding:0 2px}
.card.spa-model-card--dark .small{color:#e2e8f0;opacity:1;font-size:13px;line-height:1.45;margin:5px 0}
.card.spa-model-card--dark .spa-spec-label{display:inline-block;min-width:3rem;color:#cbd5e1;font-weight:600;font-size:12px;text-transform:capitalize}
.card.spa-model-card--dark .btn-see-more{
  display:inline-block;
  margin-top:12px;
  padding:9px 22px;
  border:1px solid rgba(255,255,255,.88);
  color:#fff;
  border-radius:999px;
  font-size:13px;
  font-weight:700;
  text-decoration:none;
  transition:background .2s ease,color .2s ease,border-color .2s ease;
}
.card.spa-model-card--dark .btn-see-more:hover{background:#fff;color:#0f172a;border-color:#fff}
.spa-cta-wrap{
  background:#f1f5f9;
  border-top:1px solid #e2e8f0;
  border-bottom:1px solid #e2e8f0;
  padding:34px 0 42px;
}
.spa-cta-card{
  max-width:720px;
  margin:0 auto;
  background:#fff;
  border-radius:18px;
  padding:34px 26px 38px;
  box-shadow:0 18px 50px rgba(15,23,42,.1);
  border:1px solid var(--line);
  text-align:center;
}
.spa-cta-card h2{margin-top:0;margin-bottom:10px}
.spa-resources-band{
  background:linear-gradient(135deg,#10263f 0%,#0a1929 100%);
  padding:40px 0 44px;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.spa-resources-band h2{color:#fff;margin-bottom:8px}
.spa-resources-sub{
  text-align:center;
  color:#cbd5e1;
  font-size:clamp(1rem,2vw,1.12rem);
  margin:0 auto 26px;
  max-width:42ch;
  font-weight:500;
}
.spa-resource-grid{gap:18px}
.spa-resource-tile{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:12px;
  background:#fff;
  border-radius:14px;
  padding:26px 16px;
  text-decoration:none;
  color:#0f172a;
  border:1px solid rgba(255,255,255,.55);
  box-shadow:0 10px 28px rgba(15,23,42,.12);
  min-height:128px;
  transition:transform .2s ease,box-shadow .2s ease;
}
.spa-resource-tile:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(15,23,42,.18)}
.spa-resource-tile-icon{font-size:2.35rem;line-height:1}
.spa-resource-tile-label{font-weight:700;font-size:1rem;text-align:center;line-height:1.25}
.financing-tagline{text-align:center;color:#475569;margin:0 0 18px;font-size:1.05rem}
.spa-faq-section .faq-accordion{max-width:880px;margin:22px auto 0}
.faq-item{
  border:1px solid var(--line);
  border-radius:12px;
  margin-bottom:12px;
  background:#fff;
  overflow:hidden;
}
.faq-item summary{
  cursor:pointer;
  list-style:none;
  padding:16px 44px 16px 18px;
  font-weight:600;
  color:var(--brand-navy);
  position:relative;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";
  position:absolute;
  right:18px;
  top:50%;
  transform:translateY(-50%);
  color:var(--accent);
  font-size:1.35rem;
  font-weight:400;
  line-height:1;
}
.faq-item[open] summary::after{content:"\2212";font-size:1.5rem}
.faq-item p{margin:0;padding:0 18px 16px;color:var(--muted);font-size:.98rem;line-height:1.55}
.pill{display:inline-block;color:#7dd3fc;font-size:12px;letter-spacing:.19em;text-transform:uppercase;font-weight:700}
.btn-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.btn{padding:12px 18px;border-radius:999px;text-decoration:none;font-weight:700;display:inline-block}
.btn.primary{
  background:linear-gradient(135deg,var(--brand-aqua),var(--brand-aqua-2));
  color:#fff;
  box-shadow:0 12px 28px rgba(0,188,212,.32);
  border:0;
  transition:transform .28s cubic-bezier(0.22,1,0.36,1),box-shadow .28s cubic-bezier(0.22,1,0.36,1),filter .28s cubic-bezier(0.22,1,0.36,1);
}
.btn.primary:hover{transform:translateY(-3px);filter:brightness(1.04);box-shadow:0 18px 38px rgba(0,188,212,.42)}
.btn.ghost{border:1px solid rgba(255,255,255,.75);color:#fff;background:rgba(255,255,255,.06)}
.btn.ghost:hover{background:rgba(255,255,255,.14)}
.grid{display:grid;gap:16px}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:0 12px 30px rgba(15,23,42,.06)}
.card{text-align:center}
.card a{color:inherit;text-decoration:none}
.card h3{margin:0 0 8px}
.card p{margin:0}
.section{margin-top:56px}
.section h2{font-size:clamp(1.5rem,2.5vw,2.15rem);margin:0 0 12px;line-height:1.15}
main.content:not(:has(.hero--home)) > .section{
  margin-top:44px;
}
main.content:not(:has(.hero--home)) > .hero + .section,
main.content:not(:has(.hero--home)) > .hero + .full-bleed.section{
  margin-top:36px;
}
/** Tighter rhythm after star trust strip (remodels, new builds, services, financing, etc.). ~14% vs default section gap. */
main.content:not(:has(.hero--home)) > .section:has(.page-trust-strip) + .section{
  margin-top:38px;
}
main.content:has(.hero--home) > .section{
  margin-top:38px;
}
main.content:has(.hero--home) > .section.home-final-cta{
  margin-top:30px;
  margin-bottom:0;
}
.muted{color:var(--muted)}
.gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.gallery img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:14px;cursor:pointer;box-shadow:0 10px 28px rgba(15,23,42,.18);transition:transform .25s ease}
.gallery img:hover{transform:translateY(-4px) scale(1.01)}
.lightbox{position:fixed;inset:0;background:#020617eb;display:none;align-items:center;justify-content:center;padding:20px;z-index:200}
.lightbox img{max-width:92vw;max-height:90vh}
.site-footer{
  background:linear-gradient(180deg,#0d1f33 0%,#10263f 40%,#0a1628 100%);
  color:#e8edf4;
  margin-top:40px;
  padding:38px 0 16px;
}
.footer-expanded{
  display:grid;
  grid-template-columns:1.15fr repeat(3,minmax(0,1fr));
  gap:32px 28px;
  align-items:start;
}
.footer-col h3.footer-heading{
  font-family:var(--font-head);
  font-size:14px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#9ecbff;
  margin:0 0 14px;
  text-align:left;
}
.footer-heading--spaced{margin-top:22px}
.footer-brand-stack{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:10px;
  max-width:300px;
}
.footer-brand-stack .footer-logo{
  margin-bottom:0;
  width:min(200px,100%);
}
.footer-tagline{margin:0;font-size:.92rem;line-height:1.5;color:#cbd5e1;max-width:32ch}
.footer-trust-badges{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin-top:2px;
}
.footer-stars{height:26px;width:auto;display:block}
.footer-badge-img{width:60px;height:auto;border-radius:8px;display:block}
.footer-links{list-style:none;margin:0;padding:0}
.footer-links li{margin:8px 0}
.footer-links a{color:#fff;text-decoration:none;font-weight:600;font-size:15px}
.footer-links a:hover{color:var(--brand-aqua)}
.footer-links--compact li{color:#cbd5e1;font-size:14px;font-weight:500}
.footer-phone{margin:0 0 6px}
.footer-phone a{color:#fff;font-size:22px;font-weight:700;text-decoration:none}
.footer-phone a:hover{color:var(--brand-aqua)}
.footer-inline-cta{margin:14px 0 0}
.btn-footer-outline{
  display:inline-block;
  padding:10px 18px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.45);
  color:#fff;
  font-weight:700;
  font-size:13px;
  text-decoration:none;
}
.btn-footer-outline:hover{border-color:var(--brand-aqua);color:var(--brand-aqua)}
.btn-footer-aqua{
  display:inline-block;
  padding:10px 20px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--brand-aqua),var(--brand-aqua-2));
  color:#fff;
  font-weight:700;
  font-size:13px;
  text-decoration:none;
  box-shadow:0 8px 20px rgba(0,188,212,.25);
}
.btn-footer-aqua:hover{filter:brightness(1.05)}
.footer-logo{height:auto;width:min(220px,100%);display:block}
.small{font-size:13px;opacity:.88}
.footer-bottom{margin-top:36px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);text-align:center}
.footer-bottom p{margin:0;font-size:13px;color:#94a3b8}
.mobile-sticky{display:none}
.mobile-sticky--dual{
  display:none;
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:120;
  padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.97);
  border-top:1px solid var(--line);
  box-shadow:0 -8px 30px rgba(15,23,42,.12);
  gap:10px;
  justify-content:center;
}
.mobile-sticky--dual a{
  flex:1;
  text-align:center;
  padding:13px 12px;
  border-radius:12px;
  font-weight:800;
  font-size:14px;
  text-decoration:none;
  max-width:200px;
}
.mobile-sticky-call{
  background:var(--brand-navy);
  color:#fff;
}
.mobile-sticky-quote{
  background:linear-gradient(135deg,var(--brand-aqua),var(--brand-aqua-2));
  color:#fff;
}
blockquote{margin:0;padding:18px 20px;border-left:4px solid var(--brand-aqua);background:#f1f5f9;border-radius:14px;color:var(--brand-navy);font-size:1.05rem;line-height:1.55}
input,textarea,button{font:inherit}
.article{max-width:860px}
.full-bleed{
  max-width:none !important;
  margin-inline:0 !important;
  padding-inline:0 !important;
}
.full-bleed > .inner{
  max-width:none;
  margin-inline:0;
  padding-inline:clamp(16px,3.2vw,42px);
}
.band{
  background:#f1f5f9;
  border-top:1px solid #e2e8f0;
  border-bottom:1px solid #e2e8f0;
  padding:34px 0 38px;
}
.dark-band{
  background:linear-gradient(135deg,#10263f 0%,#0a1929 100%);
  color:#fff;
  padding:44px 0 42px;
}
.dark-band .muted{color:#cbd5e1}
.dark-band h1,.dark-band h2{color:#fff}
.dark-band .btn-row{justify-content:center}
.dark-band-cta-inner{text-align:center}
.band-cta-row{text-align:center;margin:18px 0 0}
.band-cta-inner{text-align:center}
.city-card-btn{margin-top:12px;display:inline-block}
.section-cta-row{margin-top:14px}
.section-cta-row--center{text-align:center;margin-top:18px}
.dark-band .btn.btn-navy.btn-secondary-outline-light,
.final-cta-premium .btn.btn-navy.btn-secondary-outline-light{
  background:#fff;
  color:var(--brand-navy);
  border:0;
  box-shadow:0 8px 24px rgba(0,0,0,.15);
}
.dark-band .btn.btn-navy.btn-secondary-outline-light:hover,
.final-cta-premium .btn.btn-navy.btn-secondary-outline-light:hover{
  filter:none;
  background:#f0fdfa;
  transform:translateY(-3px);
}
.edge-gallery{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:10px;
}
.edge-gallery img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  border-radius:12px;
}
.legacy-trust-center{text-align:center;max-width:760px;margin:0 auto}
.legacy-trust-center .stars-row{max-width:240px;height:auto;margin:10px auto}
.legacy-trust-center ul{display:inline-block;text-align:left;margin:10px 0}
.legacy-trust-center .trust-badge{max-width:110px;height:auto;margin-top:10px}
.legacy-why{
  background:linear-gradient(180deg,#cfe8f7 0,#c6e2f2 100%);
  border-radius:0;
  border:0;
  box-shadow:none;
  padding:58px clamp(16px,3.2vw,42px);
}
.legacy-why h2{
  text-align:center;
  color:#1b708e;
  font-size:clamp(2rem,3.8vw,3.2rem);
  margin-bottom:6px;
}
.legacy-why > .muted{
  text-align:center;
  font-size:1.05rem;
  margin-bottom:26px;
  color:#2b4b5b;
}
.legacy-why .why-split{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:34px;
  align-items:center;
  max-width:1320px;
  margin:0 auto;
}
.legacy-why .why-split img{
  width:100%;
  border-radius:14px;
  box-shadow:0 16px 36px rgba(15,23,42,.22);
}
.legacy-why .why-split h3{
  font-size:clamp(1.7rem,2.8vw,2.5rem);
  line-height:1.1;
  margin-bottom:10px;
}
.legacy-why .why-split p{
  font-size:1.08rem;
  max-width:62ch;
  margin-inline:auto;
}
.legacy-why .why-split ul{
  margin-top:14px;
  font-size:1.04rem;
  line-height:1.75;
  display:inline-block;
  text-align:left;
}
.legacy-why .logo-stamp{max-width:260px;height:auto;margin-top:12px}

.financing-overlay{
  background:linear-gradient(180deg,#f1f5f9 0%,#e8eef4 100%);
  border-radius:20px;
  border:1px solid #e2e8f0;
  box-shadow:0 18px 44px rgba(15,23,42,.08);
  padding:clamp(36px,5vw,52px) clamp(16px,3.2vw,42px);
}
.financing-overlay h2{
  text-align:center;
  color:var(--brand-navy);
  font-size:clamp(1.75rem,3.2vw,2.5rem);
}
.financing-overlay > .muted,
.financing-overlay > .financing-tagline{
  text-align:center;
  font-size:1.02rem;
  color:var(--muted);
  margin-bottom:18px;
}
.financing-overlay > .financing-tagline{color:var(--brand-navy);font-weight:600;opacity:.95}
.financing-overlay .finance-wrap{
  display:grid;
  grid-template-columns:1fr .92fr;
  gap:0;
  align-items:center;
  max-width:1200px;
  margin:0 auto;
}
.financing-overlay .finance-panel{
  background:linear-gradient(155deg,#10263f 0%,#071525 100%);
  color:#f1f5f9;
  padding:44px 38px;
  border-radius:16px;
  box-shadow:0 20px 48px rgba(2,6,23,.35);
  border:1px solid rgba(255,255,255,.08);
  min-height:280px;
  text-align:left;
}
.financing-overlay .finance-panel h3{
  margin-top:0;
  font-size:clamp(1.65rem,3vw,2.35rem);
  letter-spacing:.04em;
  color:#fff;
  text-align:left;
}
.financing-overlay .finance-panel ul{
  margin-top:16px;
  font-size:1.15rem;
  line-height:1.6;
  color:#e2e8f0;
}
.financing-overlay .finance-logo-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:28px;
  transform:translateX(-22px);
  box-shadow:0 14px 36px rgba(15,23,42,.1);
}
.financing-overlay .finance-logo-card img{max-width:420px;width:100%;height:auto}
.financing-overlay .btn{
  display:block;
  width:max-content;
  margin:22px auto 0;
  min-width:210px;
  text-align:center;
  font-size:1.05rem;
  padding:14px 26px;
}
.review-highlight{max-width:520px;margin:0 auto 18px;border:1px solid #92b5cf;border-radius:12px;padding:14px;background:#d8ecfb;text-align:center}
.review-highlight img{max-width:210px;height:auto}
.review-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.review-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px}
.trustindex-wrapper{margin-top:18px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px}
.trustindex-widget{min-height:120px}
.article{text-align:center}
.article p{max-width:70ch;margin-inline:auto}
.service-area-list{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
  margin-top:10px;
}
.service-area-intro-copy{
  max-width:72ch;
  margin-left:auto;
  margin-right:auto;
  text-align:left;
}
.service-area-services .service-area-service-grid{
  margin-top:8px;
}
.service-area-services h2{
  text-align:center;
  margin-bottom:6px;
}
.service-area-services .card{
  text-align:left;
}
.service-area-services .card h3{
  margin-top:0;
  font-size:1.08rem;
  color:var(--brand-navy);
}
.service-area-services .card .small{
  text-align:left;
}
.service-area-why-list{
  max-width:52ch;
  margin:0 auto 16px;
  text-align:left;
  padding-left:1.25rem;
  color:var(--brand-navy);
  font-weight:600;
}
.service-area-why-list li{
  margin:8px 0;
}
.service-area-commit{
  max-width:52ch;
  margin:0 auto 22px;
  text-align:center;
  font-size:1.05rem;
  line-height:1.55;
  color:var(--brand-navy);
}
.service-area-why-heading{
  text-align:center;
  margin:0;
}
.service-area-subhead{
  text-align:center;
  font-size:1.15rem;
  color:var(--brand-navy);
  margin:0 0 12px;
}
.vinyl-liner-shapes h2{
  text-align:center;
  margin:0 0 8px;
  color:var(--brand-navy);
  font-size:clamp(1.5rem,2.8vw,2.1rem);
}
.vinyl-liner-shapes-sub{
  text-align:center;
  font-weight:700;
  color:var(--brand-navy);
  margin:0 0 22px;
  font-size:clamp(1rem,1.8vw,1.12rem);
}
.vinyl-shape-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  max-width:1040px;
  margin:0 auto;
}
.vinyl-shape-card{
  display:flex;
  flex-direction:column;
  border-radius:16px;
  overflow:hidden;
  background:#fff;
  border:2px solid #e2e8f0;
  text-decoration:none;
  color:inherit;
  box-shadow:0 10px 28px rgba(15,23,42,.08);
  transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;
}
.vinyl-shape-card:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 40px rgba(15,23,42,.14);
  border-color:#cbd5e1;
}
.vinyl-shape-card--active{
  border-color:var(--brand-navy);
  box-shadow:0 12px 34px rgba(16,38,63,.18);
}
.vinyl-shape-card-media{
  display:block;
  aspect-ratio:4/3;
  background:#f1f5f9;
}
.vinyl-shape-card-media img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}
.vinyl-shape-card--icon .vinyl-shape-card-media img{
  object-fit:contain;
  padding:22px 18px;
}
.vinyl-shape-card--composite .vinyl-shape-card-media{
  aspect-ratio:10/11;
}
.vinyl-shape-card--composite .vinyl-shape-card-media img{
  object-fit:contain;
  padding:0;
}
.vinyl-shape-card-label{
  display:block;
  text-align:center;
  font-weight:700;
  padding:12px 10px 14px;
  color:#0f172a;
  font-size:15px;
  background:#fff;
}
@media(max-width:900px){
  .vinyl-shape-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:520px){
  .vinyl-shape-grid{grid-template-columns:1fr}
}
.service-area-list span{
  display:inline-block;
  background:#e8f4fd;
  border:1px solid #c6dff0;
  color:#1d5f80;
  border-radius:999px;
  padding:8px 12px;
  font-weight:600;
  font-size:.95rem;
}
@media(max-width:900px){
  .hero:not(.hero--video):not(.hero--spa):not(.hero--image){grid-template-columns:1fr;padding:30px 18px}
  .hero:not(.hero--video):not(.hero--spa):not(.hero--image) > div{text-align:center;justify-self:center;max-width:none}
  .hero:not(.hero--video):not(.hero--spa):not(.hero--image) .btn-row{justify-content:center}
  .hero:not(.hero--video):not(.hero--spa):not(.hero--image) img,.hero-media,.hero-media video{height:280px;min-height:280px}
  .hero--video{min-height:62vh}
  .hero--video.hero--home{min-height:min(82vh,880px)}
  .hero--video .hero-content{padding:64px 18px}
  .hero--image{min-height:62vh}
  .hero--image .hero-bg-media img{min-height:62vh}
  .hero--image .hero-content{padding:64px 18px}
  body.has-hero-header .hero--video.hero--home .hero-content--stacked{
    min-height:min(72vh,760px);
    padding:88px 18px 24px;
  }
  .hero--spa{min-height:58vh}
  .hero--spa .hero-content{padding:56px 18px 64px}
  .spa-why-split{grid-template-columns:1fr;gap:28px}
  .spa-why-copy h2,.spa-why-copy h3,.spa-why-copy h4,.spa-why-copy p,.spa-why-copy ul{text-align:center}
  .spa-dealer-list{padding-left:0;list-style-position:inside}
  .spa-benefits{padding-left:0;list-style-position:inside}
  .spa-brand-panel{position:static}
  .legacy-why .why-split{grid-template-columns:1fr}
  .financing-overlay .finance-wrap{grid-template-columns:1fr}
  .financing-overlay .finance-panel{min-height:auto;padding:32px 24px}
  .financing-overlay .finance-logo-card{transform:none;margin-top:10px;padding:20px}
  .financing-overlay .finance-panel ul{font-size:1.1rem}
  .review-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
  .edge-gallery{grid-template-columns:repeat(3,minmax(0,1fr))}
  .grid.four{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid.three{grid-template-columns:repeat(2,minmax(0,1fr))}
  .gallery{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:740px){
  .menu-toggle{display:block}
  .header-cta-group{display:none}
  .nav-main{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    z-index:160;
    flex-direction:column;
    align-items:stretch;
    flex-wrap:nowrap;
    gap:0;
    padding:8px 0 16px;
    background:var(--brand-navy);
    border-bottom:1px solid rgba(255,255,255,.12);
    box-shadow:0 16px 40px rgba(0,0,0,.2);
  }
  .nav-main.is-open{display:flex}
  .nav-main a{
    color:#fff;
    padding:12px 22px;
    border-radius:0;
    font-size:15px;
  }
  .nav-main a.active{box-shadow:none;background:rgba(255,255,255,.08)}
  body.has-hero-header .site-header.site-header--transparent{position:fixed}
}
@media(max-width:640px){
  .content{padding-top:0;padding-bottom:calc(100px + env(safe-area-inset-bottom))}
  .review-strip{grid-template-columns:1fr}
  .edge-gallery{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid.two,.grid.three,.grid.four{grid-template-columns:1fr}
  .footer-expanded{grid-template-columns:1fr}
  .mobile-sticky--dual{display:flex}
}

/* --- Page upgrade patterns (services, gallery, FAQ, etc.) --- */
.page-trust-strip{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
  max-width:720px;
  margin:0 auto;
  padding:14px 18px;
  border-radius:14px;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:0 8px 24px rgba(15,23,42,.06);
}
.page-trust-strip img{height:22px;width:auto}
.page-trust-strip span{font-size:14px;font-weight:600;color:var(--brand-navy)}
.page-trust-strip--on-dark{
  background:rgba(2,6,23,.35);
  border-color:rgba(255,255,255,.2);
}
.page-trust-strip--on-dark span{color:#fef9c3}
.page-trust-strip--elevated{
  box-shadow:0 14px 36px rgba(15,23,42,.1);
  border-radius:16px;
  padding:16px 20px;
}
/* --- Services page (services.php) --- */
main.content:has(.services-page) > .services-page > .hero + .section{
  margin-top:32px;
}
main.content:has(.services-page) .services-page > .section:has(.page-trust-strip) + .section{
  margin-top:38px;
}
.services-page > .section:not(.section--services-trust):not(.hero){
  margin-top:40px;
}
.services-page > .section.services-proof-strip{
  margin-top:28px;
}
.services-proof-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  max-width:1100px;
  margin:0 auto;
}
.services-proof-cell{
  position:relative;
  display:block;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 14px 36px rgba(15,23,42,.12);
  border:1px solid var(--line);
  transition:transform .3s cubic-bezier(0.22,1,0.36,1),box-shadow .3s cubic-bezier(0.22,1,0.36,1);
}
.services-proof-cell:hover{
  transform:translateY(-4px);
  box-shadow:0 22px 48px rgba(15,23,42,.16);
}
.services-proof-cell img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  display:block;
  vertical-align:middle;
}
.services-offerings-band .inner{
  max-width:1120px;
  margin:0 auto;
}
.services-section-head{
  text-align:center;
  max-width:720px;
  margin:0 auto 22px;
}
.services-section-head h2{
  margin:0 0 10px;
  color:var(--brand-navy);
}
.services-section-head .muted{
  margin:0 auto;
  max-width:52ch;
}
.services-offerings-band .section-eyebrow{margin-bottom:6px}
.services-offering-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin-top:8px;
}
.services-offering-card{
  position:relative;
  text-align:left;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:22px 20px 22px 22px;
  box-shadow:0 12px 32px rgba(15,23,42,.07);
  transition:transform .28s cubic-bezier(0.22,1,0.36,1),box-shadow .28s cubic-bezier(0.22,1,0.36,1);
}
.services-offering-card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 44px rgba(15,23,42,.11);
}
.services-offering-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:48px;
  height:48px;
  border-radius:12px;
  margin-bottom:14px;
  color:var(--brand-aqua);
  background:linear-gradient(145deg,rgba(16,38,63,.95) 0%,#10263f 100%);
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 8px 20px rgba(16,38,63,.2);
}
.services-offering-icon svg{display:block;width:26px;height:26px}
.services-offering-card h3{
  margin:0 0 8px;
  font-size:1.02rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--brand-navy);
  text-align:left;
}
.services-offering-desc{
  margin:0;
  font-size:14px;
  line-height:1.5;
  color:var(--muted);
}
.services-mid-cta-inner{
  max-width:720px;
  margin:0 auto;
  text-align:center;
  padding:28px 24px 32px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:0 16px 44px rgba(15,23,42,.08);
}
.services-mid-cta-label{
  margin:0 0 8px;
  font-family:var(--font-head);
  font-size:clamp(1.25rem,2.2vw,1.55rem);
  font-weight:700;
  color:var(--brand-navy);
}
.services-mid-cta-copy{margin:0 0 18px;max-width:46ch;margin-left:auto;margin-right:auto}
.services-process-section .section-eyebrow{margin-bottom:6px}
.services-process{
  list-style:none;
  margin:10px auto 0;
  padding:0;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  max-width:1040px;
  counter-reset:services-step;
  align-items:stretch;
}
.services-process-step{
  position:relative;
}
.services-process-card{
  position:relative;
  height:100%;
  min-height:100%;
  display:flex;
  flex-direction:column;
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:32px 22px 26px;
  box-shadow:0 16px 42px rgba(15,23,42,.09);
  text-align:left;
  border-top:3px solid var(--brand-aqua);
}
.services-process-badge{
  position:absolute;
  top:-16px;
  left:22px;
  width:40px;
  height:40px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--brand-aqua),var(--brand-aqua-2));
  color:#fff;
  font-weight:800;
  font-size:15px;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 8px 22px rgba(0,188,212,.38);
}
.services-process-icon{
  display:flex;
  margin:8px 0 14px;
  color:var(--brand-aqua);
}
.services-process-icon svg{width:32px;height:32px;display:block}
.services-process-card h3{
  margin:0 0 10px;
  font-size:1.12rem;
  color:var(--brand-navy);
  text-align:left;
}
.services-process-card p{
  margin:0;
  margin-top:auto;
  padding-top:10px;
  font-size:14px;
  line-height:1.55;
  color:var(--muted);
}
.services-values .section-eyebrow{margin-bottom:6px}
.services-value-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  max-width:960px;
  margin:8px auto 0;
}
.services-value-card{
  display:flex;
  gap:16px;
  align-items:flex-start;
  text-align:left;
  padding:22px 20px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:0 10px 28px rgba(15,23,42,.06);
}
.services-value-icon{
  flex-shrink:0;
  width:46px;
  height:46px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--brand-navy);
  background:linear-gradient(180deg,#f1f5f9 0%,#e8eef4 100%);
  border:1px solid #e2e8f0;
}
.services-value-icon svg{width:24px;height:24px;display:block;stroke:currentColor;fill:none;stroke-width:1.75}
.services-value-icon svg circle{fill:none}
.services-value-copy h3{
  margin:0 0 6px;
  font-size:1.05rem;
  color:var(--brand-navy);
  text-align:left;
}
.services-value-copy p{margin:0;font-size:14px;line-height:1.5;text-align:left}
.services-final-cta h2{margin-top:4px}
.services-final-cta .muted{max-width:52ch;margin-left:auto;margin-right:auto}
@media(max-width:900px){
  .services-offering-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .services-process{grid-template-columns:1fr;gap:28px}
  .services-proof-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .services-offering-grid{grid-template-columns:1fr}
  .services-value-grid{grid-template-columns:1fr}
}
.service-offering-card h3{font-size:1rem;color:var(--brand-navy)}
.steps-3{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  max-width:1000px;
  margin:22px auto 0;
}
.step-card{position:relative;padding-top:28px;text-align:center}
.step-num{
  position:absolute;
  top:14px;
  left:50%;
  transform:translateX(-50%);
  width:36px;
  height:36px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--brand-aqua),var(--brand-aqua-2));
  color:#fff;
  font-weight:800;
  font-size:15px;
  line-height:36px;
  text-align:center;
}
.before-after-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  max-width:1000px;
  margin:0 auto;
}
.before-after-card{margin:0;padding:0;overflow:hidden;text-align:left}
.before-after-card img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;border-radius:14px 14px 0 0}
.before-after-card figcaption{padding:12px 16px;font-size:13px;color:var(--muted)}
.gallery-cta-span{
  column-span:all;
  text-align:center;
  padding:26px 16px 10px;
  margin:6px 0 8px;
}
.faq-page .faq-category-block{margin-bottom:40px}
.faq-category-block h2{
  text-align:left;
  color:var(--brand-navy);
  font-size:1.35rem;
  margin-bottom:14px;
}
.city-card-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.city-card h3{text-align:left;font-size:1.05rem;color:var(--brand-navy)}
.city-card p{text-align:left}
@media(max-width:900px){
  .steps-3{grid-template-columns:1fr}
  .before-after-grid{grid-template-columns:1fr}
  .city-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:640px){
  .city-card-grid{grid-template-columns:1fr}
}
