
:root{
  --bg:#f6f3ed; --paper:#fff; --ink:#1e271f; --muted:#57625b; --line:#d8d3c7;
  --brand:#2f5b3a; --brand-2:#24452c; --pill:#edf4ef; --shadow:0 10px 26px rgba(0,0,0,.08);
  --radius:16px; --radius-sm:12px; --max:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font:16px/1.55 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink)}
a{color:var(--brand)}
img{max-width:100%;display:block}
.container{width:min(var(--max), calc(100% - 2rem)); margin-inline:auto}
.small{font-size:.92rem;color:var(--muted)}
.lede{color:var(--muted);font-size:1.02rem}
.h1{font-size:clamp(1.65rem,2.2vw + 1rem,2.6rem); line-height:1.15; margin:.2rem 0 .75rem; font-weight:700}
.h2{font-size:1.3rem; line-height:1.2; margin:0 0 .4rem}
.section{padding:1.2rem 0 2rem}
.card{background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:1rem}
.notice{background:#f3f8f4;border:1px solid #d4e5d9;border-radius:12px;padding:.8rem;color:#33413a}
.stack>*+*{margin-top:.8rem}
.grid{display:grid;gap:1rem}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:900px){.grid-2{grid-template-columns:1fr}}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;border:1px solid var(--line);padding:.72rem .95rem;border-radius:999px;background:#fff;color:var(--ink);text-decoration:none;font-weight:600;cursor:pointer}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--brand);border-color:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-2)}
.btn-whatsapp{background:#eaf8ef;border-color:#bfdcc7;color:#1b5e30}
.btn-ghost{background:transparent}
.actions-row{display:flex;flex-wrap:wrap;gap:.7rem}
/* Header */
.header{position:sticky;top:0;z-index:1000;background:rgba(246,243,237,.95);backdrop-filter:blur(8px);border-bottom:1px solid rgba(0,0,0,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.65rem 0}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:inherit;min-width:0}
.brand-logo{width:42px;height:42px;border-radius:10px;object-fit:cover;background:#fff;border:1px solid var(--line)}
.brand-title{display:flex;flex-direction:column;line-height:1}
.brand-title strong{font-size:1rem}.brand-title span{font-size:.78rem;color:var(--muted)}
.nav-links{display:flex;align-items:center;gap:1rem}
.nav-links a{text-decoration:none;color:var(--ink);font-weight:600}
.nav-links a[aria-current="page"]{color:var(--brand)}
.nav-cta{display:flex;align-items:center;gap:.55rem}
.mobile-toggle{display:none}
.mobile-menu{display:none;border-top:1px solid rgba(0,0,0,.06);background:var(--paper)}
.mobile-menu a{display:block;padding:.9rem 1rem;border-bottom:1px solid rgba(0,0,0,.05);text-decoration:none;color:var(--ink);font-weight:600}
@media (max-width: 980px){
  .nav-links,.nav-cta .btn:not(.mobile-nav-quote){display:none}
  .mobile-toggle{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);background:#fff;border-radius:999px;padding:.65rem .9rem;font-weight:600;cursor:pointer}
  .mobile-menu.open{display:block}
}
/* Utility strip */
.top-strip{background:var(--brand);color:#fff}
.top-strip .strip-inner{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center;justify-content:space-between;padding:.55rem 0}
.top-strip .strip-items{display:flex;flex-wrap:wrap;gap:.7rem 1rem;align-items:center}
.top-strip .pill{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);padding:.32rem .62rem;border-radius:999px;font-weight:600;font-size:.92rem}
.top-strip a{color:#fff;text-decoration:none}
/* Hero */
.hero{padding:1rem 0 .6rem}
.hero-shell{display:grid;grid-template-columns:1.05fr .95fr;gap:1rem;align-items:stretch}
.hero-panel{background:var(--paper);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:1rem}
.hero-image-wrap{background:linear-gradient(#f8f8f5,#eff2ea);border:1px solid var(--line);border-radius:18px;padding:1rem;display:grid;place-items:center;min-height:340px}
.hero-image-wrap img{max-height:320px;object-fit:contain}
.kicker{display:inline-block;padding:.25rem .6rem;border-radius:999px;background:var(--pill);color:var(--brand);font-size:.82rem;font-weight:700;border:1px solid #dbe9df}
.trust-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.trust-pill{padding:.35rem .6rem;border-radius:999px;border:1px solid var(--line);background:#fbfbf8;font-size:.88rem}
@media (max-width:900px){.hero-shell{grid-template-columns:1fr}}
/* Lists/cards */
.hr-title{display:flex;align-items:center;gap:.8rem;margin:0 0 .8rem}
.hr-title .line{height:1px;background:var(--line);flex:1}.hr-title .text{font-weight:700;color:var(--muted);letter-spacing:.03em;text-transform:uppercase;font-size:.82rem}
.services-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
@media (max-width:1000px){.services-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:640px){.services-grid{grid-template-columns:1fr}}
.service-card h3{margin:.1rem 0 .35rem;font-size:1.05rem}
.service-card p{margin:0;color:var(--muted)}
.service-card .card-actions{margin-top:.8rem;display:flex;gap:.45rem;flex-wrap:wrap}
.page-title-row{display:flex;gap:.8rem;align-items:center}.page-title-row img{width:52px;height:52px;border-radius:12px;border:1px solid var(--line);background:#fff}
/* Forms */
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem}
.field{display:flex;flex-direction:column;gap:.35rem}.field.full{grid-column:1/-1}
.field label{font-weight:600;font-size:.95rem}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:.72rem .78rem;background:#fff;color:var(--ink);font:inherit}
.field textarea{resize:vertical;min-height:120px}
.field-help{font-size:.85rem;color:var(--muted)}
@media (max-width:700px){.form-grid{grid-template-columns:1fr}}
/* Footer */
.footer{margin-top:1rem;border-top:1px solid rgba(0,0,0,.07);background:#f1ede3}
.footer-top{display:flex;justify-content:space-between;gap:1rem;padding:1rem 0;align-items:flex-start}
.footer a{text-decoration:none}
@media (max-width:760px){.footer-top{flex-direction:column}}
/* Cookie banner */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:1200;background:rgba(32,39,34,.98);color:#fff;border-top:1px solid rgba(255,255,255,.12);box-shadow:0 -8px 24px rgba(0,0,0,.22);padding-bottom:env(safe-area-inset-bottom);transform:translateZ(0)}
.cookie-banner[hidden]{display:none!important}
.cookie-banner__inner{display:flex;align-items:center;justify-content:space-between;gap:.9rem;padding:.8rem 0;flex-wrap:wrap}
.cookie-banner p{margin:0;font-size:.95rem;line-height:1.45;color:rgba(255,255,255,.94);max-width:760px}
.cookie-banner a{color:#d8f2df;text-decoration:underline}
.cookie-banner__actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
/* Back-compat: some pages use cookie-actions instead of cookie-banner__actions */
.cookie-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
@media (max-width:680px){.cookie-banner__actions{width:100%}.cookie-banner__actions .btn{flex:1}}
@media (max-width:680px){.cookie-actions{width:100%}.cookie-actions .btn{flex:1}}
/* Accordions */
.on-page-nav{position:relative;margin:0 0 1rem}
.on-page-nav button{width:100%;justify-content:space-between}
.on-page-nav-menu{display:none;position:absolute;z-index:10;top:calc(100% + .35rem);left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:.3rem;max-height:50vh;overflow:auto}
.on-page-nav-menu a{display:block;padding:.55rem .7rem;border-radius:10px;text-decoration:none;color:var(--ink);font-weight:600}
.on-page-nav-menu a:hover{background:#f5f6f3}
.on-page-nav.open .on-page-nav-menu{display:block}
@media (hover:hover) and (pointer:fine){.on-page-nav:hover .on-page-nav-menu{display:block}}
.service-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:1rem;align-items:start}
@media (max-width:1050px){.service-layout{grid-template-columns:1fr}}
.side-cta{position:sticky;top:90px}
.section-accordion{margin:.8rem 0}
.section-accordion details{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);margin-bottom:.7rem;overflow:hidden}
.section-accordion summary{list-style:none;cursor:pointer;padding:.9rem 1rem;font-weight:700;display:flex;align-items:center;justify-content:space-between;gap:.75rem}
.section-accordion summary::-webkit-details-marker{display:none}
.section-accordion details[open] summary{border-bottom:1px solid var(--line)}
.section-accordion .summary-caret{transition:transform .2s ease}
.section-accordion details[open] .summary-caret{transform:rotate(180deg)}
.section-accordion .content{padding:0 1rem 1rem}
.section-accordion ul{padding-left:1.15rem}
.section-accordion li+li{margin-top:.25rem}
.anchor-target{scroll-margin-top:110px}
/* Legal */
.legal-page{padding:1rem 0 2rem}.legal-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.2rem}.legal-card h2{margin-top:1.05rem}.legal-card p,.legal-card li{color:var(--muted)}.legal-card ul{padding-left:1.2rem}


/* --- Design tidy (2026-02-26) --- */
.top-strip{position:relative;z-index:1}
@media (max-width:640px){
  .top-strip .strip-inner{padding:.35rem 0;gap:.5rem}
  .top-strip .strip-items{gap:.45rem .6rem}
  .top-strip .pill{padding:.22rem .5rem;font-size:.82rem}
  .top-strip .btn{padding:.45rem .7rem;font-size:.88rem}
}
@media (max-width:420px){
  .top-strip .strip-inner{justify-content:flex-start}
  .top-strip .btn{margin-top:.15rem}
}

/* Keep header sticky only (top strip scrolls away) */
.header{position:sticky;top:0;z-index:1000}

/* Improve header spacing / avoid squashed logo row */
.nav{padding:.55rem 0}
.brand-logo{width:40px;height:40px;aspect-ratio:1/1;display:block}
.brand-title strong{font-size:1.02rem}
.brand-title span{font-size:.95rem}
@media (max-width:420px){
  .brand-title strong{font-size:.98rem}
  .brand-title span{font-size:.9rem}
}



/* UI Polish v2 (mobile nav, top strip sizing, towns + guidance UI) */
@media (max-width: 520px){
  .top-strip .strip-inner{padding:.35rem 0;gap:.5rem}
  .top-strip .strip-items{gap:.45rem .5rem}
  .top-strip .pill{padding:.22rem .5rem;font-size:.82rem;line-height:1.1}
  .top-strip .btn{padding:.45rem .7rem;font-size:.85rem}
}

/* Mobile menu: off-canvas drawer */

body.menu-open{overflow:hidden;}

.mobile-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:998}
@media (max-width: 980px){
  .mobile-backdrop.open{display:block}
  .mobile-menu{display:block;position:fixed;top:0;left:0;height:100vh;height:100dvh;width:min(86vw,360px);transform:translateX(-105%);transition:transform .25s ease;z-index:999;border-right:1px solid rgba(0,0,0,.08);overflow:auto;-webkit-overflow-scrolling:touch}
  .mobile-menu.open{transform:translateX(0)}
  .mobile-menu a{padding:1rem 1.1rem;font-size:1.05rem}
  .nav{gap:.75rem}
  .brand-title{font-size:.98rem}
}

/* Locations page */
.town-search{display:flex;gap:.6rem;align-items:center;margin:1rem 0 1.2rem}
.town-search input{flex:1;padding:.75rem .9rem;border:1px solid var(--line);border-radius:999px;font-size:1rem}
.town-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
@media (max-width: 980px){.town-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 520px){.town-grid{grid-template-columns:1fr}}
.town-card{display:flex;gap:.8rem;align-items:flex-start;padding:1rem;border:1px solid rgba(0,0,0,.08);border-radius:16px;background:#fff;text-decoration:none;color:var(--ink);box-shadow:0 8px 22px rgba(0,0,0,.05)}
.town-card:hover{transform:translateY(-1px)}
.town-pin{width:38px;height:38px;flex:0 0 38px;border-radius:12px;background:linear-gradient(135deg,rgba(47,91,58,.18),rgba(47,91,58,.06));display:flex;align-items:center;justify-content:center;border:1px solid rgba(47,91,58,.18)}
.town-pin svg{width:18px;height:18px;fill:var(--brand)}
.town-card strong{display:block;font-size:1.05rem}
.town-card span{display:block;margin-top:.25rem;color:var(--muted);font-weight:600}

/* Guidance: RHS-style horizontal scrollers */
.guidance-row{display:flex;gap:1rem;overflow-x:auto;padding:.25rem 0 1rem;scroll-snap-type:x mandatory}
.guidance-row::-webkit-scrollbar{height:10px}
.guidance-row::-webkit-scrollbar-thumb{background:rgba(0,0,0,.18);border-radius:999px}
.guidance-row li{list-style:none;flex:0 0 min(320px,85vw);scroll-snap-align:start}
.guidance-row a{display:block;height:100%;padding:1.05rem;border:1px solid rgba(0,0,0,.08);border-radius:18px;background:#fff;text-decoration:none;color:var(--ink);box-shadow:0 10px 26px rgba(0,0,0,.05)}
.guidance-row h3{margin:.2rem 0 .4rem}
.guidance-row p{color:var(--muted);font-weight:600}
.guidance-row span{display:inline-block;margin-top:.55rem;font-weight:800;color:var(--brand)}
.guidance-cluster .section-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem}
.guidance-cluster .section-heading p{max-width:48ch}

/* Guidance topic summary */
.topic-cards{display:flex;gap:1rem;flex-wrap:wrap}
.topic-card{flex:1 1 220px;display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1rem 1.1rem;border:1px solid rgba(0,0,0,.08);border-radius:18px;background:linear-gradient(135deg,rgba(47,91,58,.10),rgba(255,255,255,1));text-decoration:none;color:var(--ink);box-shadow:0 10px 26px rgba(0,0,0,.05)}
.topic-card strong{font-size:1.02rem}
.topic-card span{font-weight:800;color:var(--brand)}
@media (max-width: 520px){.topic-cards{flex-direction:column}}


/* === UI Phase 1–3: parity + conversion + tips magazine === */

/* Mobile toggle (hamburger) */
.mobile-toggle{display:none; align-items:center; gap:.5rem; background:#fff; border:1px solid var(--line); border-radius:999px; padding:.55rem .85rem; font-weight:800; min-height:44px; min-width:44px; -webkit-tap-highlight-color:transparent; touch-action:manipulation;}
.mobile-toggle .burger{display:inline-grid; gap:3px;}
.mobile-toggle .burger span{display:block; width:18px; height:2px; background:var(--ink); border-radius:2px;}
.mobile-toggle .menu-label{font-size:.95rem;}

/* Ensure header layout doesn't crush */
.nav{display:flex; align-items:center; justify-content:space-between; gap:1rem;}
.nav-links{display:flex; gap:1rem; align-items:center;}
@media (max-width: 860px){
  .nav-links{display:none;}
  .mobile-toggle{display:inline-flex;}
}

/* Top strip tight on mobile */
@media (max-width: 520px){
  .top-strip .strip-inner{padding:.35rem 0;}
  .top-strip .pill{font-size:.78rem; padding:.25rem .5rem;}
  .top-strip .btn{padding:.45rem .65rem; font-size:.85rem;}
  .strip-items{gap:.35rem;}
}

/* Contact bar (mobile) */
.contact-bar{position:fixed; left:0; right:0; bottom:0; z-index:999; display:none; background:var(--paper); border-top:1px solid var(--line); box-shadow:0 -10px 26px rgba(0,0,0,.08);}
.contact-bar .cb-item{flex:1; display:flex; align-items:center; justify-content:center; gap:.4rem; padding:.75rem .5rem; font-weight:800; text-decoration:none; color:var(--ink);}
.contact-bar .cb-item span{font-size:1rem;}
.contact-bar .cb-primary{background:var(--brand); color:#fff;}
@media (max-width: 860px){
  .contact-bar{display:flex;}
  body{padding-bottom:64px;}
}

/* Floating contact widget (desktop) */
.contact-float{position:fixed; right:18px; bottom:18px; z-index:998; display:none; background:var(--paper); border:1px solid var(--line); border-radius:18px; box-shadow:var(--shadow); padding:.75rem;}
.contact-float .cf-btn{display:block; background:var(--brand); color:#fff; text-decoration:none; font-weight:900; padding:.75rem .9rem; border-radius:14px;}
.contact-float .cf-row{display:flex; gap:.5rem; margin-top:.6rem;}
.contact-float .cf-chip{flex:1; text-align:center; text-decoration:none; color:var(--ink); border:1px solid var(--line); border-radius:999px; padding:.5rem .65rem; font-weight:800;}
@media (min-width: 861px){
  .contact-float{display:block;}
}

/* Locations v2 */
.locations-tools{display:flex; gap:.85rem; align-items:center; justify-content:space-between; flex-wrap:wrap;}
.town-search input{width:min(520px, 100%); padding:.75rem .95rem; border:1px solid var(--line); border-radius:999px; background:#fff;}
.region-tabs{display:flex; gap:.5rem; flex-wrap:wrap;}
.region-tabs .tab{border:1px solid var(--line); background:linear-gradient(180deg,#ffffff,#f7f8f9); border-radius:999px; padding:.55rem .85rem; font-weight:900; cursor:pointer; transition:transform .12s ease, box-shadow .12s ease;}
.region-tabs .tab:hover{transform:translateY(-1px); box-shadow:0 10px 18px rgba(0,0,0,.06);} 
.region-tabs .tab.is-active{background:var(--brand); color:#fff; border-color:var(--brand);}
.pill-grid{display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:.6rem; margin-top:.75rem;}
@media (min-width: 560px){ .pill-grid{grid-template-columns:repeat(3, minmax(0,1fr));} }
@media (min-width: 960px){ .pill-grid{grid-template-columns:repeat(4, minmax(0,1fr));} }
.town-pill{display:inline-flex; align-items:center; gap:.5rem; padding:.52rem .72rem; border:1px solid var(--line); border-radius:999px; text-decoration:none; color:var(--ink); background:linear-gradient(180deg,#ffffff,#f7f8f9); font-weight:900; font-size:.92rem; transition:transform .12s ease, box-shadow .12s ease;}
.town-pill:hover{transform:translateY(-1px); box-shadow:0 10px 18px rgba(0,0,0,.06);} 
.town-pill:focus-visible{outline:3px solid rgba(47,91,58,.35); outline-offset:2px;}
.town-pill .pin{display:none;}
.town-pill::before{content:""; width:.45rem; height:.45rem; border-radius:999px; background:rgba(47,91,58,.45);} 

/* Guidance magazine */
.tips-mag .mag-intro{display:grid; grid-template-columns:1fr; gap:1rem; margin-bottom:1.25rem;}
@media(min-width: 960px){ .tips-mag .mag-intro{grid-template-columns:1fr 1fr;} }
.mag-card{background:var(--paper); border:1px solid var(--line); border-radius:22px; padding:1rem; box-shadow:0 10px 26px rgba(0,0,0,.05);}
.topic-chips{display:flex; gap:.5rem; flex-wrap:wrap; margin-top:.6rem;}
.topic-chips .chip{border:1px solid var(--line); border-radius:999px; padding:.5rem .75rem; text-decoration:none; color:var(--ink); font-weight:900;}
.topic-row{margin-top:1.5rem;}
.topic-head{display:flex; align-items:flex-end; justify-content:space-between; gap:1rem;}
.topic-actions{display:flex; gap:.4rem;}
.topic-actions .arrow{border:1px solid var(--line); background:var(--paper); border-radius:12px; padding:.45rem .65rem; font-weight:900; cursor:pointer;}
.card-row{display:grid; grid-auto-flow:column; grid-auto-columns:minmax(240px, 1fr); gap:.75rem; overflow-x:auto; padding:.75rem 0; scroll-snap-type:x mandatory;}
.card-row.compact{grid-auto-columns:minmax(220px, 1fr);}
.card-row::-webkit-scrollbar{height:10px;}
.article-card{scroll-snap-align:start; display:flex; flex-direction:column; gap:.45rem; padding:1rem; border:1px solid var(--line); border-radius:18px; text-decoration:none; color:var(--ink); background:var(--paper); box-shadow:0 10px 20px rgba(0,0,0,.04);}
.article-card:hover{transform:translateY(-1px); box-shadow:0 12px 24px rgba(0,0,0,.07);}
.article-card .excerpt{color:var(--muted); font-size:.95rem; line-height:1.35;}
.article-card .readmore{margin-top:auto; font-weight:900; color:var(--brand);}
.card-meta{display:flex; gap:.4rem; flex-wrap:wrap;}
.badge{display:inline-block; background:var(--pill); border:1px solid var(--line); border-radius:999px; padding:.25rem .5rem; font-size:.78rem; font-weight:900;}
.tag{display:inline-block; background:rgba(47,91,58,.08); border:1px solid rgba(47,91,58,.18); border-radius:999px; padding:.25rem .5rem; font-size:.78rem; font-weight:900; color:var(--brand);}

/* Services filters */
.filters{display:flex; gap:.5rem; flex-wrap:wrap; margin-top:1rem; align-items:center;}
.filters .filter{border:1px solid var(--line); background:linear-gradient(180deg,#ffffff,#f7f8f9); border-radius:999px; padding:.55rem .85rem; font-weight:900; cursor:pointer; transition:transform .12s ease, box-shadow .12s ease;}
.filters .filter:hover{transform:translateY(-1px); box-shadow:0 10px 18px rgba(0,0,0,.06);}
.filters .filter.is-active{background:var(--brand); color:#fff; border-color:var(--brand); box-shadow:0 14px 24px rgba(47,91,58,.25);} 
.filters .filter:focus-visible{outline:3px solid rgba(47,91,58,.35); outline-offset:2px;}
.service-meta{display:flex; flex-wrap:wrap; gap:.5rem; margin:.65rem 0 .1rem;}
.service-meta .chip{border:1px solid var(--line); background:var(--pill); border-radius:999px; padding:.25rem .55rem; font-weight:900; font-size:.8rem;}
.service-meta .muted{color:var(--muted); font-size:.9rem;}

.service-card h3{margin:.1rem 0 .35rem; font-size:1.12rem; letter-spacing:-.01em;}
.service-card p{margin:0; color:var(--muted);}
.service-meta .chip{background:rgba(47,91,58,.08); border:1px solid rgba(47,91,58,.18); color:var(--brand);}
.card-actions{display:flex; gap:.65rem; margin-top:1rem; flex-wrap:wrap;}
.card-actions .btn{border-radius:999px;}

@media (max-width: 520px){
  .town-pill{padding:.48rem .62rem; font-size:.9rem;}
  .filters .filter{padding:.52rem .75rem; font-size:.92rem;}
}

.info-box{background:var(--paper); border:1px solid var(--line); border-radius:18px; padding:.9rem; box-shadow:0 10px 20px rgba(0,0,0,.04);} 


/* Contact float close button */
.contact-float{position:fixed;}
.contact-float .cf-close{
  position:absolute;
  top:8px;
  right:10px;
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--paper);
  color:var(--ink);
  font-size:20px;
  line-height:1;
  cursor:pointer;
}
.contact-float .cf-close:hover{filter:brightness(0.97);}

/* Hero CTA spacing on articles */
.hero-cta{margin-top:.75rem;}

/* Article polish */
.guidance-article .prose-card{
  max-width: 860px;
  margin: 0 auto;
}
.guidance-article .prose-card h2{margin-top:1.6rem;}
.guidance-article .prose-card h3{margin-top:1.2rem;}
.guidance-article .prose-card p{line-height:1.7;}
.guidance-article .prose-card ul{padding-left:1.2rem;}
.guidance-article .prose-card li{margin:.35rem 0;}
.guidance-article .prose-card .btn{margin-top:.35rem;}

/* Top strip spacing (desktop + mobile) */
.top-strip .strip-items{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  align-items:center;
}
.top-strip .strip-inner{
  display:flex;
  justify-content:space-between;
  gap:.75rem;
  align-items:center;
}
@media (max-width: 720px){
  .top-strip .strip-inner{flex-direction:column; align-items:stretch;}
  .top-strip .strip-items{justify-content:center;}
  .top-strip .btn{width:100%; text-align:center;}
}


/* Article design upgrade */
.guidance-article{padding-bottom:2.5rem;}
.guidance-article .prose-card{
  background: #fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding: clamp(1rem, 2.5vw, 1.6rem);
  box-shadow: 0 18px 45px rgba(0,0,0,.06);
}
.guidance-article .prose-card h2{
  padding-top: .25rem;
  padding-bottom: .25rem;
  border-bottom: 1px solid var(--line);
}
.guidance-article .prose-card h3{
  display:inline-block;
  padding: .2rem .55rem;
  border-radius: 999px;
  background: var(--paper);
  border:1px solid var(--line);
}
.guidance-article .prose-card a:not(.btn){
  text-underline-offset: 3px;
}
.guidance-article .prose-card p + ul,
.guidance-article .prose-card p + ol{margin-top:.55rem;}
.guidance-article .prose-card ul + p,
.guidance-article .prose-card ol + p{margin-top:.65rem;}
/* Make CTA buttons feel deliberate */
.guidance-article .prose-card .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:.72rem 1rem;
  border-radius:14px;
}
/* Hero looks less like plain HTML */
.hero.hero-compact{
  background: linear-gradient(180deg, rgba(11,93,55,.10), rgba(11,93,55,0));
  border-bottom:1px solid var(--line);
}
.hero.hero-compact h1{letter-spacing:-.02em;}
.hero.hero-compact p{max-width: 70ch;}


/* --- Gardening tips UX upgrades (topic chips + search + desktop grid) --- */
.topic-shortcuts{padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(255,255,255,.35)}
.shortcut-row{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 14px}
.topic-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--line);border-radius:999px;background:var(--pill);color:var(--ink);text-decoration:none;font-weight:600;font-size:13px}
.topic-chip:hover{background:var(--paper);box-shadow:0 8px 20px rgba(0,0,0,.07);transform:translateY(-1px)}
.guidance-search{max-width:820px}
.guidance-search input{width:100%;max-width:820px;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:var(--paper);font-size:16px}
.guidance-search input:focus{outline:2px solid rgba(47,91,58,.25);border-color:rgba(47,91,58,.5)}
#guideSearchHint{margin:.35rem 0 0;color:var(--muted)}
@media (min-width: 920px){
  .tips-mag .card-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;overflow:visible;scroll-snap-type:none}
  .tips-mag .card-row .article-card{min-width:0}
  .tips-mag .topic-controls{display:none}
}



/* --- Article TOC (auto-generated) --- */
.toc-wrap { margin: 1rem 0 0; }
.toc-card { border: 1px solid rgba(0,0,0,0.08); border-radius: 16px; padding: 1rem; background: #fff; box-shadow: 0 6px 18px rgba(0,0,0,0.06); }
.toc-card__title { font-weight: 700; margin-bottom: 0.5rem; }
.toc { display: grid; gap: 0.35rem; }
.toc a { text-decoration: none; }
.toc a:hover { text-decoration: underline; }
.toc .toc-h3 { padding-left: 1rem; font-size: 0.95em; opacity: 0.9; }

/* --- Related block --- */
.related-block { margin-top: 2rem; padding-top: 1rem; border-top: 1px solid rgba(0,0,0,0.08); }
.related-list { margin: 0.5rem 0 0; padding-left: 1.1rem; }
.related-list li { margin: 0.25rem 0; }

/* --- Search input (minimal) --- */
.form-label { display: block; font-weight: 600; margin: 0.25rem 0 0.4rem; }
.input { width: 100%; max-width: 720px; padding: 0.75rem 0.9rem; border-radius: 12px; border: 1px solid rgba(0,0,0,0.16); font: inherit; }
.input:focus { outline: none; border-color: rgba(0,0,0,0.35); box-shadow: 0 0 0 4px rgba(0,0,0,0.06); }

/* --- Floating contact widget upgrades (CLS-safe) --- */
.contact-float { position: fixed; right: 16px; bottom: 16px; z-index: 50; }
.contact-float__toggle { min-height: 44px; padding: 0.75rem 1rem; border-radius: 999px; border: 0; cursor: pointer; box-shadow: 0 10px 24px rgba(0,0,0,0.18); }
.contact-float__panel { position: absolute; right: 0; bottom: 52px; width: min(320px, calc(100vw - 32px)); border-radius: 16px; padding: 0.9rem; background: #fff; border: 1px solid rgba(0,0,0,0.08); box-shadow: 0 16px 36px rgba(0,0,0,0.18); }
.contact-float__actions { display: grid; gap: 0.5rem; }
.contact-float__close { position: absolute; top: 8px; right: 10px; width: 36px; height: 36px; border-radius: 999px; border: 1px solid rgba(0,0,0,0.12); background: #fff; cursor: pointer; font-size: 20px; line-height: 1; }
.contact-float__hide-today { margin-top: 0.6rem; width: 100%; border: 0; background: transparent; cursor: pointer; text-decoration: underline; opacity: 0.8; }
.contact-float__hide-today:hover { opacity: 1; }

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  .contact-float__panel, .contact-float__toggle { transition: none !important; }
}


/* CGM ENHANCEMENTS: micro-animations + related guides carousel */

/* Focus-visible (keyboard accessibility) */
:where(a, button, input, textarea, select, summary).focus-visible,
:where(a, button, input, textarea, select, summary):focus-visible {
  outline: 3px solid currentColor;
  outline-offset: 3px;
}

/* Buttons: subtle motion */
.btn {
  transition: transform 120ms ease, box-shadow 180ms ease, filter 180ms ease;
  will-change: transform;
}
.btn:hover {
  transform: translateY(-1px);
}
.btn:active {
  transform: translateY(0) scale(0.98);
}

/* Card / tile hover elevation (safe selectors only) */
.prose-card,
.card,
.tile,
.article-card,
.service-card,
.location-card {
  transition: transform 180ms ease, box-shadow 220ms ease;
  will-change: transform;
}
.prose-card:hover,
.card:hover,
.tile:hover,
.article-card:hover,
.service-card:hover,
.location-card:hover {
  transform: translateY(-2px);
}

/* Accordions / details: smoother open */
details > summary {
  cursor: pointer;
}
details > summary::-webkit-details-marker { display:none; }
details[open] > summary { margin-bottom: 0.5rem; }
details > *:not(summary) {
  animation: cgmDetailsIn 180ms ease;
}
@keyframes cgmDetailsIn {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Related guides: desktop grid + mobile swipe carousel (no HTML changes required) */
#cgm-related-guides ul {
  list-style: none;
  padding-left: 0;
  margin: 1rem 0 0;
  display: flex;
  gap: 0.75rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 0.5rem;
}
#cgm-related-guides li {
  flex: 0 0 84%;
  scroll-snap-align: start;
}
#cgm-related-guides a {
  display: block;
  padding: 0.9rem 1rem;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,0.08);
  background: rgba(255,255,255,0.75);
  text-decoration: none;
  transition: transform 180ms ease, box-shadow 220ms ease;
}
#cgm-related-guides a:hover {
  transform: translateY(-2px);
}
@media (min-width: 760px) {
  #cgm-related-guides ul {
    overflow-x: visible;
    scroll-snap-type: none;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
  }
  #cgm-related-guides li { flex: initial; }
}

/* Simple text link style (used when removing duplicate quote buttons) */
a.text-link {
  text-decoration: underline;
}


/* Mobile toggle icon sizing (☰) */
.mobile-toggle span{font-size:1.25rem; line-height:1;}
