/* ================================================================
   In the Zone Irrigation — Design System
   Florida green · sun gold · sky blue · warm cream
   Crafted by IHC Technology
   ================================================================ */

:root{
  --green-900:#0b3d22;
  --green-700:#116b39;
  --green-500:#1c8a4b;
  --green-100:#e3f1e8;
  --sun-500:#f5b700;
  --sun-400:#ffc933;
  --sky-500:#2e86ab;
  --sky-300:#7cb7d1;
  --cream:#faf7f2;
  --ink:#161a18;
  --muted:#5a6661;
  --line:#e3ddd2;
  --white:#ffffff;

  --f-head:'Oswald',system-ui,sans-serif;
  --f-body:'Inter',system-ui,sans-serif;

  --wrap:1180px;
  --radius:10px;
  --shadow-sm:0 2px 8px rgba(11,61,34,.08);
  --shadow-md:0 8px 28px rgba(11,61,34,.12);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--f-body);color:var(--ink);
  background:var(--cream);line-height:1.65;font-size:17px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--green-700);text-decoration:none}
a:hover{color:var(--green-900);text-decoration:underline}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}

/* ========== TYPOGRAPHY ========== */
h1,h2,h3,h4{font-family:var(--f-head);font-weight:600;letter-spacing:.01em;line-height:1.15;margin:0 0 .6em}
h1{font-size:clamp(2rem,4.5vw,3.3rem);color:var(--green-900)}
h2{font-size:clamp(1.6rem,3.2vw,2.2rem);color:var(--green-900)}
h3{font-size:1.35rem;color:var(--green-700)}
h4{font-size:1.1rem;color:var(--ink);font-weight:500;text-transform:uppercase;letter-spacing:.08em}
p{margin:0 0 1rem}
ul{padding-left:1.3em;margin:0 0 1rem}
li{margin-bottom:.4rem}
.eyebrow{display:inline-block;font-family:var(--f-head);text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;color:var(--sun-500);font-weight:600;margin-bottom:.6rem}

/* ========== HEADER ========== */
.topbar{
  background:var(--green-900);color:var(--cream);
  font-size:.85rem;padding:8px 0;
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.topbar a{color:var(--sun-400)}
.topbar a:hover{color:var(--sun-500)}
.topbar .phone{font-family:var(--f-head);font-size:1rem;letter-spacing:.04em}

header.main{
  background:var(--white);border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm);
}
header.main .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:14px;padding-bottom:14px;gap:16px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--f-head);font-weight:600;color:var(--green-900);font-size:1.4rem;letter-spacing:.02em}
.brand .mark{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--green-500),var(--sky-500));
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.3rem;
}
.brand .mark::before{content:"💧"}
nav.primary{display:flex;gap:2px;flex-wrap:wrap;align-items:center}
nav.primary a{
  color:var(--ink);font-weight:500;font-size:.92rem;
  padding:8px 12px;border-radius:6px;transition:all .15s;
}
nav.primary a:hover{background:var(--green-100);color:var(--green-900);text-decoration:none}
nav.primary a.active{background:var(--green-900);color:var(--cream)}

.menu-toggle{display:none;background:none;border:2px solid var(--green-900);color:var(--green-900);font-family:var(--f-head);padding:6px 14px;border-radius:6px;cursor:pointer;font-size:.95rem}

@media (max-width:900px){
  .menu-toggle{display:block}
  nav.primary{display:none;width:100%;flex-direction:column;gap:0;padding-top:12px;border-top:1px solid var(--line);margin-top:12px}
  nav.primary.open{display:flex}
  nav.primary a{width:100%;padding:12px}
  header.main .wrap{flex-wrap:wrap}
}

/* ========== BUTTONS ========== */
.btn{
  display:inline-block;font-family:var(--f-head);font-weight:500;
  font-size:1rem;letter-spacing:.06em;text-transform:uppercase;
  padding:14px 28px;border-radius:var(--radius);
  transition:all .2s;cursor:pointer;border:2px solid transparent;text-align:center;
}
.btn-primary{background:var(--sun-500);color:var(--green-900)}
.btn-primary:hover{background:var(--sun-400);transform:translateY(-1px);box-shadow:var(--shadow-md);text-decoration:none;color:var(--green-900)}
.btn-ghost{background:transparent;color:var(--white);border-color:var(--white)}
.btn-ghost:hover{background:var(--white);color:var(--green-900);text-decoration:none}
.btn-dark{background:var(--green-900);color:var(--cream)}
.btn-dark:hover{background:var(--green-700);color:var(--white);text-decoration:none}

/* ========== HERO ========== */
.hero{
  position:relative;padding:80px 0 90px;overflow:hidden;
  background:
    linear-gradient(135deg,rgba(11,61,34,.88) 0%,rgba(17,107,57,.75) 60%,rgba(46,134,171,.72) 100%),
    url('/assets/img/hero-landscape.jpg') center/cover no-repeat,
    var(--green-900);
  color:var(--white);
}
.hero .eyebrow{color:var(--sun-400)}
.hero h1{color:var(--white);max-width:22ch}
.hero p.lead{font-size:1.2rem;max-width:60ch;opacity:.95;margin-bottom:2rem}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

