﻿@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Inter:wght@400;500;600;700&display=swap');

:root {
  --bg:         #141414;
  --fg:         #E4EAF0;
  --card:       #1E1E1E;
  --charcoal-d: #0C0C0C;
  --charcoal:   #191919;
  --steel:      #6B7A88;
  --aqua:       #1EC8D5;
  --aqua-d:     #0D97A8;
  --silver:     #8A97A6;
  --border:     rgba(255,255,255,.09);
  --secondary:  #111111;
  --muted:      #708090;
  --radius-sm:  0.5rem;
  --radius:     0.75rem;
  --radius-lg:  1rem;
  --radius-xl:  1.5rem;
  --radius-2xl: 2rem;
  --shadow-card: 0 4px 24px rgba(0,0,0,.5),0 1px 4px rgba(0,0,0,.35);
  --shadow-deep: 0 8px 40px rgba(0,0,0,.7);
  --transition:  200ms cubic-bezier(0.4,0,0.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--fg);line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font:inherit}
ul{list-style:none}

.wrap{max-width:1280px;margin-inline:auto;padding-inline:1.25rem}
@media(min-width:768px){.wrap{padding-inline:2rem}}
@media(min-width:1024px){.wrap{padding-inline:2.5rem}}
.section-pad{padding-block:5rem}

.font-display{font-family:'Oswald',sans-serif}
.eyebrow{font-family:'Oswald',sans-serif;font-size:.75rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--aqua-d)}
.eyebrow-light{color:var(--aqua)}

/* BUTTONS */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--aqua) 0%,var(--aqua-d) 100%);color:var(--charcoal-d);font-family:'Oswald',sans-serif;font-weight:600;font-size:.875rem;letter-spacing:.1em;text-transform:uppercase;border-radius:var(--radius-lg);box-shadow:0 4px 16px rgba(30,200,213,.35);transition:transform var(--transition),box-shadow var(--transition);white-space:nowrap}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(30,200,213,.5)}
.btn-dark{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--charcoal-d);color:#fff;font-family:'Oswald',sans-serif;font-weight:600;font-size:.875rem;letter-spacing:.1em;text-transform:uppercase;border-radius:var(--radius-lg);transition:transform var(--transition),background var(--transition);white-space:nowrap}
.btn-dark:hover{transform:translateY(-2px);background:var(--charcoal)}
.btn-outline-light{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;color:#fff;font-family:'Oswald',sans-serif;font-weight:600;font-size:.875rem;letter-spacing:.1em;text-transform:uppercase;border-radius:var(--radius-lg);border:1.5px solid rgba(255,255,255,.4);transition:border-color var(--transition),background var(--transition);white-space:nowrap}
.btn-outline-light:hover{border-color:var(--aqua);background:rgba(30,200,213,.1)}
.btn-outline-aqua{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--secondary);color:var(--charcoal);font-family:'Oswald',sans-serif;font-weight:600;font-size:.875rem;letter-spacing:.1em;text-transform:uppercase;border-radius:var(--radius-lg);border:1.5px solid var(--border);transition:border-color var(--transition);white-space:nowrap}
.btn-outline-aqua:hover{border-color:var(--aqua-d)}

/* WATER CARD */
.water-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-card);transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition)}
.water-card:hover{transform:translateY(-4px);border-color:var(--aqua);box-shadow:0 8px 32px rgba(30,200,213,.15)}

