/* =========================================================
   CHIMNEY GREEN — Chimney & Garden Services
   Design system & full stylesheet
   Palette: heritage forest green + brass/copper + ivory
   ========================================================= */

*,::before,::after{box-sizing:border-box}
*{margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;overflow-x:hidden}
body{min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,picture,svg,video{display:block;max-width:100%}
button,input,textarea,select{font:inherit;color:inherit}
button{background:none;border:none;cursor:pointer}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

:root{
  /* Brand — pulled from the logo */
  --copper:#B98050;
  --copper-bright:#D49A66;
  --copper-deep:#9C6740;
  --copper-dark:#7A3D21;

  --green:#1D3222;            /* deep heritage green (wordmark) */
  --green-mid:#22381F;        /* chimney body */
  --green-bright:#2E5A38;     /* accent green */
  --green-leaf:#4C7A4E;       /* foliage */

  --ivory:#F3ECE0;           /* logo background cream */
  --stone:#E4DAC9;
  --warm-stone:#D8CCB6;

  /* Dark base — deep forest charcoal, warmer than pure black */
  --bg:#0E1A12;
  --bg-elevated:#13231A;
  --surface:#16291D;
  --surface-2:#1c3325;
  --panel:#102015;

  --border:rgba(185,128,80,0.16);
  --border-strong:rgba(185,128,80,0.34);
  --border-green:rgba(76,122,78,0.20);
  --border-dim:rgba(243,236,224,0.09);

  --text:#E7E0D2;
  --text-bright:#F6F1E7;
  --text-dim:rgba(231,224,210,0.88);
  --text-faint:rgba(231,224,210,0.60);

  --risk-safe:#4C7A4E;
  --risk-warn:#C9A24A;
  --risk-mid:#C9824A;
  --risk-high:#C45A3A;

  --font-display:"Fraunces","Cormorant Garamond",Georgia,serif;
  --font-serif:"Cormorant Garamond",Georgia,serif;
  --font-sans:"Montserrat",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  --max-w:1240px;
  --max-w-narrow:880px;
  --gutter:clamp(20px,4vw,40px);
  --section-y:clamp(76px,9vw,132px);
  --ease:cubic-bezier(0.2,0.7,0.2,1);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
}

body{
  font-family:var(--font-sans);
  font-weight:400;
  font-size:17px;
  line-height:1.65;
  color:var(--text);
  background:var(--bg);
  overflow-x:hidden;
}
/* faint film grain */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;
  opacity:0.035;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
::selection{background:var(--copper);color:var(--green)}

/* ---------- Typography ---------- */
.display,h1,h2,h3{font-family:var(--font-display);font-weight:500;color:var(--text-bright);letter-spacing:-0.01em;line-height:1.08}
h1,.h1{font-size:clamp(38px,5.4vw,68px);line-height:1.02;letter-spacing:-0.02em}
h2,.h2{font-size:clamp(29px,3.8vw,48px);line-height:1.08;letter-spacing:-0.015em}
h3,.h3{font-size:clamp(22px,2.2vw,29px);line-height:1.2}
h4{font-family:var(--font-display);font-weight:500;color:var(--text-bright)}

.eyebrow{
  font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:0.3em;
  text-transform:uppercase;color:var(--copper-bright);display:inline-flex;align-items:center;gap:14px;
}
.eyebrow::before,.eyebrow::after{content:"";width:26px;height:1px;background:var(--copper);opacity:0.65}
.eyebrow--solo::after,.eyebrow--solo::before{display:none}

.lede{font-family:var(--font-serif);font-size:clamp(18px,1.6vw,22px);line-height:1.5;color:var(--text-dim);font-weight:500;font-style:italic}
p{color:var(--text-dim)}
strong,b{color:var(--text-bright);font-weight:600}
em{font-style:italic}

.wrap{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--gutter)}
.wrap--narrow{max-width:var(--max-w-narrow)}

/* ---------- Top bar ---------- */
.topbar{
  background:rgba(8,16,11,0.94);backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid rgba(185,128,80,0.16);
  padding:9px 0;position:fixed;top:0;left:0;right:0;z-index:101;
}
.topbar__inner{display:flex;justify-content:space-between;align-items:center;gap:16px}
.topbar__phone{display:inline-flex;align-items:center;gap:9px;color:var(--copper-bright);
  font-family:var(--font-sans);font-size:13px;font-weight:600;letter-spacing:0.04em;transition:color .3s var(--ease)}
.topbar__phone:hover{color:var(--copper)}
.topbar__phone svg{flex-shrink:0;opacity:0.9}
.topbar__right{display:inline-flex;align-items:center;gap:18px}
.topbar__badge{font-family:var(--font-sans);color:var(--text-dim);font-size:11px;letter-spacing:0.14em;
  text-transform:uppercase;font-weight:500;display:inline-flex;align-items:center;gap:8px}
.topbar__badge svg{width:13px;height:13px;color:var(--copper-bright)}
.topbar__hours{font-family:var(--font-sans);color:rgba(231,224,210,0.8);font-size:11px;
  letter-spacing:0.14em;text-transform:uppercase;font-weight:500}
@media (max-width:680px){
  .topbar{padding:7px 0}.topbar__inner{gap:10px}.topbar__phone{font-size:13px}
  .topbar__hours{font-size:10px;letter-spacing:0.1em}.topbar__badge{display:none}
}
@media (max-width:420px){.topbar__hours{display:none}.topbar__inner{justify-content:center}}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:39px;left:0;right:0;z-index:100;padding:16px 0;
  transition:background .4s var(--ease),border-color .4s var(--ease),padding .4s var(--ease),top .4s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.is-scrolled{
  background:rgba(11,20,14,0.86);backdrop-filter:blur(20px) saturate(140%);
  border-bottom-color:var(--border);padding:11px 0;
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:30px}
.brand{display:flex;align-items:center;gap:13px;flex-shrink:0}
.brand__mark{width:48px;height:48px;flex-shrink:0;object-fit:contain;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,0.35))}
.brand__text{font-family:var(--font-display);font-weight:600;color:var(--text-bright);
  font-size:19px;letter-spacing:0.02em;line-height:1}
.brand__sub{font-family:var(--font-sans);font-size:9.5px;letter-spacing:0.28em;
  color:var(--copper-bright);text-transform:uppercase;margin-top:5px;font-weight:600}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a{font-size:14px;font-weight:500;letter-spacing:0.04em;color:var(--text-dim);
  position:relative;padding:6px 0;transition:color .3s var(--ease)}
.nav__links a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--copper);transform:scaleX(0);transform-origin:left center;transition:transform .3s var(--ease)}
.nav__links a:hover{color:var(--text-bright)}
.nav__links a:hover::after,.nav__links a.is-active::after{transform:scaleX(1)}
.nav__links a.is-active{color:var(--text-bright)}
.nav__cta{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav__toggle{display:none;width:44px;height:44px;align-items:center;justify-content:center;
  border:1px solid var(--border-strong);border-radius:5px}
.nav__toggle span{width:18px;height:1.5px;background:var(--text);position:relative;transition:all .3s var(--ease)}
.nav__toggle span::before,.nav__toggle span::after{content:"";position:absolute;left:0;width:18px;height:1.5px;
  background:var(--text);transition:all .3s var(--ease)}
.nav__toggle span::before{top:-6px}.nav__toggle span::after{top:6px}
.nav__toggle.is-open span{background:transparent}
.nav__toggle.is-open span::before{top:0;transform:rotate(45deg)}
.nav__toggle.is-open span::after{top:0;transform:rotate(-45deg)}
.mobile-menu__cta{display:none}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:15px 28px;
  font-family:var(--font-sans);font-size:13px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;
  border-radius:3px;transition:all .3s var(--ease);position:relative;cursor:pointer;white-space:nowrap}
