/* ERE v4 - Coreplamb-template layout, re-skinned to ERE's brand palette:
   deep navy authority (#0b2545) + warm earth credibility (#f5efe6) + green
   energy accent (#1f7a3a) on white. Palette = production W-006 (styles.css).
   Layout/structure is unchanged from the plumbing template; only color
   tokens were swapped from cream->ERE. */
:root{
  /* ERE brand palette (W-006) */
  --navy-900:#0b2545; --navy-800:#13315c; --navy-700:#1d3f73; --navy-50:#eef2f8;
  --green-700:#1f7a3a; --green-600:#258a44; --green-50:#e8f5ec;
  --earth-700:#6b4f2c; --earth-100:#f5efe6;
  --ink:#15202b; --ink-2:#475569; --line:#d6dee8; --line-soft:#e6ecf3;
  --bg:#ffffff; --bg-2:#f5efe6; --bg-soft:#f7f9fc; --bg-card:#ffffff;
  --heading:#0b2545;
  --r:18px; --r-sm:12px; --r-pill:999px;
  --sans:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI Variable Display","Segoe UI",Roboto,sans-serif;
  --ease:cubic-bezier(.2,.7,.2,1);
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:5rem}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
img,svg{display:block;max-width:100%;height:auto}
a{color:var(--green-700);text-decoration:none}
a:hover{text-decoration:underline}
button{font:inherit}
:focus-visible{outline:2px solid var(--green-700);outline-offset:2px;border-radius:8px}

.container{width:100%;max-width:78rem;margin:0 auto;padding:0 1.25rem}

/* utility strip (two-tier header): phone + hours + Client Portal */
.topbar{background:var(--navy-900);color:#fff;font-size:.82rem}
.topbar__inner{display:flex;align-items:center;gap:1.1rem;min-height:38px;padding-top:.35rem;padding-bottom:.35rem}
.topbar a{color:#fff}
.topbar a:hover{text-decoration:none;opacity:.85}
.topbar__phone{font-weight:700}
.topbar__hours{color:rgba(255,255,255,.7)}
.topbar__portal{margin-left:auto;font-weight:600;font-size:.8rem;display:inline-flex;align-items:center;gap:.35rem;border:1px solid rgba(255,255,255,.4);padding:.26rem .8rem;border-radius:var(--r-pill)}
.topbar__portal:hover{background:rgba(255,255,255,.14);opacity:1}
@media(max-width:560px){.topbar__hours{display:none}}

/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);border-bottom:1px solid var(--line-soft);backdrop-filter:saturate(160%) blur(10px)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;min-height:5rem;gap:1.5rem}
.brand{display:inline-flex;align-items:center;gap:.65rem;font-weight:700;color:var(--heading);font-size:1.05rem}
.brand img{width:32px;height:32px;border-radius:8px}
.brand__name{display:block;line-height:1}
.brand__sub{display:flex;flex-wrap:wrap;align-items:baseline;gap:.35rem;font-size:.68rem;font-weight:600;color:var(--ink-2);letter-spacing:.08em;text-transform:uppercase;margin-top:3px}
.brand__sub span{white-space:nowrap}
.brand__sub span+span::before{content:"\00B7";margin-right:.35rem;color:var(--ink-2)}
/* header brand: full ERE wordmark stacked over subtitle; overrides the 32px favicon rule the footer brand still uses */
.site-header .brand{flex-direction:column;align-items:flex-start;gap:.1rem}
.site-header .brand__logo{width:auto;height:56px;border-radius:0;display:block}
@media(min-width:1000px){.site-header .brand__logo{height:68px}}  /* larger logo, halves the header whitespace */
.site-header .brand__sub{margin-top:2px}
.primary-nav{display:none}
@media(min-width:1000px){.primary-nav{display:block}}
.primary-nav ul{list-style:none;padding:0;margin:0;display:flex;gap:1.4rem}
.primary-nav a{color:var(--ink);font-size:.95rem;font-weight:500}

/* Mobile hamburger + drawer */
.nav-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);
  cursor:pointer;
}
@media(min-width:1000px){.nav-toggle{display:none}}
.nav-toggle__bars,
.nav-toggle__bars::before,
.nav-toggle__bars::after{
  display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;
  transition:transform var(--ease,.2s) cubic-bezier(.2,.7,.2,1),opacity .2s cubic-bezier(.2,.7,.2,1);
}
.nav-toggle__bars{position:relative}
.nav-toggle__bars::before,.nav-toggle__bars::after{content:"";position:absolute;left:0}
.nav-toggle__bars::before{top:-6px}
.nav-toggle__bars::after{top:6px}