/* HEADER */
#site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:4.5rem}
.logo-link{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.logo-circle{width:2.5rem;height:2.5rem;background:var(--charcoal-d);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.logo-circle svg{color:var(--aqua)}
.logo-name{font-family:'Oswald',sans-serif;font-weight:700;font-size:.875rem;letter-spacing:.05em;color:var(--charcoal-d);text-transform:uppercase;display:block}
.logo-sub{font-size:.625rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:block}
.site-nav{display:none;gap:.25rem}
.site-nav a{font-size:.8125rem;font-weight:600;letter-spacing:.04em;color:var(--steel);padding:.375rem .625rem;border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition)}
.site-nav a:hover,.site-nav a.active{color:var(--aqua-d);background:rgba(13,151,168,.06)}
.header-right{display:none;align-items:center;gap:.75rem}
.header-phone{font-size:.875rem;font-weight:700;color:var(--charcoal)}
.hamburger{width:2.5rem;height:2.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;border-radius:var(--radius-sm);transition:background var(--transition);cursor:pointer}
.hamburger:hover{background:var(--secondary)}
.hamburger span{display:block;width:20px;height:2px;background:var(--charcoal);border-radius:2px;transition:transform 300ms,opacity 300ms}
.mobile-nav{display:none;flex-direction:column;border-top:1px solid var(--border);padding:1rem;gap:.25rem;background:#fff}
.mobile-nav.open{display:flex}
.mobile-nav a{font-size:.9375rem;font-weight:600;color:var(--charcoal);padding:.625rem .75rem;border-radius:var(--radius);transition:background var(--transition),color var(--transition)}
.mobile-nav a:hover{background:var(--secondary);color:var(--aqua-d)}
.mobile-nav-btns{display:flex;gap:.75rem;padding-top:.75rem;border-top:1px solid var(--border);margin-top:.5rem}
.mobile-nav-btns .btn-primary,.mobile-nav-btns .btn-dark{flex:1;justify-content:center;font-size:.8125rem;padding:.625rem 1rem}
@media(min-width:768px){.header-phone{display:block}.hamburger{display:none}.header-right{display:flex}.mobile-nav{display:none!important}}
@media(min-width:1024px){.site-nav{display:flex}}

/* PAGE HERO */
.page-hero{position:relative;background:var(--charcoal-d);color:#fff;padding-block:5rem;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.18}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,var(--charcoal-d) 0%,rgba(20,20,20,.85) 60%,rgba(13,151,168,.12) 100%)}
.page-hero-inner{position:relative;z-index:1}
.page-hero-inner .eyebrow{color:var(--aqua);margin-bottom:.5rem}
.page-hero-inner h1{font-family:'Oswald',sans-serif;font-size:clamp(2rem,5vw,3.25rem);font-weight:700;line-height:1.1;color:#fff;margin-bottom:1rem}
.page-hero-inner .subtitle{font-size:1.0625rem;color:rgba(255,255,255,.72);max-width:38rem;line-height:1.6;margin-bottom:2rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.75rem}

/* HOME HERO */
.home-hero{position:relative;background:var(--charcoal-d);color:#fff;overflow:hidden;padding-block:5rem}
.home-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.15}
.home-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,var(--charcoal-d) 50%,rgba(20,20,20,.8) 75%,transparent 100%)}
.home-hero-inner{position:relative;z-index:1;display:grid;gap:3rem;align-items:center}
.hero-left{display:flex;flex-direction:column;justify-content:center}
.hero-left h1{font-family:'Oswald',sans-serif;font-size:clamp(2.25rem,6vw,3.75rem);font-weight:700;line-height:1.05;color:#fff;margin-bottom:1.25rem}
.hero-left h1 span{color:var(--aqua)}
.hero-sub{font-size:1.0625rem;color:rgba(255,255,255,.72);max-width:32rem;line-height:1.6;margin-bottom:2rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:1.25rem;margin-top:.5rem}
.hero-badge{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:600;color:rgba(255,255,255,.75)}
.hero-badge svg{color:var(--aqua);width:1rem;height:1rem}
.hero-right{display:none;position:relative}
.hero-img-grid{display:grid;grid-template-columns:1fr 1fr;gap:.875rem}
.hero-img-grid img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:var(--radius-xl);border:2px solid rgba(30,200,213,.3)}
.hero-img-grid img:last-child{margin-top:2.5rem}
.hero-free-badge{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--aqua),var(--aqua-d));color:var(--charcoal-d);font-family:'Oswald',sans-serif;font-weight:700;font-size:.6875rem;letter-spacing:.15em;text-transform:uppercase;padding:.375rem 1.125rem;border-radius:999px;white-space:nowrap}

/* TRUST STRIP */
.trust-strip{border-block:1px solid var(--border);background:var(--card)}
.trust-strip-inner{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;padding-block:2rem}
.trust-item{display:flex;align-items:center;gap:.75rem}
.trust-icon{width:2.75rem;height:2.75rem;background:rgba(13,151,168,.1);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--aqua-d)}
.trust-label{font-weight:700;font-size:.875rem;color:var(--charcoal);line-height:1.3}
.trust-sub{font-size:.75rem;color:var(--muted)}

/* SECTION HEADER */
.section-header{text-align:center;margin-bottom:3rem}
.section-header h2{font-family:'Oswald',sans-serif;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;color:var(--charcoal);margin-top:.5rem}
.section-header p{color:var(--muted);max-width:40rem;margin-inline:auto;margin-top:.75rem}

/* SERVICES GRID (home) */
.services-section{background:var(--secondary)}
.services-grid{display:grid;gap:1.25rem;grid-template-columns:1fr}
.service-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-card);transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition)}
.service-card:hover{transform:translateY(-4px);border-color:var(--aqua);box-shadow:0 8px 32px rgba(30,200,213,.15)}
.service-card img{width:100%;aspect-ratio:16/9;object-fit:cover}
.service-card-body{padding:1.25rem}
.service-card-body h3{font-family:'Oswald',sans-serif;font-size:1.125rem;font-weight:600;color:var(--charcoal);margin-bottom:.375rem}
.service-card-body p{font-size:.875rem;color:var(--muted);line-height:1.5}
.service-card-link{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:700;color:var(--aqua-d);margin-top:.875rem;letter-spacing:.04em}