.btn--primary{background:linear-gradient(135deg,var(--copper-bright),var(--copper));color:#15240e;
  box-shadow:0 1px 0 rgba(255,240,210,0.4) inset,0 0 0 1px var(--copper-deep)}
.btn--primary:hover{transform:translateY(-1px);
  box-shadow:0 1px 0 rgba(255,240,210,0.5) inset,0 0 0 1px var(--copper-bright),0 10px 26px -8px rgba(185,128,80,0.55)}
.btn--green{background:var(--green-bright);color:var(--text-bright);box-shadow:0 0 0 1px rgba(76,122,78,0.5)}
.btn--green:hover{background:#356642;transform:translateY(-1px);box-shadow:0 0 0 1px var(--green-leaf),0 10px 24px -10px rgba(46,90,56,0.6)}
.btn--ghost{background:transparent;color:var(--text-bright);border:1px solid var(--border-strong)}
.btn--ghost:hover{border-color:var(--copper);background:rgba(185,128,80,0.07)}
.btn--whatsapp{background:transparent;color:var(--text-bright);border:1px solid rgba(37,211,102,0.4)}
.btn--whatsapp:hover{border-color:rgb(37,211,102);background:rgba(37,211,102,0.08)}
.btn--sm{padding:10px 18px;font-size:11px}
.btn--lg{padding:18px 34px;font-size:13px}
.btn__arrow{display:inline-block;transition:transform .3s var(--ease)}
.btn:hover .btn__arrow{transform:translateX(4px)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;
  padding:150px 0 100px;overflow:hidden;background:var(--bg)}
.hero__bg{position:absolute;inset:0;z-index:1}
.hero__bg img{width:100%;height:100%;object-fit:cover;opacity:0.42}
.hero__glow{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:radial-gradient(60% 50% at 75% 110%,rgba(220,150,90,0.20),rgba(185,128,80,0.06) 32%,transparent 60%),
             radial-gradient(50% 45% at 15% 10%,rgba(46,90,56,0.22),transparent 60%)}
.hero__vignette{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(14,26,18,0.65) 0%,rgba(14,26,18,0.35) 30%,rgba(14,26,18,0.55) 70%,rgba(14,26,18,0.9) 100%)}
.hero__inner{position:relative;z-index:4;width:100%}
.hero__eyebrow{margin-bottom:24px}
.hero__title{margin-bottom:22px;max-width:940px}
.hero__title em{font-style:italic;color:var(--copper-bright);font-family:var(--font-serif);font-weight:500}
.hero__lede{max-width:560px;margin-bottom:24px}
.hero__trust{display:flex;flex-wrap:wrap;gap:14px 22px;margin:0 0 30px;padding:0;
  font-family:var(--font-sans);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;
  color:rgba(246,241,231,0.9);font-weight:600}
.hero__trust span{display:inline-flex;align-items:center;gap:9px}
.hero__trust-dot{display:inline-block;width:6px;height:6px;background:var(--copper-bright);transform:rotate(45deg);flex-shrink:0}
.hero__cta{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.hero__tagline{margin-top:26px;font-family:var(--font-display);font-size:14px;font-weight:500;
  letter-spacing:0.16em;text-transform:uppercase;color:rgba(185,128,80,0.85);font-style:italic}
.hero__scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:3;
  font-size:10px;letter-spacing:0.3em;color:var(--text-faint);text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:12px}
.hero__scroll-line{width:1px;height:34px;background:linear-gradient(180deg,var(--copper),transparent);
  animation:scrollPulse 2.4s var(--ease) infinite}
@keyframes scrollPulse{0%{transform:scaleY(0);transform-origin:center top}
  45%{transform:scaleY(1);transform-origin:center top}55%{transform:scaleY(1);transform-origin:center bottom}
  100%{transform:scaleY(0);transform-origin:center bottom}}
@media (max-width:680px){.hero{padding:124px 0 80px}.hero__scroll{display:none}}

/* military service ribbon in hero */
.hero__ribbon{display:inline-flex;align-items:center;gap:13px;padding:9px 18px 9px 9px;margin-bottom:26px;
  background:linear-gradient(135deg,rgba(46,90,56,0.22),rgba(46,90,56,0.06));
  border:1px solid rgba(76,122,78,0.4);border-radius:4px}
.hero__ribbon-badge{display:inline-flex;align-items:center;gap:7px;background:var(--green-bright);
  color:var(--text-bright);padding:6px 11px;font-family:var(--font-sans);font-size:10.5px;font-weight:700;
  letter-spacing:0.16em;text-transform:uppercase;border-radius:2px}
.hero__ribbon-badge svg{width:14px;height:14px}
.hero__ribbon-text{font-family:var(--font-sans);font-size:11.5px;letter-spacing:0.1em;text-transform:uppercase;
  color:rgba(246,241,231,0.92);font-weight:600}
@media (max-width:680px){.hero__ribbon-text{font-size:10px}}

/* ---------- Sections ---------- */
.section{padding:var(--section-y) 0;position:relative}
.section--tight{padding:calc(var(--section-y)*0.55) 0}
.section-head{text-align:center;margin-bottom:64px;max-width:740px;margin-left:auto;margin-right:auto}
.section-head .eyebrow{margin-bottom:22px}
.section-head h2{margin-bottom:18px}
.section-head p{color:var(--text-dim)}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.reveal--delay-1{transition-delay:.08s}
.reveal--delay-2{transition-delay:.16s}
.reveal--delay-3{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- Trust strip ---------- */
.trust-strip{border-top:1px solid var(--border-dim);border-bottom:1px solid var(--border-dim);
  background:linear-gradient(180deg,rgba(46,90,56,0.05),transparent)}
.trust-strip__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:34px 0}
.trust__item{display:flex;align-items:center;gap:14px}
.trust__icon{width:38px;height:38px;color:var(--copper-bright);flex-shrink:0}
.trust__label{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-faint);font-weight:600}
.trust__value{font-family:var(--font-display);font-size:17px;color:var(--text-bright);font-weight:500;margin-top:2px}
@media (max-width:880px){.trust-strip__grid{grid-template-columns:repeat(2,1fr);gap:22px 18px}}
@media (max-width:440px){.trust-strip__grid{grid-template-columns:1fr}}

/* ---------- Service cards ---------- */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service-card{background:var(--surface);border:1px solid var(--border-green);border-radius:6px;
  padding:38px 32px;transition:transform .4s var(--ease),border-color .4s var(--ease),background .4s var(--ease);
  position:relative;overflow:hidden}