.page-hero{
  background:linear-gradient(135deg,var(--green-900) 0%,var(--green-700) 100%);
  color:var(--white);padding:60px 0 50px;
}
.page-hero h1{color:var(--white);margin-bottom:.4rem}
.page-hero .sub{font-size:1.15rem;opacity:.9;max-width:60ch;margin:0}
.breadcrumb{font-size:.85rem;opacity:.75;margin-bottom:1rem;font-family:var(--f-head);letter-spacing:.08em;text-transform:uppercase}
.breadcrumb a{color:var(--sun-400)}

/* ========== SECTIONS ========== */
section{padding:64px 0}
.section-tight{padding:40px 0}

/* Services grid */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px;margin-top:40px}
.service-card{
  background:var(--white);border-radius:var(--radius);padding:28px;
  border:1px solid var(--line);transition:all .2s;
  display:flex;flex-direction:column;
}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--green-500)}
.service-card .icon{
  width:52px;height:52px;border-radius:10px;
  background:var(--green-100);color:var(--green-700);
  display:flex;align-items:center;justify-content:center;font-size:1.6rem;
  margin-bottom:16px;
}
.service-card h3{margin-bottom:.4rem;color:var(--green-900)}
.service-card p{color:var(--muted);margin-bottom:1rem;flex-grow:1}
.service-card .more{font-family:var(--f-head);font-size:.88rem;text-transform:uppercase;letter-spacing:.1em;color:var(--green-700)}

/* Service area block */
.area-block{
  background:var(--green-100);border-radius:var(--radius);
  padding:24px 28px;border-left:4px solid var(--green-500);
}
.area-block h4{margin-bottom:.5rem;color:var(--green-900);font-weight:600}
.area-block .towns{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.area-block .towns span{
  background:var(--white);padding:4px 12px;border-radius:20px;font-size:.9rem;color:var(--green-900);
  border:1px solid var(--green-500);
}

/* Content body */
.content-body{max-width:760px}
.content-body h3{margin-top:2rem}
.content-body h4{margin-top:1.8rem;color:var(--green-900)}

/* ========== CTA BAR ========== */
.cta-bar{
  background:linear-gradient(135deg,var(--green-900),var(--green-700));
  color:var(--white);padding:54px 0;text-align:center;
}
.cta-bar h2{color:var(--white);margin-bottom:.6rem}
.cta-bar p{opacity:.9;font-size:1.1rem;max-width:55ch;margin:0 auto 1.6rem}
.cta-bar .phone-big{
  display:inline-block;font-family:var(--f-head);font-size:2rem;
  color:var(--sun-400);letter-spacing:.05em;margin-right:20px;
}
.cta-bar .phone-big:hover{color:var(--sun-500);text-decoration:none}

/* ========== CONTACT ========== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
@media (max-width:760px){.contact-grid{grid-template-columns:1fr}}
.contact-form{background:var(--white);padding:32px;border-radius:var(--radius);border:1px solid var(--line)}
.contact-form label{display:block;font-weight:600;margin-bottom:6px;font-size:.95rem;color:var(--green-900)}
.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:8px;
  font-family:inherit;font-size:1rem;margin-bottom:16px;background:var(--cream);
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{
  outline:none;border-color:var(--green-500);background:var(--white);
  box-shadow:0 0 0 3px rgba(28,138,75,.15);
}
.contact-form textarea{min-height:140px;resize:vertical}
.contact-info .info-block{
  background:var(--white);padding:24px;border-radius:var(--radius);
  border:1px solid var(--line);margin-bottom:16px;
}
.contact-info .info-block strong{display:block;color:var(--green-900);font-family:var(--f-head);font-size:1.1rem;margin-bottom:4px;letter-spacing:.04em}
.contact-info a{color:var(--green-700);font-weight:500}

/* ========== GALLERY ========== */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:32px}
.gallery-grid figure{margin:0;border-radius:var(--radius);overflow:hidden;background:var(--green-100);aspect-ratio:4/3;position:relative}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.gallery-grid figure:hover img{transform:scale(1.04)}
.gallery-grid figcaption{
  position:absolute;bottom:0;left:0;right:0;padding:10px 14px;
  background:linear-gradient(transparent,rgba(11,61,34,.85));color:var(--white);
  font-family:var(--f-head);font-size:.95rem;letter-spacing:.04em;
}
.gallery-placeholder{
  aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--green-100),var(--sky-300));
  color:var(--green-900);font-family:var(--f-head);text-align:center;padding:16px;
  border-radius:var(--radius);
}