/* WHY CHOOSE */
.why-section{background:var(--charcoal-d);color:#fff}
.why-section .section-header h2{color:#fff}
.why-section .section-header p{color:rgba(255,255,255,.6)}
.why-grid{display:grid;gap:1rem;grid-template-columns:1fr}
.why-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);padding:1.25rem;display:flex;gap:1rem;align-items:flex-start;transition:background var(--transition),border-color var(--transition)}
.why-card:hover{background:rgba(255,255,255,.08);border-color:rgba(30,200,213,.3)}
.why-num{width:2.25rem;height:2.25rem;border-radius:50%;background:linear-gradient(135deg,var(--aqua),var(--aqua-d));display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-weight:700;font-size:.875rem;color:var(--charcoal-d);flex-shrink:0}
.why-text h3{font-family:'Oswald',sans-serif;font-weight:600;font-size:1rem;color:#fff;margin-bottom:.25rem}
.why-text p{font-size:.875rem;color:rgba(255,255,255,.6);line-height:1.5}

/* BEFORE/AFTER */
.ba-section{background:var(--card)}
.ba-grid{display:grid;gap:3rem}
.ba-images{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.ba-images figure{position:relative}
.ba-images img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius-xl);border:2px solid var(--border)}
.ba-label{position:absolute;bottom:.75rem;left:.75rem;background:var(--charcoal-d);color:#fff;font-family:'Oswald',sans-serif;font-weight:600;font-size:.625rem;letter-spacing:.15em;text-transform:uppercase;padding:.25rem .625rem;border-radius:999px}
.ba-label.after-label{background:var(--aqua);color:var(--charcoal-d)}
.ba-content{display:flex;flex-direction:column;justify-content:center}
.ba-content h2{font-family:'Oswald',sans-serif;font-size:clamp(1.75rem,4vw,2.25rem);font-weight:700;color:var(--charcoal);margin-top:.5rem;margin-bottom:1.25rem}
.ba-points{display:flex;flex-direction:column;gap:1rem}
.ba-point{display:flex;gap:.875rem;align-items:flex-start}
.ba-point-icon{width:2.25rem;height:2.25rem;border-radius:50%;background:rgba(13,151,168,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--aqua-d)}
.ba-point-text h4{font-weight:700;font-size:.9375rem;color:var(--charcoal)}
.ba-point-text p{font-size:.875rem;color:var(--muted);line-height:1.4}

/* GALLERY PREVIEW (home) */
.gallery-section{background:var(--secondary)}
.gallery-grid{display:grid;gap:1rem;grid-template-columns:1fr 1fr}
.gallery-item{position:relative;overflow:hidden;border-radius:var(--radius-xl);aspect-ratio:4/3;background:var(--border)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 400ms ease}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,15,15,.75) 0%,transparent 60%);display:flex;align-items:flex-end;padding:.875rem;opacity:0;transition:opacity 250ms}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay span{font-size:.75rem;font-weight:700;color:#fff;font-family:'Oswald',sans-serif;letter-spacing:.04em}

/* RES/COMM SPLIT (home) */
.rescomm-section{background:var(--card)}
.rescomm-grid{display:grid;gap:1.5rem}
.rescomm-card{border-radius:var(--radius-2xl);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-card)}
.rescomm-card-img{position:relative;aspect-ratio:16/9}
.rescomm-card-img img{width:100%;height:100%;object-fit:cover}
.rescomm-card-img .img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,15,15,.65) 0%,transparent 50%)}
.rc-badge{position:absolute;bottom:1rem;left:1rem;background:var(--aqua);color:var(--charcoal-d);font-family:'Oswald',sans-serif;font-weight:700;font-size:.6875rem;letter-spacing:.15em;text-transform:uppercase;padding:.25rem .875rem;border-radius:999px;display:inline-flex;align-items:center;gap:.375rem}
.rescomm-card-body{padding:1.5rem;background:var(--card)}
.rescomm-card.dark .rescomm-card-body{background:var(--charcoal-d)}
.rescomm-card-body h3{font-family:'Oswald',sans-serif;font-size:1.375rem;font-weight:700;color:var(--charcoal);margin-bottom:.5rem}
.rescomm-card.dark .rescomm-card-body h3{color:#fff}
.rescomm-card-body p{font-size:.9375rem;color:var(--muted);line-height:1.5;margin-bottom:1.25rem}
.rescomm-card.dark .rescomm-card-body p{color:rgba(255,255,255,.65)}
.rc-list{display:grid;grid-template-columns:1fr 1fr;gap:.5rem 1rem;margin-bottom:1.5rem}
.rc-list li{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--charcoal)}
.rescomm-card.dark .rc-list li{color:rgba(255,255,255,.8)}
.rc-list li svg{color:var(--aqua-d);flex-shrink:0}
.rescomm-card.dark .rc-list li svg{color:var(--aqua)}

/* FINAL CTA */
.final-cta{position:relative;background:var(--charcoal-d);overflow:hidden;padding-block:5rem}
.final-cta-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.12}
.final-cta-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(12,12,12,.96) 0%,rgba(20,20,20,.82) 100%)}
.final-cta-card{position:relative;z-index:1;background:rgba(255,255,255,.04);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-2xl);padding:2.5rem}
.final-cta-inner{display:grid;gap:2rem}
.cta-left .eyebrow{color:var(--aqua);margin-bottom:.5rem}
.cta-left h2{font-family:'Oswald',sans-serif;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;color:#fff;line-height:1.1;margin-bottom:1rem}
.cta-left p{color:rgba(255,255,255,.65);font-size:.9375rem;line-height:1.6}
.cta-right{display:flex;flex-direction:column;justify-content:center;align-items:stretch;gap:.875rem}
.cta-right .btn-primary,.cta-right .btn-outline-light{justify-content:center}
.cta-arlis{font-size:.75rem;color:rgba(255,255,255,.45);text-align:center;letter-spacing:.04em}

/* FOOTER */
#site-footer{background:var(--charcoal-d);color:rgba(255,255,255,.7)}
.footer-top{display:grid;gap:2.5rem;padding-block:3.5rem}
.footer-brand .logo-name{color:#fff}
.footer-brand .logo-sub{color:rgba(255,255,255,.45)}
.footer-brand .logo-circle{background:rgba(255,255,255,.08)}
.footer-desc{font-size:.875rem;color:rgba(255,255,255,.55);line-height:1.6;margin-top:1rem;max-width:22rem}
.footer-contact{margin-top:1.25rem;display:flex;flex-direction:column;gap:.5rem}
.footer-contact li{display:flex;align-items:center;gap:.625rem;font-size:.875rem;color:rgba(255,255,255,.65)}
.footer-contact li svg{color:var(--aqua);flex-shrink:0;width:1rem;height:1rem}
.footer-col h4{font-family:'Oswald',sans-serif;font-weight:600;font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:.875rem}
.footer-col ul{display:flex;flex-direction:column;gap:.375rem}
.footer-col ul a{font-size:.875rem;color:rgba(255,255,255,.65);transition:color var(--transition)}
.footer-col ul a:hover{color:var(--aqua)}
.footer-cta-box{background:rgba(30,200,213,.08);border:1px solid rgba(30,200,213,.2);border-radius:var(--radius-xl);padding:1.5rem}
.footer-cta-box p{font-size:.875rem;color:rgba(255,255,255,.65);margin-bottom:1rem}
.footer-cta-box .btn-primary{width:100%;justify-content:center;font-size:.8rem;padding:.625rem 1rem}
.footer-cta-secondary{display:block;text-align:center;margin-top:.625rem;font-size:.8rem;font-weight:700;font-family:'Oswald',sans-serif;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.55);padding:.625rem 1rem;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.12);transition:color var(--transition),border-color var(--transition)}
.footer-cta-secondary:hover{color:#fff;border-color:rgba(255,255,255,.3)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-block:1.25rem;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;align-items:center;font-size:.75rem;color:rgba(255,255,255,.4)}

/* SERVICES PAGE */
.service-row{display:grid;gap:2rem;align-items:center;margin-bottom:4rem}
.service-row:last-child{margin-bottom:0}
.service-img-col{border-radius:var(--radius-2xl);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-card)}
.service-img-col img{width:100%;aspect-ratio:4/3;object-fit:cover}
.svc-num{font-family:'Oswald',sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--aqua-d)}
.service-content h2{font-family:'Oswald',sans-serif;font-size:clamp(1.625rem,4vw,2.25rem);font-weight:700;color:var(--charcoal);margin-top:.375rem;margin-bottom:.875rem}
.service-content p{color:var(--muted);line-height:1.6}
.service-bullets{display:flex;flex-direction:column;gap:.5rem;margin-top:1.25rem}
.service-bullets li{display:flex;align-items:center;gap:.625rem;font-size:.9rem;color:var(--charcoal)}
.service-bullets li svg{color:var(--aqua-d);flex-shrink:0}
.service-btns{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}