.service-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--copper),transparent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.service-card:hover{transform:translateY(-4px);border-color:var(--border-strong);background:var(--surface-2)}
.service-card:hover::before{transform:scaleX(1)}
.service-card__icon{width:50px;height:50px;color:var(--copper-bright);margin-bottom:24px}
.service-card__title{font-size:22px;margin-bottom:14px}
.service-card__desc{color:var(--text-dim);margin-bottom:22px;font-size:15.5px;line-height:1.65}
.service-card__list{margin-bottom:26px}
.service-card__list li{font-size:13.5px;color:var(--text-faint);padding:7px 0 7px 22px;position:relative;border-top:1px solid var(--border-dim)}
.service-card__list li:first-child{border-top:none}
.service-card__list li::before{content:"";position:absolute;left:0;top:50%;width:7px;height:7px;
  background:var(--copper);transform:translateY(-50%) rotate(45deg)}
.service-card__link{display:inline-flex;align-items:center;gap:8px;color:var(--copper-bright);
  font-size:12px;letter-spacing:0.14em;text-transform:uppercase;font-weight:600;transition:gap .3s var(--ease)}
.service-card__link svg{width:18px;height:18px;transition:transform .3s var(--ease)}
.service-card__link:hover svg{transform:translateX(4px)}
@media (max-width:880px){.services{grid-template-columns:1fr}}

/* card categories — two service families */
.service-card--garden .service-card__icon{color:var(--green-leaf)}
.service-card--garden::before{background:linear-gradient(90deg,var(--green-leaf),transparent)}

/* ---------- Editorial ---------- */
.editorial{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,84px);align-items:center}
.editorial--reverse .editorial__visual{order:2}
.editorial__visual{position:relative;aspect-ratio:4/5;background:var(--surface);
  border:1px solid var(--border);overflow:hidden;border-radius:4px}
.editorial__visual::after{content:"";position:absolute;inset:14px;border:1px solid var(--border-strong);pointer-events:none;z-index:3;border-radius:2px}
.editorial__visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 28%;z-index:1}
.editorial__visual::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(14,26,18,0.1) 0%,transparent 30%,transparent 65%,rgba(14,26,18,0.55) 100%)}
.editorial__visual-caption{position:absolute;bottom:28px;left:28px;z-index:4;font-family:var(--font-sans);
  font-size:10px;letter-spacing:0.28em;text-transform:uppercase;color:var(--copper-bright);display:flex;align-items:center;gap:10px}
.editorial__visual-caption::before{content:"";width:18px;height:1px;background:var(--copper)}
.editorial__body .eyebrow{margin-bottom:20px}
.editorial__body h2{margin-bottom:20px}
.editorial__body p{margin-bottom:18px;line-height:1.8}
.editorial__body--wide{max-width:760px;margin:0 auto;text-align:center}
/* keep CTAs after a feature-list from crowding the text above */
.editorial__body .feature-list + .btn,.editorial__body .feature-list + a.btn{margin-top:34px}
.feature-list{display:grid;grid-template-columns:1fr 1fr;gap:16px 28px;margin-top:30px;list-style:none;padding:0}
/* inline icon + text items (founder / garden editorials) */
.feature-list__item{display:flex;align-items:center;gap:12px;font-size:14.5px;color:var(--text-dim);
  font-weight:500;line-height:1.4}
.feature-list__item svg{width:20px;height:20px;flex-shrink:0;color:var(--copper-bright);
  padding:3px;border:1px solid rgba(185,128,80,0.35);border-radius:50%;background:rgba(185,128,80,0.08)}
/* legacy h4/p variant (if ever used) */
.feature-list__item h4{font-size:16px;margin-bottom:7px;display:flex;align-items:center;gap:9px}
.feature-list__item h4::before{content:"";width:8px;height:8px;background:var(--copper);transform:rotate(45deg);flex-shrink:0}
.feature-list__item p{font-size:14px;color:var(--text-faint);margin:0;line-height:1.6}
@media (max-width:880px){.editorial{grid-template-columns:1fr;gap:44px}
  .editorial--reverse .editorial__visual{order:0}
  /* taller frame + top-weighted crop so portrait heads are never cut off */
  .editorial__visual{aspect-ratio:4/3;max-height:none}
  .editorial__visual img{object-position:center 18%}
  .feature-list{gap:20px}
  .editorial__body .feature-list + .btn,.editorial__body .feature-list + a.btn{margin-top:30px}}
@media (max-width:480px){.feature-list{grid-template-columns:1fr}
  .editorial__visual{aspect-ratio:3/3.4}}

/* ---------- Service families band ---------- */
.families{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.family{position:relative;border-radius:8px;overflow:hidden;border:1px solid var(--border-green);
  padding:48px 40px;min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;
  transition:transform .4s var(--ease),border-color .4s var(--ease)}
.family:hover{transform:translateY(-4px);border-color:var(--border-strong)}
.family--chimney{background:linear-gradient(180deg,rgba(22,41,29,0.4),rgba(14,26,18,0.95)),
  radial-gradient(120% 90% at 80% 0%,rgba(201,130,74,0.18),transparent 55%);}
.family--garden{background:linear-gradient(180deg,rgba(22,41,29,0.4),rgba(14,26,18,0.95)),
  radial-gradient(120% 90% at 20% 0%,rgba(76,122,78,0.22),transparent 55%);}
.family__icon{width:46px;height:46px;margin-bottom:auto;color:var(--copper-bright)}
.family--garden .family__icon{color:var(--green-leaf)}
.family__eyebrow{font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--copper-bright);font-weight:600;margin-bottom:14px}
.family--garden .family__eyebrow{color:var(--green-leaf)}
.family h3{font-size:27px;margin-bottom:14px}
.family p{color:var(--text-dim);font-size:15px;margin-bottom:24px;max-width:420px}
.family__tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:26px}
.family__tag{font-size:11.5px;letter-spacing:0.08em;color:var(--text-faint);padding:5px 12px;
  border:1px solid var(--border-dim);border-radius:30px}
@media (max-width:880px){.families{grid-template-columns:1fr}.family{min-height:300px;padding:40px 32px}}

/* ---------- Areas ---------- */
.areas{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.areas__map{position:relative;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center}
.areas__map svg{width:100%;height:auto}
.areas__list h2{margin-bottom:22px}.areas__list p{margin-bottom:30px}
.areas__columns{columns:2;column-gap:30px;margin-bottom:30px}
.areas__columns li{padding:9px 0 9px 22px;position:relative;font-size:15px;color:var(--text-dim);
  border-bottom:1px solid var(--border-dim);break-inside:avoid}
.areas__columns li::before{content:"";position:absolute;left:0;top:50%;width:6px;height:6px;
  background:var(--copper);transform:translateY(-50%) rotate(45deg)}
@media (max-width:880px){.areas{grid-template-columns:1fr}.areas__map{max-width:440px;margin:0 auto}}

/* radar map animation */
@keyframes radar-pulse{0%{transform:scale(0.35);opacity:0;stroke-width:1.2}
  10%{opacity:0.55}100%{transform:scale(3);opacity:0;stroke-width:0.3}}
@keyframes radar-sweep{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}
@keyframes radar-blip{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.55;transform:scale(1.2)}}
.radar-ring{transform-origin:200px 200px;animation:radar-pulse 4s var(--ease) infinite}
.radar-ring--2{animation-delay:1.3s}.radar-ring--3{animation-delay:2.6s}
.radar-sweep-arm{transform-origin:200px 200px;animation:radar-sweep 6s linear infinite}
.radar-blip{animation:radar-blip 3s var(--ease) infinite}
@media (prefers-reduced-motion:reduce){.radar-ring,.radar-sweep-arm,.radar-blip{animation:none}}