.mobile-nav{
  display:none;
  /* very light tint of the logo blue (#008dd2) so the drawer reads as a
     distinct, on-brand surface against the white page */
  background:#eaf5fc;
  border-top:1px solid #cfe7f6;
  border-bottom:1px solid #cfe7f6;
  padding:1rem 1.25rem 1.5rem;
}
.mobile-nav__list{list-style:none;padding:0;margin:0;display:grid;gap:.25rem}
.mobile-nav__list a{
  display:block;padding:.85rem .5rem;
  text-decoration:none;color:var(--ink);font-weight:600;font-size:1.125rem;
  border-bottom:1px solid var(--line-soft);
}
/* #2 CTA buttons are full pill buttons (no link separator border); text centered */
.mobile-nav__cta{margin-top:1rem;width:100%;display:flex;align-items:center;justify-content:center}

/* Open state via :has() (modern browsers). Safari 15.4+, Chrome 105+, Firefox 121+ */
.site-header:has(.nav-toggle[aria-expanded="true"]) .mobile-nav{display:block}
.site-header:has(.nav-toggle[aria-expanded="true"]) .nav-toggle__bars{background:transparent}
.site-header:has(.nav-toggle[aria-expanded="true"]) .nav-toggle__bars::before{top:0;transform:rotate(45deg)}
.site-header:has(.nav-toggle[aria-expanded="true"]) .nav-toggle__bars::after{top:0;transform:rotate(-45deg)}
/* Hide the Book-Now button on small viewports so the hamburger has room */
@media(max-width:639px){.site-header__inner > a.btn--primary{display:none}}

/* Mobile header brand (#3): bigger logo with the 3 core services as a bulleted
   column to its right (desktop keeps the stacked logo + inline dotted subtitle) */
@media(max-width:999px){
  .site-header__inner{gap:.85rem;min-height:4.25rem}  /* #1 halve logo top/bottom whitespace on mobile */
  .site-header .brand{flex-direction:row;align-items:center;gap:.55rem}
}

