/* =====================================================================
   ECOVERDE VALETING — Eco-Luxe design system
   West London mobile car valeting & detailing
   ===================================================================== */

:root{
  /* greens */
  --forest:#0B3326;       /* deepest ink-green */
  --pine:#0E4633;
  --emerald:#177B53;
  --leaf:#2DA56F;
  --leaf-bright:#3FC07F;
  /* water blues */
  --teal:#137C8B;
  --aqua:#1FA0B3;
  --sky:#4FC3CE;
  /* neutrals */
  --ink:#0C201A;
  --ink-soft:#4C6359;
  --mist:#EDF5EF;         /* page bg */
  --mist-2:#E2F0E8;
  --paper:#F7FBF8;
  --white:#ffffff;
  --gold:#E2A93B;         /* stars */
  /* glass + lines */
  --glass:rgba(255,255,255,.66);
  --glass-2:rgba(255,255,255,.5);
  --line:rgba(11,51,38,.10);
  --line-2:rgba(11,51,38,.16);
  /* type */
  --display:"Fraunces",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  /* shape */
  --r:32px;
  --r-md:22px;
  --r-sm:14px;
  --r-pill:999px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --shadow:0 30px 70px -34px rgba(8,46,33,.5);
  --shadow-soft:0 18px 48px -26px rgba(8,46,33,.34);
  --shadow-card:0 24px 50px -30px rgba(8,46,33,.4);
  --grad-green:linear-gradient(135deg,var(--leaf) 0%,var(--emerald) 55%,var(--teal) 100%);
  --grad-deep:linear-gradient(135deg,var(--pine),var(--forest));
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--mist);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  position:relative;
  overflow-x:hidden;
}
/* ambient gradient mesh + grain */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(900px 680px at 84% -8%, rgba(63,192,127,.20), transparent 60%),
    radial-gradient(820px 720px at -6% 6%, rgba(31,160,179,.16), transparent 58%),
    radial-gradient(760px 760px at 50% 116%, rgba(45,165,111,.14), transparent 60%),
    linear-gradient(180deg,#F4FAF6 0%, #E6F1EA 100%);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.4;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
ul{list-style:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--leaf);color:#fff}
.wrap{max-width:1240px;margin:0 auto;padding:0 26px}

/* shared type */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-size:.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--emerald);
}
.eyebrow::before{content:"";width:22px;height:1.5px;background:var(--leaf);border-radius:2px}
.eyebrow.center::after{content:"";width:22px;height:1.5px;background:var(--leaf);border-radius:2px}
.eyebrow.center{justify-content:center}
h1,h2,h3,h4{font-family:var(--display);font-weight:500;line-height:1.06;letter-spacing:-.01em;color:var(--ink)}
.section-head{max-width:680px}
.section-head.center{margin:0 auto;text-align:center}
h2.title{font-size:clamp(2rem,4.6vw,3.3rem);margin:16px 0 14px}
h2.title em{font-style:italic;color:var(--emerald)}
.lead{font-size:1.06rem;color:var(--ink-soft);max-width:60ch}
.center .lead{margin-inline:auto}

/* buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-weight:600;font-size:.96rem;padding:15px 26px;border-radius:var(--r-pill);
  border:1px solid transparent;white-space:nowrap;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),filter .3s var(--ease),background .3s var(--ease);
}
.btn svg{width:17px;height:17px}
.btn-primary{color:#fff;background:var(--grad-green);box-shadow:0 14px 30px -12px rgba(23,123,83,.7)}
.btn-primary:hover{transform:translateY(-3px);filter:brightness(1.05);box-shadow:0 22px 40px -14px rgba(23,123,83,.8)}
.btn-ghost{background:var(--glass);color:var(--forest);border-color:var(--line-2);backdrop-filter:blur(10px)}
.btn-ghost:hover{transform:translateY(-3px);background:#fff;box-shadow:var(--shadow-soft)}
.btn-dark{background:var(--grad-deep);color:#fff;box-shadow:0 14px 30px -14px rgba(11,51,38,.7)}
.btn-dark:hover{transform:translateY(-3px);filter:brightness(1.08)}

/* =====================  HEADER  ===================== */
header{position:sticky;top:0;z-index:100;padding:16px 0 0}
.navbar{
  display:flex;align-items:center;gap:18px;
  height:72px;padding:0 14px 0 22px;
  background:var(--glass);
  backdrop-filter:blur(20px) saturate(150%);
  -webkit-backdrop-filter:blur(20px) saturate(150%);
  border:1px solid rgba(255,255,255,.62);
  box-shadow:var(--shadow-soft);
  border-radius:22px;
  transition:box-shadow .4s var(--ease),background .4s var(--ease);
}
header.scrolled .navbar{box-shadow:0 22px 50px -28px rgba(8,46,33,.5);background:rgba(255,255,255,.78)}
.brand{display:flex;align-items:center;gap:11px;flex-shrink:0}
.brand img.mark{width:42px;height:42px;flex-shrink:0;object-fit:contain}
.brand .word{font-family:var(--display);font-weight:600;font-size:1.32rem;letter-spacing:-.02em;color:var(--forest);line-height:1}
.brand .word b{color:var(--emerald);font-weight:600}
.brand .word span{display:block;font-family:var(--sans);font-weight:600;font-size:.56rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-soft);margin-top:2px}

.menu{display:flex;align-items:center;gap:2px;margin-left:14px}
.menu a{
  font-size:.92rem;font-weight:500;color:var(--ink);
  padding:10px 14px;border-radius:11px;
  transition:background .25s var(--ease),color .25s var(--ease);
}
.menu a:hover{background:rgba(23,123,83,.10);color:var(--emerald)}
.nav-right{display:flex;align-items:center;gap:12px;margin-left:auto}
.eco-chip{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.8rem;font-weight:600;color:var(--emerald);
  padding:8px 14px;border-radius:var(--r-pill);
  background:rgba(45,165,111,.12);border:1px solid rgba(45,165,111,.22);
}
.eco-chip svg{width:15px;height:15px}
.call-btn{
  display:inline-flex;align-items:center;gap:9px;color:#fff;font-weight:600;font-size:.92rem;
  padding:12px 20px;border-radius:var(--r-pill);background:var(--grad-green);
  box-shadow:0 12px 26px -12px rgba(23,123,83,.7);
  transition:transform .25s var(--ease),filter .25s var(--ease),box-shadow .25s var(--ease);
}
.call-btn:hover{transform:translateY(-2px);filter:brightness(1.06)}
.call-btn svg{width:16px;height:16px}
.burger{display:none;width:46px;height:46px;border:1px solid var(--line-2);border-radius:13px;background:var(--glass);position:relative}
.burger span{position:absolute;left:13px;right:13px;height:2px;background:var(--forest);border-radius:2px;transition:.3s var(--ease)}
.burger span:nth-child(1){top:17px}
.burger span:nth-child(2){top:23px}
.burger span:nth-child(3){top:29px}
body.nav-open .burger span:nth-child(1){top:23px;transform:rotate(45deg)}
body.nav-open .burger span:nth-child(2){opacity:0}
body.nav-open .burger span:nth-child(3){top:23px;transform:rotate(-45deg)}

