
:root{
  --sand:#f0ebe2;--sand-deep:#e0d8c8;--dune:#c8b99a;--stone:#52504c;
  --slate:#2e2c28;--navy:#0c1e2e;--navy2:#0f2a3a;--obsidian:#181715;
  --water:#2a7fa8;--water-light:#5ba8cc;--water-pale:#d4eaf5;
  --white:#fdfcfa;--gold:#b08d57;--r:12px;--rs:8px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;font-weight:400;font-size:16px;line-height:1.85;background:var(--white);color:var(--stone);overflow-x:hidden;}
body.lb-open{overflow:hidden;position:fixed;left:0;right:0;width:100%;}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:500;display:flex;align-items:center;justify-content:space-between;padding:18px 52px;transition:all .4s;}
nav.scrolled{background:rgba(12,30,46,.97);backdrop-filter:blur(16px);padding:12px 52px;}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:1.52rem;font-weight:300;color:var(--white);letter-spacing:.15em;cursor:pointer;white-space:nowrap;text-decoration:none;}
.nav-logo span{color:var(--water-light);}
.nav-links{display:flex;gap:4px;list-style:none;align-items:center;}
.nav-links>li{position:relative;display:flex;align-items:center;}
.nav-links>li>a{font-size:.69rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(253,252,250,.78);text-decoration:none;transition:color .3s;cursor:pointer;white-space:nowrap;padding:8px 14px;display:flex;align-items:center;border-radius:6px;min-height:40px;}
.nav-links>li>a:hover,.nav-links>li>a.active{color:var(--water-light);}
.nav-cta>a{background:var(--water)!important;color:var(--white)!important;padding:8px 18px!important;border-radius:var(--rs)!important;}
.nav-cta>a:hover{background:var(--water-light)!important;}
/* Dropdowns */
.has-drop>a::after{content:' ▾';font-size:.55rem;opacity:.6;margin-left:2px;}
.drop-menu{position:absolute;top:calc(100%);left:0;min-width:230px;background:rgba(10,24,36,.98);border-top:2px solid var(--water);border-radius:0 0 var(--rs) var(--rs);padding:6px 0;opacity:0;pointer-events:none;transform:translateY(8px);transition:all .25s;z-index:600;box-shadow:0 20px 48px rgba(0,0,0,.35);}
.has-drop:hover .drop-menu{opacity:1;pointer-events:auto;transform:translateY(0);}
.drop-menu::before{content:'';position:absolute;top:-10px;left:0;right:0;height:10px;} .has-drop{padding-bottom:0;}
.drop-menu a{display:block;padding:10px 20px;font-size:.69rem;letter-spacing:.13em;text-transform:uppercase;color:rgba(253,252,250,.65);text-decoration:none;transition:all .2s;border-bottom:1px solid rgba(255,255,255,.05);cursor:pointer;}
.drop-menu a:last-child{border-bottom:none;}
.drop-menu a:hover{color:var(--water-light);padding-left:26px;}

/* ── MOBILE NAV ── */
.nav-toggle{display:none;align-items:center;justify-content:center;flex-direction:column;gap:5px;width:46px;height:46px;background:transparent;border:1px solid rgba(253,252,250,.18);border-radius:10px;cursor:pointer;transition:background .25s,border-color .25s;}
.nav-toggle:hover{background:rgba(255,255,255,.06);border-color:rgba(253,252,250,.32);}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--white);transition:transform .25s,opacity .25s;}
.nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.active span:nth-child(2){opacity:0;}
.nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.mob-nav{display:none;position:fixed;top:0;right:0;bottom:0;width:min(380px,92vw);background:rgba(10,24,36,.985);backdrop-filter:blur(18px);z-index:700;transform:translateX(100%);transition:transform .3s ease;box-shadow:-24px 0 60px rgba(0,0,0,.28);overflow:hidden;flex-direction:column;}
.mob-nav.open{transform:translateX(0);}
.mob-nav-backdrop{display:none;position:fixed;inset:0;background:rgba(8,18,28,.55);z-index:650;opacity:0;pointer-events:none;transition:opacity .3s ease;}
.mob-nav-backdrop.open{opacity:1;pointer-events:auto;}
.mob-nav-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:calc(env(safe-area-inset-top,0px) + 14px) 18px 14px;margin:0;border-bottom:1px solid rgba(255,255,255,.08);background:linear-gradient(to bottom,rgba(10,24,36,.98),rgba(10,24,36,.93));position:sticky;top:0;z-index:2;}
.mob-brand{font-family:'Cormorant Garamond',serif;font-size:1.38rem;font-weight:300;letter-spacing:.14em;color:var(--white);text-decoration:none;display:inline-flex;align-items:center;min-height:40px;}
.mob-brand span{color:var(--water-light);}
.mob-close{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid rgba(255,255,255,.14);border-radius:10px;background:transparent;color:var(--white);font-size:1.5rem;cursor:pointer;flex-shrink:0;}
.mob-menu,.mob-submenu{list-style:none;}
.mob-menu{flex:1 1 auto;overflow-y:auto;padding:4px 18px 14px;}
.mob-item{border-bottom:1px solid rgba(255,255,255,.08);}
.mob-link,.mob-group-btn,.mob-submenu a{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;background:transparent;border:none;color:rgba(253,252,250,.88);text-decoration:none;text-align:left;cursor:pointer;}
.mob-link,.mob-group-btn{padding:15px 0;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;}
.mob-link.active,.mob-group-btn.active,.mob-submenu a.active{color:var(--water-light);}
.mob-group-btn .chev{font-size:1rem;line-height:1;transition:transform .25s;opacity:.8;}
.mob-item.open .mob-group-btn .chev{transform:rotate(180deg);}
.mob-submenu{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease;}
.mob-item.open .mob-submenu{grid-template-rows:1fr;}
.mob-submenu-inner{overflow:hidden;padding:0 0 6px 14px;}
.mob-submenu a{padding:9px 0 11px;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(253,252,250,.64);}
.mob-cta{margin-top:auto;padding:14px 18px calc(env(safe-area-inset-bottom,0px) + 16px);border-top:1px solid rgba(255,255,255,.08);background:linear-gradient(to top,rgba(10,24,36,1),rgba(10,24,36,.9));position:sticky;bottom:0;z-index:2;}
.mob-cta .btn-p{display:block;text-align:center;width:100%;padding:15px 22px;max-width:none;}
body.nav-open{overflow:hidden;}