/* ========== FOOTER ========== */
footer.site{
  background:var(--green-900);color:var(--cream);
  padding:56px 0 20px;margin-top:40px;
}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
@media (max-width:760px){footer.site .cols{grid-template-columns:1fr 1fr}}
@media (max-width:480px){footer.site .cols{grid-template-columns:1fr}}
footer.site h5{font-family:var(--f-head);text-transform:uppercase;letter-spacing:.1em;font-size:.95rem;color:var(--sun-400);margin:0 0 14px}
footer.site a{color:var(--cream);opacity:.85}
footer.site a:hover{color:var(--sun-400);opacity:1;text-decoration:none}
footer.site ul.foot-links{list-style:none;padding:0;margin:0}
footer.site ul.foot-links li{margin-bottom:8px}
footer.site .legal{
  border-top:1px solid rgba(255,255,255,.15);margin-top:40px;padding-top:20px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.85rem;opacity:.75;
}

/* Home-specific sections */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px;margin-top:40px}
.stat{text-align:center;padding:24px;background:var(--white);border-radius:var(--radius);border:1px solid var(--line)}
.stat .num{font-family:var(--f-head);font-size:2.6rem;color:var(--green-700);line-height:1;margin-bottom:6px}
.stat .lbl{font-size:.9rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}

.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px;margin-top:36px}
.why-card{padding:24px;border-left:3px solid var(--sun-500)}
.why-card h3{color:var(--green-900);margin-bottom:.4rem;font-size:1.1rem}
.why-card p{color:var(--muted);margin:0;font-size:.95rem}

/* Skip link for accessibility */
.skip{position:absolute;left:-9999px;top:0;background:var(--green-900);color:#fff;padding:10px 16px;z-index:200}
.skip:focus{left:10px;top:10px}

/* ================================================================
   ENHANCED VISUALS — Phase 2
   ================================================================ */

/* ---- HEADER with real logo ---- */
.brand img.logo{height:54px;width:auto;display:block}
.brand .brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand .brand-text .name{font-family:var(--f-head);font-weight:600;color:var(--green-900);font-size:1.25rem;letter-spacing:.01em}
.brand .brand-text .tag{font-family:var(--f-head);color:var(--sky-500);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500}
@media (max-width:560px){
  .brand .brand-text .tag{font-size:.65rem;letter-spacing:.15em}
  .brand img.logo{height:44px}
  .brand .brand-text .name{font-size:1.05rem}
}

/* ---- PHOTO HERO ---- */
.hero-v2{
  position:relative;min-height:640px;display:flex;align-items:center;
  padding:90px 0 110px;overflow:hidden;color:var(--white);isolation:isolate;
}
.hero-v2::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:url('/assets/img/hero-main.jpg') center/cover no-repeat;
  transform:scale(1.02);
}
.hero-v2::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(115deg,rgba(11,61,34,.92) 0%,rgba(17,107,57,.78) 45%,rgba(46,134,171,.55) 100%);
}
.hero-v2 .wrap{position:relative;z-index:1;max-width:1180px}
.hero-v2 h1{color:var(--white);max-width:18ch;font-size:clamp(2.3rem,5vw,3.8rem);margin-bottom:.4em;text-shadow:0 2px 20px rgba(0,0,0,.3)}
.hero-v2 .lead{font-size:1.2rem;max-width:58ch;opacity:.95;margin-bottom:2rem;text-shadow:0 1px 10px rgba(0,0,0,.25)}
.hero-v2 .eyebrow{color:var(--sun-400);font-size:.85rem}
.hero-v2 .hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:2.5rem}

/* Floating accent card over hero bottom */
.hero-trust{
  position:relative;margin-top:-60px;z-index:5;margin-bottom:30px;
}
.hero-trust .card{
  background:var(--white);border-radius:var(--radius);
  padding:24px 32px;box-shadow:var(--shadow-md);
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  border-top:4px solid var(--sun-500);
}
.hero-trust .item{text-align:center}
.hero-trust .item svg{width:36px;height:36px;color:var(--green-700);margin:0 auto 8px}
.hero-trust .item strong{display:block;font-family:var(--f-head);color:var(--green-900);font-size:.95rem;margin-bottom:2px;letter-spacing:.03em;text-transform:uppercase}
.hero-trust .item span{color:var(--muted);font-size:.88rem}
@media (max-width:760px){.hero-trust .card{grid-template-columns:1fr 1fr}}
@media (max-width:420px){.hero-trust .card{grid-template-columns:1fr}}

/* ---- SVG ICONS in service cards ---- */
.service-card .icon{
  width:56px;height:56px;border-radius:12px;
  background:linear-gradient(135deg,var(--green-100),#c7e4d3);
  color:var(--green-700);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
}
.service-card .icon svg{width:30px;height:30px}

/* ---- FEATURED WORK STRIP ---- */
.feature-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:36px;
}
.feature-strip a{
  position:relative;aspect-ratio:1/1;overflow:hidden;border-radius:var(--radius);
  display:block;background:var(--green-100);
}
.feature-strip img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.feature-strip a:hover img{transform:scale(1.08)}
.feature-strip a::after{
  content:attr(data-label);position:absolute;bottom:0;left:0;right:0;
  padding:16px 14px 12px;color:#fff;font-family:var(--f-head);font-size:.88rem;
  letter-spacing:.04em;background:linear-gradient(transparent,rgba(11,61,34,.92));
}
@media (max-width:760px){.feature-strip{grid-template-columns:1fr 1fr}}

