/* =====================================================================
   Clive Richards Tree Surgery — Design System
   Fraunces (serif display) · Inter (sans body)
   Warm cream canvas · deep bark-green dark · ochre + moss earthy accents
   ===================================================================== */

/* ---------- 1. Tokens ------------------------------------------------- */
:root{
  /* surfaces */
  --cream:        #F4EEE2;
  --cream-soft:   #FAF6ED;
  --cream-2:      #EDE5D4;
  --cream-3:      #E4D9C3;
  /* dark / bark-green */
  --forest:       #1C2719;
  --forest-2:     #243121;
  --forest-3:     #2E3B28;
  --ink:          #1A1F16;
  /* earthy accents */
  --moss:         #7C8A55;
  --moss-deep:    #5E6B3E;
  --ochre:        #C0904E;
  --ochre-deep:   #A2743A;
  --gold-soft:    #D8BD83;
  --rust:         #9E5A37;
  --bark:         #5E5446;
  --bark-soft:    #7A6E5E;
  /* lines */
  --line:         rgba(28,39,25,0.12);
  --line-strong:  rgba(28,39,25,0.20);
  --line-light:   rgba(244,238,226,0.16);
  /* type */
  --font-serif: 'Fraunces', 'Source Serif 4', Georgia, serif;
  --font-sans:  'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  /* spacing scale (8pt) */
  --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px; --sp-5: 24px;
  --sp-6: 32px; --sp-7: 48px; --sp-8: 64px; --sp-9: 96px; --sp-10: 128px;
  /* layout */
  --container: 1200px;
  --container-narrow: 760px;
  --radius:   14px;
  --radius-lg: 22px;
  --radius-sm: 9px;
  /* shadow */
  --shadow-sm: 0 1px 2px rgba(26,31,22,.06), 0 4px 14px rgba(26,31,22,.06);
  --shadow-md: 0 6px 18px rgba(26,31,22,.08), 0 18px 50px rgba(26,31,22,.10);
  --shadow-lg: 0 20px 60px rgba(26,31,22,.16);
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- 1b. Page loader ------------------------------------------ */
.page-loader{
  position:fixed; inset:0; z-index:3000; display:flex; align-items:center; justify-content:center;
  background:var(--cream);
  transition:opacity .6s var(--ease), visibility .6s var(--ease);
}
.page-loader.is-done{ opacity:0; visibility:hidden; }
body.loading{ overflow:hidden; }
.loader-inner{ display:flex; flex-direction:column; align-items:center; gap:26px; }
.loader-mark{ width:min(260px,64vw); height:auto; animation:loaderPulse 1.8s var(--ease) infinite; }
.loader-bar{ position:relative; width:170px; height:3px; border-radius:4px; background:rgba(94,107,62,.16); overflow:hidden; }
.loader-bar i{ position:absolute; top:0; left:0; height:100%; width:42%; border-radius:4px;
  background:linear-gradient(90deg,var(--moss-deep),var(--ochre)); animation:loaderBar 1.25s var(--ease) infinite; }
@keyframes loaderBar{ 0%{ transform:translateX(-130%); } 100%{ transform:translateX(360%); } }
@keyframes loaderPulse{ 0%,100%{ opacity:.74; transform:scale(.99); } 50%{ opacity:1; transform:scale(1.01); } }
@media (prefers-reduced-motion: reduce){
  .loader-mark,.loader-bar i{ animation:none; }
}

/* ---------- 2. Reset / base ------------------------------------------ */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0;
  font-family:var(--font-sans);
  font-size:17px;
  line-height:1.7;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
ul{ margin:0; padding:0; list-style:none; }
::selection{ background:var(--moss); color:var(--cream); }

.skip-link{
  position:absolute; left:-9999px; top:0; z-index:2000;
  background:var(--forest); color:var(--cream); padding:12px 18px; border-radius:0 0 8px 0;
}
.skip-link:focus{ left:0; }

:focus-visible{ outline:2.5px solid var(--ochre); outline-offset:3px; border-radius:4px; }

/* ---------- 3. Typography -------------------------------------------- */
h1,h2,h3,h4{
  font-family:var(--font-serif);
  font-weight:440;
  line-height:1.08;
  letter-spacing:-0.01em;
  margin:0 0 .5em;
  font-optical-sizing:auto;
}
h1{ font-size:clamp(2.6rem, 6vw, 4.6rem); letter-spacing:-0.025em; }
h2{ font-size:clamp(2rem, 3.6vw, 3.1rem); letter-spacing:-0.02em; }
h3{ font-size:clamp(1.3rem, 2vw, 1.6rem); }
h4{ font-size:1.12rem; font-weight:500; }
h1 em,h2 em,h3 em{ font-style:italic; font-weight:380; color:var(--ochre-deep); }
p{ margin:0 0 1.1em; }
strong{ font-weight:600; }

.eyebrow{
  display:inline-block;
  font-family:var(--font-sans);
  font-size:.74rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  color:var(--moss-deep);
  margin-bottom:var(--sp-4);
}
.eyebrow::before{ content:""; display:inline-block; width:26px; height:1px; background:var(--ochre); vertical-align:middle; margin-right:10px; transform:translateY(-3px); }
.eyebrow-gold{ color:var(--gold-soft); }
.eyebrow-gold::before{ background:var(--gold-soft); }
/* eyebrows removed site-wide per client request */
.eyebrow{ display:none !important; }

.lead{ font-size:1.18rem; line-height:1.65; color:var(--bark); }
.text-center{ text-align:center; }

/* ---------- 4. Layout ------------------------------------------------ */
.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 28px; }
.container-narrow{ width:100%; max-width:var(--container-narrow); margin:0 auto; padding:0 28px; }
.section{ position:relative; padding:clamp(64px,9vw,120px) 0; }
.section-tight{ position:relative; padding:clamp(48px,6vw,80px) 0; }
.bg-cream-2{ background:var(--cream-2); }
.bg-cream-soft{ background:var(--cream-soft); }
.section-head{ max-width:680px; margin:0 0 var(--sp-7); }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }

/* botanical divider */
.divider{ display:flex; justify-content:center; padding:8px 0; }
.divider svg{ width:min(880px,90%); height:auto; }