/* ── PAGES ── */
.page{display:none;min-height:100vh;}
.page.active{display:block;}

/* ── BUTTONS ── */
.btn-p,.btn-g,.btn-d,.btn-w{display:inline-block;padding:13px 32px;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;text-decoration:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:500;transition:all .3s;border-radius:var(--rs);border:none;}
.btn-p{background:var(--water);color:var(--white);border:1px solid var(--water);}
.btn-p:hover{background:var(--water-light);border-color:var(--water-light);}
.btn-g{background:transparent;color:var(--white);border:1px solid rgba(253,252,250,.32);}
.btn-g:hover{border-color:var(--white);}
.btn-d{background:var(--slate);color:var(--white);}
.btn-d:hover{background:var(--obsidian);}
.btn-w{background:var(--white);color:var(--water);}
.btn-w:hover{background:var(--water-pale);}

/* ── SECTIONS ── */
section{padding:88px 52px;}
.mw{max-width:1160px;margin:0 auto;}
.eyebrow{font-size:.67rem;letter-spacing:.3em;text-transform:uppercase;color:var(--water);margin-bottom:12px;}
.eyebrow-lt{color:var(--water-light);}
.ttl{font-family:'Cormorant Garamond',serif;font-size:clamp(2.6rem,4.2vw,3.8rem);font-weight:300;line-height:1.1;color:var(--slate);margin-bottom:20px;}
.ttl em{font-style:italic;color:var(--water);}
.ttl-lt{color:var(--white);}
.ttl-lt em{color:var(--water-light);}
.body-txt{font-size:1rem;line-height:1.85;color:var(--stone);}
.body-lt{color:rgba(253,252,250,.65);}
.sc{text-align:center;}
.sc .body-txt,.sc .ttl{max-width:660px;margin-left:auto;margin-right:auto;}
@media (min-width:1024px){
  .hero-sub{max-width:760px;text-wrap:balance;}
  .ph-sub{max-width:780px;text-wrap:balance;}
  .cta-sub{max-width:760px;text-wrap:balance;}
  .sc .body-txt{max-width:760px;text-wrap:balance;}
  .sc .ttl{max-width:1040px;text-wrap:balance;}
  .cta-ttl,.ttl,.ph-ttl,.hero-ttl{text-wrap:balance;}
}