/* ---------- Safety cards ---------- */
.safety__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.safety-card{background:var(--surface);border:1px solid var(--border-green);border-radius:6px;padding:36px 30px;position:relative}
.safety-card__num{font-family:var(--font-display);font-size:48px;color:rgba(185,128,80,0.22);line-height:1;margin-bottom:14px;font-weight:500}
.safety-card__title{font-size:21px;margin-bottom:14px}
.safety-card__body{font-size:15px;color:var(--text-dim);line-height:1.7}
.safety-card__source{font-size:11px;color:var(--text-faint);margin-top:14px;font-style:italic}
@media (max-width:880px){.safety__grid{grid-template-columns:1fr}}

/* ---------- Why-sweep frequency ---------- */
.whysweep__head{text-align:center;max-width:720px;margin:0 auto 56px}
.whysweep__head h2{margin:18px 0}
.whysweep__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:60px}
.whysweep-card{background:var(--surface);border:1px solid var(--border-green);border-radius:6px;
  padding:30px 24px;display:flex;flex-direction:column;gap:18px;align-items:flex-start}
.whysweep-card__icon{width:44px;height:44px;color:var(--copper-bright)}
.whysweep-card__title{font-family:var(--font-display);font-size:18px;color:var(--text-bright);font-weight:500}
.whysweep-card__freq{font-size:14px;color:var(--text-faint)}
.whysweep-card__freq strong{color:var(--copper-bright)}
.whysweep__divider{display:flex;align-items:center;gap:20px;max-width:400px;margin:0 auto 40px}
.whysweep__divider-line{flex:1;height:1px;background:var(--border-dim)}
.whysweep__divider-text{font-family:var(--font-display);font-style:italic;color:var(--text-faint);font-size:18px}
.whysweep__sub{text-align:center;max-width:560px;margin:0 auto 40px}
.whysweep__sub h3{margin-bottom:10px}
.whysweep__reasons{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:880px;margin:0 auto}
.whysweep-reason{display:flex;gap:18px;background:var(--surface);border:1px solid var(--border-green);border-radius:6px;padding:28px}
.whysweep-reason__icon{width:42px;height:42px;color:var(--copper-bright);flex-shrink:0}
.whysweep-reason__title{font-family:var(--font-display);font-size:17px;color:var(--text-bright);margin-bottom:7px;font-weight:500}
.whysweep-reason__desc{font-size:14px;color:var(--text-dim);line-height:1.6}
@media (max-width:880px){.whysweep__grid{grid-template-columns:1fr 1fr}.whysweep__reasons{grid-template-columns:1fr}}
@media (max-width:480px){.whysweep__grid{grid-template-columns:1fr}}

/* ---------- CTA banner ---------- */
.cta-banner{background:linear-gradient(180deg,var(--bg),var(--panel));position:relative;overflow:hidden}
.cta-banner::before{content:"";position:absolute;inset:0;
  background:radial-gradient(60% 80% at 50% 120%,rgba(201,130,74,0.16),transparent 60%);pointer-events:none}
.cta-banner__inner{text-align:center;position:relative;z-index:1;max-width:720px;margin:0 auto}
.cta-banner__inner .eyebrow{margin-bottom:22px}
.cta-banner__inner h2{margin-bottom:18px}
.cta-banner__inner .lede{margin-bottom:36px}
.cta-banner__buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.divider{display:flex;align-items:center;gap:18px;justify-content:center}
.divider__line{width:60px;height:1px;background:var(--border-strong)}
.divider__diamond{width:9px;height:9px;background:var(--copper);transform:rotate(45deg)}

/* ---------- Seasonal hook ---------- */
.winter-hook__inner{text-align:center;max-width:680px;margin:0 auto}
.winter-hook__eyebrow{font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--copper-bright);margin-bottom:18px}
.winter-hook__title{margin-bottom:18px}
.winter-hook__lede{font-family:var(--font-serif);font-style:italic;font-size:20px;color:var(--text-dim);margin-bottom:24px}
.winter-hook__body{font-size:16px;line-height:1.75;color:var(--text-dim);margin-bottom:16px}
.winter-hook__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:30px}

/* ---------- Pledge / military band ---------- */
.pledge{background:linear-gradient(180deg,var(--panel),var(--bg));position:relative;overflow:hidden}
.pledge::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--copper),transparent);opacity:0.4}
.pledge__inner{max-width:860px;margin:0 auto;text-align:center}
.pledge__chevron{display:inline-flex;gap:5px;margin-bottom:24px;color:var(--copper-bright)}
.pledge__chevron svg{width:22px;height:22px}
.pledge__quote{font-family:var(--font-display);font-size:clamp(24px,3.4vw,38px);line-height:1.3;
  color:var(--text-bright);font-weight:500;font-style:italic;margin-bottom:28px}
.pledge__quote em{color:var(--copper-bright);font-style:italic}
.pledge__attrib{font-size:12px;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-faint);font-weight:600}
.pledge__values{display:flex;justify-content:center;gap:36px;flex-wrap:wrap;margin-top:44px}
.pledge__value{display:flex;flex-direction:column;align-items:center;gap:8px}
.pledge__value-num{font-family:var(--font-display);font-size:34px;color:var(--copper-bright);font-weight:500}
.pledge__value-label{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-faint);font-weight:600}
@media (max-width:600px){.pledge__values{gap:26px}}

/* ---------- Page head ---------- */
.page-head{position:relative;padding:190px 0 84px;background:var(--bg);overflow:hidden;border-bottom:1px solid var(--border)}
.page-head__glow{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(60% 60% at 50% 120%,rgba(201,130,74,0.14),transparent 60%),
             radial-gradient(50% 60% at 0% 0%,rgba(46,90,56,0.16),transparent 60%)}
.page-head__inner{position:relative;z-index:2;text-align:center}
.page-head .eyebrow{margin-bottom:22px}
.page-head h1{margin-bottom:18px}
.page-head p{max-width:620px;margin:0 auto;color:var(--text-dim)}
.page-head__cta{margin-top:30px;display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
@media (max-width:680px){.page-head{padding:128px 0 56px}
  .page-head__cta{flex-direction:column;width:100%}.page-head__cta .btn{width:100%}}

/* breadcrumb */
.breadcrumb-inline{display:flex;justify-content:center;margin-bottom:22px}
.breadcrumb__list{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;font-family:var(--font-sans);
  font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-faint)}
.breadcrumb__list li{display:inline-flex;align-items:center}
.breadcrumb__list li+li::before{content:"›";margin-right:10px;color:rgba(185,128,80,0.5);font-size:14px}
.breadcrumb__list a{color:rgba(231,224,210,0.8);transition:color .3s var(--ease)}
.breadcrumb__list a:hover{color:var(--copper-bright)}
.breadcrumb__list [aria-current="page"]{color:var(--copper-bright)}