/* mobile drawer */
.drawer{
  position:fixed;inset:0;z-index:99;display:none;
  padding:96px 26px 40px;
  background:rgba(237,245,239,.94);backdrop-filter:blur(18px);
  overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
}
body.nav-open{overflow:hidden}
.drawer a{
  display:block;font-family:var(--display);font-size:1.7rem;color:var(--forest);
  padding:16px 4px;border-bottom:1px solid var(--line);
}
.drawer .btn{width:100%;margin-top:22px}
body.nav-open .drawer{display:block;animation:fade .3s var(--ease)}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* =====================  HERO  ===================== */
.hero{position:relative;padding:54px 0 40px}
.hero-grid{display:grid;grid-template-columns:1.06fr .94fr;gap:48px;align-items:center}
.hero-copy .eyebrow{margin-bottom:20px}
.hero h1{font-size:clamp(2.6rem,5.6vw,4.5rem);letter-spacing:-.025em}
.hero h1 em{font-style:italic;color:var(--emerald)}
.hero h1 .grad{
  background:var(--grad-green);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic;
}
.hero p.sub{font-size:1.12rem;color:var(--ink-soft);max-width:50ch;margin:22px 0 30px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-trust{display:flex;flex-wrap:wrap;align-items:center;gap:20px;margin-top:34px}
.stars-line{display:flex;align-items:center;gap:11px}
.stars{color:var(--gold);font-size:1rem;letter-spacing:1px}
.stars-line b{font-weight:700}
.stars-line small{display:block;color:var(--ink-soft);font-size:.82rem}
.trust-div{width:1px;height:34px;background:var(--line-2)}

/* hero visual */
.hero-visual{position:relative}
.hero-frame{
  position:relative;border-radius:42px 42px 42px 120px;overflow:hidden;
  aspect-ratio:4/4.6;box-shadow:var(--shadow);
  border:6px solid rgba(255,255,255,.7);
}
.hero-frame img{width:100%;height:100%;object-fit:cover;transform:scale(1.02)}
.hero-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(11,51,38,.36))}
/* floating glass cards */
.float-card{
  position:absolute;background:var(--glass);backdrop-filter:blur(16px) saturate(150%);
  border:1px solid rgba(255,255,255,.65);border-radius:var(--r-md);
  box-shadow:var(--shadow-card);padding:16px 18px;
}
.fc-rating{top:26px;left:-26px;display:flex;align-items:center;gap:12px}
.fc-rating .num{font-family:var(--display);font-size:1.9rem;line-height:1;color:var(--forest)}
.fc-rating .stars{font-size:.82rem}
.fc-rating small{color:var(--ink-soft);font-size:.74rem;font-weight:600}
.fc-eco{bottom:96px;right:-22px;display:flex;align-items:center;gap:12px;max-width:230px}
.fc-eco .ico{width:42px;height:42px;border-radius:12px;background:rgba(45,165,111,.15);display:grid;place-items:center;flex-shrink:0}
.fc-eco .ico svg{width:22px;height:22px;color:var(--emerald)}
.fc-eco b{font-size:.9rem;display:block}
.fc-eco small{color:var(--ink-soft);font-size:.78rem;line-height:1.3}
.fc-book{
  bottom:18px;left:50%;transform:translateX(-50%);
  display:flex;align-items:center;gap:10px;white-space:nowrap;
  background:rgba(12,32,26,.62);border-color:rgba(255,255,255,.18);color:#fff;
}
.fc-book .dot{width:9px;height:9px;border-radius:50%;background:var(--leaf-bright);box-shadow:0 0 0 4px rgba(63,192,127,.3);animation:pulse 2s infinite}
.fc-book span{font-size:.84rem;font-weight:600}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(63,192,127,.3)}50%{box-shadow:0 0 0 8px rgba(63,192,127,0)}}
.blob{position:absolute;border-radius:50%;filter:blur(46px);z-index:-1}
.blob.b1{width:280px;height:280px;background:rgba(63,192,127,.5);top:-30px;right:30px}
.blob.b2{width:240px;height:240px;background:rgba(31,160,179,.42);bottom:-20px;left:-10px}

/* =====================  MARQUEE / ECO STRIP  ===================== */
.ecostrip{margin-top:30px}
.ecostrip .wrap{
  display:flex;flex-wrap:wrap;justify-content:center;gap:14px 30px;
  padding:22px 30px;border-radius:var(--r-md);
  background:var(--glass);border:1px solid rgba(255,255,255,.6);box-shadow:var(--shadow-soft);
  backdrop-filter:blur(12px);
  max-width:1240px;
}
.es-item{display:flex;align-items:center;gap:10px;font-weight:600;font-size:.92rem;color:var(--forest)}
.es-item svg{width:20px;height:20px;color:var(--emerald);flex-shrink:0}
.es-sep{width:1px;height:20px;background:var(--line-2)}

/* =====================  SECTION SHELL  ===================== */
section.block{padding:88px 0}
.sec-top{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:46px}

/* ---- section background bands (distinct tones, soft-fading edges so sections flow) ---- */
.band-paper{
  background:linear-gradient(180deg,
    transparent 0%,
    #F8FCF9 7%,
    #F4FAF6 50%,
    #F8FCF9 93%,
    transparent 100%);
}
.band-tint{
  background:
    radial-gradient(720px 420px at 10% 16%, rgba(45,165,111,.14), transparent 60%),
    radial-gradient(700px 460px at 92% 84%, rgba(31,160,179,.13), transparent 62%),
    linear-gradient(180deg,
      transparent 0%,
      rgba(214,238,225,.62) 9%,
      rgba(210,236,224,.62) 50%,
      rgba(214,238,225,.62) 91%,
      transparent 100%);
}
/* decorative blurred orb to bridge bands organically */
.band-tint::after{
  content:"";position:absolute;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(63,192,127,.18),transparent 65%);
  filter:blur(20px);right:6%;top:-60px;z-index:-1;pointer-events:none;
}
.band-tint{position:relative;overflow:hidden}

/* =====================  SERVICES  ===================== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc-card{
  position:relative;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-soft);
  transition:transform .4s var(--ease-out),box-shadow .4s var(--ease-out);
  display:flex;flex-direction:column;
}
.svc-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.svc-media{position:relative;aspect-ratio:16/11;overflow:hidden}
.svc-media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out)}
.svc-card:hover .svc-media img{transform:scale(1.07)}
.svc-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(11,51,38,.5))}
.svc-price{
  position:absolute;top:14px;left:14px;z-index:2;
  font-size:.82rem;font-weight:700;color:var(--forest);
  padding:7px 13px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.85);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.7);
}
.svc-tag{
  position:absolute;bottom:13px;left:14px;z-index:2;color:#fff;
  font-size:.74rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;opacity:.92;
}
.svc-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.svc-body h3{font-size:1.35rem;margin-bottom:9px}
.svc-body p{font-size:.93rem;color:var(--ink-soft);margin-bottom:18px;flex:1}
.svc-link{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.9rem;color:var(--emerald)}
.svc-link svg{width:15px;height:15px;transition:transform .3s var(--ease)}
.svc-card:hover .svc-link svg{transform:translateX(4px)}

/* =====================  WHY ECO (split)  ===================== */
.why{position:relative}
.why-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:54px;align-items:center}
.why-visual{position:relative}
.why-img{border-radius:120px 42px 42px 42px;overflow:hidden;aspect-ratio:5/5.4;box-shadow:var(--shadow);border:6px solid rgba(255,255,255,.7)}
.why-img img{width:100%;height:100%;object-fit:cover}
.why-badge{
  position:absolute;bottom:-22px;right:-18px;
  background:var(--grad-deep);color:#fff;border-radius:var(--r-md);
  padding:20px 24px;box-shadow:var(--shadow);text-align:center;
}
.why-badge .n{font-family:var(--display);font-size:2.4rem;line-height:1}
.why-badge small{font-size:.76rem;opacity:.82;letter-spacing:.04em}
.eco-list{display:grid;gap:18px;margin-top:30px}
.eco-row{display:flex;gap:16px;align-items:flex-start}
.eco-row .ico{
  width:50px;height:50px;border-radius:15px;flex-shrink:0;display:grid;place-items:center;
  background:rgba(45,165,111,.12);border:1px solid rgba(45,165,111,.2);
}
.eco-row .ico svg{width:24px;height:24px;color:var(--emerald)}
.eco-row h4{font-family:var(--sans);font-weight:700;font-size:1.02rem;margin-bottom:3px}
.eco-row p{font-size:.92rem;color:var(--ink-soft);margin:0}