/* ── HERO ── */
.hero{height:100vh;min-height:680px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.hero-bg{position:absolute;inset:0;background:linear-gradient(160deg,#0a1e2e,#143348);}
.hero-img,.hero-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.45;}
.hero-ov{position:absolute;inset:0;background:linear-gradient(175deg,rgba(8,18,28,.55) 0%,rgba(8,18,28,.3) 50%,rgba(8,18,28,.65) 100%);}
.hero-ct{position:relative;z-index:2;text-align:center;padding:0 24px;max-width:980px;}
.hero-eye{font-size:.67rem;letter-spacing:.35em;text-transform:uppercase;color:var(--water-light);margin-bottom:20px;}
.hero-ttl{font-family:'Cormorant Garamond',serif;font-size:clamp(3rem,6vw,5.5rem);font-weight:300;line-height:1.06;color:var(--white);margin-bottom:22px;}
.hero-ttl em{font-style:italic;color:var(--water-light);}
.hero-sub{font-size:1.05rem;color:rgba(253,252,250,.75);line-height:1.85;max-width:560px;margin:0 auto 36px;}
.hero-acts{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.hero-scr{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(253,252,250,.4);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;}
.hero-scr::after{content:'';width:1px;height:40px;background:linear-gradient(to bottom,rgba(253,252,250,.3),transparent);display:block;}

/* ── PAGE HEROES ── */
.ph{padding:152px 52px 80px;position:relative;overflow:hidden;text-align:center;}
.ph-bg{position:absolute;inset:0;background:linear-gradient(160deg,#0a1e2e,#143348);}
.ph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.42;}
.ph-ov{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(8,18,28,.62) 0%,rgba(8,18,28,.38) 55%,rgba(8,18,28,.72) 100%);}
.ph-ct{position:relative;z-index:1;}
.ph-eye{font-size:.67rem;letter-spacing:.3em;text-transform:uppercase;color:var(--water-light);margin-bottom:14px;}
.ph-ttl{font-family:'Cormorant Garamond',serif;font-size:clamp(2.6rem,5.5vw,4.8rem);font-weight:300;color:var(--white);line-height:1.08;}
.ph-ttl em{font-style:italic;color:var(--water-light);}
.ph-sub{font-size:1.02rem;color:rgba(253,252,250,.7);max-width:580px;margin:18px auto 0;line-height:1.85;}

/* ── TWO COL ── */
.tc{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;max-width:1160px;margin:0 auto;}
.tc.rev{direction:rtl;}.tc.rev>*{direction:ltr;}

/* ── IMAGES ── */
.ib{position:relative;overflow:hidden;border-radius:var(--r);}
.ib img{width:100%;height:100%;object-fit:cover;display:block;}
.ib-tall{aspect-ratio:4/5;}.ib-sq{aspect-ratio:1;}.ib-wide{aspect-ratio:16/9;}
.ib-badge{position:absolute;bottom:20px;left:-8px;background:var(--water);color:var(--white);padding:11px 18px;font-size:.65rem;letter-spacing:.13em;text-transform:uppercase;max-width:210px;line-height:1.6;border-radius:0 var(--rs) var(--rs) 0;}

/* ── GALLERY ── */
.gg{display:grid;gap:10px;max-width:1160px;margin:0 auto;}
.gg.g3{grid-template-columns:repeat(3,1fr);}
.gg.g4{grid-template-columns:repeat(4,1fr);}
.gg.gh{grid-template-columns:repeat(4,1fr);grid-template-rows:260px 260px;}
.gi{overflow:hidden;background:var(--sand-deep);position:relative;cursor:pointer;border-radius:var(--r);}
.gi img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s;}
.gi:hover img{transform:scale(1.05);}
.gi.s2{grid-column:span 2;}.gi.r2{grid-row:span 2;}
.gcap{position:absolute;bottom:0;left:0;right:0;padding:14px;background:linear-gradient(to top,rgba(8,18,28,.72),transparent);color:var(--white);font-size:.75rem;letter-spacing:.1em;opacity:0;transition:opacity .3s;}
.gi:hover .gcap{opacity:1;}

.gg.gm{grid-auto-flow:dense;grid-auto-rows:180px;}
.gg.gm .gi{height:auto !important;min-height:180px;}
.gg.gm .gi.wide{grid-column:span 2;}
.gg.gm .gi.tall{grid-row:span 2;}
.gg.gm .gi.big{grid-column:span 2;grid-row:span 2;}

/* ── LIGHTBOX ── */
.lb{position:fixed;inset:0;background:rgba(8,14,22,.96);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px;overflow:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:none;}
.lb.open{display:flex;}
.lb.lb-tall{align-items:flex-start;justify-content:center;padding:88px 20px 42px;overflow-y:auto;touch-action:pan-y;}
.lb img{display:block;width:auto;max-width:min(96vw,1600px);height:auto;max-height:calc(var(--lb-vh, 100dvh) - 40px);object-fit:contain;border-radius:var(--r);box-shadow:0 24px 60px rgba(0,0,0,.35);margin:0 auto;user-select:none;-webkit-user-drag:none;touch-action:none;}
.lb.lb-tall img{max-height:none;max-width:min(96vw,1600px);margin:0 auto 72px;touch-action:pan-y;}
.lb-x{position:fixed;top:20px;right:28px;background:none;border:none;color:var(--white);font-size:2.2rem;cursor:pointer;opacity:.65;line-height:1;z-index:1002;}
.lb-x:hover{opacity:1;}
.lb-arr{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:none;color:var(--white);font-size:2rem;cursor:pointer;padding:12px 18px;transition:background .2s;border-radius:var(--rs);z-index:1002;}
.lb-arr:hover{background:rgba(255,255,255,.2);}
.lb-prev{left:16px;}.lb-next{right:16px;}
.lb-cap{position:fixed;bottom:16px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.72);font-size:.8rem;text-align:center;max-width:80vw;z-index:1002;pointer-events:none;text-shadow:0 2px 10px rgba(0,0,0,.45);}

/* ── STATS STRIP ── */
.stats-strip{background:var(--navy);padding:48px 52px;}
.stats-in{display:flex;max-width:940px;margin:0 auto;}
.stat-it{flex:1;text-align:center;padding:0 24px;border-right:1px solid rgba(255,255,255,.07);}
.stat-it:last-child{border-right:none;}
.stat-ico{width:50px;height:50px;background:rgba(42,127,168,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;}
.stat-ico svg{width:24px;height:24px;fill:var(--water-light);}
.stat-n{font-family:'Cormorant Garamond',serif;font-size:2.9rem;font-weight:300;color:var(--water-light);display:block;line-height:1;}
.stat-l{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(253,252,250,.4);margin-top:6px;}

/* ── FEATURE LIST ── */
.fl{list-style:none;margin-top:22px;}
.fl li{display:flex;align-items:flex-start;gap:14px;padding:10px 0;border-bottom:1px solid var(--sand-deep);font-size:.97rem;color:var(--stone);line-height:1.75;}
.fl li::before{content:'→';color:var(--water);flex-shrink:0;margin-top:1px;font-weight:500;}

/* ── GET CERTIFIED INSTALL PROCESS ── */
.install-process-grid{
  display:grid;
  grid-template-columns:minmax(280px,420px) 1fr;
  gap:64px;
  align-items:center;
  max-width:1100px;
  margin:0 auto;
}

.install-process-media{
  display:flex;
  flex-direction:column;
  align-items:center;
}

.install-process-video-wrap{
  width:100%;
  max-width:420px;
  border-radius:var(--r);
  overflow:hidden;
  box-shadow:0 16px 56px rgba(0,0,0,.14);
  background:#000;
}

.install-process-video{
  width:100%;
  height:auto;
  display:block;
  aspect-ratio:9 / 16;
  object-fit:cover;
  background:#000;
}

.install-process-credit{
  text-align:center;
  margin-top:12px;
  font-size:.78rem;
  color:var(--stone);
}

.install-process-copy .ttl,
.install-process-copy .body-txt{
  max-width:640px;
}

@media(max-width:980px){
  .install-process-grid{
    grid-template-columns:1fr;
    gap:28px;
    align-items:start;
  }

  .install-process-media{
    order:1;
  }

  .install-process-copy{
    order:2;
  }

  .install-process-video-wrap{
    max-width:360px;
    margin:0 auto;
  }
}
/* ── PROCESS STEPS ── */
.ps{display:grid;grid-template-columns:repeat(4,1fr);max-width:1100px;margin:0 auto;}
.ps-item{padding:32px 28px;position:relative;}
.ps-item::after{content:'';position:absolute;top:54px;right:0;width:1px;height:48px;background:var(--sand-deep);}
.ps-item:last-child::after{display:none;}
.ps-badge{width:68px;height:68px;margin-bottom:20px;flex-shrink:0;}
.ps-badge svg{width:68px;height:68px;}
.ps-ttl{font-size:.84rem;font-weight:600;letter-spacing:.08em;color:var(--slate);margin-bottom:9px;text-transform:uppercase;}
.ps-desc{font-size:.95rem;color:var(--stone);line-height:1.78;}

/* ── POOL SHAPES ── */
.shapes-track{overflow:hidden;padding:0 0 12px;}
.shapes-row{display:flex;gap:22px;width:max-content;animation:shscroll 44s linear infinite;align-items:flex-start;}
.shapes-row:hover{animation-play-state:paused;}
@keyframes shscroll{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
.shp-card{position:relative;width:360px;background:var(--white);border-radius:var(--r);border:1px solid #d7d1c6;flex-shrink:0;overflow:hidden;transition:transform .3s,box-shadow .3s;box-shadow:0 8px 24px rgba(0,0,0,.04);}
.shp-card:hover{transform:translateY(-5px);box-shadow:0 20px 50px rgba(0,0,0,.1);}
.shp-img{display:block;background:#0b4d73;padding:0;line-height:0;}
.shp-img img{width:100%;height:auto;display:block;object-fit:contain;}
.shp-body{position:relative;padding:12px 14px;background:var(--white);display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid var(--sand-deep);}
.shp-name{font-family:'Cormorant Garamond',serif;font-size:1.35rem;font-weight:400;letter-spacing:.04em;text-transform:uppercase;color:var(--navy);margin:0;line-height:1;}
.shp-btn{padding:9px 14px;font-size:.58rem;letter-spacing:.16em;white-space:nowrap;}
.shp-desc{display:none;}
.shp-tag{display:none;}

/* ── COMPARE TABLE ── */
.cmp-wrap{overflow-x:auto;max-width:1060px;margin:0 auto;}
.cmp{width:100%;border-collapse:collapse;font-size:.83rem;}
.cmp th{padding:13px 14px;text-align:center;font-weight:500;letter-spacing:.08em;font-size:.67rem;text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,.1);color:rgba(253,252,250,.48);}
.cmp th.fc{text-align:left;}
.cmp th.hi{color:var(--water-light);background:rgba(42,127,168,.14);border-top:2px solid var(--water);}
.cmp td{padding:11px 14px;text-align:center;border-bottom:1px solid rgba(255,255,255,.06);color:rgba(253,252,250,.62);font-size:.83rem;}
.cmp td.fc{text-align:left;color:rgba(253,252,250,.84);font-weight:400;}
.cmp td.hc{background:rgba(42,127,168,.07);color:var(--water-light);}
.ck{color:#5cc87a;}.xx{color:rgba(255,255,255,.2);}.pt{color:var(--dune);font-size:.78rem;}

/* ── COATING SWATCHES ── */
.cg{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;max-width:1060px;margin:40px auto 0;}
.cs-wrap{text-align:center;}
.cs-box{aspect-ratio:1;border-radius:var(--rs);overflow:hidden;border:2px solid var(--sand-deep);margin-bottom:8px;}
.cs-box img{width:100%;height:100%;object-fit:cover;}
.cs-name{font-size:.82rem;color:var(--slate);font-weight:500;}
.cs-type{font-size:.72rem;color:var(--stone);font-style:italic;}
.coating-group{max-width:1060px;margin:28px auto 0;}
.coating-group-ttl{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--water);margin:0 0 14px;text-align:left;}
.cg.grp{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-top:0;}

/* ── LAYER DIAGRAM ── */
.ld{max-width:960px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:start;}
.ll{list-style:none;}
.ll-item{display:flex;align-items:flex-start;gap:14px;padding:11px 0;border-bottom:1px solid var(--sand-deep);}
.ll-num{width:28px;height:28px;border-radius:50%;background:var(--water);color:var(--white);font-size:.78rem;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;}
.ll-ttl{font-size:.82rem;font-weight:600;color:var(--slate);letter-spacing:.05em;text-transform:uppercase;margin-bottom:2px;}
.ll-desc{font-size:.88rem;color:var(--stone);line-height:1.65;}

/* ── TICKER ── */
.ticker-sec{background:var(--navy);padding:60px 52px;}
.ticker-in{display:flex;max-width:900px;margin:0 auto;}
.ticker-it{flex:1;text-align:center;padding:0 28px;border-right:1px solid rgba(255,255,255,.07);}
.ticker-it:last-child{border-right:none;}
.ticker-ico{width:52px;height:52px;background:rgba(42,127,168,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;}
.ticker-ico svg{width:24px;height:24px;fill:var(--water-light);}
.ticker-n{font-family:'Cormorant Garamond',serif;font-size:3.2rem;font-weight:300;color:var(--water-light);display:block;line-height:1;}
.ticker-l{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(253,252,250,.4);margin-top:6px;}

/* ── CTA BAND ── */
.cta-band{background:linear-gradient(135deg,var(--water),#185f80);padding:70px 52px;text-align:center;}
.cta-ttl{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,3.5vw,3rem);font-weight:300;color:var(--white);margin-bottom:12px;}
.cta-sub{color:rgba(255,255,255,.7);font-size:1rem;margin-bottom:30px;max-width:520px;margin-left:auto;margin-right:auto;}

/* ── INSTALLER CALLOUT ── */
.inst-band{background:var(--obsidian);padding:88px 52px;}
.inst-band .body-txt{color:rgba(253,252,250,.85);}
.inst-band .ttl{color:var(--white);}
.inst-band .eyebrow{color:var(--water-light);}
.inst-band .inst-list li{color:rgba(253,252,250,.82);}
.inst-band .inst-list li svg{fill:var(--water-light);}
.inst-in{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.inst-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);padding:40px;border-radius:var(--r);}
.inst-card-ttl{font-family:'Cormorant Garamond',serif;font-size:1.9rem;color:var(--white);margin-bottom:10px;}
.inst-card-sub{color:rgba(253,252,250,.52);font-size:.97rem;margin-bottom:22px;line-height:1.85;}
.inst-list{list-style:none;}
.inst-list li{display:flex;gap:14px;align-items:flex-start;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.07);color:rgba(253,252,250,.72);font-size:.95rem;line-height:1.65;}
.inst-ico{width:22px;height:22px;flex-shrink:0;margin-top:1px;fill:var(--water-light);}

/* ── PAVE CARDS ── */
.pave-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:1100px;margin:44px auto 0;}
.pave-card{background:var(--white);overflow:hidden;border:1px solid var(--sand-deep);transition:box-shadow .3s,transform .3s;border-radius:var(--r);}
.pave-card:hover{box-shadow:0 16px 44px rgba(0,0,0,.09);transform:translateY(-4px);}
.pave-card-img{height:200px;overflow:hidden;}
.pave-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
.pave-card:hover .pave-card-img img{transform:scale(1.05);}
.pave-card-body{padding:20px 22px 22px;}
.pave-card-name{font-size:.8rem;font-weight:600;letter-spacing:.08em;color:var(--slate);margin-bottom:6px;text-transform:uppercase;}
.pave-card-desc{font-size:.9rem;color:var(--stone);line-height:1.72;}
.pave-card-tag{display:inline-block;margin-top:10px;background:var(--water-pale);color:var(--water);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;padding:3px 10px;border-radius:4px;}

/* ── PRODUCT COLOR GRID ── */
.pcg{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:1060px;margin:0 auto;}
.pcc{border-radius:var(--r);overflow:hidden;border:2px solid var(--sand-deep);cursor:pointer;transition:transform .3s,box-shadow .3s;}
.pcc:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(0,0,0,.1);}
.pcc-img{aspect-ratio:1;overflow:hidden;}
.pcc-img img{width:100%;height:100%;object-fit:cover;}
.pcc-swatch{aspect-ratio:1;}
.pcc-lbl{padding:12px 14px;background:var(--white);}
.pcc-name{font-size:.82rem;font-weight:500;color:var(--slate);}
.pcc-type{font-size:.72rem;color:var(--stone);font-style:italic;}

/* ── STONE PRODUCT CARDS ── */
.stone-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:1100px;margin:0 auto;}
.stone-card{background:var(--white);border-radius:var(--r);overflow:hidden;border:1px solid var(--sand-deep);transition:transform .3s,box-shadow .3s;cursor:pointer;}
.stone-card:hover{transform:translateY(-5px);box-shadow:0 20px 50px rgba(0,0,0,.1);}
.stone-card-img{height:220px;overflow:hidden;}
.stone-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
.stone-card:hover .stone-card-img img{transform:scale(1.05);}
.stone-card-body{padding:20px 22px 22px;}
.stone-card-collection{font-size:.65rem;letter-spacing:.16em;text-transform:uppercase;color:var(--water);margin-bottom:4px;}
.stone-card-name{font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:var(--slate);margin-bottom:6px;}
.stone-card-desc{font-size:.88rem;color:var(--stone);line-height:1.72;}
.stone-card-tag{display:inline-block;margin-top:10px;background:var(--sand);color:var(--stone);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;padding:4px 10px;border-radius:4px;}

/* ── ABOUT PRINCIPLES ── */
.princ{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;max-width:1100px;margin:0 auto;}
.pl{list-style:none;}
.pl-item{display:grid;grid-template-columns:34px 1fr;gap:16px;padding:22px 0;border-bottom:1px solid var(--sand-deep);}
.pl-num{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--water);line-height:1;padding-top:2px;}
.pl-ttl{font-size:.88rem;font-weight:600;letter-spacing:.06em;color:var(--slate);margin-bottom:5px;}
.pl-desc{font-size:.95rem;color:var(--stone);line-height:1.78;}