/* ---------- Prices ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.price-card{background:var(--surface);border:1px solid var(--border-green);border-radius:8px;
  padding:38px 32px;display:flex;flex-direction:column;position:relative;transition:transform .4s var(--ease),border-color .4s var(--ease)}
.price-card:hover{transform:translateY(-4px);border-color:var(--border-strong)}
.price-card--featured{border-color:var(--border-strong);background:linear-gradient(180deg,rgba(185,128,80,0.06),var(--surface))}
.price-card__flag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--copper);
  color:#15240e;font-size:10px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;padding:6px 16px;border-radius:30px}
.price-card__name{font-family:var(--font-display);font-size:22px;color:var(--text-bright);margin-bottom:8px;font-weight:500}
.price-card__desc{font-size:14px;color:var(--text-faint);margin-bottom:24px;min-height:42px}
.price-card__price{display:flex;align-items:baseline;gap:6px;margin-bottom:6px}
.price-card__from{font-size:12px;color:var(--text-faint);text-transform:uppercase;letter-spacing:0.14em}
.price-card__amount{font-family:var(--font-display);font-size:48px;color:var(--copper-bright);font-weight:500;line-height:1}
.price-card__unit{font-size:14px;color:var(--text-faint)}
.price-card__list{margin:26px 0 30px;flex:1}
.price-card__list li{font-size:14px;color:var(--text-dim);padding:10px 0 10px 26px;position:relative;border-top:1px solid var(--border-dim)}
.price-card__list li:first-child{border-top:none}
.price-card__list li::before{content:"";position:absolute;left:0;top:14px;width:14px;height:8px;
  border-left:2px solid var(--copper);border-bottom:2px solid var(--copper);transform:rotate(-45deg)}
@media (max-width:880px){.price-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}}

.price-note{max-width:760px;margin:48px auto 0;padding:24px 28px;
  background:linear-gradient(180deg,rgba(185,128,80,0.05),transparent);
  border:1px solid var(--border);border-left:3px solid var(--copper);border-radius:4px}
.price-note__label{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--copper-bright);font-weight:600;margin-bottom:12px}
.price-note p{font-family:var(--font-serif);font-size:17px;line-height:1.55;color:var(--text-dim);margin:0}

/* ---------- FAQ ---------- */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-top:1px solid var(--border-dim)}
.faq-item:last-child{border-bottom:1px solid var(--border-dim)}
.faq-item__q{width:100%;text-align:left;padding:28px 0;display:flex;align-items:center;justify-content:space-between;gap:24px;
  font-family:var(--font-display);font-size:19px;font-weight:500;color:var(--text-bright);transition:color .3s var(--ease)}
.faq-item__q:hover{color:var(--copper-bright)}
.faq-item__icon{width:22px;height:22px;flex-shrink:0;position:relative}
.faq-item__icon::before,.faq-item__icon::after{content:"";position:absolute;background:var(--copper);transition:transform .3s var(--ease)}
.faq-item__icon::before{top:50%;left:0;width:100%;height:1.5px;transform:translateY(-50%)}
.faq-item__icon::after{left:50%;top:0;width:1.5px;height:100%;transform:translateX(-50%)}
.faq-item.is-open .faq-item__icon::after{transform:translateX(-50%) scaleY(0)}
.faq-item__a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.faq-item.is-open .faq-item__a{max-height:600px}
.faq-item__a-inner{padding:0 0 30px;font-size:15.5px;line-height:1.8;color:var(--text-dim);max-width:700px}

/* ---------- Reviews ---------- */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review-card{background:var(--surface);border:1px solid var(--border-green);border-radius:6px;padding:32px 28px;display:flex;flex-direction:column;gap:16px}
.review-card__stars{display:flex;gap:3px;color:var(--copper-bright)}
.review-card__stars svg{width:18px;height:18px}
.review-card__body{font-family:var(--font-serif);font-size:18px;line-height:1.6;color:var(--text-dim);font-style:italic;flex:1}
.review-card__author{display:flex;align-items:center;gap:12px;border-top:1px solid var(--border-dim);padding-top:16px}
.review-card__avatar{width:40px;height:40px;border-radius:50%;background:var(--green-bright);display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);color:var(--text-bright);font-size:16px;font-weight:500;flex-shrink:0}
.review-card__name{font-size:14px;color:var(--text-bright);font-weight:600}
.review-card__meta{font-size:11px;color:var(--text-faint);letter-spacing:0.08em}
@media (max-width:880px){.reviews-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}}

.reviews-placeholder{max-width:680px;margin:0 auto;text-align:center;padding:40px 20px}
.reviews-placeholder__icon{width:58px;height:58px;margin:0 auto 28px;color:var(--copper-bright);opacity:0.75}
.reviews-placeholder__title{font-family:var(--font-display);font-size:clamp(26px,3.4vw,36px);color:var(--text-bright);margin-bottom:24px;font-weight:500}
.reviews-placeholder__body{font-family:var(--font-serif);font-size:18px;line-height:1.65;color:var(--text-dim);margin-bottom:16px;font-style:italic}

/* ---------- Process steps ---------- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:step}
.process-step{position:relative;padding-top:20px}
.process-step__num{font-family:var(--font-display);font-size:14px;letter-spacing:0.1em;color:var(--copper-bright);font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.process-step__num::before{content:"";width:30px;height:30px;border:1px solid var(--border-strong);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--copper-bright);counter-increment:step;content:counter(step,decimal-leading-zero)}
.process-step h3{font-size:18px;margin-bottom:10px}
.process-step p{font-size:14px;color:var(--text-dim);line-height:1.65}
@media (max-width:880px){.process{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.process{grid-template-columns:1fr}}

/* ---------- Service detail blocks ---------- */
.svc-detail{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center;padding:clamp(60px,7vw,90px) 0;border-bottom:1px solid var(--border-dim)}
.svc-detail:nth-child(even) .svc-detail__visual{order:2}
.svc-detail__visual{aspect-ratio:4/3;border-radius:6px;overflow:hidden;border:1px solid var(--border);position:relative}
.svc-detail__visual img{width:100%;height:100%;object-fit:cover}
.svc-detail__icon{width:48px;height:48px;color:var(--copper-bright);margin-bottom:20px}
.svc-detail h2{margin-bottom:18px}
.svc-detail p{margin-bottom:16px;line-height:1.8}
.svc-detail__list{margin:24px 0}
.svc-detail__list li{padding:10px 0 10px 28px;position:relative;font-size:15px;color:var(--text-dim);border-top:1px solid var(--border-dim)}
.svc-detail__list li::before{content:"";position:absolute;left:0;top:15px;width:14px;height:8px;border-left:2px solid var(--copper);border-bottom:2px solid var(--copper);transform:rotate(-45deg)}
@media (max-width:880px){.svc-detail{grid-template-columns:1fr;gap:40px}.svc-detail:nth-child(even) .svc-detail__visual{order:0}}