.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.5rem;border-radius:var(--r-pill);font-weight:700;border:1px solid transparent;cursor:pointer;white-space:nowrap;transition:background .2s var(--ease),transform .15s var(--ease)}
.btn--primary{background:var(--green-700);color:#fff;box-shadow:0 6px 18px rgba(31,122,58,.25)}
.btn--primary:hover{background:var(--green-600);text-decoration:none;color:#fff}
.btn--primary:active{transform:translateY(1px)}
.btn--ghost{background:transparent;color:var(--navy-800);border:1px solid var(--navy-800)}
.btn--ghost:hover{background:var(--navy-800);color:#fff;text-decoration:none}
.btn--lg{padding:1rem 1.75rem;font-size:1.05rem}

.eyebrow{display:inline-block;font-size:1.55rem;font-weight:800;letter-spacing:.05em;line-height:1.12;text-transform:uppercase;color:var(--green-700)}

.link-arrow{display:inline-flex;align-items:center;gap:.3rem;color:var(--green-700);font-weight:700;font-size:.95rem;margin-top:.4rem}
.link-arrow::after{content:"\2192";transition:transform .2s var(--ease)}
.link-arrow:hover{text-decoration:none}
.link-arrow:hover::after{transform:translateX(3px)}

/* hero */
.hero{padding:clamp(2rem,3vw + 1rem,4rem) 0 clamp(2.5rem,4vw + 1rem,5rem);background:
  radial-gradient(700px 400px at 10% 100%,rgba(31,122,58,.10),transparent 60%),
  radial-gradient(820px 520px at 100% 0%,rgba(11,37,69,.07),transparent 60%),
  var(--bg)}
.hero__grid{display:grid;grid-template-columns:1fr;gap:2rem;align-items:center}
@media(min-width:880px){.hero__grid{grid-template-columns:1.05fr .95fr;gap:3rem}}
.hero h1{font-size:clamp(2.1rem,4vw + .5rem,3.6rem);line-height:1.04;letter-spacing:-.02em;font-weight:760;margin:.85rem 0 1rem;color:var(--heading);text-wrap:balance}
.hero .lede{color:var(--ink-2);font-size:1.1rem;max-width:46ch;margin:0 0 1.75rem}
.hero__ctas{display:flex;flex-wrap:wrap;gap:.7rem}

.hero__photo{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:1/1;background:#ddd;box-shadow:0 24px 48px rgba(11,37,69,.16)}
.hero__photo img{width:100%;height:100%;object-fit:cover}
.hero__photo-tag{position:absolute;bottom:1rem;left:1rem;background:rgba(255,255,255,.95);padding:.7rem 1rem;border-radius:14px;box-shadow:0 6px 18px rgba(0,0,0,.1)}
.hero__photo-tag strong{display:block;color:var(--green-700);font-weight:800}
.hero__photo-tag span{display:block;font-size:.85rem;color:var(--ink-2)}

/* stats pills */
.stats{margin-top:3rem;display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;background:var(--bg-card);padding:1.25rem;border-radius:24px;border:1px solid var(--line-soft);box-shadow:0 8px 24px rgba(11,37,69,.06)}
@media(min-width:760px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat{padding:.85rem 1rem;text-align:center}
.stat strong{display:block;font-size:clamp(1.6rem,2vw + .5rem,2.2rem);font-weight:800;color:var(--heading);letter-spacing:-.02em;line-height:1}
.stat span{display:block;color:var(--ink-2);font-size:.84rem;margin-top:.4rem;line-height:1.3}

/* sections */
.section{padding:clamp(3.5rem,5vw + 1rem,6rem) 0}
.section--soft{background:var(--bg-2)}
.section-head{margin-bottom:2.5rem;max-width:44rem;display:grid;gap:.6rem}
.section-head h2{font-size:clamp(1.7rem,2.4vw + .5rem,2.5rem);line-height:1.12;letter-spacing:-.018em;font-weight:760;margin:0;color:var(--heading);text-wrap:balance}
.section-head p{color:var(--ink-2);margin:0;font-size:1.05rem}
/* homepage services: 'What we do' stands alone as the (enlarged) section label */
#services .services-label{margin:0;font-size:1.55rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--green-700);line-height:1.1}

/* picks (icon-card grid) */
.picks{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:680px){.picks{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1040px){.picks{grid-template-columns:repeat(4,1fr)}}
/* 3-up variant for inner pages with 3 or 5 cards (additive; does not affect home .picks) */
@media(min-width:1040px){.picks--3{grid-template-columns:repeat(3,1fr)}}
.pick{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:var(--r);padding:1.5rem;display:grid;gap:.6rem;transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.pick:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(11,37,69,.10)}
.pick__icon{width:48px;height:48px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:var(--green-50);color:var(--green-700)}
.pick h3{margin:0;font-size:1.05rem;color:var(--heading);font-weight:700}
.pick p{margin:0;color:var(--ink-2);font-size:.95rem}

/* service-row (photo cards) */
.service-row{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:640px){.service-row{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1040px){.service-row{grid-template-columns:repeat(4,1fr)}}
.service-card{background:var(--bg-card);border-radius:var(--r);overflow:hidden;display:grid;align-content:start;gap:.75rem;border:1px solid var(--line-soft);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.service-card:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(11,37,69,.10)}
.service-card__photo{aspect-ratio:16/10;background:#eee;overflow:hidden}
.service-card__photo img{width:100%;height:100%;object-fit:cover}
.service-card h3{margin:.25rem 1.25rem 0;font-size:1.15rem;line-height:1.3;min-height:3rem;color:var(--heading);font-weight:700}
.service-card p{margin:0 1.25rem 1.25rem;color:var(--ink-2)}
/* compact Learn More button under each card heading (aligned across tiles, above the fold) */
.service-card__btn{justify-self:start;margin:.1rem 1.25rem 0;padding:.5rem 1.05rem;font-size:.9rem;color:var(--green-700);border-color:var(--green-700)}
.service-card__btn:hover{background:var(--green-700);color:#fff;text-decoration:none}
/* mobile single-column: drop the heading min-height so the Learn More button sits the
   same distance below the title text on every card (no reserved gap on 1-line titles) */
@media(max-width:639px){.service-card h3{min-height:0}}
/* mobile: process-page step list fills the screen width (remove the default <ol> indent) */
@media(max-width:639px){.process-list{padding-left:0}}

/* reviews */
.reviews{display:grid;grid-template-columns:1fr;gap:1.25rem}
@media(min-width:780px){.reviews{grid-template-columns:repeat(3,1fr)}}
.review{margin:0;background:var(--bg-card);border-radius:var(--r);padding:1.5rem;border:1px solid var(--line-soft);display:grid;gap:.75rem}
.stars{color:#d99700;font-size:1rem;letter-spacing:.1em}
.review blockquote{margin:0;color:var(--ink);font-size:1rem;line-height:1.5}
.review figcaption strong{color:var(--heading);display:block;font-weight:700}
.review figcaption span{color:var(--ink-2);font-size:.85rem}

/* FAQ */
.faq-wrap{max-width:50rem}
.faq{display:grid;gap:.4rem}
.faq details{background:var(--bg-card);border-radius:var(--r);padding:1.1rem 1.25rem;border:1px solid var(--line-soft)}
.faq summary{list-style:none;cursor:pointer;font-weight:700;display:flex;justify-content:space-between;gap:1rem;align-items:center;color:var(--heading)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--green-700);font-size:1.4rem;line-height:1;transition:transform .2s var(--ease)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{margin:.7rem 0 0;color:var(--ink-2)}

/* cta band - card */
.cta-band{padding:0 0 4rem}
.cta-card{background:var(--green-700);color:#fff;padding:clamp(2rem,3vw + 1rem,3.5rem);border-radius:28px;display:grid;grid-template-columns:1fr;gap:1.5rem;align-items:center;background-image:radial-gradient(500px 240px at 100% 100%,rgba(255,255,255,.12),transparent 60%)}
@media(min-width:780px){.cta-card{grid-template-columns:1fr auto;gap:2.5rem}}
.cta-card h2{font-size:clamp(1.5rem,2vw + .5rem,2.25rem);color:#fff;margin:0 0 .5rem;letter-spacing:-.02em;font-weight:760;line-height:1.15}
.cta-card p{color:rgba(255,255,255,.85);margin:0;max-width:42ch}
.cta-card .btn--primary{background:#fff;color:var(--green-700)}
.cta-card .btn--primary:hover{background:#f0fff5}

/* process timeline cards */
.process{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;counter-reset:n}
.process>li{flex:1 1 100%}
@media(min-width:780px){.process{gap:1.25rem}.process>li{flex:0 1 calc(50% - 0.625rem)}}
@media(min-width:1080px){.process>li{flex:0 1 calc(25% - 0.9375rem)}}
.process-step{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:var(--r);padding:1.5rem;display:grid;gap:.55rem;align-content:start;position:relative;transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.process-step:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(11,37,69,.10)}
.process-step__num{font-family:ui-monospace,SFMono-Regular,monospace;font-size:.78rem;font-weight:800;color:#fff;background:var(--green-700);padding:.3rem .65rem;border-radius:var(--r-pill);justify-self:start;letter-spacing:.05em}
/* #3 center the process step content on mobile (single-column) */
@media(max-width:779px){.process-step{text-align:center}.process-step__num{justify-self:center}}
.process-step h3{margin:.25rem 0 0;font-size:1.02rem;color:var(--heading);font-weight:780}
.process-step p{margin:0;color:var(--ink-2);font-size:.93rem}
.process-cta{margin:2rem 0 0;text-align:center}

/* warm-on-soft ghost button (for testimonials cta) */
.btn--ghost-warm{background:var(--bg-card);color:var(--navy-800);border:1px solid var(--navy-800)}
.btn--ghost-warm:hover{background:var(--navy-800);color:#fff;text-decoration:none}
.reviews-cta{text-align:center;margin:2.5rem 0 0}

/* =============================================
   INNER-PAGE COMPONENTS (about, contact, services, cities, etc.)
   Same v4 visual language as the homepage applied to deeper pages.
   ============================================= */

/* breadcrumb */
.breadcrumb{font-size:.82rem;color:var(--ink-2);margin-bottom:1rem}
.breadcrumb a{color:var(--green-deep,#1a6932);text-decoration:none;font-weight:600}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb [aria-hidden]{margin:0 .4rem;opacity:.5}

/* inner-page hero */
.page-hero{
  padding:clamp(.6rem,1vw + .25rem,1.1rem) 0 clamp(2rem,3vw + 1rem,3.5rem);  /* #10 cut top whitespace ~75% */
  background:
    radial-gradient(700px 380px at 10% 100%,rgba(31,122,58,.09),transparent 60%),
    radial-gradient(900px 480px at 100% 0%,rgba(11,37,69,.07),transparent 60%),
    var(--bg);
  border-bottom:1px solid var(--line-soft);
}
.page-hero h1{
  font-family:var(--sans);
  font-size:clamp(2rem,3.5vw + .5rem,3.25rem);
  line-height:1.06;letter-spacing:-.02em;font-weight:760;
  color:var(--heading);margin:.25rem 0 1rem;
  text-wrap:balance;max-width:24ch;
}
.page-hero h1 .alt{color:var(--green-700);font-weight:680;display:block;font-size:.65em;margin-top:.25rem;letter-spacing:0}
.page-hero .lede{color:var(--ink-2);font-size:1.1rem;max-width:56ch;margin:0 0 1.25rem;line-height:1.55}
.page-hero__ctas{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:.5rem}
/* service-area hero: map beside the copy on desktop, stacked on mobile */
.page-hero__grid{display:grid;grid-template-columns:1fr;gap:1.75rem;align-items:center}
.page-hero__copy{min-width:0}
@media(min-width:880px){.page-hero__grid{grid-template-columns:0.82fr 1.18fr;gap:1.5rem}}

/* optional 2-col inner-page hero: text on the left, photo on the right.
   Photo shows on desktop only (>=920px); hidden on mobile to keep the
   phone hero tight and text-first. Stats stay full-width below the grid. */
.page-hero__grid{display:grid;grid-template-columns:1fr;gap:2rem;align-items:center}
.page-hero__media{display:none}
@media(min-width:920px){
  .page-hero__grid{grid-template-columns:0.82fr 1.18fr;gap:1.5rem}
  .page-hero__media{display:block}
  .page-hero__media img{width:100%;height:auto;aspect-ratio:3/2;object-fit:cover;border-radius:24px;box-shadow:0 24px 48px rgba(11,37,69,.16)}
}

/* prose container (article-style content) */
.prose{max-width:46rem;color:var(--ink);font-size:1.02rem;line-height:1.7}
.prose h2{
  font-size:clamp(1.5rem,2vw + .5rem,2rem);font-weight:760;letter-spacing:-.018em;
  margin:2.5rem 0 .9rem;color:var(--heading);line-height:1.2;text-wrap:balance;
}
.prose h2:first-child{margin-top:0}
.prose h3{
  font-size:1.2rem;font-weight:760;letter-spacing:-.01em;
  margin:2rem 0 .6rem;color:var(--heading);
}
.prose p{margin:0 0 1rem;color:var(--ink)}
.prose p:last-child{margin-bottom:0}
.prose strong{color:var(--ink);font-weight:700}
.prose a{color:var(--green-deep,#1a6932);font-weight:600}
.prose a:hover{text-decoration:underline}
/* Buttons inside .prose must keep their button colors, not inherit the
   green .prose-link color (specificity: .prose a (0,1,1) was overriding
   .btn--primary (0,1,0), turning the button text dark-green on green). */
.prose a.btn{font-weight:700}
.prose a.btn:hover{text-decoration:none}
.prose a.btn--primary{color:#fff}
.prose a.btn--ghost,.prose a.btn--ghost-warm{color:var(--navy-800)}
.prose ul:not(.included-check):not(.bento-cells){padding-left:1.25rem;margin:0 0 1.25rem}
.prose ul:not(.included-check):not(.bento-cells) li{margin-bottom:.5rem}

/* included check-list (replaces v1's .included-list) */
.included-check{list-style:none;padding:0;margin:0 0 1.5rem;display:grid;gap:.75rem}
.included-check li{
  position:relative;padding:.85rem 1rem .85rem 3rem;
  background:var(--bg-card);border:1px solid var(--line-soft);
  border-radius:var(--r-sm);
  color:var(--ink);
}
.included-check li::before{
  content:"\2713";
  position:absolute;left:.95rem;top:.95rem;
  width:1.5rem;height:1.5rem;
  background:var(--green-700);color:#fff;
  border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.85rem;line-height:1;
}
.included-check li strong{color:var(--ink);font-weight:700;display:inline}

/* simple v4 cta link (replaces .page-cta) */
.page-cta{margin:2.5rem 0 0;text-align:center}

/* alt section / warm stripe */
.section-stripe{background:var(--bg-2);padding:clamp(2.5rem,4vw + 1rem,4rem) 0}

/* contact form */
.contact-form{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:var(--r);padding:clamp(1.25rem,2vw + .5rem,2rem)}
.form-grid{display:grid;grid-template-columns:1fr;gap:1.1rem}
@media(min-width:680px){.form-grid--2{grid-template-columns:1fr 1fr;gap:1rem 1.25rem}}
.form-field{display:grid;gap:.4rem}
.form-field label{color:var(--ink);font-weight:600;font-size:.92rem}
.form-field input,.form-field select,.form-field textarea{
  font:inherit;font-size:1rem;
  width:100%;min-width:0;
  padding:.85rem 1rem;
  border:1px solid var(--line);background:#fff;color:var(--ink);
  border-radius:var(--r-sm);
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  outline:none;border-color:var(--green-700);box-shadow:0 0 0 3px rgba(31,122,58,.15);background:#fff;
}
.form-field textarea{min-height:7rem;resize:vertical}
.form-field--required label::after{content:" *";color:#b91c1c}
.form-help{font-size:.85rem;color:var(--ink-2);margin:.25rem 0 0}
.form-actions{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center;margin-top:.5rem}

/* contact page layout (ported from v1 styles.css so v4 contact renders the
   2-col form+sidebar correctly and hides the honeypot - these classes were
   referenced by contact.html but missing from v4.css). */
.contact-grid{display:grid;gap:2rem;grid-template-columns:minmax(0,1fr)}
@media(min-width:1000px){.contact-grid{grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:3rem;align-items:start}}
.contact-form-wrap h2,.contact-sidebar h2{font-size:clamp(1.4rem,1.5vw + .5rem,1.8rem);color:var(--heading);font-weight:760;letter-spacing:-.01em;margin:0 0 .5rem}
.contact-form{margin-top:1.25rem}
.form-row{display:grid;gap:1rem;grid-template-columns:minmax(0,1fr);margin-bottom:1rem}
@media(min-width:680px){.form-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}}
.form-row .form-field{margin-bottom:0}
.contact-form .form-field{margin-bottom:1rem}
/* Honeypot - visually hidden from real users (bots fill it; function drops it) */
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{margin-top:.75rem;color:var(--ink-2);font-size:.88rem}
.form-error{border:1px solid var(--c-danger,#b91c1c);border-left:4px solid var(--c-danger,#b91c1c);background:#fef2f2;color:var(--ink);border-radius:8px;padding:.75rem 1rem;margin:0 0 1.25rem;font-size:.95rem;line-height:1.5}
.form-error a{color:#b91c1c;font-weight:600}
.contact-sidebar{display:grid;gap:1rem;margin-top:2rem}
@media(min-width:1000px){.contact-sidebar{margin-top:0}}
.contact-card .muted,.muted{color:var(--ink-2);font-size:.88rem}
.contact-link{color:var(--green-700);font-weight:600}
.contact-link:hover{text-decoration:underline}

/* contact sidebar cards */
.contact-aside{display:grid;gap:1rem}
.contact-card{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:var(--r);padding:1.1rem 1.25rem}
.contact-card h3{margin:0 0 .35rem;font-size:.92rem;font-weight:700;color:var(--heading);text-transform:uppercase;letter-spacing:.08em}
.contact-card p,.contact-card address{margin:0;color:var(--ink);font-style:normal;line-height:1.55;font-size:.95rem}

/* city stat grid */
.city-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem;margin:1.5rem 0 0;background:var(--bg-card);padding:1rem;border-radius:var(--r);border:1px solid var(--line-soft)}
@media(min-width:760px){.city-stats{grid-template-columns:repeat(4,1fr)}}
.city-stats > div{text-align:center;padding:.5rem .25rem}
.city-stats strong{display:block;font-size:1.2rem;font-weight:800;color:var(--heading);letter-spacing:-.01em}
.city-stats span{display:block;font-size:.78rem;color:var(--ink-2);margin-top:.2rem;line-height:1.3}

/* city/service-area lists */
.city-list{display:grid;grid-template-columns:1fr;gap:.5rem;list-style:none;padding:0;margin:0}
@media(min-width:680px){.city-list{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.city-list{grid-template-columns:repeat(3,1fr)}}
.city-list li{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:var(--r-sm);padding:.85rem 1rem;color:var(--ink)}
.city-list li a{color:var(--ink);font-weight:600;text-decoration:none}
.city-list li a:hover{color:var(--green-700)}

/* service-area: city grids (clean multi-column chips; cities with their own
   page get a subtle highlight) + page headings (content sits in .area-page). */
.city-grid{list-style:none;padding:0;margin:1rem 0 1.5rem;display:grid;grid-template-columns:repeat(2,1fr);gap:.4rem .6rem}
@media(min-width:680px){.city-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1040px){.city-grid{grid-template-columns:repeat(4,1fr)}}
.city-grid li{padding:.45rem .7rem;border-radius:8px;color:var(--ink-2);font-size:.92rem;border:1px solid transparent}
.city-grid li:has(a){background:var(--bg-soft);border-color:var(--line-soft)}
.city-grid li a{color:var(--ink);font-weight:600}
.city-grid li a:hover{color:var(--green-700)}
.area-count{color:var(--ink-2);font-weight:500;font-size:.62em;letter-spacing:0}
.area-page > p{color:var(--ink-2);max-width:62ch;margin:0 0 .5rem}
.area-page > p a{color:var(--green-700);font-weight:600}
.area-page h2{font-size:clamp(1.5rem,2vw + .5rem,2rem);color:var(--heading);font-weight:760;letter-spacing:-.018em;line-height:1.2;margin:2.75rem 0 .4rem;text-wrap:balance}
.area-page > h2:first-child{margin-top:0}
.area-page h3{font-size:1.15rem;color:var(--heading);font-weight:760;margin:1.75rem 0 .3rem}
.area-page .included-check{max-width:46rem}

/* service-area coverage map (#2) */
.section--map{padding-top:0;padding-bottom:clamp(.875rem,1.25vw + .25rem,1.5rem)}  /* #12 tighten map->text */
.area-map{margin:0;border-radius:var(--r);overflow:hidden;border:1px solid var(--line-soft);box-shadow:0 12px 32px rgba(11,37,69,.10);background:#eaf5fc}
.area-map img{display:block;width:100%;height:auto}
.area-map figcaption{margin:0;padding:.85rem 1.15rem;font-size:.9rem;line-height:1.45;color:var(--ink-2);background:var(--bg-card);border-top:1px solid var(--line-soft)}

/* in-prose figure (e.g. QII photo on the Title 24 page) */
.prose-figure{margin:1.5rem 0;border-radius:var(--r);overflow:hidden;border:1px solid var(--line-soft)}
.prose-figure img{display:block;width:100%;height:auto}
.prose-figure figcaption{margin:0;padding:.7rem 1rem;font-size:.88rem;color:var(--ink-2);background:var(--bg-soft);border-top:1px solid var(--line-soft)}

/* booking page: lead with the calendar (compact title, then widget at top) */
.book-top{padding-top:clamp(1.75rem,3vw + .5rem,2.75rem)}
.book-top h1{font-size:clamp(1.8rem,2.5vw + .5rem,2.6rem);color:var(--heading);font-weight:760;letter-spacing:-.02em;line-height:1.1;margin:0 0 .5rem;text-wrap:balance}

/* booking page: Bookeo embed container + "prefer to talk to a human" fallback */
.booking-embed{min-height:240px;margin:1.5rem 0 2rem}
.booking-embed__loading{color:var(--ink-2)}
.booking-fallback{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:var(--r);padding:1.25rem 1.5rem;margin:1.5rem 0 2rem}
.booking-fallback h2{font-size:1.15rem;color:var(--heading);font-weight:760;margin:0 0 .5rem}
.booking-fallback p{margin:.35rem 0;color:var(--ink)}

/* legal pages */
.prose--legal h2{font-size:1.35rem;margin-top:2rem}
.prose--legal h3{font-size:1.05rem;margin-top:1.5rem}

/* FAQ items - style v1's .faq-item class directly so v4-ported pages
   render the accordion as a card with green + toggle, no .faq wrapper needed. */
.faq-item{
  background:var(--bg-card);border:1px solid var(--line-soft);
  border-radius:var(--r);
  padding:1.1rem 1.25rem;
  margin-bottom:.5rem;
  list-style:none;
}
.faq-item summary{
  list-style:none;cursor:pointer;
  font-weight:700;color:var(--heading);
  display:flex;justify-content:space-between;gap:1rem;align-items:center;
  padding-right:.25rem;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";color:var(--green-700);
  font-size:1.4rem;line-height:1;font-weight:600;
  transition:transform .2s cubic-bezier(.2,.7,.2,1);
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{margin:.85rem 0 0;color:var(--ink-2);line-height:1.6}
.faq-item p strong{color:var(--ink)}

/* Plain UL bullets inside .prose - green-disc bullets instead of default */
.prose ul:not(.included-check):not(.bento-cells){padding-left:1.25rem;margin:0 0 1.25rem;list-style:none}
.prose ul:not(.included-check):not(.bento-cells) li{position:relative;padding-left:1.25rem;margin-bottom:.5rem}
.prose ul:not(.included-check):not(.bento-cells) li::before{
  content:"";position:absolute;left:0;top:.7em;
  width:8px;height:8px;border-radius:50%;background:var(--green-700);
}

/* Page-CTA centered standalone link */
.prose .page-cta,
.section .page-cta{margin:2.5rem 0 1rem;text-align:center}

/* Ensure .section has enough breathing room above footer when a single-CTA closes a page */
main > .section:last-child{padding-bottom:clamp(3rem,4vw + 1rem,5rem)}

/* CTA-band on inner pages - margin reset */
.cta-band{margin-top:0}

/* footer grid */
.site-footer{padding:clamp(3rem,4vw + 1rem,4.5rem) 0 1.5rem;background:var(--navy-900);color:#9aa9bf;font-size:.92rem}
.site-footer a{color:#c7d6ea;text-decoration:none}
.site-footer a:hover{color:#fff;text-decoration:underline}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.1)}
@media(min-width:760px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr;gap:3rem}}
.brand--footer{color:#fff;margin-bottom:.85rem;display:inline-flex}
.brand--footer .brand__name{color:#fff;font-size:1.05rem}
.footer-tag{margin:.75rem 0 0;line-height:1.6;color:#9aa9bf;max-width:32ch}
.site-footer h3{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;margin:0 0 1rem;font-weight:800}
.site-footer ul{list-style:none;padding:0;margin:0;display:grid;gap:.5rem}
.site-footer address{font-style:normal;line-height:1.7;color:#9aa9bf}
.footer-hours{display:block;margin-top:.4rem;color:#6f83a0;font-size:.82rem}
.footer-soon{color:#6f83a0}
.footer-bar{display:flex;flex-direction:column;gap:.6rem;padding-top:1.5rem;font-size:.82rem;color:#6f83a0;text-align:center}
@media(min-width:760px){.footer-bar{flex-direction:row;justify-content:space-between;align-items:center;text-align:left}}
.footer-bar p{margin:0}

/* ==== v5 unified header (mobile + desktop matched) ==== */
.header-phone{display:none}
.primary-nav__portal{display:inline-flex;align-items:center;gap:.3rem}
.topbar{display:none}                          /* navy utility bar removed on all viewports */
.eyebrow--lg{font-size:1.55rem;letter-spacing:.05em;line-height:1.12}
.process-step__num{font-size:1.55rem;padding:.45rem .95rem}
@media(min-width:1000px){
  .primary-nav{flex:1;display:flex;justify-content:center}   /* #2 center nav between logo and buttons */
  .primary-nav ul{gap:1.2rem}
  .primary-nav a{font-size:1.035rem}   /* header menu font (was 1.15rem, now 90%) */
  .header-phone{display:inline-flex;padding-left:.4rem;padding-right:.4rem;margin-right:-.8rem}  /* width matches Book Now; -.8rem => .7rem gap to Book Now (matches page-hero CTAs) */
}

/* ==== v5 batch 3 ==== */
#services{padding-top:clamp(1.75rem,2.5vw + .5rem,3rem)}        /* #7 halve gap above What we do */
.section--map + .section{padding-top:clamp(.875rem,1.25vw + .25rem,1.5rem)}  /* #12 tighten map->text */
@media(min-width:1000px){
  #how-heading{white-space:nowrap}                              /* #8 one line on desktop */
  #how .section-head{max-width:none}
}