/* ── CERT BENEFITS ── */
.cb-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;max-width:980px;margin:44px auto 0;}
.cb{padding:30px;background:var(--white);border-left:3px solid var(--water);border-radius:0 var(--r) var(--r) 0;}
.cb-ico{width:46px;height:46px;margin-bottom:14px;fill:var(--water);}
.cb-ttl{font-size:.84rem;font-weight:600;letter-spacing:.07em;color:var(--slate);margin-bottom:8px;text-transform:uppercase;}
.cb-desc{font-size:.95rem;color:var(--stone);line-height:1.78;}

/* ── FORMS ── */
.form-sec{background:var(--sand);padding:88px 52px;}
.form-in{max-width:760px;margin:0 auto;}
.fw{background:var(--white);border-radius:var(--r);padding:44px;margin-top:38px;box-shadow:0 8px 40px rgba(0,0,0,.06);}
.fg{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.fg input,.fg select,.fg textarea{width:100%;padding:14px 16px;background:var(--sand);border:1.5px solid var(--sand-deep);border-radius:var(--rs);font-family:'DM Sans',sans-serif;font-size:.95rem;color:var(--slate);outline:none;transition:border-color .3s;}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--water);background:var(--white);}
.fg .full{grid-column:1/-1;}
.fg textarea{height:110px;resize:vertical;}
.fsub{grid-column:1/-1;background:var(--water);color:var(--white);border:none;padding:16px;font-family:'DM Sans',sans-serif;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:background .3s;width:100%;border-radius:var(--rs);}
.fsub:hover{background:var(--water-light);}