/* ---------- Article ---------- */
.article{padding:56px 0 80px}
.article__container{max-width:760px;margin:0 auto;padding:0 var(--gutter)}
.article__meta{display:flex;gap:14px;align-items:center;font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--copper-bright);margin-bottom:22px}
.article__meta span:nth-child(n+2){color:var(--text-faint)}
.article__title{font-size:clamp(32px,5vw,52px);line-height:1.08;margin-bottom:22px}
.article__deck{font-family:var(--font-serif);font-size:clamp(19px,1.9vw,23px);font-style:italic;line-height:1.5;
  color:var(--text-dim);margin-bottom:46px;padding-bottom:30px;border-bottom:1px solid var(--border)}
.article__body h2{font-size:clamp(24px,3vw,32px);margin:44px 0 18px}
.article__body h3{font-size:22px;margin:32px 0 14px}
.article__body p{margin-bottom:20px;line-height:1.85;font-size:17px}
.article__body ul,.article__body ol{margin:0 0 24px;padding-left:0}
.article__body li{position:relative;padding:6px 0 6px 28px;line-height:1.7;color:var(--text-dim)}
.article__body ul li::before{content:"";position:absolute;left:0;top:14px;width:7px;height:7px;background:var(--copper);transform:rotate(45deg)}
.article__body ol{counter-reset:n}
.article__body ol li{counter-increment:n}
.article__body ol li::before{content:counter(n);position:absolute;left:0;top:6px;color:var(--copper-bright);font-family:var(--font-display);font-weight:600}
.article__body blockquote{border-left:3px solid var(--copper);padding:6px 0 6px 26px;margin:28px 0;
  font-family:var(--font-serif);font-style:italic;font-size:20px;color:var(--text-bright)}
.article__body a{color:var(--copper-bright);text-decoration:underline;text-underline-offset:3px}
.article__callout{background:var(--surface);border:1px solid var(--border-green);border-left:3px solid var(--copper);
  border-radius:4px;padding:26px 28px;margin:32px 0}
.article__callout h4{font-size:17px;margin-bottom:10px;color:var(--copper-bright)}
.article__callout p{font-size:15px;margin-bottom:0;color:var(--text-dim)}

/* blog cards */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.blog-card{background:var(--surface);border:1px solid var(--border-green);border-radius:6px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .4s var(--ease),border-color .4s var(--ease)}
.blog-card:hover{transform:translateY(-4px);border-color:var(--border-strong)}
.blog-card__meta{display:flex;gap:14px;align-items:center;font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--copper-bright);padding:24px 26px 10px}
.blog-card__meta span:nth-child(2){color:var(--text-faint)}
.blog-card__title{font-family:var(--font-display);font-size:21px;color:var(--text-bright);padding:0 26px 14px;font-weight:500;line-height:1.25}
.blog-card__excerpt{font-size:14.5px;color:var(--text-dim);padding:0 26px 24px;line-height:1.65;flex:1}
.blog-card__link{padding:0 26px 26px;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--copper-bright);font-weight:600;display:inline-flex;align-items:center;gap:8px}
@media (max-width:880px){.blog-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}}

/* ---------- Booking form ---------- */
.booking{max-width:720px;margin:0 auto}
.booking__progress{display:flex;justify-content:space-between;margin-bottom:42px;position:relative}
.booking__progress::before{content:"";position:absolute;top:16px;left:0;right:0;height:1px;background:var(--border-dim);z-index:0}
.booking__progress-step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:10px;flex:1}
.booking__progress-dot{width:34px;height:34px;border-radius:50%;background:var(--surface);border:1px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:14px;color:var(--text-faint);transition:all .3s var(--ease)}
.booking__progress-step.is-active .booking__progress-dot{background:var(--copper);color:#15240e;border-color:var(--copper)}
.booking__progress-step.is-done .booking__progress-dot{background:var(--green-bright);color:var(--text-bright);border-color:var(--green-bright)}
.booking__progress-label{font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-faint);font-weight:600;text-align:center}
.booking__progress-step.is-active .booking__progress-label{color:var(--copper-bright)}
.booking__step{display:none;animation:stepIn .5s var(--ease)}
.booking__step.is-active{display:block}
@keyframes stepIn{0%{opacity:0;transform:translateY(8px)}100%{opacity:1;transform:translateY(0)}}
.booking__step h3{font-size:24px;margin-bottom:8px}
.booking__step-sub{font-size:14px;color:var(--text-faint);margin-bottom:28px}
.field{margin-bottom:20px}
.field label{display:block;font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-faint);font-weight:600;margin-bottom:9px}
.field input,.field select,.field textarea{width:100%;padding:15px 16px;background:var(--panel);border:1px solid var(--border-strong);
  border-radius:4px;color:var(--text-bright);font-size:15px;transition:border-color .3s var(--ease)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--copper)}
.field textarea{resize:vertical;min-height:110px}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.choice{position:relative}
.choice input{position:absolute;opacity:0;pointer-events:none}
.choice label{display:flex;align-items:center;gap:12px;padding:16px;background:var(--panel);border:1px solid var(--border-strong);
  border-radius:4px;cursor:pointer;transition:all .3s var(--ease);text-transform:none;letter-spacing:0;font-size:14px;color:var(--text-dim);margin:0}
.choice label:hover{border-color:var(--copper)}
.choice input:checked+label{border-color:var(--copper);background:rgba(185,128,80,0.08);color:var(--text-bright)}
.choice__icon{width:24px;height:24px;color:var(--copper-bright);flex-shrink:0}
.booking__nav{display:flex;justify-content:space-between;gap:14px;margin-top:32px}
.booking__error{display:none;background:rgba(196,90,58,0.12);border:1px solid rgba(196,90,58,0.4);border-radius:4px;
  padding:16px 18px;margin-bottom:20px;font-size:14px;color:#e8a08a}
.booking__error.is-visible{display:block}
.booking__success{text-align:center;padding:40px 20px}
.booking__success-icon{width:60px;height:60px;margin:0 auto 24px;color:var(--green-leaf)}
.booking__success h3{font-size:28px;margin-bottom:14px}
[data-submit].is-loading{opacity:0.7;pointer-events:none}
@media (max-width:560px){.field--row,.choice-grid{grid-template-columns:1fr}}

.book-trust{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:0 0 44px;padding:24px;
  background:linear-gradient(180deg,rgba(185,128,80,0.05),transparent);border:1px solid var(--border);border-top:2px solid var(--border-strong);border-radius:4px}
.book-trust__item{display:flex;gap:12px;align-items:flex-start}
.book-trust__item svg{width:22px;height:22px;color:var(--copper-bright);flex-shrink:0;margin-top:2px}
.book-trust__item strong{font-family:var(--font-display);font-size:13px;color:var(--text-bright);display:block;margin-bottom:2px;font-weight:500}
.book-trust__item span{font-size:11px;color:var(--text-faint);line-height:1.4}
@media (max-width:880px){.book-trust{grid-template-columns:repeat(2,1fr);gap:18px 14px}}
@media (max-width:480px){.book-trust{grid-template-columns:1fr}}

/* ---------- Footer ---------- */
.site-footer{background:var(--panel);border-top:1px solid var(--border);padding:72px 0 36px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:52px}
.footer__brand .brand{margin-bottom:20px}
.footer__about{font-size:14px;color:var(--text-faint);line-height:1.7;max-width:320px;margin-bottom:22px}
.footer__social{display:flex;gap:12px}
.footer__social a{width:38px;height:38px;border:1px solid var(--border-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:var(--text-dim);transition:all .3s var(--ease)}
.footer__social a:hover{border-color:var(--copper);color:var(--copper-bright)}
.footer__social svg{width:18px;height:18px}
.footer__col h5{font-family:var(--font-sans);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--copper-bright);font-weight:600;margin-bottom:18px}
.footer__col ul li{margin-bottom:11px}
.footer__col ul a{font-size:14px;color:var(--text-faint);transition:color .3s var(--ease)}
.footer__col ul a:hover{color:var(--text-bright)}
.footer__col p{font-size:14px;color:var(--text-faint);margin-bottom:6px}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:18px;padding-top:30px;border-top:1px solid var(--border-dim);flex-wrap:wrap}
.footer__bottom p{font-size:12.5px;color:var(--text-faint)}
.footer__legal{display:flex;gap:22px}
.footer__legal a{font-size:12.5px;color:var(--text-faint);transition:color .3s var(--ease)}
.footer__legal a:hover{color:var(--copper-bright)}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:480px){.footer-grid{grid-template-columns:1fr}.footer__bottom{flex-direction:column;text-align:center}}