/* =====================  PROCESS  ===================== */
.process{background:var(--grad-deep);border-radius:46px;color:#fff;position:relative;overflow:hidden;margin:0 0}
.process::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(63,192,127,.4),transparent 65%);top:-180px;right:-120px}
.process::after{content:"";position:absolute;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(31,160,179,.34),transparent 65%);bottom:-200px;left:-130px}
.process .wrap{position:relative;z-index:2;padding:74px 26px}
.process .eyebrow{color:var(--leaf-bright)}
.process .eyebrow::before{background:var(--leaf-bright)}
.process h2.title{color:#fff}
.process h2.title em{color:var(--leaf-bright)}
.process .lead{color:rgba(255,255,255,.74)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:48px}
.step{position:relative;padding:26px 22px;border-radius:var(--r-md);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(6px)}
.step .num{font-family:var(--display);font-size:1rem;font-weight:600;color:var(--leaf-bright);width:42px;height:42px;border-radius:12px;background:rgba(63,192,127,.16);display:grid;place-items:center;margin-bottom:18px}
.step h4{font-family:var(--sans);font-weight:700;font-size:1.08rem;color:#fff;margin-bottom:8px}
.step p{font-size:.9rem;color:rgba(255,255,255,.68);margin:0}
.process-note{margin-top:34px;display:flex;align-items:center;gap:12px;font-size:.92rem;color:rgba(255,255,255,.82)}
.process-note svg{width:20px;height:20px;color:var(--leaf-bright);flex-shrink:0}

/* =====================  GALLERY  ===================== */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:16px}
.g-item{position:relative;overflow:hidden;border-radius:var(--r-md);box-shadow:var(--shadow-soft)}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out)}
.g-item:hover img{transform:scale(1.08)}
.g-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(11,51,38,.32));opacity:0;transition:opacity .4s}
.g-item:hover::after{opacity:1}
.g-tall{grid-row:span 2}
.g-wide{grid-column:span 2}

/* =====================  REVIEWS  ===================== */
.reviews{position:relative}
.rev-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;margin-bottom:44px}
.rev-score{display:flex;align-items:center;gap:18px}
.rev-score .big{font-family:var(--display);font-size:3.4rem;line-height:.9;color:var(--forest)}
.rev-score .stars{font-size:1.1rem}
.rev-score small{color:var(--ink-soft);font-weight:600;font-size:.86rem}
.rev-badges{display:flex;gap:12px;flex-wrap:wrap}
.rev-badge{display:flex;align-items:center;gap:9px;font-size:.86rem;font-weight:600;color:var(--forest);padding:11px 18px;border-radius:var(--r-pill);background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.rev-badge svg{width:18px;height:18px;color:var(--emerald)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rev-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:28px 26px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column}
.rev-card .stars{font-size:.92rem;margin-bottom:14px}
.rev-card p{font-size:.98rem;color:var(--ink);line-height:1.6;flex:1}
.rev-card .who{display:flex;align-items:center;gap:13px;margin-top:22px}
.rev-card .av{width:44px;height:44px;border-radius:50%;background:var(--grad-green);color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--display);flex-shrink:0}
.rev-card .who b{display:block;font-size:.92rem}
.rev-card .who small{color:var(--ink-soft);font-size:.8rem}

/* =====================  AREAS  ===================== */
.areas{position:relative}
.area-wrap{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:46px 44px;box-shadow:var(--shadow-soft);
  display:grid;grid-template-columns:.8fr 1.2fr;gap:46px;align-items:center;
}
.area-tags{display:flex;flex-wrap:wrap;gap:10px}
.area-tags span{
  display:inline-flex;align-items:center;gap:7px;font-size:.88rem;font-weight:500;color:var(--forest);
  padding:9px 15px;border-radius:var(--r-pill);background:var(--mist);border:1px solid var(--line);
  transition:.25s var(--ease);
}
.area-tags span:hover{background:rgba(45,165,111,.12);border-color:rgba(45,165,111,.25);color:var(--emerald)}
.area-tags span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--leaf)}

/* =====================  CTA BAND  ===================== */
.cta-band{position:relative}
.cta-inner{
  position:relative;overflow:hidden;border-radius:46px;
  background:var(--grad-green);color:#fff;text-align:center;
  padding:74px 30px;box-shadow:var(--shadow);
}
.cta-inner::before{content:"";position:absolute;inset:0;opacity:.5;
  background:radial-gradient(600px 400px at 20% 0%,rgba(255,255,255,.3),transparent 60%),radial-gradient(600px 400px at 90% 100%,rgba(11,51,38,.4),transparent 60%)}
.cta-inner > *{position:relative;z-index:2}
.cta-inner h2{font-size:clamp(2rem,4.4vw,3.2rem);color:#fff;margin-bottom:14px}
.cta-inner p{font-size:1.1rem;opacity:.92;max-width:54ch;margin:0 auto 30px}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.cta-inner .btn-light{background:#fff;color:var(--emerald)}
.cta-inner .btn-light:hover{transform:translateY(-3px);box-shadow:0 20px 40px -16px rgba(0,0,0,.4)}
.cta-inner .btn-outline{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.4)}
.cta-inner .btn-outline:hover{background:rgba(255,255,255,.22);transform:translateY(-3px)}

/* =====================  FAQ  ===================== */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 26px;align-items:start}
.faq{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;transition:box-shadow .3s var(--ease)}
.faq[open]{box-shadow:var(--shadow-soft)}
.faq summary{
  list-style:none;cursor:pointer;padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-weight:600;font-size:1.04rem;color:var(--forest);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{width:28px;height:28px;border-radius:9px;background:rgba(45,165,111,.12);display:grid;place-items:center;flex-shrink:0;position:relative;transition:.3s var(--ease)}
.faq summary .pm::before,.faq summary .pm::after{content:"";position:absolute;background:var(--emerald);border-radius:2px}
.faq summary .pm::before{width:13px;height:2px}
.faq summary .pm::after{width:2px;height:13px;transition:transform .3s var(--ease)}
.faq[open] summary .pm{background:var(--emerald)}
.faq[open] summary .pm::before,.faq[open] summary .pm::after{background:#fff}
.faq[open] summary .pm::after{transform:scaleY(0)}
.faq .ans{padding:0 24px 24px;color:var(--ink-soft);font-size:.96rem}

/* =====================  FOOTER  ===================== */
footer{position:relative;margin-top:30px;color:#dfeee6;
  background:var(--grad-deep);border-radius:46px 46px 0 0;overflow:hidden}
footer::before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(63,192,127,.22),transparent 65%);top:-260px;left:-120px}
footer .wrap{position:relative;z-index:2;padding:66px 26px 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1.1fr;gap:34px}
.foot-brand .brand .word{color:#fff}
.foot-brand .brand .word b{color:var(--leaf-bright)}
.foot-brand .brand .word span{color:rgba(255,255,255,.6)}
.foot-brand p{margin:20px 0;font-size:.94rem;color:rgba(255,255,255,.72);max-width:34ch}
.foot-social{display:flex;gap:11px}
.foot-social a{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);transition:.3s var(--ease)}
.foot-social a:hover{background:var(--leaf);transform:translateY(-3px)}
.foot-social svg{width:18px;height:18px;color:#fff}
.foot-col h5{font-family:var(--sans);font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:18px}
.foot-col ul{display:grid;gap:11px}
.foot-col a,.foot-col li{font-size:.94rem;color:rgba(255,255,255,.8);transition:color .25s}
.foot-col a:hover{color:var(--leaf-bright)}
.foot-contact li{display:flex;gap:11px;align-items:flex-start;margin-bottom:13px}
.foot-contact svg{width:18px;height:18px;color:var(--leaf-bright);flex-shrink:0;margin-top:3px}
.foot-contact b{color:#fff;font-weight:600}
.foot-bottom{margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.84rem;color:rgba(255,255,255,.6)}
.foot-bottom a:hover{color:var(--leaf-bright)}

/* floating whatsapp */
.wa-float{
  position:fixed;bottom:24px;right:24px;z-index:90;
  width:60px;height:60px;border-radius:50%;display:grid;place-items:center;
  background:#25D366;box-shadow:0 14px 30px -8px rgba(37,211,102,.6);
  transition:transform .3s var(--ease);
}
.wa-float:hover{transform:scale(1.08) translateY(-2px)}
.wa-float svg{width:30px;height:30px;color:#fff}

/* =====================  REVEAL ANIM  ===================== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{animation:none!important}}

/* =====================  RESPONSIVE  ===================== */
@media (max-width:1080px){
  .menu{display:none}
  .svc-grid,.rev-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:60px}
  .hero-visual{max-width:460px;margin:0 auto;width:100%}
  .why-grid{grid-template-columns:1fr;gap:60px}
  .why-visual{max-width:420px;margin:0 auto;width:100%}
  .area-wrap{grid-template-columns:1fr;gap:30px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:34px}
  .faq-grid{grid-template-columns:1fr}
  .burger{display:block}
  .eco-chip{display:none}
}
@media (max-width:720px){
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}
  .nav-right .call-btn span{display:none}
  .call-btn{padding:12px 14px}
}
@media (max-width:560px){
  .wrap{padding:0 18px}
  .navbar{gap:10px;padding:0 12px}
  .nav-book{display:none}
  .brand img.mark{width:44px;height:44px}
  .brand .word{font-size:1.15rem}
  .brand .word span{display:none}
  section.block{padding:64px 0}
  .svc-grid,.rev-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .ecostrip .es-sep{display:none}
  .hero-trust{gap:14px}
  .fc-rating{left:-8px}.fc-eco{right:-6px}
  .process{border-radius:32px}
  .cta-inner{border-radius:32px}
}

/* ============================================================
   v2 — full-bleed hero · review slider · image-background bands
   ============================================================ */

/* ---- HERO: full-bleed background ---- */
.hero{min-height:92vh;display:flex;align-items:center;padding:154px 0 92px;margin-top:-94px;isolation:isolate;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:50% 40%}
.hero-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(102deg, rgba(6,38,27,.95) 0%, rgba(8,50,36,.86) 33%, rgba(10,58,42,.5) 62%, rgba(10,58,42,.10) 100%),
  linear-gradient(0deg, rgba(6,34,24,.72), transparent 44%)}