/* ---- TWO-UP photo+text sections ---- */
.two-up{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.two-up.reverse{grid-template-columns:1fr 1fr}
.two-up .photo{
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);
  aspect-ratio:5/4;
}
.two-up .photo img{width:100%;height:100%;object-fit:cover}
@media (max-width:760px){.two-up,.two-up.reverse{grid-template-columns:1fr;gap:28px}}

/* ---- TESTIMONIALS ---- */
.testimonials{background:var(--white);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px}
@media (max-width:900px){.t-grid{grid-template-columns:1fr}}
.t-card{
  background:var(--cream);border-radius:var(--radius);padding:28px;
  border:1px solid var(--line);position:relative;
}
.t-card::before{
  content:"";position:absolute;top:-12px;left:24px;
  font-family:Georgia,serif;font-size:80px;color:var(--sun-500);
  line-height:1;font-weight:700;
}
.t-card::before{content:"\201C"}
.t-card blockquote{margin:0 0 16px;color:var(--ink);font-size:1.02rem;line-height:1.6;font-style:italic}
.t-card .who{display:flex;align-items:center;gap:12px}
.t-card .avatar{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--green-500),var(--sky-500));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-family:var(--f-head);font-weight:600;
}
.t-card .who strong{display:block;color:var(--green-900);font-size:.95rem}
.t-card .who span{color:var(--muted);font-size:.85rem}
.t-card .stars{color:var(--sun-500);letter-spacing:2px;margin-bottom:10px;font-size:.95rem}

/* ---- SERVICE PAGE hero photos ---- */
.page-hero-photo{
  position:relative;color:var(--white);overflow:hidden;isolation:isolate;
  padding:80px 0 70px;
}
.page-hero-photo::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:var(--photo-url) center/cover no-repeat;
}
.page-hero-photo::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(110deg,rgba(11,61,34,.78) 0%,rgba(17,107,57,.55) 55%,rgba(46,134,171,.35) 100%);
}
.page-hero-photo h1{color:var(--white);text-shadow:0 2px 20px rgba(0,0,0,.3)}
.page-hero-photo .sub{color:rgba(255,255,255,.92);font-size:1.15rem;max-width:60ch;text-shadow:0 1px 10px rgba(0,0,0,.25)}
.page-hero-photo .breadcrumb a{color:var(--sun-400)}

/* ---- SERVICE PAGE inline photo ---- */
.service-photo{
  border-radius:var(--radius);overflow:hidden;margin:24px 0 32px;box-shadow:var(--shadow-md);
}
.service-photo img{width:100%;height:auto;display:block;aspect-ratio:16/9;object-fit:cover}

/* ---- CONTACT MAP + RESPONSE PROMISE ---- */
.contact-hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:28px;align-items:stretch;margin-top:-40px;position:relative;z-index:3}
@media (max-width:860px){.contact-hero-grid{grid-template-columns:1fr}}
.contact-promise{
  background:var(--white);border-radius:var(--radius);
  padding:28px;box-shadow:var(--shadow-md);
  border-top:4px solid var(--sun-500);
}
.contact-promise h3{color:var(--green-900);margin-bottom:.4em}
.contact-promise .response{
  display:flex;align-items:center;gap:14px;
  background:var(--green-100);padding:14px 18px;border-radius:8px;margin:14px 0;
}
.contact-promise .response svg{width:32px;height:32px;color:var(--green-700);flex-shrink:0}
.contact-promise .response div strong{display:block;color:var(--green-900);font-family:var(--f-head)}
.contact-promise .response div span{color:var(--muted);font-size:.9rem}
.map-embed{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:16/10;background:var(--green-100);position:relative}
.map-embed iframe{width:100%;height:100%;border:0;display:block;position:relative;z-index:2}
.map-embed .map-fallback{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--green-700),var(--sky-500));color:#fff;padding:24px;text-align:center;z-index:1;
}
.map-embed .map-fallback svg{width:48px;height:48px;margin-bottom:12px}
.map-embed .map-fallback strong{font-family:var(--f-head);font-size:1.1rem;letter-spacing:.04em;display:block;margin-bottom:4px}
.map-embed .map-fallback a{color:var(--sun-400);margin-top:8px;font-weight:500}

/* ---- GALLERY real images (override placeholder behavior) ---- */
.gallery-grid figure{aspect-ratio:4/3}
.gallery-grid img{width:100%;height:100%;object-fit:cover}
/* ================================================================
   PIZAZZ LAYER — Motion · Effects · Micro-interactions
   "Florida Quiet Luxury" — restrained, organic, premium
   ================================================================ */