/* ---------- Mobile menu ---------- */
.mobile-menu{position:fixed;inset:0;background:rgba(11,20,14,0.98);backdrop-filter:blur(20px);z-index:99;
  padding:120px var(--gutter) 40px;transform:translateY(-100%);visibility:hidden;pointer-events:none;
  transition:transform .5s var(--ease-out),visibility 0s .5s;display:flex;flex-direction:column}
.mobile-menu.is-open{transform:translateY(0);visibility:visible;pointer-events:auto;transition:transform .5s var(--ease-out)}
.mobile-menu nav{display:flex;flex-direction:column;gap:4px}
.mobile-menu a{font-family:var(--font-display);font-size:26px;color:var(--text-bright);padding:14px 0;border-bottom:1px solid var(--border-dim);font-weight:500}
.mobile-menu a.mobile-menu__cta{margin-top:24px;border:none;color:var(--copper-bright)}
@media (max-width:980px){.nav__links{display:none}.nav__cta .btn--whatsapp{display:none}.nav__toggle{display:flex}.mobile-menu__cta{display:block}}
@media (max-width:680px){.nav__cta .btn--primary{display:none}.brand__mark{width:42px;height:42px}.brand__text{font-size:17px}.brand__sub{font-size:9px}}

/* ---------- Area coverage strip ---------- */
.area-coverage{padding:44px 0;background:linear-gradient(180deg,rgba(46,90,56,0.04),transparent);border-bottom:1px solid var(--border-dim)}
.area-coverage__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;align-items:start}
.area-coverage__big{font-family:var(--font-display);font-size:26px;color:var(--text-bright);margin-bottom:8px;font-weight:500}
.area-coverage__item .eyebrow{margin-bottom:14px}
.postcode-chips{display:flex;flex-wrap:wrap;gap:8px}
.postcode-chip{padding:6px 12px;background:rgba(185,128,80,0.08);border:1px solid var(--border-strong);
  color:var(--copper-bright);font-size:12px;font-weight:600;letter-spacing:0.08em;border-radius:30px}
@media (max-width:880px){.area-coverage__grid{grid-template-columns:1fr;gap:30px}}

/* misc */
.center{text-align:center}
.mt-40{margin-top:40px}
.section-alt{background:var(--bg-elevated)}
.text-link{color:var(--copper-bright);text-decoration:underline;text-underline-offset:3px}
.badge-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:30px}
.badge-pill{display:inline-flex;align-items:center;gap:9px;padding:9px 16px;background:var(--surface);
  border:1px solid var(--border-green);border-radius:30px;font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-dim);font-weight:600}
.badge-pill svg{width:15px;height:15px;color:var(--copper-bright)}

/* ============================================================
   MOODFUL IMAGE BACKGROUNDS (added in imagery pass)
   ============================================================ */

/* A section that sits on a full-bleed photo with a dark, brand-tinted overlay
   so foreground text stays crisp. Usage:
   <section class="section bg-section">
     <div class="bg-section__img" style="background-image:url(...)"></div>
     <div class="wrap"> ...content... </div>
   </section>
*/
.bg-section{position:relative;overflow:hidden;isolation:isolate}
.bg-section > .wrap,.bg-section > .article__container{position:relative;z-index:2}
.bg-section__img{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;
  transform:scale(1.02)}
.bg-section__img::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(8,16,11,0.78),rgba(8,16,11,0.86) 55%,rgba(8,16,11,0.94));}
/* lighter overlay variant when content sits in a column (text on one side) */
.bg-section--side .bg-section__img::after{
  background:linear-gradient(90deg,rgba(8,16,11,0.92) 0%,rgba(8,16,11,0.78) 42%,rgba(8,16,11,0.45) 100%);}
.bg-section--right .bg-section__img::after{
  background:linear-gradient(270deg,rgba(8,16,11,0.92) 0%,rgba(8,16,11,0.78) 42%,rgba(8,16,11,0.5) 100%);}
/* subtle ember grain compatibility: keep film-grain above */
.bg-section__img{filter:saturate(1.05)}

/* Page-head sitting on a photo */
.page-head.bg-section{padding-top:calc(var(--section-y) + 60px)}
.page-head.bg-section .page-head__glow{opacity:.5}

/* CTA banner / pledge on photo: stronger center darkening for centered text */
.bg-section--center .bg-section__img::after{
  background:radial-gradient(ellipse at center,rgba(8,16,11,0.72),rgba(8,16,11,0.9) 70%);}

/* A slim full-bleed cinematic divider band with a line of text */
.moodband{position:relative;min-height:340px;display:flex;align-items:center;overflow:hidden;isolation:isolate}
.moodband__img{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center}
.moodband__img::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(8,16,11,0.55),rgba(8,16,11,0.78))}
.moodband__inner{position:relative;z-index:2;text-align:center;max-width:760px;margin:0 auto;padding:60px 0}
.moodband__eyebrow{font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:0.26em;
  text-transform:uppercase;color:var(--copper-bright);margin-bottom:20px}
.moodband__title{font-family:var(--font-display);font-weight:500;color:var(--text-bright);
  font-size:clamp(28px,4.4vw,46px);line-height:1.08;margin-bottom:18px}
.moodband__title em{font-style:italic;color:var(--copper-bright)}
.moodband__text{font-family:var(--font-serif);font-size:clamp(17px,2vw,21px);font-style:italic;
  color:var(--text-dim);line-height:1.5}
@media (max-width:640px){.moodband{min-height:280px}}

/* Hero: make the photo read richer than the old 0.42 stove crop */
.hero--photo .hero__bg img{opacity:0.58}
.hero--photo .hero__vignette{background:
  radial-gradient(ellipse 120% 90% at 30% 40%,transparent 0%,rgba(8,16,11,0.55) 70%,rgba(8,16,11,0.9) 100%),
  linear-gradient(180deg,rgba(8,16,11,0.5) 0%,transparent 22%,transparent 55%,rgba(8,16,11,0.85) 100%)}