/* GALLERY PAGE */
.filter-bar{border-bottom:1px solid var(--border);background:var(--card)}
.filter-bar-inner{display:flex;flex-wrap:wrap;gap:.5rem;padding-block:1.25rem;overflow-x:auto}
.filter-btn{padding:.4375rem 1rem;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;transition:background var(--transition),color var(--transition);background:var(--secondary);color:var(--muted);white-space:nowrap}
.filter-btn:hover{background:rgba(30,200,213,.12);color:var(--aqua-d)}
.filter-btn.active{background:var(--charcoal-d);color:#fff}
.gallery-note{background:rgba(13,151,168,.06);border:1px dashed rgba(13,151,168,.3);border-radius:var(--radius);padding:.875rem 1.25rem;font-size:.875rem;color:var(--charcoal);margin-bottom:2rem}
.gallery-note strong{color:var(--aqua-d)}
.gallery-page-grid{display:grid;gap:1.25rem;grid-template-columns:1fr}
.gallery-project-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-card);transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition)}
.gallery-project-card:hover{transform:translateY(-4px);border-color:var(--aqua);box-shadow:0 8px 32px rgba(30,200,213,.15)}
.gallery-project-card .card-img{position:relative;aspect-ratio:4/3;overflow:hidden}
.gallery-project-card .card-img img{width:100%;height:100%;object-fit:cover;transition:transform 400ms}
.gallery-project-card:hover .card-img img{transform:scale(1.05)}
.card-cat-badge{position:absolute;top:.75rem;left:.75rem;display:inline-flex;align-items:center;gap:.375rem;background:rgba(12,12,12,.88);color:var(--aqua);font-family:'Oswald',sans-serif;font-size:.625rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;padding:.25rem .625rem;border-radius:999px}
.gallery-project-card .card-body{padding:1.125rem}
.gallery-project-card .card-body h3{font-family:'Oswald',sans-serif;font-size:1rem;font-weight:700;color:var(--charcoal);margin-bottom:.25rem}
.gallery-project-card .card-body p{font-size:.8125rem;color:var(--muted)}

/* ABOUT PAGE */
.about-grid{display:grid;gap:3rem}
.about-story h2{font-family:'Oswald',sans-serif;font-size:clamp(1.75rem,4vw,2.25rem);font-weight:700;color:var(--charcoal);margin-top:.5rem;margin-bottom:1rem}
.about-story p{color:var(--muted);line-height:1.7;margin-bottom:1rem}
.about-values{display:grid;grid-template-columns:1fr 1fr;gap:.875rem;margin-top:1.75rem}
.about-value-card{background:var(--secondary);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}
.about-value-card h4{font-family:'Oswald',sans-serif;font-weight:600;font-size:.9375rem;color:var(--charcoal);margin-bottom:.25rem}
.about-value-card p{font-size:.8125rem;color:var(--muted);line-height:1.4}
.about-aside{display:flex;flex-direction:column;gap:1.25rem}
.about-img{border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-card)}
.about-img img{width:100%;aspect-ratio:4/3;object-fit:cover}
.owner-contact-card{background:var(--charcoal-d);border-radius:var(--radius-xl);padding:1.5rem;color:#fff}
.owner-contact-card .eyebrow{color:var(--aqua);margin-bottom:.375rem}
.owner-contact-card h3{font-family:'Oswald',sans-serif;font-size:1.375rem;font-weight:700;color:#fff}
.owner-title{font-size:.8125rem;color:rgba(255,255,255,.55);margin-bottom:1.25rem}
.owner-info-item{display:flex;align-items:center;gap:.75rem;background:rgba(255,255,255,.06);border-radius:var(--radius);padding:.75rem 1rem;margin-bottom:.625rem}
.owner-info-item svg{color:var(--aqua);flex-shrink:0}
.owner-info-label{font-size:.625rem;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.45)}
.owner-info-val{font-size:.9375rem;font-weight:700;color:#fff}

/* RESCOMM PAGE */
.rescomm-page-grid{display:grid;gap:1.5rem}
.rescomm-page-card{border-radius:var(--radius-2xl);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-card)}
.rescomm-page-card .card-hero{position:relative;aspect-ratio:16/9}
.rescomm-page-card .card-hero img{width:100%;height:100%;object-fit:cover}
.rescomm-page-card .card-hero .img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,15,15,.65) 0%,transparent 50%)}
.rescomm-page-card.dark{border-color:rgba(255,255,255,.06)}
.rescomm-page-body{padding:2rem;background:var(--card)}
.rescomm-page-card.dark .rescomm-page-body{background:var(--charcoal-d)}
.rescomm-page-body h2{font-family:'Oswald',sans-serif;font-size:1.75rem;font-weight:700;color:var(--charcoal);margin-bottom:.625rem}
.rescomm-page-card.dark .rescomm-page-body h2{color:#fff}
.rescomm-page-body > p{color:var(--muted);line-height:1.6;margin-bottom:1.5rem}
.rescomm-page-card.dark .rescomm-page-body > p{color:rgba(255,255,255,.65)}
.rescomm-checklist{display:grid;grid-template-columns:1fr 1fr;gap:.625rem;margin-bottom:1.75rem}
.rescomm-checklist li{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--charcoal)}
.rescomm-page-card.dark .rescomm-checklist li{color:rgba(255,255,255,.8)}
.rescomm-checklist li svg{color:var(--aqua-d);flex-shrink:0;width:1rem;height:1rem}
.rescomm-page-card.dark .rescomm-checklist li svg{color:var(--aqua)}