/* section watermark (decorative leaf behind content) */
.section-watermark{
  position:absolute; pointer-events:none; opacity:.1;
  width:min(780px,72vw); height:auto; right:-170px; top:50%; transform:translateY(-50%);
  filter:brightness(0) invert(1); /* render the green element as a soft light texture on dark sections */
}

/* ---------- 5. Buttons ----------------------------------------------- */
.btn{
  --btn-bg:var(--forest); --btn-fg:var(--cream);
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--font-sans); font-weight:600; font-size:.96rem; letter-spacing:.005em;
  padding:15px 28px; border-radius:100px;
  background:var(--btn-bg); color:var(--btn-fg);
  position:relative; overflow:hidden;
  transition:transform .45s var(--ease), box-shadow .45s var(--ease), background .3s, color .3s;
  will-change:transform;
}
.btn::after{ /* sheen */
  content:""; position:absolute; inset:0; background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.16) 50%,transparent 70%);
  transform:translateX(-120%); transition:transform .7s var(--ease);
}
.btn:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn:hover::after{ transform:translateX(120%); }
.btn:active{ transform:translateY(0); }
.btn-sm{ padding:11px 20px; font-size:.88rem; }
.btn-block{ display:flex; width:100%; }

.btn-primary{ --btn-bg:var(--forest); --btn-fg:var(--cream); }
.btn-primary:hover{ background:var(--forest-2); }
.btn-gold{ --btn-bg:var(--ochre); --btn-fg:#231a0c; }
.btn-gold:hover{ background:var(--gold-soft); }
.btn-whatsapp{ --btn-bg:#1faf54; --btn-fg:#fff; }
.btn-whatsapp:hover{ --btn-bg:#1a9a4a; }
.btn-outline{ --btn-bg:transparent; --btn-fg:var(--forest); border:1.5px solid var(--line-strong); }
.btn-outline:hover{ background:var(--forest); color:var(--cream); border-color:var(--forest); }
.btn-ghost-light{ --btn-bg:transparent; --btn-fg:var(--cream); border:1.5px solid var(--line-light); }
.btn-ghost-light:hover{ background:rgba(244,238,226,.1); }

.text-link{ display:inline-flex; align-items:center; gap:7px; font-weight:600; color:var(--moss-deep); }
.text-link .arr{ transition:transform .35s var(--ease); }
.text-link:hover .arr{ transform:translateX(5px); }

/* ---------- 6. Header ------------------------------------------------ */
.site-header{
  position:sticky; top:0; z-index:1200;
  background:rgba(244,238,226,0); backdrop-filter:saturate(120%) blur(0px);
  transition:background .4s var(--ease), box-shadow .4s var(--ease), border-color .4s;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(247,242,233,.86); backdrop-filter:saturate(140%) blur(14px);
  border-bottom-color:var(--line); box-shadow:0 8px 30px rgba(26,31,22,.06);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; height:96px; gap:24px; }
.site-header.scrolled .header-inner{ height:80px; }
.header-inner{ transition:height .4s var(--ease); }

/* logo lockup */
.logo-lockup{ display:inline-flex; align-items:center; gap:12px; color:var(--forest); }
.logo-mark-wrap{ display:grid; place-items:center; width:46px; height:46px; color:var(--moss-deep); transition:transform .6s var(--ease); }
.logo:hover .logo-mark-wrap{ transform:rotate(-8deg); }
.logo-words{ display:flex; flex-direction:column; line-height:1; }
.logo-name{ font-family:var(--font-serif); font-size:1.32rem; font-weight:500; letter-spacing:-.01em; }
.logo-tag{ font-family:var(--font-sans); font-size:.6rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--bark-soft); margin-top:4px; }
.logo-light .logo-lockup{ color:var(--cream); }
.logo-light .logo-mark-wrap{ color:var(--gold-soft); }
.logo-light .logo-tag{ color:rgba(244,238,226,.55); }
/* image-based brand logo */
.brand-logo{ display:block; width:auto; height:74px; transition:opacity .3s var(--ease), filter .35s var(--ease), height .4s var(--ease); }
.site-header.scrolled .brand-logo{ height:60px; }
.footer .brand-logo{ height:60px; }
.logo:hover .brand-logo{ opacity:.82; }
@media (max-width:640px){ .brand-logo{ height:54px; } .site-header.scrolled .brand-logo{ height:50px; } }
/* full-colour brand logo in the header; soft shadow lifts it off the hero video */
.site-header:not(.scrolled) .brand-logo{ filter:drop-shadow(0 2px 10px rgba(0,0,0,.45)); }
/* white/reverse logo on the dark footer */
.logo-light .brand-logo{ filter:brightness(0) invert(1); }

.nav{ display:flex; align-items:center; gap:28px; }
.nav-item{ position:relative; display:flex; align-items:center; }
.nav-link{ font-size:.95rem; font-weight:500; color:var(--ink); position:relative; padding:8px 0; display:inline-flex; align-items:center; gap:5px; }
.nav-link::after{ content:""; position:absolute; left:0; bottom:2px; width:0; height:1.5px; background:var(--ochre); transition:width .35s var(--ease); }
.nav-link:hover::after,.nav-link.is-active::after{ width:100%; }
.nav-link.is-active{ color:var(--moss-deep); }
.nav-caret{ width:11px; height:11px; transition:transform .35s var(--ease); opacity:.6; }
.nav-item.has-sub:hover .nav-caret,.nav-item.has-sub:focus-within .nav-caret{ transform:rotate(180deg); }

/* desktop dropdown panel */
.nav-sub{ position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(10px);
  padding-top:18px; opacity:0; visibility:hidden; pointer-events:none; transition:opacity .3s var(--ease), transform .3s var(--ease); z-index:50; }
.nav-item.has-sub:hover .nav-sub,.nav-item.has-sub:focus-within .nav-sub{ opacity:1; visibility:visible; pointer-events:auto; transform:translateX(-50%) translateY(0); }
.nav-sub-inner{ background:var(--cream-soft); border:1px solid var(--line); border-radius:16px; box-shadow:var(--shadow-lg); padding:14px; }
.nav-sub-grid{ display:grid; grid-template-columns:1fr 1fr; gap:2px 10px; min-width:460px; }
.nav-sub-grid.areas{ min-width:430px; }
.nav-sub a{ display:flex; align-items:center; gap:11px; padding:11px 13px; border-radius:10px; font-size:.92rem; font-weight:500; color:var(--ink); transition:background .25s, color .25s; }
.nav-sub a:hover{ background:rgba(124,138,85,.12); color:var(--moss-deep); }
.nav-sub a .svc-icon{ width:24px; height:24px; margin:0; color:var(--moss-deep); flex:none; }
.nav-sub a .sub-county{ display:block; font-size:.72rem; font-weight:400; color:var(--bark-soft); margin-top:1px; }
.nav-sub-foot{ margin-top:8px; padding:11px 13px 5px; border-top:1px solid var(--line); }
.nav-sub-foot a{ padding:0; font-weight:600; color:var(--moss-deep); }

.header-actions{ display:flex; align-items:center; gap:16px; }
.header-phone{ display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:.95rem; color:var(--forest); }
.header-phone svg{ color:var(--moss-deep); }
.header-phone:hover{ color:var(--moss-deep); }

.nav-toggle{ display:none; flex-direction:column; gap:5px; width:42px; height:42px; align-items:center; justify-content:center; }
.nav-toggle span{ display:block; width:24px; height:2px; background:var(--forest); border-radius:2px; transition:transform .35s var(--ease), opacity .25s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.mobile-menu{ position:fixed; top:0; right:0; bottom:0; height:100dvh; width:min(380px,86vw);
  background:var(--cream-soft); z-index:1100;
  transform:translateX(100%); transition:transform .5s var(--ease); box-shadow:var(--shadow-lg);
  padding:96px 28px 40px; display:flex; flex-direction:column; }
.mobile-menu.open{ transform:translateX(0); }
.mobile-menu-inner{ display:flex; flex-direction:column; gap:0; overflow-y:auto; -webkit-overflow-scrolling:touch; flex:1; }
.m-item{ border-bottom:1px solid var(--line); }
.m-row{ display:flex; align-items:center; justify-content:space-between; }
.m-row > a{ font-family:var(--font-serif); font-size:1.5rem; padding:12px 0; flex:1; }
.m-sub-toggle{ width:46px; height:46px; display:grid; place-items:center; color:var(--bark); }
.m-sub-toggle svg{ width:16px; height:16px; transition:transform .35s var(--ease); }
.m-sub-toggle[aria-expanded="true"] svg{ transform:rotate(180deg); }
.m-sub{ overflow:hidden; max-height:0; transition:max-height .4s var(--ease); }
.m-sub.open{ max-height:760px; }
.m-sub a{ display:block; font-family:var(--font-sans); font-size:1rem; color:var(--bark); padding:9px 0 9px 14px; }
.m-sub a:hover{ color:var(--moss-deep); }
.m-sub-inner{ padding:2px 0 14px; }
.mobile-menu-cta{ display:flex; flex-direction:column; gap:12px; margin-top:24px; }
.menu-backdrop{ position:fixed; inset:0; background:rgba(26,31,22,.5); z-index:1080; opacity:0; pointer-events:none; transition:opacity .4s; }
/* hide the header logo while the mobile drawer is open so it doesn't overlay the menu */
body.menu-open .site-header .logo{ opacity:0; visibility:hidden; pointer-events:none; transition:opacity .25s; }
.menu-backdrop.show{ opacity:1; pointer-events:auto; }

/* ---------- 7. Hero -------------------------------------------------- */
.hero{ position:relative; min-height:clamp(620px,92vh,940px); display:flex; align-items:center; overflow:hidden; color:var(--cream); }
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-media video,.hero-media img{ width:100%; height:100%; object-fit:cover; }
/* crossfading hero video slideshow */
.hero-video{ position:absolute; inset:0; opacity:0; transition:opacity 1.4s ease; will-change:opacity; }
.hero-video.is-active{ opacity:1; }
@media (prefers-reduced-motion: reduce){ .hero-video{ transition:none; } }
.hero-fallback{ position:absolute; inset:0; background:
  radial-gradient(120% 90% at 75% 18%, rgba(110,122,70,.55), transparent 55%),
  linear-gradient(165deg, #2f3d27 0%, #1d2817 55%, #141d10 100%); }
.hero-overlay{ position:absolute; inset:0; z-index:1;
  background:linear-gradient(95deg, rgba(15,21,11,.82) 0%, rgba(15,21,11,.55) 42%, rgba(15,21,11,.2) 100%); }
.hero-vignette{ position:absolute; inset:0; z-index:1; box-shadow:inset 0 -120px 160px rgba(11,16,8,.6), inset 0 60px 120px rgba(11,16,8,.35); }
.hero .container{ position:relative; z-index:3; }
.hero-inner{ max-width:760px; padding:120px 0 90px; }
.hero h1{ color:var(--cream); margin-bottom:var(--sp-5); }
.hero h1 em{ color:var(--gold-soft); }
.hero-sub{ font-size:1.22rem; color:rgba(244,238,226,.84); max-width:540px; margin-bottom:var(--sp-6); }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:var(--sp-5); }
.hero-email{ font-size:.95rem; color:rgba(244,238,226,.62); }
.hero-email a{ color:var(--gold-soft); border-bottom:1px solid rgba(216,189,131,.4); }

/* hero floating rating chip */
.hero-rating{ display:inline-flex; align-items:center; gap:12px; background:rgba(244,238,226,.1);
  border:1px solid rgba(244,238,226,.18); backdrop-filter:blur(6px); padding:10px 18px; border-radius:100px; margin-bottom:var(--sp-5); }
.hero-rating .stars{ color:var(--gold-soft); letter-spacing:2px; }
.hero-rating .stars-num{ font-weight:600; }
.hero-rating small{ color:rgba(244,238,226,.7); }

/* slider dots (1 slide ready to extend) */
.hero-dots{ position:absolute; bottom:34px; left:50%; transform:translateX(-50%); z-index:4; display:flex; gap:10px; }
.hero-dots button{ width:9px; height:9px; border-radius:50%; background:rgba(244,238,226,.35); transition:all .3s; }
.hero-dots button.active{ width:30px; border-radius:6px; background:var(--gold-soft); }

.hero-scroll{ position:absolute; bottom:30px; right:40px; z-index:4; display:flex; align-items:center; gap:10px; color:rgba(244,238,226,.6); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; writing-mode:vertical-rl; }
.hero-scroll .line{ width:1px; height:46px; background:linear-gradient(var(--gold-soft),transparent); }

/* compact page hero */
.page-hero{ position:relative; color:var(--cream); padding:clamp(120px,16vh,180px) 0 clamp(56px,8vw,90px); overflow:hidden; }
.page-hero .hero-fallback{ background:linear-gradient(160deg,#2c3925 0%,#1c2718 60%,#161f12 100%); }
.page-hero-bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.page-hero-overlay{ position:absolute; inset:0; z-index:1;
  background:linear-gradient(100deg,rgba(13,18,9,.86),rgba(13,18,9,.55) 70%),
             linear-gradient(0deg,rgba(13,18,9,.5),transparent 55%); }
.page-hero .container{ position:relative; z-index:2; }
.page-hero h1{ color:var(--cream); }
.page-hero h1 em{ color:var(--gold-soft); }
.page-hero .eyebrow{ color:var(--gold-soft); }
.page-hero .eyebrow::before{ background:var(--gold-soft); }
.page-hero-sub{ font-size:1.18rem; color:rgba(244,238,226,.82); max-width:620px; margin-top:var(--sp-4); }
.breadcrumb{ display:flex; gap:8px; font-size:.82rem; color:rgba(244,238,226,.6); margin-bottom:var(--sp-5); }
.breadcrumb a:hover{ color:var(--gold-soft); }
.breadcrumb span{ opacity:.5; }

/* ---------- 8. Trust bar --------------------------------------------- */
.trust-bar{ background:var(--forest); color:var(--cream); }
.trust-bar-inner{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:20px 36px; padding:26px 0; }
.trust-item{ display:flex; align-items:baseline; gap:9px; font-size:.92rem; color:rgba(244,238,226,.72); }
.trust-item strong{ font-family:var(--font-serif); font-size:1.5rem; font-weight:500; color:var(--gold-soft); }

/* ---------- 8b. Accreditations --------------------------------------- */
.accreditations{ text-align:center; }
.accred-head{ margin-bottom:var(--sp-6); }
.accred-head h3{ font-size:clamp(1.5rem,2.6vw,2rem); margin-bottom:14px; }
.accred-head p{ color:var(--bark); font-size:1.05rem; line-height:1.65; }
.accred-label{ font-size:.78rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--bark-soft); margin:0 0 var(--sp-6); }
.accred-row{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:44px 80px; }
.accred-item{ background:none; border:none; box-shadow:none; padding:0;
  display:grid; place-items:center; transition:transform .45s var(--ease), opacity .3s var(--ease); }
.accred-item:hover{ transform:translateY(-4px); }
.accred-logo{ width:auto; height:auto; object-fit:contain; }
/* optically balanced — each logo trimmed to a similar visual footprint */
.accred-logo--seal{ max-height:90px; max-width:90px; }
.accred-logo--nptc{ max-height:62px; max-width:150px; }
.accred-logo--ea{ max-height:58px; max-width:165px; }
.accred-logo--wordmark{ max-height:66px; max-width:200px; }
.accred-item--text{ flex-direction:column; }
.accred-insured{ display:flex; align-items:center; gap:12px; }
.accred-insured strong{ font-family:var(--font-serif); font-size:2.6rem; font-weight:500; line-height:1; color:var(--moss-deep); }
.accred-insured span{ text-align:left; font-size:.84rem; font-weight:600; color:var(--bark); line-height:1.3; }
@media (max-width:620px){
  .accred-row{ gap:30px 46px; }
  .accred-logo--seal{ max-height:70px; max-width:70px; }
  .accred-logo--nptc{ max-height:48px; max-width:120px; }
  .accred-logo--ea{ max-height:46px; max-width:130px; }
  .accred-logo--wordmark{ max-height:36px; max-width:140px; }
}

/* ---------- 9. Services ---------------------------------------------- */
.services-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.service-card{
  display:flex; flex-direction:column; background:var(--cream-soft);
  border:1px solid var(--line); border-radius:var(--radius-lg); padding:34px 30px;
  position:relative; overflow:hidden; transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .4s;
}
.service-card::before{ content:""; position:absolute; left:0; top:0; height:3px; width:0; background:linear-gradient(90deg,var(--moss),var(--ochre)); transition:width .5s var(--ease); }
.service-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:transparent; }
.service-card:hover::before{ width:100%; }
.svc-icon{ width:42px; height:42px; color:var(--moss-deep); margin-bottom:var(--sp-5); transition:transform .5s var(--ease); }
.service-card:hover .svc-icon{ transform:scale(1.08) rotate(-3deg); color:var(--ochre-deep); }
.service-card h3{ margin-bottom:10px; }
.service-card p{ color:var(--bark); font-size:.98rem; margin-bottom:var(--sp-5); flex:1; }
.service-card .arrow{ font-weight:600; font-size:.9rem; color:var(--moss-deep); display:inline-flex; gap:6px; align-items:center; }
.service-card:hover .arrow{ color:var(--ochre-deep); }

/* services page — image cards */
.services-grid-lg{ display:grid; grid-template-columns:repeat(2,1fr); gap:26px; }
.service-card-lg{ display:grid; grid-template-columns:200px 1fr; background:var(--cream-soft); border:1px solid var(--line);
  border-radius:var(--radius-lg); overflow:hidden; transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.service-card-lg:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); }
.service-card-lg .svc-illus-wrap{ position:relative; overflow:hidden; }
.svc-illus{ width:100%; height:100%; min-height:210px; object-fit:cover; transition:transform .9s var(--ease); }
.service-card-lg:hover .svc-illus{ transform:scale(1.06); }
.service-card-lg .card-body{ padding:30px 30px 26px; display:flex; flex-direction:column; }
.service-card-lg h3{ margin-bottom:10px; }
.service-card-lg p{ color:var(--bark); font-size:.98rem; flex:1; }
.service-card-lg .arrow{ font-weight:600; color:var(--moss-deep); margin-top:var(--sp-4); }

/* ---------- 10. Split ------------------------------------------------ */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,84px); align-items:center; }
.split.reverse .split-media{ order:2; }
.split-media{ position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:4/5; box-shadow:var(--shadow-md); }
.split-media img,.split-media .svc-illus{ width:100%; height:100%; object-fit:cover; }
.split-media.wide{ aspect-ratio:5/4; }
.media-tag{ position:absolute; left:16px; bottom:16px; z-index:2; background:rgba(15,21,11,.62); color:var(--cream);
  font-size:.74rem; letter-spacing:.04em; padding:7px 13px; border-radius:100px; backdrop-filter:blur(4px); }
.split-content h2{ margin-bottom:var(--sp-4); }
.split-content p{ color:var(--bark); margin-bottom:var(--sp-4); }
.split-content .btn{ margin-top:var(--sp-3); }

/* ---------- 11. Reviews ---------------------------------------------- */
.reviews-section{ background:var(--cream-2); }
.checkatrade{ max-width:560px; margin:0 auto var(--sp-8); text-align:center; background:var(--cream-soft);
  border:1px solid var(--line); border-radius:var(--radius-lg); padding:40px; box-shadow:var(--shadow-sm); }
.checkatrade .rating{ font-family:var(--font-serif); font-size:3.6rem; line-height:1; color:var(--forest); }
.checkatrade .stars{ color:var(--ochre); font-size:1.4rem; letter-spacing:4px; margin:10px 0 6px; }
.checkatrade .count{ font-size:.92rem; color:var(--bark); }
.checkatrade .subscores{ display:flex; justify-content:center; flex-wrap:wrap; gap:8px 22px; margin-top:18px; font-size:.84rem; color:var(--bark); }
.checkatrade .subscores strong{ color:var(--moss-deep); }

/* Checkatrade — brand colours */
:root{ --ck-red:#F94B43; --ck-navy:#0B0B4D; }

/* full badge (logo + text) */
.ck-badge{ display:inline-flex; align-items:center; gap:14px; background:#fff; color:var(--ck-navy);
  padding:12px 18px 12px 14px; border-radius:14px; border:1px solid rgba(11,11,77,.10);
  box-shadow:0 10px 30px rgba(11,11,77,.12); text-align:left;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.ck-badge:hover{ transform:translateY(-3px); box-shadow:0 18px 40px rgba(11,11,77,.18); }
.ck-logo{ flex:none; display:grid; place-items:center; }
.ck-text{ display:flex; flex-direction:column; line-height:1.2; }
.ck-word{ font-family:var(--font-sans); font-weight:800; font-size:1.24rem; letter-spacing:-.02em; color:var(--ck-navy); }
.ck-dot{ color:var(--ck-red); }
.ck-sub{ font-size:.76rem; color:#5b5e74; margin-top:3px; }
.ck-sub strong{ color:var(--ck-navy); font-weight:700; }
.ck-go{ margin-left:4px; color:var(--ck-red); font-weight:800; transition:transform .35s var(--ease); }
.ck-badge:hover .ck-go{ transform:translateX(4px); }
.ck-badge--white{ background:#fff; }
/* badge sitting on top of the checkatrade card */
.checkatrade .ck-badge{ margin-bottom:26px; }

/* compact pill (hero / top of page) — white */
.ck-pill{ display:inline-flex; align-items:center; gap:10px; background:#fff; color:var(--ck-navy);
  padding:8px 16px 8px 10px; border-radius:100px; box-shadow:0 10px 30px rgba(11,11,77,.22);
  font-size:.86rem; transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.ck-pill:hover{ transform:translateY(-2px); box-shadow:0 16px 38px rgba(11,11,77,.28); }
.ck-pill-text{ color:#3a3c52; }
.ck-pill-text strong{ color:var(--ck-navy); font-weight:700; }
.ck-pill-score{ color:var(--ck-red); font-weight:700; }
.hero-pill-wrap{ display:inline-block; margin-bottom:var(--sp-5); }

/* Area pages — services grid in 2 columns (scoped, homepage stays 3) */
.services-grid--two{ grid-template-columns:repeat(2,1fr); }

/* Areas map embed */
.area-map.has-map{ background:none; }
.area-map iframe{ width:100%; height:100%; border:0; display:block; filter:saturate(.9) contrast(1.02); }
.area-map .map-pin-label{ position:absolute; left:16px; bottom:16px; z-index:2; background:var(--forest); color:var(--cream);
  font-size:.78rem; font-weight:600; padding:8px 15px; border-radius:100px; box-shadow:var(--shadow-md); pointer-events:none; }

.testimonial-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.testimonial{ background:var(--cream-soft); border:1px solid var(--line); border-radius:var(--radius); padding:30px 28px;
  display:flex; flex-direction:column; transition:transform .45s var(--ease), box-shadow .45s var(--ease); }
.testimonial:hover{ transform:translateY(-4px); box-shadow:var(--shadow-sm); }
.testimonial .stars{ color:var(--ochre); letter-spacing:2px; margin-bottom:14px; }
.testimonial-top{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:14px; }
.testimonial-top .stars{ margin-bottom:0; }
.ck-verified{ display:inline-flex; align-items:center; gap:6px; font-size:.7rem; font-weight:700; letter-spacing:.02em; color:var(--ck-navy); white-space:nowrap; }
.ck-verified .ck-logo-mark{ flex:none; }
.testimonial blockquote{ margin:0 0 18px; font-size:1rem; line-height:1.65; color:var(--ink); font-family:var(--font-serif); font-weight:380; flex:1; }
.testimonial .attr strong{ display:block; font-family:var(--font-sans); font-size:.95rem; }
.testimonial .attr span{ font-size:.82rem; color:var(--bark-soft); }

/* ---------- 12. Sustainability / green ------------------------------- */
.green-section{ background:var(--forest); color:var(--cream); position:relative; overflow:hidden; }
.green-section .eyebrow{ color:var(--gold-soft); }
.green-section .eyebrow::before{ background:var(--gold-soft); }
.green-section h2{ color:var(--cream); max-width:14ch; }
.green-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; margin-top:var(--sp-7); }
.green-item{ padding-top:24px; border-top:1px solid var(--line-light); }
.green-item h3{ color:var(--gold-soft); font-size:1.25rem; margin-bottom:10px; }
.green-item p{ color:rgba(244,238,226,.72); font-size:.97rem; }

/* ---------- 13. Areas ------------------------------------------------ */
.areas-section{ background:var(--cream-2); }
.area-map{ position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:1/1; background:
  radial-gradient(90% 90% at 40% 30%, #34432a, #1d2817); box-shadow:var(--shadow-md); display:grid; place-items:center; }
.area-pin{ position:relative; z-index:2; background:var(--ochre); color:#231a0c; font-weight:600; font-size:.82rem;
  padding:8px 16px; border-radius:100px; box-shadow:0 8px 24px rgba(0,0,0,.3); }
.area-pin::after{ content:""; position:absolute; left:50%; top:-9px; width:18px; height:18px; transform:translateX(-50%);
  border-radius:50%; border:2px solid var(--gold-soft); animation:pulse 2.4s var(--ease) infinite; }
@keyframes pulse{ 0%{ transform:translateX(-50%) scale(.6); opacity:.9 } 100%{ transform:translateX(-50%) scale(2.6); opacity:0 } }

.areas-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:14px; margin-top:var(--sp-6); }
.area-chip{ display:flex; align-items:center; justify-content:space-between; gap:8px; background:var(--cream-soft);
  border:1px solid var(--line); border-radius:100px; padding:12px 20px; font-weight:500; font-size:.95rem;
  transition:transform .35s var(--ease), background .3s, color .3s, border-color .3s; }
.area-chip:hover{ background:var(--forest); color:var(--cream); transform:translateY(-3px); border-color:var(--forest); }
.area-chip .arr{ color:var(--ochre); transition:transform .35s var(--ease); }
.area-chip:hover .arr{ transform:translateX(4px); color:var(--gold-soft); }

.areas-list{ display:grid; grid-template-columns:1fr 1fr; gap:36px; margin-top:var(--sp-6); }
.areas-list h3{ color:var(--moss-deep); margin-bottom:12px; }
.areas-list p{ color:var(--bark); line-height:2; }

/* ---------- 14. CTA band --------------------------------------------- */
.cta-band{ position:relative; background:linear-gradient(150deg,#2a3723,#1a2414); color:var(--cream); text-align:center; overflow:hidden; padding:clamp(64px,9vw,110px) 0; }
.cta-bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.cta-band::before{ content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(150deg, rgba(24,33,18,.88), rgba(16,23,11,.8)); }
.cta-band .section-watermark{ right:auto; left:-170px; opacity:.09; }
.cta-inner{ position:relative; z-index:2; max-width:640px; margin:0 auto; }
.cta-title{ color:var(--cream); }
.cta-title em{ color:var(--gold-soft); }
.cta-sub{ font-size:1.12rem; color:rgba(244,238,226,.78); margin-bottom:var(--sp-6); }
.cta-buttons{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; margin-bottom:var(--sp-5); }
.cta-email{ font-size:.95rem; color:rgba(244,238,226,.6); }
.cta-email a{ color:var(--gold-soft); border-bottom:1px solid rgba(216,189,131,.4); }

/* ---------- 15. Footer ----------------------------------------------- */
.footer{ background:var(--forest); color:rgba(244,238,226,.72); padding:clamp(56px,7vw,84px) 0 32px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; padding-bottom:var(--sp-7); border-bottom:1px solid var(--line-light); }
.footer-blurb{ margin:18px 0; max-width:30ch; font-size:.95rem; }
.footer-contact li{ margin-bottom:8px; }
.footer-contact a:hover{ color:var(--gold-soft); }
.footer-base{ margin-top:14px; color:rgba(244,238,226,.5); }
.footer h4{ color:var(--cream); font-family:var(--font-sans); font-size:.78rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; margin-bottom:18px; }
.footer-links li{ margin-bottom:10px; }
.footer-links a{ font-size:.94rem; transition:color .25s, padding .3s; }
.footer-links a:hover{ color:var(--gold-soft); padding-left:4px; }
.footer-badges{ display:flex; flex-wrap:wrap; gap:8px; margin-top:22px; }
.footer-badge{ font-size:.72rem; padding:6px 11px; border:1px solid var(--line-light); border-radius:100px; color:rgba(244,238,226,.6); }
.footer-bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; padding-top:26px; font-size:.84rem; color:rgba(244,238,226,.5); }
.footer-bottom-links{ display:flex; gap:22px; }
.footer-bottom-links a:hover{ color:var(--gold-soft); }

/* ---------- 16. WhatsApp widget -------------------------------------- */
.wa-widget{ position:fixed; right:22px; bottom:22px; z-index:920; }
.wa-bubble{ position:relative; width:60px; height:60px; border-radius:50%; background:#1faf54; color:#fff;
  display:grid; place-items:center; box-shadow:0 12px 30px rgba(31,175,84,.4); transition:transform .4s var(--ease); }
.wa-bubble:hover{ transform:scale(1.07); }
.wa-bubble-dot{ position:absolute; top:2px; right:2px; width:16px; height:16px; background:var(--rust); color:#fff;
  border-radius:50%; border:2px solid #1faf54; }
.wa-bubble::after{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid #1faf54; animation:pulse 2.6s var(--ease) infinite; }
.wa-panel{ position:absolute; right:0; bottom:78px; width:330px; max-width:calc(100vw - 44px); background:var(--cream-soft);
  border-radius:18px; box-shadow:var(--shadow-lg); overflow:hidden; transform-origin:bottom right; }
.wa-panel-head{ display:flex; align-items:center; gap:12px; background:#0a7b3d; color:#fff; padding:16px 18px; }
.wa-avatar{ display:grid; place-items:center; width:40px; height:40px; border-radius:50%; background:rgba(255,255,255,.16); color:#fff; }
.wa-panel-head strong{ display:block; font-size:.98rem; }
.wa-status{ font-size:.76rem; color:rgba(255,255,255,.8); display:flex; align-items:center; gap:6px; }
.wa-online{ width:8px; height:8px; border-radius:50%; background:#7df3a6; }
.wa-close{ margin-left:auto; color:#fff; font-size:1.5rem; line-height:1; width:28px; height:28px; }
.wa-panel-body{ padding:22px 18px; background:#e9e3d6 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M0 20h40M20 0v40' stroke='%23000' stroke-opacity='0.02'/%3E%3C/svg%3E"); }
.wa-msg{ background:#fff; padding:13px 16px; border-radius:4px 16px 16px 16px; font-size:.92rem; color:var(--ink); box-shadow:var(--shadow-sm); margin:0; }
.wa-start{ margin:0 16px 16px; }

/* ---------- 17. Mobile bar ------------------------------------------- */
.mobile-bar{ position:fixed; left:0; right:0; bottom:0; z-index:910; display:none;
  background:rgba(247,242,233,.92); backdrop-filter:blur(12px); border-top:1px solid var(--line); padding:9px 12px calc(9px + env(safe-area-inset-bottom)); }
.mobile-bar-btn{ flex:1; display:flex; flex-direction:column; align-items:center; gap:3px; font-size:.72rem; font-weight:600; color:var(--forest); padding:6px; }
.mobile-bar-cta{ background:var(--forest); color:var(--cream); border-radius:100px; justify-content:center; padding:11px; }

/* ---------- 18. Page content (service/area detail) ------------------ */
.prose{ max-width:var(--container-narrow); }
.prose h2{ margin-top:var(--sp-7); }
.prose h2:first-child{ margin-top:0; }
.prose p{ color:var(--bark); line-height:1.8; }
.prose .lead{ color:var(--ink); }
.prose ul{ margin:0 0 1.4em; }
.prose ul li{ position:relative; padding-left:30px; margin-bottom:12px; color:var(--bark); }
.prose ul li::before{ content:""; position:absolute; left:4px; top:11px; width:9px; height:9px; border-radius:50%;
  background:var(--moss); box-shadow:0 0 0 4px rgba(124,138,85,.16); }
.pull{ font-family:var(--font-serif); font-size:1.35rem; font-style:italic; color:var(--forest);
  margin:36px 0; padding-left:26px; border-left:3px solid var(--ochre); line-height:1.5; }

.faq-item{ border-top:1px solid var(--line); padding:22px 0; }
.faq-item h4{ font-family:var(--font-serif); font-weight:500; font-size:1.18rem; margin-bottom:8px; color:var(--forest); }
.faq-item p{ margin:0; color:var(--bark); }

/* related services */
.related{ background:var(--cream-2); }
.related-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:var(--sp-6); }

/* pull quote band (about) */
.quote-band{ background:var(--forest); color:var(--cream); text-align:center; padding:clamp(60px,8vw,100px) 0; }
.quote-band blockquote{ font-family:var(--font-serif); font-size:clamp(1.8rem,3.4vw,2.8rem); font-weight:360; line-height:1.25; max-width:18ch; margin:0 auto 18px; }
.quote-band blockquote em{ color:var(--gold-soft); }
.quote-band cite{ font-style:normal; font-size:.9rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(244,238,226,.6); }

.reassurance{ background:var(--moss-deep); color:var(--cream); text-align:center; padding:54px 0; }
.reassurance p{ font-family:var(--font-serif); font-size:clamp(1.3rem,2.4vw,1.9rem); font-style:italic; margin:0; max-width:24ch; margin:0 auto; }

/* ---------- 19. Gallery ---------------------------------------------- */
.gallery-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; grid-auto-flow:dense; }
.gallery-item{ position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:4/3; box-shadow:var(--shadow-sm);
  transition:box-shadow .5s var(--ease); display:block; }
.gallery-item.tall{ aspect-ratio:4/5; grid-row:span 1; }
.gallery-item.wide{ grid-column:span 2; aspect-ratio:8/5; }
.gallery-item .gallery-illus,.gallery-item img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.gallery-item:hover{ box-shadow:var(--shadow-lg); }
.gallery-item:hover .gallery-illus,.gallery-item:hover img{ transform:scale(1.08); }
.gallery-caption{ position:absolute; inset:auto 0 0 0; z-index:2; padding:46px 20px 18px; color:var(--cream);
  background:linear-gradient(transparent,rgba(11,16,8,.85)); transform:translateY(10px); opacity:.92; transition:transform .5s var(--ease); }
.gallery-item:hover .gallery-caption{ transform:translateY(0); }
.gallery-cat{ display:inline-block; font-size:.7rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--gold-soft); margin-bottom:5px; }
.gallery-title{ font-family:var(--font-serif); font-size:1.18rem; line-height:1.2; }
.gallery-loc{ font-size:.82rem; color:rgba(244,238,226,.7); margin-top:3px; }
.gallery-filter{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:var(--sp-7); }
.filter-btn{ padding:9px 18px; border-radius:100px; border:1px solid var(--line-strong); font-size:.88rem; font-weight:500; color:var(--bark); transition:all .3s; }
.filter-btn.active,.filter-btn:hover{ background:var(--forest); color:var(--cream); border-color:var(--forest); }

/* ---------- 20. Contact / multi-step form ---------------------------- */
.contact-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.contact-card{ background:var(--cream-soft); border:1px solid var(--line); border-radius:var(--radius-lg); padding:32px 28px; text-align:center;
  transition:transform .45s var(--ease), box-shadow .45s var(--ease); }
.contact-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.contact-card.primary{ background:var(--forest); color:var(--cream); }
.contact-card.primary p{ color:rgba(244,238,226,.74); }
.contact-icon{ width:54px; height:54px; border-radius:50%; display:grid; place-items:center; margin:0 auto 18px; background:rgba(124,138,85,.16); color:var(--moss-deep); }
.contact-card.primary .contact-icon{ background:rgba(216,189,131,.18); color:var(--gold-soft); }
.contact-card h3{ font-size:1.2rem; margin-bottom:6px; }
.contact-detail{ font-weight:600; font-size:1.05rem; margin-bottom:10px; }
.contact-card.primary .contact-detail{ color:var(--gold-soft); }
.contact-detail.email{ font-size:.92rem; word-break:break-word; }
.contact-card p{ color:var(--bark); font-size:.92rem; margin-bottom:20px; }

/* process steps */
.process-steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; margin-top:var(--sp-6); }
.process-step{ position:relative; padding-top:18px; }
.step-number{ width:48px; height:48px; border-radius:50%; background:var(--forest); color:var(--gold-soft);
  font-family:var(--font-serif); font-size:1.3rem; display:grid; place-items:center; margin-bottom:16px; }
.process-step h4{ font-family:var(--font-serif); font-size:1.25rem; font-weight:500; margin-bottom:8px; }
.process-step p{ color:var(--bark); font-size:.96rem; }

/* multi-step quote form */
.quote-form-wrap{ max-width:720px; margin:0 auto; background:var(--cream-soft); border:1px solid var(--line);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-md); overflow:hidden; }
.form-progress{ display:flex; align-items:center; gap:0; padding:24px 32px; background:var(--forest); }
.fp-step{ display:flex; align-items:center; flex:1; }
.fp-step:last-child{ flex:0; }
.fp-dot{ width:34px; height:34px; border-radius:50%; flex:none; display:grid; place-items:center; font-size:.85rem; font-weight:600;
  background:rgba(244,238,226,.14); color:rgba(244,238,226,.7); transition:all .4s var(--ease); }
.fp-step.active .fp-dot{ background:var(--ochre); color:#231a0c; }
.fp-step.done .fp-dot{ background:var(--moss); color:#fff; }
.fp-line{ flex:1; height:2px; background:rgba(244,238,226,.14); margin:0 8px; position:relative; overflow:hidden; }
.fp-line::after{ content:""; position:absolute; inset:0; width:0; background:var(--moss); transition:width .5s var(--ease); }
.fp-step.done .fp-line::after{ width:100%; }
.form-progress-label{ padding:0 32px; margin-top:-6px; }

.quote-form{ padding:36px 32px 40px; }
.form-step{ display:none; }
.form-step.active{ display:block; animation:stepIn .5s var(--ease); }
@keyframes stepIn{ from{ opacity:0; transform:translateX(18px); } to{ opacity:1; transform:translateX(0); } }
.form-step h3{ margin-bottom:6px; }
.form-step .step-hint{ color:var(--bark); margin-bottom:24px; font-size:.96rem; }

.option-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.option-grid.cols-3{ grid-template-columns:repeat(3,1fr); }
.option{ position:relative; }
.option input{ position:absolute; opacity:0; inset:0; cursor:pointer; }
.option label{ display:flex; flex-direction:column; gap:4px; padding:18px; border:1.5px solid var(--line-strong); border-radius:var(--radius);
  cursor:pointer; transition:all .3s var(--ease); height:100%; }
.option label .opt-title{ font-weight:600; display:flex; align-items:center; gap:10px; }
.option label .opt-icon{ color:var(--moss-deep); }
.option label .opt-desc{ font-size:.85rem; color:var(--bark-soft); }
.option input:checked + label{ border-color:var(--moss); background:rgba(124,138,85,.08); box-shadow:0 0 0 3px rgba(124,138,85,.14); }
.option input:focus-visible + label{ outline:2px solid var(--ochre); outline-offset:2px; }

.field{ margin-bottom:18px; }
.field label{ display:block; font-weight:600; font-size:.9rem; margin-bottom:7px; }
.field .req{ color:var(--rust); }
.field input,.field select,.field textarea{ width:100%; padding:14px 16px; border:1.5px solid var(--line-strong); border-radius:var(--radius-sm);
  font-family:inherit; font-size:1rem; background:#fff; color:var(--ink); transition:border-color .25s, box-shadow .25s; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--moss); box-shadow:0 0 0 3px rgba(124,138,85,.14); }
.field textarea{ min-height:120px; resize:vertical; }
.field .help{ font-size:.82rem; color:var(--bark-soft); margin-top:6px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field .error-msg{ color:var(--rust); font-size:.82rem; margin-top:6px; display:none; }
.field.invalid input,.field.invalid select{ border-color:var(--rust); }
.field.invalid .error-msg{ display:block; }

.form-nav{ display:flex; justify-content:space-between; gap:14px; margin-top:30px; }
.form-nav .spacer{ flex:1; }
.btn-back{ background:transparent; color:var(--bark); font-weight:600; padding:15px 10px; }
.btn-back:hover{ color:var(--forest); }

.form-summary{ background:rgba(124,138,85,.08); border:1px solid var(--line); border-radius:var(--radius); padding:22px; margin-bottom:22px; }
.form-summary h4{ margin-bottom:12px; }
.summary-row{ display:flex; justify-content:space-between; gap:14px; padding:7px 0; border-bottom:1px dashed var(--line); font-size:.94rem; }
.summary-row:last-child{ border-bottom:none; }
.summary-row .lbl{ color:var(--bark-soft); }
.summary-row .val{ font-weight:600; text-align:right; }

.form-success{ text-align:center; padding:30px 10px; display:none; }
.form-success.show{ display:block; animation:stepIn .5s var(--ease); }
.success-check{ width:72px; height:72px; border-radius:50%; background:var(--moss); color:#fff; display:grid; place-items:center; margin:0 auto 22px; }

/* ---------- 21. Reveal animation base (Motion-driven) ---------------- */
.js [data-reveal]{ opacity:0; }
.js [data-reveal-img]{ opacity:0; }
@media (prefers-reduced-motion: reduce){
  .js [data-reveal],.js [data-reveal-img]{ opacity:1 !important; transform:none !important; }
  .btn::after,.area-pin::after,.wa-bubble::after{ display:none; }
}

/* ---------- 22. Responsive ------------------------------------------- */
@media (max-width:1040px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:34px; }
  .services-grid-lg{ grid-template-columns:1fr; }
}
@media (max-width:900px){
  .nav,.header-phone,.header-cta{ display:none; }
  .nav-toggle{ display:flex; }
  .services-grid,.testimonial-grid,.green-grid,.contact-grid,.process-steps,.related-grid,.gallery-grid{ grid-template-columns:1fr 1fr; }
  .split{ grid-template-columns:1fr; gap:32px; }
  .split.reverse .split-media{ order:0; }
  .split-media{ aspect-ratio:5/4; }
  .gallery-item.wide{ grid-column:span 2; }
  .areas-list{ grid-template-columns:1fr; }
  .mobile-bar{ display:flex; align-items:center; gap:8px; }
  body{ padding-bottom:64px; }
  .wa-widget{ bottom:80px; }
}
@media (max-width:620px){
  body{ font-size:16px; }
  .services-grid,.testimonial-grid,.green-grid,.contact-grid,.process-steps,.related-grid,.gallery-grid,.option-grid,.option-grid.cols-3,.field-row{ grid-template-columns:1fr; }
  .gallery-item.wide{ grid-column:span 1; aspect-ratio:4/3; }
  .service-card-lg{ grid-template-columns:1fr; }
  .service-card-lg .svc-illus{ min-height:180px; }
  .trust-bar-inner{ justify-content:flex-start; gap:14px 26px; }
  .hero-inner{ padding:90px 0 70px; }
  .hero-scroll{ display:none; }
  .quote-form,.form-progress{ padding-left:20px; padding-right:20px; }
  .footer-grid{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; }
}