.hero--photo .hero__glow{background:radial-gradient(circle at 78% 62%,rgba(212,154,102,0.16),transparent 45%)}

/* tools / family backgrounds upgraded to real photos */
.family--chimney.family--photo{background:
  linear-gradient(180deg,rgba(14,26,18,0.62),rgba(14,26,18,0.93)),var(--_img) center/cover}
.family--garden.family--photo{background:
  linear-gradient(180deg,rgba(14,26,18,0.62),rgba(14,26,18,0.93)),var(--_img) center/cover}

/* ============================================================
   FLYING EMBERS / FLUE GLIMMER (added: modern eye-catching layer)
   ============================================================ */
.embers{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.ember{position:absolute;bottom:-12px;width:5px;height:5px;border-radius:50%;
  background:radial-gradient(circle,#F2C28A,var(--copper-bright) 45%,rgba(212,154,102,0.25) 65%,transparent 72%);
  opacity:0;will-change:transform,opacity;
  animation:ember-rise var(--dur,9s) linear infinite;animation-delay:var(--delay,0s);
  filter:drop-shadow(0 0 6px rgba(226,168,110,0.85))}
.ember--sm{width:3px;height:3px}
.ember--lg{width:7px;height:7px;filter:drop-shadow(0 0 9px rgba(226,168,110,0.95))}
@keyframes ember-rise{
  0%{opacity:0;transform:translateY(0) translateX(0) scale(0.5)}
  8%{opacity:1}
  45%{opacity:0.95}
  75%{opacity:0.65}
  100%{opacity:0;transform:translateY(var(--rise,-440px)) translateX(var(--drift,30px)) scale(1.1)}}
@media (prefers-reduced-motion:reduce){.ember{animation:none;opacity:0}}

/* Hero gets a warm living ember layer over the photo */
.hero .embers{z-index:2}
/* embers over moodbands / bg-sections sit above the photo, below text */
.moodband .embers,.bg-section .embers{z-index:1}

/* ============================================================
   SUFFOLK COASTAL RADAR (areas)
   ============================================================ */
.radarmap{position:relative;max-width:560px;margin:0 auto;width:100%}
.radarmap svg{width:100%;height:auto;display:block;overflow:visible}
.radarmap__label text{font-family:var(--font-sans);font-weight:600;fill:var(--text-bright);
  paint-order:stroke;stroke:rgba(8,16,11,0.85);stroke-width:3px;stroke-linejoin:round}
.radarmap__town{font-size:12px}
.radarmap__town--major{font-size:14px;fill:var(--copper-bright)}
.radarmap__dot{fill:var(--copper-bright)}
.radarmap__dot--major{fill:var(--copper-bright)}
.radarmap__blip{animation:none;opacity:1}
/* each town dot gets a brief glow ping as the beam passes (synced to 7s sweep) */
.radarmap__ping{transform-origin:center;transform-box:fill-box;opacity:0;
  animation:radar-ping 7s linear infinite}
@keyframes radar-ping{
  0%{opacity:0;transform:scale(0.6)}
  3%{opacity:0.9;transform:scale(1)}
  14%{opacity:0;transform:scale(2.4)}
  100%{opacity:0;transform:scale(2.4)}}
.radarmap__coast{fill:none;stroke:rgba(118,160,180,0.5);stroke-width:1.4;stroke-dasharray:4 4}
.radarmap__region{fill:rgba(46,90,56,0.10);stroke:rgba(76,122,78,0.45);stroke-width:1.2}
.radarmap__sea{fill:rgba(40,70,90,0.16)}
.radarmap__grid{stroke:rgba(185,128,80,0.16);stroke-width:0.7}
.radarmap__ring{transform-origin:center;animation:radar-pulse 4.5s var(--ease) infinite;
  fill:none;stroke:rgba(185,128,80,0.5)}
.radarmap__sweep{transform-origin:var(--cx) var(--cy);animation:radar-sweep 7s linear infinite}
@media (prefers-reduced-motion:reduce){.radarmap__ring,.radarmap__sweep,.radarmap__blip{animation:none}}

/* area town pill list under the radar */
.area-towns{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.area-town{padding:7px 14px;background:rgba(185,128,80,0.07);border:1px solid var(--border-strong);
  color:var(--text-dim);font-size:13px;font-weight:500;border-radius:30px;transition:all .3s var(--ease)}
.area-town:hover{border-color:var(--copper);color:var(--copper-bright)}
.area-town--major{background:rgba(185,128,80,0.13);color:var(--copper-bright);font-weight:600}

/* ============================================================
   UK FLAG ACCENTS (slow waving Union Jack)
   ============================================================ */
.ukflag{display:inline-block;line-height:0;position:relative}
.ukflag__svg{display:block;width:100%;height:auto;border-radius:2px}
/* small flag inside the ex-forces ribbon */
.hero__ribbon .ukflag{width:30px;flex:0 0 auto;border-radius:2px;overflow:hidden;
  box-shadow:0 1px 4px rgba(0,0,0,0.4)}
/* gentle overall sway on top of the cloth ripple */
@keyframes flag-sway{0%,100%{transform:rotate(-1deg)}50%{transform:rotate(1.2deg)}}
.ukflag--sway{animation:flag-sway 6s ease-in-out infinite;transform-origin:left center}
@media (prefers-reduced-motion:reduce){.ukflag--sway{animation:none}}

/* large atmospheric flag in the pledge band */
.pledge__flag{position:absolute;top:50%;right:6%;transform:translateY(-50%);
  width:min(280px,26vw);opacity:0.16;pointer-events:none;z-index:0;
  filter:saturate(0.9) drop-shadow(0 10px 30px rgba(0,0,0,0.5))}
.pledge__flag .ukflag__svg{border-radius:4px}
.pledge .wrap{position:relative;z-index:1}
@media (max-width:880px){
  /* on mobile: large faint centred flag backdrop behind the values, never cut off */
  .pledge__flag{display:block;right:auto;left:50%;top:auto;bottom:5%;
    transform:translateX(-50%);width:min(360px,74vw);opacity:0.1}
}

/* atmospheric flag layer for moodbands / sections (big, faint, drifting) */
.flag-mood{position:absolute;z-index:1;pointer-events:none;opacity:0.12;
  width:min(420px,50vw);filter:saturate(0.85) drop-shadow(0 12px 36px rgba(0,0,0,0.55))}
.flag-mood--right{right:-4%;top:50%;transform:translateY(-50%)}
.flag-mood--left{left:-6%;bottom:-8%}
.moodband .moodband__inner{position:relative;z-index:2}
@media (max-width:880px){
  .flag-mood{opacity:0.14;width:min(320px,70vw)}
  .flag-mood--right{right:-14%;top:6%;transform:none}
  .flag-mood--left{left:-16%;top:auto;bottom:-4%}
}

/* flag on a pole accent (optional, for moodbands) */
.flagpole{position:absolute;z-index:1;width:120px;pointer-events:none;opacity:0.9}