/* ── CERT FORM ── */
.cf-sec{background:var(--navy);padding:88px 52px;}
.cf-in{max-width:800px;margin:0 auto;}
.cf-in .ttl{color:var(--white);}
.cf-in .eyebrow{color:var(--water-light);}
.cf-in .body-txt{color:rgba(253,252,250,.6);}
.cfw{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:var(--r);padding:40px;margin-top:36px;}
.cfg{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.cfg input,.cfg select,.cfg textarea{width:100%;padding:14px 16px;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.12);border-radius:var(--rs);font-family:'DM Sans',sans-serif;font-size:.95rem;color:var(--white);outline:none;transition:border-color .3s;}
.cfg input::placeholder{color:rgba(255,255,255,.32);}
.cfg select option{background:var(--navy);}
.cfg input:focus,.cfg select:focus,.cfg textarea:focus{border-color:var(--water-light);}
.cfg .full{grid-column:1/-1;}
.cfg textarea{height:110px;resize:vertical;}
.cfsub{grid-column:1/-1;background:var(--water);color:var(--white);border:none;padding:16px;font-family:'DM Sans',sans-serif;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:background .3s;width:100%;border-radius:var(--rs);}
.cfsub:hover{background:var(--water-light);}
.ck-lbl{color:rgba(255,255,255,.7);font-size:.9rem;display:flex;align-items:center;gap:8px;}
.ck-lbl input[type="checkbox"]{width:auto;padding:0;margin:0;accent-color:var(--water);}