/* CONTACT PAGE */
.contact-grid{display:grid;gap:2.5rem}
.contact-form-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-2xl);padding:2rem;box-shadow:var(--shadow-card)}
.contact-form-card h2{font-family:'Oswald',sans-serif;font-size:clamp(1.5rem,4vw,2rem);font-weight:700;color:var(--charcoal);margin-top:.375rem;margin-bottom:1.75rem}
.form-row-2{display:grid;grid-template-columns:1fr;gap:1rem}
.field-group{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1rem}
.field-label{font-family:'Oswald',sans-serif;font-size:.6875rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--charcoal)}
.field-req{color:var(--aqua-d)}
.field-input,.field-select,.field-textarea{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--card);font-family:'Inter',sans-serif;font-size:.9rem;color:var(--fg);outline:none;transition:border-color var(--transition),box-shadow var(--transition);appearance:none;-webkit-appearance:none}
.field-input:focus,.field-select:focus,.field-textarea:focus{border-color:var(--aqua);box-shadow:0 0 0 3px rgba(30,200,213,.15)}
.field-textarea{resize:vertical}
.file-upload-label{display:flex;align-items:center;gap:.625rem;padding:.75rem 1rem;border:1px dashed var(--border);border-radius:var(--radius-lg);background:var(--secondary);cursor:pointer;font-size:.875rem;color:var(--muted);transition:border-color var(--transition)}
.file-upload-label:hover{border-color:var(--aqua-d)}
.file-upload-label svg{color:var(--aqua-d);flex-shrink:0}
.btn-submit{width:100%;padding:1rem;background:linear-gradient(135deg,var(--aqua) 0%,var(--aqua-d) 100%);color:var(--charcoal-d);font-family:'Oswald',sans-serif;font-weight:700;font-size:1rem;letter-spacing:.08em;text-transform:uppercase;border:none;border-radius:var(--radius-lg);cursor:pointer;box-shadow:0 4px 16px rgba(30,200,213,.35);transition:transform var(--transition),box-shadow var(--transition);margin-top:1.5rem}
.btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(30,200,213,.5)}
.form-consent{text-align:center;font-size:.75rem;color:var(--muted);margin-top:.75rem}
.contact-sidebar{display:flex;flex-direction:column;gap:1.25rem}
.contact-owner-card{background:var(--charcoal-d);border-radius:var(--radius-2xl);padding:1.5rem;color:#fff}
.contact-owner-card .eyebrow{color:var(--aqua);margin-bottom:.375rem}
.contact-owner-card h3{font-family:'Oswald',sans-serif;font-size:1.375rem;font-weight:700}
.o-title{font-size:.8125rem;color:rgba(255,255,255,.55);margin-bottom:1.25rem}
.contact-trust-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-2xl);padding:1.5rem;box-shadow:var(--shadow-card)}
.contact-trust-card h4{font-family:'Oswald',sans-serif;font-size:1.125rem;font-weight:700;color:var(--charcoal);margin-bottom:.875rem}
.trust-list{display:flex;flex-direction:column;gap:.625rem}
.trust-list li{display:flex;align-items:center;gap:.625rem;font-size:.9rem;color:var(--charcoal)}
.trust-list li svg{color:var(--aqua-d);flex-shrink:0}
.form-success{display:flex;flex-direction:column;align-items:center;text-align:center;padding-block:3rem}
.check-circle{width:4rem;height:4rem;border-radius:50%;background:rgba(13,151,168,.12);display:flex;align-items:center;justify-content:center;color:var(--aqua-d);margin-bottom:1.5rem}
.form-success h2{font-family:'Oswald',sans-serif;font-size:1.625rem;font-weight:700;color:var(--charcoal);margin-bottom:.75rem}
.form-success p{color:var(--muted);max-width:30rem}

/* SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 500ms ease,transform 500ms ease}
.reveal.visible{opacity:1;transform:none}

/* MOBILE STICKY CTA BAR */
.mobile-cta-bar{position:fixed;bottom:0;left:0;right:0;z-index:200;display:flex;gap:.5rem;background:var(--charcoal-d);border-top:2px solid rgba(30,200,213,.2);padding:.625rem 1rem;padding-bottom:calc(.625rem + env(safe-area-inset-bottom,0px))}
.mcta-call{flex:1;display:flex;align-items:center;justify-content:center;gap:.375rem;font-family:'Oswald',sans-serif;font-weight:600;font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;border-radius:var(--radius);padding:.5625rem .375rem;background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.15);transition:background var(--transition)}
.mcta-call:hover{background:rgba(255,255,255,.18)}
.mcta-call svg{width:13px;height:13px;flex-shrink:0}
.mcta-estimate{flex:1;display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-weight:700;font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;border-radius:var(--radius);padding:.5625rem .375rem;background:linear-gradient(135deg,var(--aqua),var(--aqua-d));color:var(--charcoal-d)}
@media(min-width:768px){.mobile-cta-bar{display:none}}
body{padding-bottom:4rem}
@media(min-width:768px){body{padding-bottom:0}}

/* HAMBURGER X ANIMATION */
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* CONTACT RADIO/SELECT ENHANCEMENTS */
.field-select-wrap{position:relative}
.field-select-wrap::after{content:'';position:absolute;right:.875rem;top:50%;transform:translateY(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid var(--muted);pointer-events:none}
.radio-group{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}
.radio-opt{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;color:var(--charcoal);cursor:pointer;transition:border-color var(--transition),background var(--transition)}
.radio-opt:has(input:checked){border-color:var(--aqua-d);background:rgba(13,151,168,.06);color:var(--aqua-d)}
.radio-opt input{width:14px;height:14px;accent-color:var(--aqua-d)}

/* ENHANCED BEFORE/AFTER BAND */
.ba-band{background:var(--charcoal-d);position:relative;overflow:hidden;padding-block:5rem}
.ba-band-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.1}
.ba-band-overlay{position:absolute;inset:0;background:linear-gradient(135deg,var(--charcoal-d) 0%,rgba(14,14,14,.92) 100%)}
.ba-band-inner{position:relative;z-index:1}
.ba-band-header{text-align:center;margin-bottom:3rem}
.ba-band-header .eyebrow{color:var(--aqua)}
.ba-band-header h2{font-family:'Oswald',sans-serif;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;color:#fff;margin-top:.5rem}
.ba-proof-grid{display:grid;gap:1.25rem;grid-template-columns:1fr}
.ba-proof-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);padding:1.5rem;display:flex;gap:1rem;align-items:flex-start;transition:border-color var(--transition),background var(--transition)}
.ba-proof-card:hover{border-color:rgba(30,200,213,.4);background:rgba(255,255,255,.08)}
.ba-proof-icon{width:2.5rem;height:2.5rem;border-radius:50%;background:linear-gradient(135deg,var(--aqua),var(--aqua-d));display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--charcoal-d)}
.ba-proof-card h3{font-family:'Oswald',sans-serif;font-size:1.0625rem;font-weight:700;color:#fff;margin-bottom:.25rem}
.ba-proof-card p{font-size:.875rem;color:rgba(255,255,255,.6);line-height:1.5}
.ba-image-strip{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:3rem}
.ba-strip-img{position:relative;border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:3/2;border:2px solid rgba(30,200,213,.25)}
.ba-strip-img img{width:100%;height:100%;object-fit:cover}
.ba-strip-label{position:absolute;bottom:.625rem;left:.625rem;font-family:'Oswald',sans-serif;font-weight:700;font-size:.625rem;letter-spacing:.15em;text-transform:uppercase;padding:.25rem .625rem;border-radius:999px}
.ba-strip-label.before{background:var(--charcoal-d);color:rgba(255,255,255,.8)}
.ba-strip-label.after{background:var(--aqua);color:var(--charcoal-d)}
@media(min-width:640px){.ba-proof-grid{grid-template-columns:1fr 1fr 1fr}}

/* ABOUT CONTACT BANNER */
.about-cta-banner{background:linear-gradient(135deg,var(--aqua) 0%,var(--aqua-d) 100%);border-radius:var(--radius-xl);padding:1.5rem;color:var(--charcoal-d);display:flex;flex-direction:column;gap:1rem}
.about-cta-banner h3{font-family:'Oswald',sans-serif;font-weight:700;font-size:1.25rem}
.about-cta-banner p{font-size:.875rem;opacity:.85;line-height:1.5}
.about-cta-banner .btn-dark{align-self:flex-start;background:var(--charcoal-d);color:#fff}

/* ============================
   ANIMATIONS & VISUAL EFFECTS
   ============================ */

@keyframes heroFadeUp {
  from { opacity:0; transform:translateY(28px); }
  to   { opacity:1; transform:none; }
}
@keyframes heroFadeRight {
  from { opacity:0; transform:translateX(28px); }
  to   { opacity:1; transform:none; }
}
@keyframes shimmer {
  0%       { left:-100%; }
  55%,100% { left:150%; }
}
@keyframes floatBadge {
  0%,100% { transform:translateX(-50%) translateY(0); }
  50%     { transform:translateX(-50%) translateY(-10px); }
}
@keyframes pulseRing {
  0%   { box-shadow:0 4px 16px rgba(30,200,213,.35),0 0 0 0 rgba(30,200,213,.45); }
  70%  { box-shadow:0 4px 16px rgba(30,200,213,.35),0 0 0 16px rgba(30,200,213,0); }
  100% { box-shadow:0 4px 16px rgba(30,200,213,.35),0 0 0 0 rgba(30,200,213,0); }
}
@keyframes dropFall {
  0%   { opacity:0; transform:translateY(-10px) scale(.4); }
  8%   { opacity:1; }
  92%  { opacity:.6; }
  100% { opacity:0; transform:translateY(110vh) scale(.7); }
}
@keyframes popIn {
  0%   { opacity:0; transform:scale(.3) rotate(-15deg); }
  70%  { transform:scale(1.2) rotate(4deg); }
  100% { opacity:1; transform:scale(1) rotate(0deg); }
}
@keyframes ctaGlow {
  0%,100% { box-shadow:0 0 0 1px rgba(30,200,213,.12),0 8px 40px rgba(0,0,0,.35); }
  50%     { box-shadow:0 0 0 2px rgba(30,200,213,.45),0 8px 50px rgba(30,200,213,.12); }
}
@keyframes scanLine {
  0%   { transform:translateX(-100%); }
  100% { transform:translateX(260%); }
}

/* Scroll progress bar */
#scroll-progress{position:fixed;top:0;left:0;height:3px;z-index:9999;width:0%;background:linear-gradient(90deg,var(--aqua),var(--aqua-d));transition:width 80ms linear;pointer-events:none}

/* Hero entrance — home page only */
.home-hero .hero-left .eyebrow{animation:heroFadeUp .55s ease both}
.home-hero .hero-left h1{animation:heroFadeUp .6s ease both .12s}
.home-hero .hero-sub{animation:heroFadeUp .6s ease both .26s}
.home-hero .hero-ctas{animation:heroFadeUp .6s ease both .4s}
.home-hero .hero-trust{animation:heroFadeUp .5s ease both .55s}
.home-hero .hero-right{animation:heroFadeRight .7s ease both .32s}

/* Floating badge */
.hero-free-badge{animation:floatBadge 3.5s ease-in-out infinite}

/* Hero call button pulse ring */
.home-hero .hero-ctas .btn-primary:first-child{animation:pulseRing 2.5s ease-out infinite 1.4s}

/* Button shimmer */
.btn-primary{position:relative;overflow:hidden}
.btn-primary::after{content:'';position:absolute;top:0;left:-100%;width:55%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);animation:shimmer 3.2s ease infinite 1.8s;pointer-events:none}
.btn-submit{position:relative;overflow:hidden}
.btn-submit::after{content:'';position:absolute;top:0;left:-100%;width:55%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);animation:shimmer 3.6s ease infinite 2.4s;pointer-events:none}