/* ---- Smooth everything ---- */
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
}

/* ---- SCROLL PROGRESS BAR ---- */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0%;z-index:1000;
  background:linear-gradient(90deg,var(--sun-500),var(--green-500),var(--sky-500));
  transition:width .08s ease-out;box-shadow:0 0 12px rgba(245,183,0,.6);
}

/* ---- BODY ENTRY ---- */
body{opacity:0;animation:bodyIn .8s ease forwards}
@keyframes bodyIn{to{opacity:1}}

/* ---- SCROLL REVEAL ---- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.16,.84,.44,1),transform .9s cubic-bezier(.16,.84,.44,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.16,.84,.44,1),transform .7s cubic-bezier(.16,.84,.44,1)}
.reveal-stagger.in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.12s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.19s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.26s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.33s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.40s}
.reveal-stagger.in > *:nth-child(7){transition-delay:.47s}
.reveal-stagger.in > *:nth-child(8){transition-delay:.54s}

/* ---- HERO PARALLAX + ANIMATED OVERLAY ---- */
.hero-v2{perspective:1000px}
.hero-v2::before{
  transform:scale(1.08);
  animation:heroZoom 18s ease-out infinite alternate;
}
@keyframes heroZoom{
  0%{transform:scale(1.08) translate(0,0)}
  100%{transform:scale(1.15) translate(-1.5%,-1%)}
}

/* Animated water drops drifting across hero */
.hero-drops{
  position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;
}
.hero-drops .drop{
  position:absolute;width:6px;height:6px;background:var(--sun-400);
  border-radius:50% 50% 50% 0;transform:rotate(-45deg);opacity:0;
  box-shadow:0 0 12px rgba(255,201,51,.7);
  animation:dropFall linear infinite;
}
@keyframes dropFall{
  0%{transform:translateY(-20px) rotate(-45deg);opacity:0}
  10%{opacity:.7}
  90%{opacity:.5}
  100%{transform:translateY(120vh) rotate(-45deg);opacity:0}
}

/* Hero text staggered entry */
.hero-v2 .eyebrow{opacity:0;animation:slideUp .8s .3s ease forwards}
.hero-v2 h1{opacity:0;animation:slideUp 1s .5s cubic-bezier(.16,.84,.44,1) forwards}
.hero-v2 .lead{opacity:0;animation:slideUp .9s .8s ease forwards}
.hero-v2 .hero-cta{opacity:0;animation:slideUp .9s 1.05s ease forwards}
@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

/* Floating sun-glow accent on hero */
.hero-v2::after{
  background:
    radial-gradient(ellipse 800px 400px at 75% 30%,rgba(255,201,51,.18),transparent 60%),
    linear-gradient(115deg,rgba(11,61,34,.92) 0%,rgba(17,107,57,.78) 45%,rgba(46,134,171,.55) 100%);
}

/* ---- TRUST CARD with shimmer entry ---- */
.hero-trust{opacity:0;transform:translateY(40px);animation:trustIn 1s 1.3s cubic-bezier(.16,.84,.44,1) forwards}
@keyframes trustIn{to{opacity:1;transform:translateY(0)}}
.hero-trust .item{position:relative;overflow:hidden}
.hero-trust .item svg{transition:transform .4s cubic-bezier(.34,1.56,.64,1)}
.hero-trust .item:hover svg{transform:scale(1.15) rotate(-5deg);color:var(--sun-500)}

/* ---- BUTTONS ---- */
.btn{position:relative;overflow:hidden;transition:all .3s cubic-bezier(.16,.84,.44,1)}
.btn::before{
  content:"";position:absolute;top:50%;left:50%;width:0;height:0;
  border-radius:50%;background:rgba(255,255,255,.25);
  transform:translate(-50%,-50%);transition:width .6s,height .6s;
}
.btn:hover::before{width:300%;height:300%}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(245,183,0,.4)}
.btn-dark:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(11,61,34,.4)}

/* ---- SERVICE CARDS — magnetic hover + icon animation ---- */
.service-card{position:relative;overflow:hidden;transition:all .4s cubic-bezier(.16,.84,.44,1)}
.service-card::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,var(--green-500),var(--sky-500));
  opacity:0;transition:opacity .4s;z-index:0;
}
.service-card::after{
  content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;
  background:radial-gradient(circle,rgba(245,183,0,.15),transparent 40%);
  transform:rotate(45deg) translate(100%,0);transition:transform .8s cubic-bezier(.16,.84,.44,1);
  z-index:0;pointer-events:none;
}
.service-card:hover{transform:translateY(-8px);border-color:var(--green-500);box-shadow:0 20px 40px rgba(11,61,34,.18)}
.service-card:hover::after{transform:rotate(45deg) translate(-30%,30%)}
.service-card > *{position:relative;z-index:1}
.service-card .icon{transition:all .5s cubic-bezier(.34,1.56,.64,1)}
.service-card:hover .icon{transform:scale(1.1) rotate(-8deg);background:linear-gradient(135deg,var(--sun-400),var(--sun-500));color:var(--green-900)}
.service-card .icon svg{transition:transform .4s}
.service-card:hover .icon svg{transform:scale(1.1)}
.service-card .more{transition:all .3s;display:inline-block}
.service-card:hover .more{transform:translateX(6px);color:var(--green-900)}