/* ── POOL QUOTE PAGE ── */
.quote-wrap{max-width:1120px;margin:0 auto;}
.quote-intro{display:grid;grid-template-columns:minmax(260px,.8fr) 1.2fr;gap:28px;align-items:start;margin-bottom:24px;}
.quote-intro-head{padding-right:10px;}
.quote-intro-head .ttl{margin-bottom:0;}
.quote-copy{max-width:none;}
.quote-list{margin:8px 0 0;padding-left:20px;color:var(--stone);}
.quote-list li{font-size:1rem;line-height:1.8;margin:0 0 8px 0;}
.quote-layout{display:block;}
.quote-form{width:100%;max-width:none;margin-top:0;padding:46px 48px;}
.quote-form-title{font-family:'Cormorant Garamond',serif;font-size:1.85rem;color:var(--slate);margin-bottom:22px;}
.quote-response{margin-top:18px;padding:18px 20px;background:var(--sand);border-radius:var(--r);border-left:3px solid var(--water);}
.quote-response-label{font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin-bottom:6px;}
.quote-response-copy{font-size:.95rem;color:var(--stone);line-height:1.7;}
.quote-form .fg{grid-template-columns:1fr 1fr;gap:14px;}
.quote-form .fg input,.quote-form .fg select,.quote-form .fg textarea{font-size:1rem;padding:16px 18px;}
.quote-form .fg textarea{min-height:150px;}
.quote-form .fsub{margin-top:4px;padding:17px 18px;font-size:.74rem;}

/* ── GENERIC FORM MOBILE TUNING ── */
.form-card,.contact-card{width:100%;}
.contact-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);padding:40px;border-radius:var(--r);}
.contact-form{display:grid;gap:11px;}
.contact-row{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
.contact-form input,.contact-form select,.contact-form textarea{padding:14px 16px;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.1);border-radius:var(--rs);color:var(--white);font-family:'DM Sans',sans-serif;font-size:.95rem;outline:none;width:100%;}
.contact-form select{color:rgba(255,255,255,.7);}
.contact-form textarea{height:120px;resize:vertical;}
.contact-submit{background:var(--water);color:var(--white);border:none;padding:15px;font-family:'DM Sans',sans-serif;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:background .3s;width:100%;border-radius:var(--rs);}

/* ── TESTIMONIALS ── */
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1100px;margin:44px auto 0;}
.test-card{padding:36px;background:var(--sand);position:relative;border-radius:var(--r);}
.test-card::before{content:'\201C';font-family:'Cormorant Garamond',serif;font-size:4.8rem;color:var(--water);opacity:.5;position:absolute;top:6px;left:20px;line-height:1;}
.test-txt{font-size:.98rem;line-height:1.85;color:var(--slate);padding-top:34px;margin-bottom:20px;}
.test-auth{font-size:.76rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);}
.test-role{font-size:.7rem;color:var(--water);margin-top:3px;}