.hero .wrap{position:relative;z-index:2;width:100%}
.hero-inner{max-width:720px}
.hero-inner .eyebrow{color:#86E6B0;margin-bottom:22px}
.hero-inner .eyebrow::before{background:#86E6B0}
.hero h1{font-size:clamp(2.7rem,6vw,5.1rem);color:#fff}
.hero h1 em{font-style:italic;color:#86E6B0}
.hero h1 .grad{background:linear-gradient(100deg,#86E6B0,#5BC8D6);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic}
.hero p.sub{font-size:1.17rem;color:rgba(255,255,255,.88);max-width:54ch;margin:24px 0 34px}
.hero .btn-ghost{background:rgba(255,255,255,.13);color:#fff;border-color:rgba(255,255,255,.3);backdrop-filter:blur(10px)}
.hero .btn-ghost:hover{background:rgba(255,255,255,.22);box-shadow:none}
.hero-trust{margin-top:40px;gap:24px}
.hero-trust .stars-line b{color:#fff}
.hero-trust .stars-line small{color:rgba(255,255,255,.72)}
.hero-trust .trust-div{background:rgba(255,255,255,.24)}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.hero-badges span{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;font-weight:600;color:#fff;padding:9px 15px;border-radius:999px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(8px)}
.hero-badges svg{width:15px;height:15px;color:#86E6B0}
.hero-scroll{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.62);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:9px}
.hero-scroll i{width:1px;height:36px;background:linear-gradient(rgba(255,255,255,.65),transparent);animation:scrolld 2.1s infinite}
@keyframes scrolld{0%{opacity:0;transform:scaleY(.2);transform-origin:top}45%{opacity:1;transform:scaleY(1)}100%{opacity:0;transform:scaleY(1);transform-origin:bottom}}

/* ---- REVIEW SLIDER (section 2) ---- */
.revslider{padding:62px 0 74px;position:relative;overflow:hidden}
.rs-head{display:flex;align-items:center;justify-content:center;gap:14px 30px;flex-wrap:wrap;margin-bottom:38px}
.rs-rating{display:flex;align-items:center;gap:14px}
.rs-rating .gicon{width:38px;height:38px;flex-shrink:0}
.rs-rating .num{font-family:var(--display);font-size:2.5rem;line-height:1;color:var(--forest)}
.rs-rating .stars{color:var(--gold);font-size:1.05rem;letter-spacing:1px}
.rs-rating small{color:var(--ink-soft);font-weight:600;font-size:.84rem}
.rs-sources{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.rs-src{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;color:var(--forest);padding:8px 13px;border-radius:999px;background:var(--paper);border:1px solid var(--line)}
.rs-src b{color:var(--emerald)}
.marquee{position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.marquee + .marquee{margin-top:18px}
.mq-track{display:flex;gap:18px;width:max-content;animation:marq 70s linear infinite}
.mq-track.rev{animation-direction:reverse;animation-duration:82s}
.marquee:hover .mq-track{animation-play-state:paused}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.rcard{width:352px;flex-shrink:0;background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:22px 22px 20px;box-shadow:var(--shadow-soft);white-space:normal}
.rcard .rc-top{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.rcard .av{width:42px;height:42px;border-radius:50%;background:var(--grad-green);color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--display);font-size:1.05rem;flex-shrink:0}
.rcard .who b{display:block;font-size:.9rem;line-height:1.2}
.rcard .who small{color:var(--ink-soft);font-size:.76rem}
.rcard .gicon{margin-left:auto;width:19px;height:19px;flex-shrink:0}
.rcard .stars{color:var(--gold);font-size:.84rem;letter-spacing:1px;margin-bottom:8px}
.rcard p{font-size:.91rem;color:var(--ink);line-height:1.55}

/* ---- IMAGE BANDS ---- */
.imgband{position:relative;isolation:isolate;color:#fff;overflow:hidden}
.imgband-bg{position:absolute;inset:0;z-index:0}
.imgband-bg img{width:100%;height:100%;object-fit:cover}
.imgband .wrap{position:relative;z-index:2;padding:94px 26px}
.imgband h2.title,.imgband .lead,.imgband .eco-pt h4,.imgband .eco-pt p,.imgband .stat .n,.imgband .stat p{text-shadow:0 2px 18px rgba(4,26,18,.4)}
.imgband .eyebrow{color:#86E6B0}.imgband .eyebrow::before{background:#86E6B0}
.imgband .eyebrow.center::after{background:#86E6B0}
.imgband h2.title{color:#fff}.imgband h2.title em{color:#86E6B0}
.imgband .lead{color:rgba(255,255,255,.84)}
.eco-band .imgband-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(100deg, rgba(5,32,22,.97) 0%, rgba(6,42,30,.94) 46%, rgba(8,50,36,.78) 66%, rgba(10,58,42,.3) 100%)}
.eco-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px 32px;margin-top:38px;max-width:780px}
.eco-pt{display:flex;gap:14px;align-items:flex-start}
.eco-pt .ico{width:46px;height:46px;border-radius:13px;flex-shrink:0;display:grid;place-items:center;background:rgba(134,230,176,.16);border:1px solid rgba(134,230,176,.3)}
.eco-pt .ico svg{width:22px;height:22px;color:#86E6B0}
.eco-pt h4{font-family:var(--sans);font-weight:700;font-size:1rem;color:#fff;margin-bottom:3px}
.eco-pt p{font-size:.88rem;color:rgba(255,255,255,.76);margin:0}

.stats-band .imgband-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg, rgba(6,34,24,.88), rgba(7,42,30,.92)),radial-gradient(720px 380px at 82% 18%, rgba(31,160,179,.32),transparent 60%)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat .n{font-family:var(--display);font-size:clamp(2.4rem,4.2vw,3.5rem);line-height:1;color:#fff}
.stat .n em{color:#86E6B0;font-style:normal}
.stat p{font-size:.9rem;color:rgba(255,255,255,.74);margin-top:8px}
.stats-sources{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:46px}
.stats-sources span{font-size:.82rem;font-weight:600;color:#fff;padding:9px 15px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18)}
.stats-sources span b{color:#86E6B0}

.cta-band-img .imgband-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(120deg, rgba(23,123,83,.94), rgba(19,124,139,.88))}
.cta-band-img .wrap{padding:96px 26px;text-align:center}
.cta-band-img h2{color:#fff;font-size:clamp(2rem,4.4vw,3.2rem);margin-bottom:14px}
.cta-band-img p{font-size:1.1rem;color:rgba(255,255,255,.92);max-width:54ch;margin:0 auto 30px}

/* ---- MEET JOHN ---- */
.meet-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:54px;align-items:center}
.meet-img{position:relative;border-radius:42px 120px 42px 42px;overflow:hidden;aspect-ratio:5/4.3;box-shadow:var(--shadow);border:6px solid rgba(255,255,255,.7)}
.meet-img img{width:100%;height:100%;object-fit:cover}
.meet-sig{margin-top:20px;font-family:var(--display);font-style:italic;font-size:1.35rem;color:var(--emerald)}
.guarantee{display:flex;gap:16px;align-items:flex-start;margin-top:26px;padding:20px 22px;border-radius:18px;background:rgba(45,165,111,.1);border:1px solid rgba(45,165,111,.22)}
.guarantee .ico{width:48px;height:48px;border-radius:14px;background:var(--grad-green);display:grid;place-items:center;flex-shrink:0}
.guarantee .ico svg{width:24px;height:24px;color:#fff}
.guarantee h4{font-family:var(--sans);font-weight:700;font-size:1.02rem;margin-bottom:3px}
.guarantee p{font-size:.92rem;color:var(--ink-soft);margin:0}

@media(max-width:900px){
  .eco-grid{grid-template-columns:1fr;gap:16px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:34px 20px}
  .meet-grid{grid-template-columns:1fr;gap:40px}
  .meet-img{max-width:470px;margin:0 auto;aspect-ratio:5/4}
  .hero{min-height:auto;padding:130px 0 68px}
  .imgband .wrap{padding:74px 26px}
}
@media(max-width:560px){
  .rcard{width:282px}
  .hero h1{font-size:2.6rem}
  .rs-rating .num{font-size:2rem}
}

/* ============================================================
   v3 — clear hero + glass card · booking modal
   ============================================================ */

/* ---- HERO: clear image, Ken Burns zoom, frosted glass card ---- */
.hero-clear .hero-bg::after{display:none}                 /* remove green gradient — image stays clear */
.hero-clear .hero-bg{overflow:hidden}
.hero-clear .hero-bg img{animation:kenburns 24s ease-in-out infinite alternate;transform-origin:60% 56%;will-change:transform}
@keyframes kenburns{from{transform:scale(1.04)}to{transform:scale(1.16)}}
.hero-clear .hero-bg::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(0deg,rgba(6,30,22,.28),transparent 24%)}
.hero-card{
  position:relative;z-index:2;max-width:560px;margin-left:auto;
  background:rgba(255,255,255,.5);
  backdrop-filter:blur(30px) saturate(165%);
  -webkit-backdrop-filter:blur(30px) saturate(165%);
  border:1px solid rgba(255,255,255,.72);
  border-radius:30px;padding:42px 42px 36px;
  box-shadow:0 38px 84px -34px rgba(8,46,33,.58);
}
.hero-card .eyebrow{color:var(--emerald);margin-bottom:18px}
.hero-card h1{color:var(--ink);font-size:clamp(2.2rem,4.1vw,3.5rem);line-height:1.06}
.hero-card h1 .grad{background:var(--grad-green);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic}
.hero-card p.sub{color:var(--ink-soft);font-size:1.06rem;margin:20px 0 28px;max-width:46ch}
.hero-card .hero-cta{display:flex;flex-wrap:wrap;gap:13px}
.hero-card .btn-ghost{background:rgba(255,255,255,.55);color:var(--forest);border-color:var(--line-2)}
.hero-card .btn-ghost:hover{background:#fff}
.hero-card .hero-trust{margin-top:28px;gap:18px;display:flex;flex-wrap:wrap;align-items:center}
.hero-card .hero-trust .stars-line b{color:var(--ink)}
.hero-card .hero-trust .stars-line small{color:var(--ink-soft)}
.hero-card .trust-div{background:var(--line-2);height:30px}
.hero-clear .hero-scroll{color:rgba(255,255,255,.9);text-shadow:0 1px 8px rgba(0,0,0,.45)}
.hero-clear .hero-scroll i{background:linear-gradient(rgba(255,255,255,.9),transparent)}
@media (prefers-reduced-motion:reduce){.hero-clear .hero-bg img{animation:none}}
@media(max-width:900px){.hero-card{margin:0 auto;max-width:600px}}
@media(max-width:560px){.hero-card{padding:30px 24px;border-radius:24px}}

/* ---- BOOKING MODAL ---- */
.modal{position:fixed;inset:0;z-index:1000;display:none;align-items:flex-start;justify-content:center;padding:2.5vh 16px}
.modal.open{display:flex}
body.modal-open{overflow:hidden}
.modal-backdrop{position:fixed;inset:0;background:rgba(6,30,22,.58);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:mfade .3s var(--ease)}
@keyframes mfade{from{opacity:0}to{opacity:1}}
.modal-card{position:relative;z-index:2;width:100%;max-width:560px;background:var(--paper);border-radius:28px;box-shadow:0 50px 110px -34px rgba(6,34,24,.6);max-height:95vh;overflow-y:auto;animation:mpop .42s var(--ease-out)}
@keyframes mpop{from{opacity:0;transform:translateY(26px) scale(.98)}to{opacity:1;transform:none}}
.modal-x{position:absolute;top:15px;right:15px;width:40px;height:40px;border-radius:12px;background:var(--mist);border:1px solid var(--line);display:grid;place-items:center;color:var(--ink);z-index:3;transition:.2s}
.modal-x:hover{background:#fff;transform:rotate(90deg)}
.modal-x svg{width:18px;height:18px}
.modal-body{padding:26px 32px 28px}
.modal-head{margin-bottom:14px;padding-right:40px}
.modal-head h3{font-family:var(--display);font-size:1.7rem;font-weight:500;margin:11px 0 9px}
.modal-head p{font-size:.92rem;color:var(--ink-soft);line-height:1.5}
.modal-head p b{color:var(--forest)}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field{margin-bottom:11px}
.field label{display:block;font-size:.82rem;font-weight:600;color:var(--forest);margin-bottom:6px}
.field label span{color:#c0392b}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1px solid var(--line-2);border-radius:12px;background:#fff;font-family:var(--sans);font-size:.94rem;color:var(--ink);transition:border .2s,box-shadow .2s}
.field input::placeholder,.field textarea::placeholder{color:#9fb1a8}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--leaf);box-shadow:0 0 0 3px rgba(45,165,111,.16)}
.field textarea{resize:vertical}
.field .err{border-color:#e0573e;box-shadow:0 0 0 3px rgba(224,87,62,.12)}
.uploader{display:flex;align-items:center;gap:14px;padding:18px;border:1.5px dashed var(--line-2);border-radius:14px;cursor:pointer;color:var(--ink-soft);transition:.2s;background:#fff}
.uploader:hover,.uploader.drag{border-color:var(--leaf);background:rgba(45,165,111,.06)}
.uploader svg{width:26px;height:26px;color:var(--emerald);flex-shrink:0}
.uploader span{font-size:.85rem;line-height:1.35}.uploader b{color:var(--forest)}
.thumbs{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.thumb{position:relative;width:62px;height:62px;border-radius:10px;overflow:hidden;border:1px solid var(--line);background:var(--mist)}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb button{position:absolute;top:2px;right:2px;width:19px;height:19px;border-radius:50%;background:rgba(6,30,22,.72);color:#fff;border:none;font-size:12px;line-height:1;display:grid;place-items:center;cursor:pointer;padding:0}
.form-note{display:flex;gap:10px;align-items:flex-start;font-size:.84rem;color:var(--ink-soft);background:rgba(45,165,111,.08);border:1px solid rgba(45,165,111,.2);border-radius:12px;padding:12px 14px;margin:8px 0 4px}
.form-note svg{width:18px;height:18px;color:var(--emerald);flex-shrink:0;margin-top:1px}
.modal-success{padding:50px 34px}
.modal-success{text-align:center}
.ok-ico{width:74px;height:74px;border-radius:50%;background:var(--grad-green);display:grid;place-items:center;margin:0 auto 22px;box-shadow:0 16px 30px -12px rgba(23,123,83,.6);animation:mpop .5s var(--ease-out)}
.ok-ico svg{width:34px;height:34px;color:#fff}
.modal-success h3{font-family:var(--display);font-size:1.55rem;font-weight:500;margin-bottom:11px}
.modal-success > p{color:var(--ink-soft);font-size:.96rem;margin-bottom:6px;line-height:1.55}
.ok-tip{margin-top:20px!important;font-weight:600;color:var(--forest)!important}
.modal-success .btn{margin-top:12px}
@media(max-width:560px){.f-row{grid-template-columns:1fr}.modal{padding:1.5vh 12px}.modal-card{max-height:94dvh}.modal-body{padding:24px 20px calc(26px + env(safe-area-inset-bottom,0px))}.modal-success{padding:40px 20px}}

/* ============================================================
   v4 — mega menu · bigger logo · wider hero · eco decor · brands
   ============================================================ */

/* ---- logo 25% bigger ---- */
.brand img.mark{width:53px;height:53px}
.brand .word{font-size:1.42rem}
.brand .word span{font-size:.58rem}
.navbar{height:78px}

/* ---- hero card wider (≈55%) ---- */
.hero-card{width:55%;max-width:700px;min-width:0}
@media(max-width:900px){.hero-card{width:100%;max-width:600px}}

/* ---- MEGA MENU ---- */
.has-mega{position:static}
.mega-trigger{display:inline-flex;align-items:center;gap:7px;font-family:var(--sans);font-size:.92rem;font-weight:500;color:var(--ink);padding:10px 14px;border-radius:11px;background:none;border:none;transition:background .25s,color .25s}
.has-mega:hover .mega-trigger,.has-mega.open .mega-trigger{background:rgba(23,123,83,.1);color:var(--emerald)}
.chev{width:8px;height:8px;border-right:1.8px solid currentColor;border-bottom:1.8px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform .3s var(--ease)}
.has-mega:hover .chev,.has-mega.open .chev{transform:rotate(-135deg) translateY(-1px)}
.mega{
  position:absolute;top:calc(100% + 14px);left:0;right:0;z-index:90;
  background:rgba(247,251,248,.98);backdrop-filter:blur(30px) saturate(160%);-webkit-backdrop-filter:blur(30px) saturate(160%);
  border:1px solid rgba(11,51,38,.08);border-radius:var(--r);box-shadow:var(--shadow);
  padding:24px;opacity:0;visibility:hidden;transform:translateY(-12px) scale(.99);transform-origin:top center;
  transition:opacity .3s var(--ease),transform .3s var(--ease),visibility .3s;
}
.has-mega:hover .mega,.has-mega.open .mega{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.mega-head{padding:2px 6px 18px;display:flex;flex-direction:column;gap:5px}
.mega-head h3{font-family:var(--display);font-size:1.2rem;font-weight:500}
.mega-head h3 span{color:var(--emerald);font-style:italic}
.mega-head p{font-size:.85rem;color:var(--ink-soft)}
.mega-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.mega-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.mega-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-soft)}
.mc-img{display:block;aspect-ratio:4/3;overflow:hidden}
.mc-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.mega-card:hover .mc-img img{transform:scale(1.08)}
.mc-txt{padding:14px 15px 16px}
.mc-txt b{display:block;font-size:.98rem;color:var(--forest);margin-bottom:5px}
.mc-txt small{font-size:.81rem;color:var(--ink-soft);line-height:1.45}
.mega-foot{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-top:18px;padding:16px 6px 2px;border-top:1px solid var(--line)}
.mega-foot span{font-size:.88rem;color:var(--ink-soft)}
.mega-foot .btn{padding:11px 20px;font-size:.88rem}
.mega-sub{display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px;margin-top:16px;padding:14px 6px 2px;border-top:1px solid var(--line)}
.mega-sub-lbl{font-size:.7rem;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.mega-sub a{font-size:.85rem;font-weight:500;color:var(--emerald);padding:5px 10px;border:1px solid var(--line);border-radius:999px;transition:background .2s,border-color .2s}
.mega-sub a:hover{background:rgba(23,123,83,.09);border-color:var(--emerald)}
@media(max-width:1080px){.mega{display:none}}

/* drawer submenu */
.drawer-toggle{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;font-family:var(--display);font-size:1.7rem;color:var(--forest);padding:16px 4px;border:0;border-bottom:1px solid var(--line);background:none;cursor:pointer;text-align:left}
.dt-chev{width:11px;height:11px;border-right:2.5px solid var(--forest);border-bottom:2.5px solid var(--forest);transform:rotate(45deg);transition:transform .3s var(--ease);flex:none;margin:-4px 6px 0 0}
.drawer-toggle.open .dt-chev{transform:rotate(-135deg);margin:4px 6px 0 0}
.drawer-sub{display:flex;flex-direction:column;gap:0;max-height:0;overflow:hidden;opacity:0;margin:0;padding-left:14px;border-left:2px solid rgba(45,165,111,.3);transition:max-height .35s var(--ease),opacity .25s var(--ease),margin .35s var(--ease)}
.drawer-toggle.open + .drawer-sub{max-height:680px;opacity:1;margin:-2px 0 8px}
.drawer-sub a{font-family:var(--sans);font-size:1.05rem;font-weight:500;color:var(--ink-soft);padding:10px 4px;border:none}

/* ---- ECO DECOR (floating leaves + clouds, parallax) ---- */
.block{position:relative}
.block > .wrap{position:relative;z-index:2}
.eco-deco{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.deco-item{position:absolute;will-change:transform}
.leaf{display:block;color:rgba(45,165,111,.16);animation:floaty 7s ease-in-out infinite}
.leaf svg{width:100%;height:100%;display:block}
.cloud{display:block;border-radius:50%;background:radial-gradient(ellipse at center,rgba(255,255,255,.8),rgba(255,255,255,0) 70%);filter:blur(4px);animation:floaty 13s ease-in-out infinite}
.cloud-wrap{opacity:.8}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-16px) rotate(calc(var(--r,0deg) - 7deg))}}
@media (prefers-reduced-motion:reduce){.leaf,.cloud{animation:none}.deco-item{transform:none!important}}

/* ---- BRANDS BAND ---- */
.brands-band{background:#0d0f12;padding:30px 0}
.brands-band .wrap{display:flex;justify-content:center}
.brands-band img{width:100%;max-width:1080px;height:auto;opacity:.96}
@media(max-width:560px){.brands-band{padding:20px 0}}

/* ============================================================
   v5 — inner pages (services, about, contact) + Trustindex
   ============================================================ */

/* ---- compact page hero ---- */
.page-hero{position:relative;isolation:isolate;overflow:hidden;margin-top:-94px;padding:150px 0 64px;color:#fff}
.page-hero-bg{position:absolute;inset:0;z-index:0}
.page-hero-bg img{width:100%;height:100%;object-fit:cover}
.page-hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(6,38,27,.92),rgba(8,52,37,.78) 60%,rgba(10,58,42,.6))}
.page-hero .wrap{position:relative;z-index:2}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.84rem;color:rgba(255,255,255,.75);margin-bottom:18px}
.breadcrumb a{color:rgba(255,255,255,.75);transition:color .2s}
.breadcrumb a:hover{color:#86E6B0}
.breadcrumb span{opacity:.5}
.page-hero h1{font-size:clamp(2.3rem,4.6vw,3.7rem);color:#fff;max-width:18ch}
.page-hero h1 em{font-style:italic;color:#86E6B0}
.page-hero p{font-size:1.12rem;color:rgba(255,255,255,.86);max-width:56ch;margin-top:16px}
.page-hero .eyebrow{color:#86E6B0;margin-bottom:18px}
.page-hero .eyebrow::before{background:#86E6B0}
.page-hero .price-pill{display:inline-flex;align-items:center;gap:8px;margin-top:22px;padding:11px 20px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);font-weight:600;backdrop-filter:blur(8px)}
.page-hero .price-pill b{color:#86E6B0}

/* ---- generic content ---- */
.prose{max-width:720px}
.prose p{font-size:1.05rem;color:var(--ink-soft);margin-bottom:18px}
.prose p:last-child{margin-bottom:0}

/* ===== Blog / article (v16) ===== */
.article{max-width:760px;margin:0 auto;padding:54px 0 10px}
.article-prose{font-size:1.06rem;line-height:1.72;color:#2c3a34}
.article-prose>*:first-child{margin-top:0}
.article-prose h2{font-family:'Fraunces',Georgia,serif;font-weight:500;font-size:clamp(1.5rem,3vw,1.95rem);line-height:1.18;color:var(--emerald);margin:42px 0 14px}
.article-prose h3{font-family:'Fraunces',Georgia,serif;font-weight:500;font-size:1.32rem;color:var(--ink);margin:30px 0 10px}
.article-prose h4{font-weight:700;font-size:1.06rem;color:var(--ink);margin:24px 0 8px}
.article-prose p{margin:0 0 20px}
.article-prose a{color:var(--green);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.article-prose a:hover{color:var(--emerald)}
.article-prose ul,.article-prose ol{margin:0 0 22px;padding-left:4px;list-style:none}
.article-prose ul li,.article-prose ol li{position:relative;padding-left:30px;margin-bottom:11px}
.article-prose ul li::before{content:"";position:absolute;left:6px;top:.62em;width:7px;height:7px;border-radius:50%;background:var(--green)}
.article-prose ol{counter-reset:n}
.article-prose ol li{counter-increment:n}
.article-prose ol li::before{content:counter(n);position:absolute;left:0;top:.05em;width:22px;height:22px;border-radius:50%;background:var(--paper,#eef3f0);color:var(--emerald);font-size:.78rem;font-weight:700;display:flex;align-items:center;justify-content:center}
.article-prose img{width:100%;height:auto;border-radius:14px;margin:14px 0 26px;display:block}
.article-prose figure{margin:14px 0 26px}
.article-prose figcaption{font-size:.86rem;color:var(--ink-soft);text-align:center;margin-top:8px}
.article-prose blockquote{margin:24px 0;padding:14px 22px;border-left:4px solid var(--green);background:#f3f8f5;border-radius:8px;font-style:italic;color:#33463d}
.article-prose strong{color:var(--ink)}
.article-prose table{width:100%;border-collapse:collapse;margin:0 0 24px;font-size:.95rem}
.article-prose th,.article-prose td{border:1px solid var(--line);padding:9px 12px;text-align:left}
.article-prose th{background:var(--paper,#f6f9f7)}
.article-meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px 16px;color:var(--ink-soft);font-size:.9rem;margin-top:14px}
.article-meta .dot{width:4px;height:4px;border-radius:50%;background:currentColor;opacity:.5}
.back-blog{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--green);margin:0 0 6px}
.back-blog svg{width:17px;height:17px}

.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:26px}
.blog-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .2s}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -22px rgba(14,70,51,.4);border-color:#cfe0d7}
.blog-card .bc-img{aspect-ratio:16/10;overflow:hidden;background:var(--paper)}
.blog-card .bc-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.blog-card:hover .bc-img img{transform:scale(1.05)}
.blog-card .bc-body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.blog-card .bc-meta{display:flex;align-items:center;gap:10px;font-size:.76rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--green);margin-bottom:11px}
.blog-card .bc-meta .cat{background:rgba(23,123,83,.1);padding:4px 9px;border-radius:999px}
.blog-card .bc-meta .date{color:var(--ink-soft);font-weight:500;text-transform:none;letter-spacing:0}
.blog-card h3{font-family:'Fraunces',Georgia,serif;font-weight:500;font-size:1.22rem;line-height:1.22;color:var(--ink);margin:0 0 9px}
.blog-card p{font-size:.94rem;color:var(--ink-soft);margin:0 0 16px;line-height:1.55}
.blog-card .bc-more{margin-top:auto;font-weight:600;font-size:.9rem;color:var(--green);display:inline-flex;align-items:center;gap:7px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.split.flip .split-media{order:2}
.split-media{position:relative;border-radius:42px 120px 42px 42px;overflow:hidden;aspect-ratio:5/4.2;box-shadow:var(--shadow);border:6px solid rgba(255,255,255,.7)}
.split.flip .split-media{border-radius:120px 42px 42px 42px}
.split-media img{width:100%;height:100%;object-fit:cover}

/* checkmark feature list */
.feat-list{display:grid;gap:14px;margin-top:24px}
.feat-list li{display:flex;gap:13px;align-items:flex-start;font-size:1rem;color:var(--ink)}
.feat-list .tick{width:26px;height:26px;border-radius:8px;background:rgba(45,165,111,.14);display:grid;place-items:center;flex-shrink:0;margin-top:1px}
.feat-list .tick svg{width:15px;height:15px;color:var(--emerald)}

/* pricing rows */
.price-list{display:grid;gap:12px;margin-top:8px}
.price-row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 22px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);transition:.25s var(--ease)}
.price-row:hover{box-shadow:var(--shadow-soft);transform:translateY(-2px)}
.price-row.bookable{cursor:pointer}
.price-row.bookable:hover{border-color:var(--green)}
/* ===== rich service cards (v20) ===== */
.svc-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:24px;margin-top:8px}
.svc-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;transition:.25s var(--ease)}
.svc-card:hover{box-shadow:var(--shadow-soft);transform:translateY(-3px);border-color:#cfe0d7}
.svc-card-img{aspect-ratio:16/10;overflow:hidden;background:var(--paper)}
.svc-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .45s var(--ease)}
.svc-card:hover .svc-card-img img{transform:scale(1.05)}
.svc-card-body{display:flex;flex-direction:column;flex:1;padding:20px 20px 22px}
.svc-card-body h3{font-family:var(--display);font-weight:500;font-size:1.22rem;color:var(--forest);margin:0 0 9px;line-height:1.2}
.svc-card-body>p{font-size:.92rem;color:var(--ink-soft);line-height:1.55;margin:0 0 16px}
.svc-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:auto 0 16px;padding-top:13px;border-top:1px solid var(--line)}
.svc-dur{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;font-weight:600;color:var(--ink-soft)}
.svc-dur svg{width:15px;height:15px;flex:none}
.svc-dur-empty{display:inline-block}
.svc-price{font-family:var(--display);font-size:1.25rem;color:var(--emerald);white-space:nowrap}
.svc-actions{display:grid;gap:9px}
.svc-actions .btn{width:100%;justify-content:center;padding:11px 14px;font-size:.9rem}
.inc-actions{margin-top:24px;display:grid;gap:10px}
.inc-actions .btn{width:100%;justify-content:center}
/* ===== per-service sections: card left, FAQ right (v22) ===== */
.svc-sections{display:flex;flex-direction:column}
.svc-row{display:grid;grid-template-columns:minmax(0,0.82fr) minmax(0,1.18fr);gap:40px;align-items:start;padding:40px 0}
.svc-row:first-child{padding-top:6px}
.svc-divider{border:0;border-top:1px solid var(--line);margin:0}
.svc-row-card .svc-card{height:100%}
.svc-row-faq{padding-top:4px}
.svc-faq-h{font-family:var(--display);font-weight:500;font-size:1.18rem;color:var(--forest);margin:0 0 16px}
.svc-faq-list{display:flex;flex-direction:column;gap:11px}
.svc-row-faq .faq{background:#fff}
@media(max-width:880px){.svc-row{grid-template-columns:1fr;gap:24px;padding:30px 0}}
.price-row .pr-name{font-weight:600;color:var(--forest)}
.price-row .pr-name small{display:block;font-weight:400;color:var(--ink-soft);font-size:.86rem;margin-top:2px}
.price-row .pr-price{font-family:var(--display);font-size:1.3rem;color:var(--emerald);white-space:nowrap}
.price-row .pr-end{display:flex;align-items:center;gap:16px;flex:none}
.inc-btn{font:inherit;cursor:pointer;font-size:.82rem;font-weight:600;color:var(--emerald);background:#fff;border:1px solid var(--line);padding:8px 14px;border-radius:999px;white-space:nowrap;display:inline-flex;align-items:center;gap:6px;transition:background .2s,border-color .2s;text-decoration:none}
.inc-btn:hover{background:rgba(23,123,83,.08);border-color:var(--emerald)}
@media(max-width:600px){.price-row{flex-wrap:wrap}.price-row .pr-end{width:100%;justify-content:space-between;margin-top:4px}}
.inc-modal .modal-head .eyebrow{margin-bottom:6px}
.inc-content h4{font-family:var(--display);color:var(--emerald);font-size:1.08rem;margin:20px 0 8px}
.inc-content h5{font-weight:700;color:var(--ink);font-size:.86rem;letter-spacing:.04em;margin:18px 0 9px;text-transform:uppercase}
.inc-content h4:first-child,.inc-content h5:first-child{margin-top:0}
.inc-content ul{list-style:none;padding:0;margin:0 0 8px}
.inc-content li{position:relative;padding-left:26px;margin-bottom:9px;color:var(--ink-soft);font-size:.96rem;line-height:1.5}
.inc-content li::before{content:"";position:absolute;left:5px;top:.55em;width:7px;height:7px;border-radius:50%;background:var(--green)}
.inc-content p{font-size:.96rem;color:var(--ink-soft);margin:0 0 12px}

/* related services */
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.rel-card{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-soft);transition:.35s var(--ease)}
.rel-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.rel-card .rc-media{aspect-ratio:16/10;overflow:hidden}
.rel-card .rc-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.rel-card:hover .rc-media img{transform:scale(1.07)}
.rel-card .rc-b{padding:20px 22px}
.rel-card h3{font-size:1.2rem;margin-bottom:7px}
.rel-card p{font-size:.9rem;color:var(--ink-soft);margin-bottom:14px}
.rel-card .svc-link{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:.9rem;color:var(--emerald)}
.rel-card .svc-link svg{width:15px;height:15px}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start}
.contact-info .ci-row{display:flex;gap:16px;align-items:flex-start;padding:20px 0;border-bottom:1px solid var(--line)}
.contact-info .ci-row:last-child{border-bottom:none}
.contact-info .ci-ico{width:50px;height:50px;border-radius:14px;background:rgba(45,165,111,.12);border:1px solid rgba(45,165,111,.2);display:grid;place-items:center;flex-shrink:0}
.contact-info .ci-ico svg{width:23px;height:23px;color:var(--emerald)}
.contact-info h4{font-family:var(--sans);font-weight:700;font-size:1rem;margin-bottom:3px}
.contact-info a,.contact-info p{color:var(--ink-soft);font-size:.96rem}
.contact-info a:hover{color:var(--emerald)}
.contact-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:34px;box-shadow:var(--shadow-soft)}
.contact-card h3{font-family:var(--display);font-size:1.5rem;margin-bottom:6px}
.contact-card > p{color:var(--ink-soft);font-size:.95rem;margin-bottom:22px}

/* ---- Trustindex section ---- */
.trustindex{padding:30px 0 14px}
.ti-head{text-align:center;max-width:680px;margin:0 auto 28px}
.ti-embed{max-width:1100px;margin:0 auto;min-height:60px}
.ti-placeholder{max-width:900px;margin:0 auto;text-align:center;padding:40px 30px;border:1.5px dashed var(--line-2);border-radius:var(--r);background:var(--paper);color:var(--ink-soft)}
.ti-placeholder svg{width:38px;height:38px;color:var(--emerald);margin-bottom:12px}
.ti-placeholder b{color:var(--forest)}

@media(max-width:900px){
  .split{grid-template-columns:1fr;gap:40px}
  .split.flip .split-media{order:0}
  .split-media{max-width:480px;margin:0 auto}
  .contact-grid{grid-template-columns:1fr;gap:34px}
  .rel-grid{grid-template-columns:1fr}
  .page-hero{padding:130px 0 54px}
}

/* v7 — constrain anything Trustindex injects */
#ti-certificate img,#ti-certificate iframe,#ti-certificate>div{max-width:300px;height:auto;margin:0 auto}
#ti-widget img{max-width:100%;height:auto}
.ti-placeholder svg{width:38px!important;height:38px!important}

/* v8 — area (local SEO) pages */
.trust-row{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:30px}
.trust-row .tb{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.9rem;color:var(--forest);padding:11px 18px;border-radius:var(--r-pill);background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.trust-row .tb b{color:var(--emerald)}
.tb svg{width:18px;height:18px;flex:none;color:var(--emerald)}
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.info-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:26px 24px;box-shadow:var(--shadow-soft)}
.info-card .ico{width:48px;height:48px;border-radius:13px;background:rgba(45,165,111,.12);border:1px solid rgba(45,165,111,.2);display:grid;place-items:center;margin-bottom:16px}
.info-card .ico svg{width:23px;height:23px;color:var(--emerald)}
.info-card h3{font-size:1.18rem;margin-bottom:8px}
.info-card p{font-size:.94rem;color:var(--ink-soft);margin:0}
.svc-price-range{display:inline-block;margin-top:4px;font-family:var(--display);font-size:1.15rem;color:var(--emerald)}
.area-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.area-list span{display:inline-flex;align-items:center;gap:7px;font-size:.88rem;font-weight:500;color:var(--forest);padding:9px 15px;border-radius:var(--r-pill);background:var(--mist);border:1px solid var(--line)}
.area-list span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--leaf)}
@media(max-width:900px){.info-grid{grid-template-columns:1fr}}

/* v10 — Service Areas dropdown + linked area tags */
.has-drop{position:relative}
.drop-trigger{display:inline-flex;align-items:center;gap:7px;font-family:var(--sans);font-size:.92rem;font-weight:500;color:var(--ink);padding:10px 14px;border-radius:11px;background:none;border:none;transition:background .25s,color .25s}
.has-drop:hover .drop-trigger,.has-drop.open .drop-trigger{background:rgba(23,123,83,.1);color:var(--emerald)}
.has-drop:hover .chev,.has-drop.open .chev{transform:rotate(-135deg) translateY(-1px)}
.drop{position:absolute;top:calc(100% + 12px);left:0;min-width:236px;z-index:90;background:rgba(247,251,248,.98);backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border:1px solid rgba(11,51,38,.08);border-radius:18px;box-shadow:var(--shadow);padding:8px;opacity:0;visibility:hidden;transform:translateY(-10px) scale(.98);transform-origin:top left;transition:opacity .25s var(--ease),transform .25s var(--ease),visibility .25s}
.has-drop:hover .drop,.has-drop.open .drop{opacity:1;visibility:visible;transform:none}
.drop a{display:block;padding:11px 14px;border-radius:11px;font-size:.92rem;font-weight:500;color:var(--ink);transition:background .2s,color .2s}
.drop a:hover{background:rgba(23,123,83,.1);color:var(--emerald)}
@media(max-width:1080px){.drop{display:none}}
/* linked area tags behave like the span tags */
.area-list a{display:inline-flex;align-items:center;gap:7px;font-size:.88rem;font-weight:500;color:var(--forest);padding:9px 15px;border-radius:var(--r-pill);background:var(--mist);border:1px solid var(--line);transition:.25s var(--ease)}
.area-list a::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--leaf)}
.area-list a:hover{background:rgba(45,165,111,.12);border-color:rgba(45,165,111,.25);color:var(--emerald);transform:translateY(-2px)}

/* v11 — restructured header: areas mega, phone pill, Book Now */
.nav-phone{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;font-weight:600;color:var(--forest);padding:11px 16px;border-radius:var(--r-pill);background:var(--glass);border:1px solid var(--line-2);backdrop-filter:blur(8px);transition:.25s var(--ease)}
.nav-phone:hover{background:#fff;color:var(--emerald);transform:translateY(-2px);box-shadow:var(--shadow-soft)}
.nav-phone svg{width:16px;height:16px;color:var(--emerald)}
.nav-book{padding:12px 20px;font-size:.92rem}
/* areas mega */
.areas-mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 36px}
.amega-col{padding:4px 6px}
.amega-hub{display:flex;align-items:center;justify-content:space-between;font-family:var(--display);font-size:1.08rem;font-weight:600;color:var(--forest);padding:6px 8px 12px;border-bottom:1px solid var(--line);transition:color .25s}
.amega-hub span{color:var(--emerald);transition:transform .25s var(--ease)}
.amega-hub:hover{color:var(--emerald)}
.amega-hub:hover span{transform:translateX(4px)}
.amega-links{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:10px}
.amega-links a{font-size:.84rem;font-weight:500;color:var(--ink-soft);padding:8px 9px;border-radius:9px;transition:background .2s,color .2s}
.amega-links a:hover{background:rgba(23,123,83,.09);color:var(--emerald)}
@media(max-width:1240px){.nav-phone span{display:none}.nav-phone{padding:11px 13px}}
@media(max-width:1080px){.areas-mega-grid{grid-template-columns:1fr}.nav-phone{display:none}}
@media(max-width:560px){.amega-links{grid-template-columns:repeat(2,1fr)}}

/* v13 — linked area chips (homepage Service Areas) match span chips */
.area-tags a{display:inline-flex;align-items:center;gap:7px;font-size:.88rem;font-weight:500;color:var(--forest);padding:9px 15px;border-radius:var(--r-pill);background:var(--mist);border:1px solid var(--line);transition:.25s var(--ease)}
.area-tags a::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--leaf)}
.area-tags a:hover{background:rgba(45,165,111,.12);border-color:rgba(45,165,111,.25);color:var(--emerald);transform:translateY(-2px)}