/* ---- ORGANIC SECTION DIVIDER (animated water/grass) ---- */
.wave-divider{
  position:relative;height:80px;margin:-1px 0;overflow:hidden;background:transparent;
}
.wave-divider svg{position:absolute;left:0;top:0;width:100%;height:100%;display:block}
.wave-divider .wave-fill{fill:var(--white)}
.wave-divider.dark .wave-fill{fill:var(--green-900)}
.wave-divider.cream .wave-fill{fill:var(--cream)}
.wave-divider svg path{animation:waveMove 12s ease-in-out infinite alternate}
@keyframes waveMove{0%{transform:translateX(0)}100%{transform:translateX(-2%)}}

/* ---- TWO-UP photo zoom on scroll ---- */
.two-up .photo{position:relative;overflow:hidden}
.two-up .photo img{transition:transform 1.2s cubic-bezier(.16,.84,.44,1)}
.two-up .photo:hover img{transform:scale(1.06)}
.two-up .photo::after{
  content:"";position:absolute;inset:0;border:2px solid var(--sun-500);
  border-radius:var(--radius);opacity:0;transform:scale(.95);
  transition:all .5s cubic-bezier(.16,.84,.44,1);pointer-events:none;
}
.two-up .photo:hover::after{opacity:.6;transform:scale(.98)}

/* ---- FEATURE STRIP — image lift + rotate ---- */
.feature-strip a{transition:all .5s cubic-bezier(.16,.84,.44,1)}
.feature-strip a:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(11,61,34,.25);z-index:2}
.feature-strip a img{transition:transform .8s cubic-bezier(.16,.84,.44,1),filter .4s}
.feature-strip a:hover img{transform:scale(1.12);filter:saturate(1.2)}

/* ---- TESTIMONIALS — flip in ---- */
.t-card{transition:all .4s cubic-bezier(.16,.84,.44,1)}
.t-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(11,61,34,.15);border-color:var(--sun-500)}
.t-card::before{transition:transform .4s cubic-bezier(.34,1.56,.64,1),color .3s}
.t-card:hover::before{transform:scale(1.15) rotate(-8deg);color:var(--green-700)}
.t-card .stars{transition:transform .3s}
.t-card:hover .stars{transform:scale(1.05)}

/* ---- COUNTER NUMBERS ---- */
.stat-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  background:var(--green-900);color:var(--cream);
  border-radius:var(--radius);overflow:hidden;
  margin:50px 0;
}
.stat-strip .stat{
  text-align:center;padding:36px 16px;background:transparent;border:0;
  position:relative;border-right:1px solid rgba(255,255,255,.1);
}
.stat-strip .stat:last-child{border-right:0}
.stat-strip .num{
  font-family:var(--f-head);font-size:3.2rem;color:var(--sun-400);
  line-height:1;margin-bottom:8px;font-weight:600;
}
.stat-strip .lbl{color:rgba(255,255,255,.85);font-size:.85rem;text-transform:uppercase;letter-spacing:.12em}
@media (max-width:760px){.stat-strip{grid-template-columns:1fr 1fr}.stat-strip .stat{border-bottom:1px solid rgba(255,255,255,.1)}.stat-strip .num{font-size:2.4rem}}

/* ---- HEADER scroll behavior ---- */
header.main{transition:padding .3s,background .3s,box-shadow .3s}
header.main.scrolled{padding-top:6px;padding-bottom:6px;background:rgba(255,255,255,.96);backdrop-filter:blur(10px)}
header.main.scrolled .wrap{padding-top:8px;padding-bottom:8px}
nav.primary a{position:relative}
nav.primary a:not(.active)::after{
  content:"";position:absolute;bottom:4px;left:12px;right:12px;height:2px;
  background:var(--sun-500);transform:scaleX(0);transform-origin:left;
  transition:transform .3s cubic-bezier(.16,.84,.44,1);
}
nav.primary a:not(.active):hover::after{transform:scaleX(1)}

/* ---- BRAND logo subtle pulse ---- */
.brand img.logo{transition:transform .5s cubic-bezier(.34,1.56,.64,1)}
.brand:hover img.logo{transform:rotate(-8deg) scale(1.08)}