/* ── CONTACT ── */
.cnt-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;max-width:1000px;margin:0 auto;}
.cnt-info{padding:44px;}
.cnt-ttl{font-family:'Cormorant Garamond',serif;font-size:1.55rem;color:var(--white);margin-bottom:26px;}
.cnt-det{display:flex;gap:14px;margin-bottom:20px;align-items:flex-start;}
.cnt-ico{width:36px;height:36px;background:rgba(42,127,168,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cnt-ico svg{width:16px;height:16px;fill:var(--water-light);}
.cnt-lbl{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(253,252,250,.38);margin-bottom:2px;}
.cnt-val{font-size:.94rem;color:rgba(253,252,250,.82);line-height:1.65;}
.cnt-links{margin-top:28px;list-style:none;}
.cnt-links li{padding:9px 0;border-bottom:1px solid rgba(255,255,255,.06);}
.cnt-links a{color:rgba(253,252,250,.5);text-decoration:none;font-size:.9rem;transition:color .3s;cursor:pointer;}
.cnt-links a:hover{color:var(--water-light);}

/* ── PRODUCT PAGE HEADER ── */
.prod-hdr{padding:148px 52px 68px;background:linear-gradient(160deg,#0a1e2e,#143348);text-align:center;position:relative;}
.prod-hdr::after{content:'';position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(to bottom,transparent,var(--white));}
.prod-hdr .ttl{color:var(--white);position:relative;z-index:1;}
.prod-hdr .ttl em{color:var(--water-light);}
.prod-sub{font-size:1rem;color:rgba(253,252,250,.62);margin-top:10px;position:relative;z-index:1;}
.breadcrumb{font-size:.72rem;letter-spacing:.12em;color:rgba(253,252,250,.42);margin-bottom:14px;position:relative;z-index:1;}
.breadcrumb a{color:var(--water-light);cursor:pointer;text-decoration:none;}

/* ── MICROBAN ── */
.mb-section{background:var(--white);padding:56px 52px;}
.mb-inner{max-width:1060px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;background:var(--sand);border-radius:var(--r);padding:44px;}

/* ── PAVE APPLICATION GALLERY ── */
.app-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-width:1100px;margin:44px auto 0;}
.app-item{border-radius:var(--r);overflow:hidden;position:relative;height:260px;cursor:pointer;}
.app-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s;}
.app-item:hover img{transform:scale(1.05);}
.app-label{position:absolute;bottom:0;left:0;right:0;padding:20px 22px;background:linear-gradient(to top,rgba(8,18,28,.75),transparent);color:var(--white);}
.app-label-name{font-family:'Cormorant Garamond',serif;font-size:1.45rem;font-weight:300;}
.app-label-sub{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:2px;}

/* ── FOOTER ── */
footer{background:var(--obsidian);padding:60px 52px 30px;}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;max-width:1160px;margin:0 auto 46px;}
.ft-brand{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:300;color:var(--white);letter-spacing:.12em;margin-bottom:12px;}
.ft-brand span{color:var(--water-light);}
.ft-sub{font-size:.82rem;line-height:1.85;color:rgba(253,252,250,.34);}
.ft-col-ttl{font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(253,252,250,.58);margin-bottom:16px;font-weight:500;}
.ft-nav{list-style:none;}
.ft-nav li{margin-bottom:9px;}
.ft-nav a{color:rgba(253,252,250,.36);text-decoration:none;font-size:.84rem;transition:color .3s;cursor:pointer;}
.ft-nav a:hover{color:var(--water-light);}
.ft-bottom{border-top:1px solid rgba(255,255,255,.05);padding-top:22px;display:flex;justify-content:space-between;align-items:center;font-size:.7rem;max-width:1160px;margin:0 auto;color:rgba(253,252,250,.28);}
.ft-bottom a{color:rgba(253,252,250,.28);text-decoration:none;cursor:pointer;}
.ft-bottom a:hover{color:var(--water-light);}

/* ── REVEAL ── */
.rv{opacity:0;transform:translateY(22px);transition:opacity .8s ease,transform .8s ease;}
.rv.vis{opacity:1;transform:translateY(0);}


/* ── Pool shape reference lightbox (legacy style) ── */
.shape-lb{position:fixed;inset:0;background:rgba(8,14,22,.96);z-index:1010;display:none;align-items:center;justify-content:center;padding:20px;}
.shape-lb.open{display:flex;}
.shape-lb-dialog{position:relative;display:flex;align-items:center;justify-content:center;width:min(94vw,1100px);max-height:92vh;}
.shape-lb-body{max-height:92vh;overflow:auto;display:flex;align-items:flex-start;justify-content:center;padding:0 48px;}
.shape-lb-body img{display:block;max-width:min(92vw,980px);height:auto;object-fit:contain;border-radius:var(--r);background:var(--white);}
.shape-lb-cap{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.55);font-size:.8rem;text-align:center;pointer-events:none;}
.shape-lb .lb-x,.shape-lb .lb-arr{z-index:2;}

/* ── RESPONSIVE ── */
@media(max-width:980px){
  nav{padding:14px 24px;}
  nav.scrolled{padding:12px 24px;}
  .nav-toggle,.mob-nav,.mob-nav-backdrop{display:flex;}
  .nav-links{display:none;}
  section,.stats-strip,.ticker-sec,.cta-band,.inst-band,.form-sec,.cf-sec,footer{padding-left:24px;padding-right:24px;}
  section{padding-top:60px;padding-bottom:60px;}
  .ph,.prod-hdr{padding-left:24px;padding-right:24px;}
  .contact-sec{padding:60px 24px !important;}
  .tc,.inst-in,.princ,.cb-grid,.cnt-grid,.ft-grid,.ld,.mb-inner{grid-template-columns:1fr;gap:36px;}
  .tc.rev{direction:ltr;}
  .stats-in,.ticker-in{flex-direction:column;}
  .gg.g3,.gg.g4{grid-template-columns:repeat(2,1fr);}
  .shp-card{width:330px;}
  .gg.gh{grid-template-columns:1fr 1fr;grid-template-rows:auto;}
  .gi.r2,.gi.s2,.gg.gm .gi.wide,.gg.gm .gi.tall,.gg.gm .gi.big{grid-row:auto;grid-column:auto;}
  .ps{grid-template-columns:1fr 1fr;}
  .pave-grid,.stone-grid{grid-template-columns:1fr 1fr;}
  .cg{grid-template-columns:repeat(3,1fr);}
  .pcg{grid-template-columns:repeat(2,1fr);}
  .fg,.cfg{grid-template-columns:1fr;}
  .hero{min-height:620px;height:auto;padding-top:110px;padding-bottom:58px;}
  .hero-sub,.ph-sub{max-width:100%;}
  .hero-acts{gap:10px;}
  .btn-p,.btn-g,.btn-d,.btn-w{width:100%;max-width:360px;text-align:center;}
  .inst-card,.fw,.cfw,.cnt-info{padding:30px;}
  .quote-wrap{max-width:100%;}
  .quote-intro{grid-template-columns:1fr;gap:14px;margin-bottom:18px;}
  .quote-intro-head{padding-right:0;}
  .quote-copy{max-width:100%;}
  .quote-form{padding:34px 30px;}
  .quote-form .fg{grid-template-columns:1fr;}
  .contact-row{grid-template-columns:1fr 1fr;}
  .stat-it,.ticker-it{border-right:none;border-bottom:1px solid rgba(255,255,255,.07);padding:16px 0;}
  .stat-it:last-child,.ticker-it:last-child{border-bottom:none;}
  .ph{padding:130px 24px 60px;}
  .ft-bottom{flex-direction:column;gap:12px;text-align:center;}
}
@media(max-width:640px){
  nav{padding:12px 16px;}
  nav.scrolled{padding:10px 16px;}
  section,.stats-strip,.ticker-sec,.cta-band,.inst-band,.form-sec,.cf-sec,footer,.ph,.prod-hdr{padding-left:16px;padding-right:16px;}
  .contact-sec{padding:52px 16px !important;}
  section{padding-top:52px;padding-bottom:52px;}
  .hero{min-height:540px;padding-top:98px;padding-bottom:46px;}
  .hero-ttl{font-size:clamp(2.35rem,12vw,3.6rem);}
  .hero-sub,.body-txt,.body-lt,.ph-sub{font-size:.96rem;line-height:1.75;}
  .hero-scr{display:none;}
  .nav-logo{font-size:1.2rem;letter-spacing:.1em;}
  .mob-nav{width:100%;max-width:100%;}
  .mob-nav-head{padding:calc(env(safe-area-inset-top,0px) + 12px) 16px 12px;}
  .mob-menu{padding:2px 16px 12px;}
  .mob-cta{padding:12px 16px calc(env(safe-area-inset-bottom,0px) + 14px);}
  .ps,.pave-grid,.stone-grid,.cb-grid,.gg.g3,.gg.g4,.cg,.pcg{grid-template-columns:1fr;}
  .gg.gh{grid-template-columns:1fr;}
  .test-grid{grid-template-columns:1fr;}
  .shapes-track{overflow-x:auto;overflow-y:hidden;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;padding:0 0 10px;}
  .shapes-track::-webkit-scrollbar{display:none;}
  .shapes-row{animation:none;width:auto;gap:14px;}
  .shp-card{width:min(84vw,320px);scroll-snap-align:start;}
  .shp-img{height:auto;padding:0;}
  .shp-body{padding:10px 12px;gap:10px;align-items:center;}
  .shp-name{display:none;}
  .shp-body{padding:10px 12px;gap:0;align-items:center;justify-content:center;}
  .shp-btn{padding:10px 14px;font-size:.54rem;letter-spacing:.14em;margin:0 auto;display:inline-flex;justify-content:center;align-items:center;}
  .gal-tabs{gap:8px;margin-bottom:24px;}
  .gal-tab{padding:10px 14px;font-size:.6rem;letter-spacing:.15em;}
  .cnt-info,.inst-card,.fw,.cfw{padding:24px;}
  .quote-form{padding:24px 18px;}
  .quote-form-title{font-size:1.55rem;margin-bottom:18px;}
  .quote-list{padding-left:18px;}
  .quote-list li{font-size:.98rem;line-height:1.7;}
  .quote-form .fg input,.quote-form .fg select,.quote-form .fg textarea,.fg input,.fg select,.fg textarea,.cfg input,.cfg select,.cfg textarea,.contact-form input,.contact-form select,.contact-form textarea{font-size:16px !important;padding:15px 14px !important;}
  .quote-form .fsub,.fsub,.cfsub,.contact-submit{font-size:.68rem;letter-spacing:.16em;padding:16px 14px;}
  .quote-response{padding:16px 16px;}
  .contact-row{grid-template-columns:1fr;}
  .contact-card{padding:24px;}
  .fw,.cfw{padding:24px;}
  .lb-arr{padding:10px 14px;font-size:1.5rem;}
  .shape-lb{padding:12px;}
  .shape-lb-dialog{width:100%;max-height:88vh;}
  .shape-lb-body{max-height:88vh;padding:0 40px;}
  .shape-lb-body img{max-width:calc(100vw - 80px);}
}