/* Water drop particles (JS-injected spans) */
.hero-drops{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.hero-drop{position:absolute;border-radius:50%;background:radial-gradient(circle at 35% 35%,rgba(30,200,213,.32),rgba(30,200,213,.06));box-shadow:inset 0 0 3px rgba(30,200,213,.2),0 1px 6px rgba(30,200,213,.1);animation:dropFall linear infinite}

/* Why-num pop on reveal */
.why-card.visible .why-num{animation:popIn .5s cubic-bezier(.34,1.56,.64,1) both .08s}

/* Stagger reveal support */
.reveal{transition-delay:var(--reveal-delay,0ms)}

/* Gallery scale reveal */
.gallery-item.reveal{transform:scale(.95) translateY(16px)}
.gallery-item.reveal.visible{transform:scale(1) translateY(0)}

/* Service card link arrow nudge */
.service-card-link svg{transition:transform 200ms ease}
.service-card:hover .service-card-link svg{transform:translateX(5px)}

/* Trust icon glow */
.trust-icon{transition:box-shadow 300ms ease}
.trust-item:hover .trust-icon{box-shadow:0 0 0 8px rgba(13,151,168,.12)}

/* Before/after scan line sweep */
.ba-strip-img::after{content:'';position:absolute;inset:0;width:50%;background:linear-gradient(90deg,transparent,rgba(30,200,213,.18),transparent);animation:scanLine 4s ease-in-out infinite;pointer-events:none}

/* Final CTA card glow pulse */
.final-cta-card{animation:ctaGlow 3.5s ease-in-out infinite}

/* Page hero entrance for inner pages */
.page-hero-inner .eyebrow{animation:heroFadeUp .5s ease both}
.page-hero-inner h1{animation:heroFadeUp .6s ease both .1s}
.page-hero-inner .subtitle{animation:heroFadeUp .55s ease both .22s}
.page-hero-inner .hero-ctas{animation:heroFadeUp .55s ease both .35s}

/* Prefers-reduced-motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .hero-drops{display:none}
}

/* RESPONSIVE */
@media(min-width:640px){
  .trust-strip-inner{grid-template-columns:repeat(4,1fr)}
  .services-grid{grid-template-columns:1fr 1fr}
  .why-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .form-row-2{grid-template-columns:1fr 1fr}
  .gallery-page-grid{grid-template-columns:1fr 1fr}
}
@media(min-width:768px){
  .home-hero-inner{grid-template-columns:1fr 1fr}
  .hero-right{display:block}
  .ba-grid{grid-template-columns:1fr 1fr;align-items:center}
  .rescomm-grid{grid-template-columns:1fr 1fr}
  .about-grid{grid-template-columns:1.4fr 1fr;align-items:start}
  .contact-grid{grid-template-columns:1.4fr 1fr;align-items:start}
  .rescomm-page-grid{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1.5fr 1fr 1fr 1.25fr}
  .service-row{grid-template-columns:1fr 1fr}
  .service-row.reverse>:first-child{order:2}
  .final-cta-inner{grid-template-columns:1.2fr 1fr;align-items:center}
}
@media(min-width:1024px){
  .services-grid{grid-template-columns:repeat(3,1fr)}
  .why-grid{grid-template-columns:repeat(3,1fr)}
  .gallery-grid{grid-template-columns:repeat(4,1fr)}
  .gallery-page-grid{grid-template-columns:repeat(3,1fr)}
}

/* ============================
   DARK THEME OVERRIDES
   Logo-matched gunmetal palette
   ============================ */

/* Header — dark glass */
#site-header{background:rgba(14,14,14,.94);border-bottom-color:rgba(255,255,255,.07)}
.logo-name{color:#fff}
.logo-sub{color:rgba(255,255,255,.45)}
.logo-circle{background:rgba(255,255,255,.1)}
.header-phone{color:rgba(255,255,255,.85)}
.header-phone:hover{color:var(--aqua)}
.site-nav a{color:rgba(255,255,255,.6)}
.site-nav a:hover,.site-nav a.active{color:var(--aqua);background:rgba(30,200,213,.09)}
.hamburger span{background:rgba(255,255,255,.85)}
.hamburger:hover{background:rgba(255,255,255,.06)}
.mobile-nav{background:var(--charcoal);border-top-color:rgba(255,255,255,.07)}
.mobile-nav a{color:rgba(255,255,255,.8)}
.mobile-nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.mobile-nav-btns{border-top-color:rgba(255,255,255,.08)}

/* Section headings */
.section-header h2{color:#fff}
.section-header p{color:var(--muted)}
.eyebrow{color:var(--aqua)}
.eyebrow-light{color:var(--aqua)}

/* Trust strip */
.trust-strip{background:var(--secondary);border-color:rgba(255,255,255,.06)}
.trust-label{color:#fff}
.trust-sub{color:var(--muted)}
.trust-icon{background:rgba(30,200,213,.1)}

/* Service cards */
.service-card{background:var(--card);border-color:var(--border)}
.service-card-body h3{color:#fff}
.service-card-body p{color:var(--muted)}

/* Before/after section */
.ba-section{background:var(--secondary)}
.ba-content h2{color:#fff}
.ba-point-text h4{color:#fff}
.ba-point-text p{color:var(--muted)}
.ba-images img{border-color:rgba(255,255,255,.09)}

/* Gallery section & cards */
.gallery-section{background:var(--bg)}
.gallery-project-card{background:var(--card);border-color:var(--border)}
.gallery-project-card .card-body h3{color:#fff}
.gallery-project-card .card-body p{color:var(--muted)}

/* Gallery filter bar */
.filter-bar{background:var(--secondary);border-bottom-color:rgba(255,255,255,.07)}
.filter-btn{background:rgba(255,255,255,.06);color:rgba(255,255,255,.5)}
.filter-btn:hover{background:rgba(30,200,213,.14);color:var(--aqua)}
.filter-btn.active{background:var(--aqua);color:var(--charcoal-d)}
.gallery-note{background:rgba(30,200,213,.07);border-color:rgba(30,200,213,.25);color:rgba(255,255,255,.7)}
.gallery-note strong{color:var(--aqua)}

/* Rescomm section */
.rescomm-section{background:var(--secondary)}
.rescomm-card{border-color:var(--border)}
.rescomm-card-body{background:var(--card)}
.rescomm-card-body h3{color:#fff}
.rescomm-card-body p{color:var(--muted)}
.rc-list li{color:rgba(255,255,255,.75)}

/* Rescomm page */
.rescomm-page-card{border-color:var(--border)}
.rescomm-page-body{background:var(--card)}
.rescomm-page-body h2{color:#fff}
.rescomm-page-body>p{color:var(--muted)}
.rescomm-checklist li{color:rgba(255,255,255,.75)}

/* About page */
.about-story h2{color:#fff}
.about-story p{color:var(--muted)}
.about-value-card{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.07)}
.about-value-card h4{color:#fff}
.about-value-card p{color:var(--muted)}
.about-img{border-color:rgba(255,255,255,.08)}

/* Services page */
.service-content h2{color:#fff}
.service-content p{color:var(--muted)}
.service-bullets li{color:rgba(255,255,255,.8)}
.service-img-col{border-color:rgba(255,255,255,.08)}

/* Contact page */
.contact-form-card{background:var(--card);border-color:var(--border)}
.contact-form-card h2{color:#fff}
.field-label{color:rgba(255,255,255,.7)}
.field-req{color:var(--aqua)}
.field-input,.field-select,.field-textarea{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1);color:#fff;color-scheme:dark}
.field-input::placeholder,.field-textarea::placeholder{color:rgba(255,255,255,.28)}
.field-select option{background:var(--charcoal);color:#fff}
.file-upload-label{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.12);color:rgba(255,255,255,.45)}
.form-consent{color:rgba(255,255,255,.35)}
.radio-opt{border-color:rgba(255,255,255,.12);color:rgba(255,255,255,.7)}
.radio-opt:has(input:checked){border-color:var(--aqua-d);background:rgba(13,151,168,.12);color:var(--aqua)}
.contact-trust-card{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.07)}
.contact-trust-card h4{color:#fff}
.trust-list li{color:rgba(255,255,255,.75)}
.trust-list li svg{color:var(--aqua)}
.form-success h2{color:#fff}
.form-success p{color:var(--muted)}
.check-circle{background:rgba(30,200,213,.12)}

/* Button outline adjustments on dark bg */
.btn-dark{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.15)}
.btn-dark:hover{background:rgba(255,255,255,.18)}
.btn-outline-aqua{background:rgba(255,255,255,.06);color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.15)}
.btn-outline-aqua:hover{border-color:var(--aqua-d);color:var(--aqua)}

/* Footer */
#site-footer{background:var(--charcoal-d)}
.footer-bottom{border-top-color:rgba(255,255,255,.06)}

/* Water card generic */
.water-card{background:var(--card);border-color:var(--border)}

/* Mobile sticky bar */
.mobile-cta-bar{background:var(--charcoal-d);border-top-color:rgba(30,200,213,.18)}

/* Scrollbar */
::-webkit-scrollbar{width:6px;background:var(--charcoal-d)}
::-webkit-scrollbar-thumb{background:rgba(30,200,213,.28);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(30,200,213,.5)}