/* ---- CTA BAR — sun rays animation ---- */
.cta-bar{position:relative;overflow:hidden}
.cta-bar::before{
  content:"";position:absolute;top:50%;left:50%;width:600px;height:600px;
  background:radial-gradient(circle,rgba(245,183,0,.15) 0%,transparent 60%);
  transform:translate(-50%,-50%);animation:pulse 4s ease-in-out infinite;
  pointer-events:none;
}
@keyframes pulse{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.4}50%{transform:translate(-50%,-50%) scale(1.15);opacity:.7}}
.cta-bar > *{position:relative;z-index:1}
.cta-bar .phone-big{
  position:relative;padding:8px 0;display:inline-block;transition:all .3s;
}
.cta-bar .phone-big:hover{transform:translateY(-2px) scale(1.04)}

/* ---- CONTACT FORM — focus glow ---- */
.contact-form input,.contact-form select,.contact-form textarea{transition:all .3s cubic-bezier(.16,.84,.44,1)}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{
  transform:translateY(-1px);
  box-shadow:0 0 0 3px rgba(28,138,75,.2),0 6px 20px rgba(11,61,34,.1);
}
.contact-form label{transition:color .3s}
.contact-form input:focus + label{color:var(--sun-500)}
.contact-promise .response{transition:all .3s}
.contact-promise .response:hover{transform:translateX(4px);background:#d8eddf}

/* ---- INFO BLOCKS hover ---- */
.contact-info .info-block{transition:all .3s cubic-bezier(.16,.84,.44,1);position:relative;overflow:hidden}
.contact-info .info-block::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--sun-500);transform:scaleY(0);transform-origin:bottom;
  transition:transform .4s cubic-bezier(.16,.84,.44,1);
}
.contact-info .info-block:hover::before{transform:scaleY(1)}
.contact-info .info-block:hover{transform:translateX(4px);box-shadow:0 8px 20px rgba(11,61,34,.08);border-color:var(--green-500)}

/* ---- GALLERY — lightbox + figure motion ---- */
.gallery-grid figure{cursor:zoom-in;transition:all .4s cubic-bezier(.16,.84,.44,1)}
.gallery-grid figure:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 20px 40px rgba(11,61,34,.2);z-index:5}
.gallery-grid figure img{transition:transform .8s cubic-bezier(.16,.84,.44,1),filter .4s}
.gallery-grid figure:hover img{transform:scale(1.08);filter:saturate(1.15) brightness(1.05)}
.gallery-grid figcaption{transform:translateY(8px);opacity:.9;transition:all .4s cubic-bezier(.16,.84,.44,1)}
.gallery-grid figure:hover figcaption{transform:translateY(0);opacity:1;background:linear-gradient(transparent,rgba(11,61,34,.95))}

.lightbox{
  position:fixed;inset:0;background:rgba(11,61,34,.96);z-index:9999;
  display:none;align-items:center;justify-content:center;padding:40px;
  opacity:0;transition:opacity .4s;backdrop-filter:blur(8px);cursor:zoom-out;
}
.lightbox.open{display:flex;opacity:1}
.lightbox img{
  max-width:90vw;max-height:85vh;object-fit:contain;
  border-radius:var(--radius);box-shadow:0 20px 60px rgba(0,0,0,.5);
  transform:scale(.92);transition:transform .5s cubic-bezier(.34,1.56,.64,1);
}
.lightbox.open img{transform:scale(1)}
.lightbox .lb-cap{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  color:var(--cream);font-family:var(--f-head);letter-spacing:.05em;
  background:rgba(0,0,0,.4);padding:10px 24px;border-radius:30px;
}
.lightbox .lb-close{
  position:absolute;top:20px;right:20px;width:48px;height:48px;
  background:rgba(255,255,255,.15);border:0;color:#fff;font-size:1.6rem;
  border-radius:50%;cursor:pointer;transition:all .3s;
  display:flex;align-items:center;justify-content:center;
}
.lightbox .lb-close:hover{background:var(--sun-500);color:var(--green-900);transform:rotate(90deg) scale(1.1)}

/* ---- PAGE HERO — subtle drift ---- */
.page-hero-photo::before{animation:slowDrift 25s ease-in-out infinite alternate}
@keyframes slowDrift{0%{transform:scale(1.05) translate(0,0)}100%{transform:scale(1.1) translate(-1%,-.5%)}}
.page-hero-photo h1,.page-hero-photo .sub,.page-hero-photo .breadcrumb{opacity:0;animation:slideUp .9s ease forwards}
.page-hero-photo .breadcrumb{animation-delay:.1s}
.page-hero-photo h1{animation-delay:.25s}
.page-hero-photo .sub{animation-delay:.45s}

/* ---- AREA BLOCK — chips animate in ---- */
.area-block .towns span{
  cursor:default;transition:all .25s cubic-bezier(.34,1.56,.64,1);
  display:inline-block;
}
.area-block .towns span:hover{
  background:var(--green-700);color:var(--cream);
  transform:translateY(-2px) scale(1.05);
  border-color:var(--green-700);
}