.shp-img img{width:100%;height:100%;object-fit:contain;object-position:center center;display:block;}
.shp-btn{max-width:none;padding:12px 18px;font-size:.64rem;letter-spacing:.18em;white-space:nowrap;flex-shrink:0;}


@media(max-width:640px){
  .lb{padding:12px;}
  .lb.lb-tall{padding:82px 12px 54px;}
  .lb img{width:auto;max-width:96vw;max-height:calc(var(--lb-vh, 100dvh) - 24px);}
  .lb.lb-tall img{max-height:none;}
}




/* ── GALLERY TABS ── */
.gal-tabs{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin:0 auto 30px;}
.gal-tab{display:inline-flex;align-items:center;justify-content:center;padding:12px 20px;border:1px solid var(--sand-deep);border-radius:999px;background:var(--white);color:var(--slate);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:all .25s;}
.gal-tab:hover{border-color:var(--water);color:var(--water);}
.gal-tab.active{background:var(--water);border-color:var(--water);color:var(--white);}
.gal-sec{display:none;}
.gal-sec.active{display:block;}

/* Gallery masonry update */
.gg.gm{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));grid-auto-rows:8px;gap:14px;align-items:start;}
.gg.gm .gi{grid-column:span 4;height:auto !important;min-height:0;overflow:hidden;background:var(--sand-deep);position:relative;cursor:pointer;border-radius:var(--r);align-self:start;}
.gg.gm .gi.wide{grid-column:span 7;}
.gg.gm .gi img{width:100%;height:auto !important;display:block;object-fit:contain;background:var(--sand-deep);transition:transform .6s;}
.gg.gm .gi:hover img{transform:scale(1.02);}
.gg.gm .gcap{opacity:0;position:absolute;left:0;right:0;bottom:0;padding:14px;background:linear-gradient(to top,rgba(8,18,28,.72),transparent);color:var(--white);font-size:.75rem;letter-spacing:.08em;}
.gg.gm .gi:hover .gcap{opacity:1;}
@media (max-width:1024px){.gg.gm .gi,.gg.gm .gi.wide{grid-column:span 6;}}
@media (max-width:767px){.gg.gm{display:grid;grid-template-columns:1fr;grid-auto-rows:auto;}.gg.gm .gi,.gg.gm .gi.wide{grid-column:span 1;grid-row:auto !important;}}


/* Logo image support */
.nav-logo img,
.mob-brand img,
.ft-brand img{display:block;width:auto;height:auto;}
.nav-logo img{height:34px;filter:brightness(0) invert(1);}
.mob-brand img{height:30px;filter:brightness(0) invert(1);}
.ft-brand{display:inline-block;}
.ft-brand img{height:42px;filter:brightness(0) invert(1);}
@media(max-width:640px){
  .nav-logo img{height:28px;}
  .mob-brand img{height:26px;}
  .ft-brand img{height:36px;}
}

.about-gal{margin-top:24px;}
.about-gal .gi img{object-fit:cover;}
@media (max-width:900px){
  .about-gal{grid-template-columns:1fr !important;}
  .about-gal .gi{aspect-ratio:16/10 !important;}
}