/* ---- FOOTER hover ---- */
footer.site ul.foot-links li{transition:transform .25s}
footer.site ul.foot-links li:hover{transform:translateX(4px)}
footer.site h5{position:relative;display:inline-block;padding-bottom:8px}
footer.site h5::after{
  content:"";position:absolute;bottom:0;left:0;width:30px;height:2px;
  background:var(--sun-500);transition:width .4s cubic-bezier(.16,.84,.44,1);
}
footer.site .col:hover h5::after{width:60px}

/* ---- LOADING SHIMMER on images ---- */
img{background:linear-gradient(110deg,var(--green-100) 8%,#d4e8da 18%,var(--green-100) 33%);background-size:200% 100%;animation:shimmer 1.5s linear infinite}
img[src*=".jpg"],img[src*=".png"],img[src*=".webp"],img[src*=".svg"]{animation:none}
@keyframes shimmer{to{background-position-x:-200%}}

/* ===== Sticky mobile click-to-call bar ===== */
.mobile-callbar{position:fixed;left:0;right:0;bottom:0;z-index:900;display:none;
  grid-template-columns:1fr 1fr;gap:0;box-shadow:0 -4px 16px rgba(11,61,34,.18)}
.mobile-callbar a{display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 8px;font-family:var(--f-head);font-weight:600;font-size:1.02rem;
  letter-spacing:.3px;text-decoration:none;text-transform:uppercase}
.mobile-callbar .mc-call{background:var(--green-700);color:#fff}
.mobile-callbar .mc-quote{background:var(--sun-500);color:var(--green-900)}
.mobile-callbar a:active{filter:brightness(.94)}
@media (max-width:760px){
  .mobile-callbar{display:grid}
  body{padding-bottom:56px}
  .cta-bar{margin-bottom:0}
}
@media (prefers-reduced-motion:no-preference){
  .mobile-callbar{transition:transform .3s ease}
}

/* ===== FAQ section ===== */
.faq{background:var(--cream);padding:72px 0}
.faq .eyebrow{color:var(--sun-500)}
.faq h2{max-width:18ch}
.faq-intro{color:var(--muted);max-width:62ch;margin:0 0 28px}
.faq-list{display:flex;flex-direction:column;gap:12px;max-width:880px}
.faq-list details{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);overflow:hidden}
.faq-list summary{list-style:none;cursor:pointer;padding:18px 22px;font-family:var(--f-head);
  font-weight:500;font-size:1.08rem;color:var(--green-900);display:flex;justify-content:space-between;
  align-items:center;gap:16px}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";font-size:1.5rem;color:var(--green-500);line-height:1;flex-shrink:0;
  transition:transform .25s ease}
.faq-list details[open] summary::after{transform:rotate(45deg)}
.faq-list summary:hover{color:var(--green-700)}
.faq-a{padding:0 22px 20px;color:var(--muted);line-height:1.7}
.faq-a a{color:var(--green-700);font-weight:500}
@media (prefers-reduced-motion:reduce){.faq-list summary::after{transition:none}}

/* Testimonials: "see all reviews" CTA card */
.t-card--cta{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
  background:var(--green-900);color:#fff}
.t-card--cta blockquote{color:#e3f1e8}
.t-card--cta .btn{margin-top:14px}

/* Linked service-area chips inherit chip styling */
.towns a{ all: unset; }
.towns span, .towns a{
  display:inline-block;background:var(--green-100);color:var(--green-900);
  padding:7px 14px;border-radius:999px;font-size:.92rem;margin:4px;cursor:default;
  font-family:var(--f-body)}
.towns a{cursor:pointer;transition:background .2s,color .2s}
.towns a:hover{background:var(--green-700);color:#fff}

/* ===== Nav: Service Areas dropdown ===== */
.nav-dropdown{position:relative;display:inline-block}
.nav-dd-toggle{display:inline-block;padding:8px 12px;border-radius:6px;cursor:pointer;
  font-family:var(--f-body);font-size:.95rem;color:var(--ink);user-select:none;white-space:nowrap}
.nav-dd-toggle:hover{background:var(--green-100);color:var(--green-900)}
.nav-dd-toggle.active{background:var(--green-900);color:var(--cream)}
.nav-dd-menu{position:absolute;top:100%;left:0;min-width:210px;background:#fff;
  border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-md);
  padding:6px;display:none;flex-direction:column;z-index:300}
.nav-dropdown:hover .nav-dd-menu,
.nav-dropdown:focus-within .nav-dd-menu{display:flex}
.nav-dd-menu a{white-space:nowrap;padding:9px 12px;border-radius:6px;width:auto}
.nav-dd-menu a::after{display:none !important}
@media (max-width:900px){
  .nav-dropdown{width:100%}
  .nav-dd-toggle{width:100%;padding:12px;border-bottom:1px solid var(--line)}
  .nav-dd-menu{position:static;display:flex;box-shadow:none;border:none;
    border-radius:0;padding:0 0 0 14px;background:transparent;min-width:0}
  .nav-dd-menu a{padding:11px 12px}
}

/* Hide sticky call bar while mobile nav menu is open */
body.nav-open .mobile-callbar{display:none}
