/* ============================================================
   seesmile Dental Studio — brand styles
   ============================================================ */

/* ---------- Fonts ---------- */
@font-face{font-family:"Domaine Display Narrow";src:url("assets/fonts/DomaineDispNar-Regular.otf") format("opentype");font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:"Domaine Display Narrow";src:url("assets/fonts/DomaineDispNar-RegularItalic.otf") format("opentype");font-weight:400;font-style:italic;font-display:swap;}
@font-face{font-family:"Domaine Display Narrow";src:url("assets/fonts/DomaineDispNar-Medium.otf") format("opentype");font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:"Domaine Display Narrow";src:url("assets/fonts/DomaineDispNar-MediumItalic.otf") format("opentype");font-weight:500;font-style:italic;font-display:swap;}
@font-face{font-family:"Domaine Display Narrow";src:url("assets/fonts/DomaineDispNar-Semibold.otf") format("opentype");font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:"Domaine Display Narrow";src:url("assets/fonts/DomaineDispNar-Bold.otf") format("opentype");font-weight:700;font-style:normal;font-display:swap;}

@font-face{font-family:"Lexend Deca";src:url("assets/fonts/LexendDeca-Light.ttf") format("truetype");font-weight:300;font-style:normal;font-display:swap;}
@font-face{font-family:"Lexend Deca";src:url("assets/fonts/LexendDeca-Regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:"Lexend Deca";src:url("assets/fonts/LexendDeca-Medium.ttf") format("truetype");font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:"Lexend Deca";src:url("assets/fonts/LexendDeca-SemiBold.ttf") format("truetype");font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:"Lexend Deca";src:url("assets/fonts/LexendDeca-Bold.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap;}

/* ---------- Tokens ----------
   BRAND PALETTE (the ONLY allowed colors, + black & white):
   Hooker's green #51726F · Cambridge blue #A5C2AE · Ash gray #C0D3C0
   Alabaster #E4E6D8 · Alabaster #EFE9DF · Dun #D8C4B2 · Beaver #A0826D
*/
:root{
  /* core palette */
  --green:#51726F;        /* Hooker's green */
  --cambridge:#A5C2AE;    /* Cambridge blue */
  --ash:#C0D3C0;          /* Ash gray */
  --alabaster-cool:#E4E6D8; /* Alabaster (cooler) */
  --alabaster:#EFE9DF;    /* Alabaster (warm) — default page bg */
  --dun:#D8C4B2;          /* Dun */
  --beaver:#A0826D;       /* Beaver */
  --cream:#FFFFFF;
  --white:#FFFFFF;

  /* aliases kept for existing rules (all map onto the palette) */
  --green-700:#51726F;
  --green-900:#51726F;
  --beaver-700:#A0826D;
  --ink:#000000;
  --ink-soft:color-mix(in srgb,#000 70%,transparent);
  --ink-max:#000000;

  --serif:"Domaine Display Narrow",Georgia,serif;
  --sans:"Lexend Deca",system-ui,sans-serif;

  --hairline:1px solid color-mix(in srgb, var(--green) 18%, transparent);
  --radius-card:16px;
  --radius-lg:24px;

  --maxw:1280px;
  --gutter:clamp(22px,5vw,56px);

  --scrim:0.42; /* hero overlay strength, tweakable */
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--alabaster);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  font-size:16px;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}

/* ---------- Reusable type ---------- */
.eyebrow{
  font-family:var(--sans);
  font-weight:600;
  font-size:11px;
  letter-spacing:0.26em;
  text-transform:uppercase;
  color:var(--green);
  display:inline-flex;
  align-items:center;
  gap:14px;
}
.eyebrow::before{
  content:"";
  width:34px;height:1px;
  background:currentColor;
  opacity:.55;
}
.eyebrow.center::after{
  content:"";
  width:34px;height:1px;
  background:currentColor;
  opacity:.55;
}
.eyebrow.center{justify-content:center;}
.eyebrow.no-rule::before{display:none;}

h1,h2,h3{font-family:var(--serif);font-weight:500;color:var(--ink-max);letter-spacing:-0.01em;line-height:1.04;margin:0;text-wrap:balance;}
.h1{font-size:clamp(45px,7vw,96px);font-weight:500;line-height:0.98;letter-spacing:-0.02em;}
.h2{font-size:clamp(32px,4.4vw,54px);letter-spacing:-0.02em;}
.lead{font-size:clamp(16px,1.4vw,19px);color:var(--ink-soft);max-width:42ch;text-wrap:pretty;}
em,.it{font-style:italic;}

/* ---------- Layout ---------- */
.section{padding:clamp(72px,10vw,140px) var(--gutter);}
.wrap{max-width:var(--maxw);margin:0 auto;}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--green);--fg:var(--cream);--bd:transparent;
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--sans);font-weight:600;font-size:12px;
  letter-spacing:0.12em;text-transform:uppercase;
  padding:15px 28px;border-radius:999px;
  background:var(--bg);color:var(--fg);border:1.5px solid var(--bd);
  cursor:pointer;transition:transform .25s cubic-bezier(.2,.7,.3,1),background .25s,color .25s,box-shadow .25s;
  white-space:nowrap;
}
.btn .arrow{transition:transform .3s cubic-bezier(.2,.7,.3,1);}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px -14px rgba(0,0,0,.55);}
.btn:hover .arrow{transform:translate(4px,0);}
.btn--light{--bg:var(--cream);--fg:var(--green-900);}
.btn--outline{--bg:transparent;--fg:var(--green-900);--bd:color-mix(in srgb,var(--green) 40%, transparent);}
.btn--outline-light{--bg:transparent;--fg:var(--cream);--bd:color-mix(in srgb,#fff 55%, transparent);}
/* On light sections the "outline-light" CTA (cream text) is unreadable — remap to green, like hero--light/ctaband already do. */
.firstvisit .btn--outline-light{--fg:var(--green-900);--bd:color-mix(in srgb,var(--green) 45%, transparent);}
.btn--ghost{--bg:transparent;--fg:var(--green);--bd:color-mix(in srgb,var(--green) 30%, transparent);}

/* ---------- Placeholder imagery ---------- */
.ph{
  position:relative;overflow:hidden;
  background:
    repeating-linear-gradient(135deg,
      color-mix(in srgb,var(--cambridge) 32%,transparent) 0 14px,
      color-mix(in srgb,var(--cambridge) 20%,transparent) 14px 28px);
  border-radius:var(--radius-lg);
  isolation:isolate;
}
.ph::after{
  content:attr(data-ph);
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:ui-monospace,"SFMono-Regular",Menlo,monospace;
  font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--green-700);opacity:.62;text-align:center;
  padding:10px 16px;border:1px dashed color-mix(in srgb,var(--green) 45%,transparent);
  border-radius:8px;background:color-mix(in srgb,var(--cream) 60%,transparent);
  max-width:80%;line-height:1.5;
}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.3,1),transform .9s cubic-bezier(.2,.7,.3,1);}
.reveal.in{opacity:1;transform:none;}
.reveal[data-d="1"]{transition-delay:.08s;}
.reveal[data-d="2"]{transition-delay:.16s;}
.reveal[data-d="3"]{transition-delay:.24s;}
.reveal[data-d="4"]{transition-delay:.32s;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:sticky;top:0;left:0;right:0;z-index:50;background:var(--green);transition:box-shadow .4s ease,padding .4s ease;padding:8px var(--gutter);}
.nav__inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px;height:84px;}
.nav__logo-img{height:51px;width:auto;}
.nav__logo-img--green{display:none;}
.nav__links{display:flex;gap:clamp(18px,2.4vw,40px);font-size:15px;font-weight:400;color:var(--cream);}
.nav__links a{position:relative;padding:6px 0;opacity:.92;transition:opacity .25s;}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:currentColor;transition:right .3s cubic-bezier(.2,.7,.3,1);}
.nav__links a:hover{opacity:1;}
.nav__links a:hover::after{right:0;}
.nav__actions{display:flex;align-items:center;gap:14px;}
.nav__cta{padding:14px 24px;font-size:12px;background:var(--cream);color:var(--green-900);}
.nav__burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;border:none;background:transparent;cursor:pointer;padding:0;}
.nav__burger span{display:block;height:2px;width:24px;margin:0 auto;background:var(--cream);transition:transform .3s,opacity .3s;}

/* scrolled state — solid green bar, just deepen the shadow */
.nav.scrolled{box-shadow:0 6px 26px -18px rgba(0,0,0,.6);}

/* The bar is always green, so the logo/menu/CTA keep their cream (light)
   treatment in every state — including the light-hero `nav--dark` pages. */

/* mobile menu */
.mobilemenu[hidden]{display:none;}
.mobilemenu{position:fixed;inset:0;z-index:45;background:var(--green-900);color:var(--cream);display:flex;flex-direction:column;justify-content:center;gap:40px;padding:var(--gutter);animation:menuin .35s ease;}
@keyframes menuin{from{opacity:0;}to{opacity:1;}}
.mobilemenu__links{display:flex;flex-direction:column;gap:2px;font-family:var(--sans);font-size:18px;font-weight:500;letter-spacing:.01em;}
.mobilemenu__links a{padding:13px 0;border-bottom:1px solid color-mix(in srgb,#fff 14%,transparent);}
.mobilemenu__foot{display:flex;flex-direction:column;gap:14px;}
.mobilemenu__foot .btn{justify-content:center;}
body.menu-open{overflow:hidden;}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:calc(100svh - 100px);display:flex;align-items:flex-end;padding:0 var(--gutter) clamp(48px,7vh,84px);overflow:hidden;}
.hero__media{position:absolute;inset:0;border-radius:0;object-fit:cover;width:100%;height:100%;object-position:60% 40%;}
@media (max-width:680px){.hero__media{object-position:26% 50%;}}
/* services hero: raise the image so more of the storefront (planter + ground) shows */
#services-img1{object-position:60% 60%;}
@media (max-width:680px){#services-img1{object-position:50% 60%;}}
.hero__scrim{position:absolute;inset:0;pointer-events:none;background:
  linear-gradient(180deg, rgba(0,0,0,0.14) 0%, rgba(0,0,0,0.02) 38%, rgba(0,0,0,0.12) 62%, rgba(0,0,0,0.62) 100%);}
.hero__inner{position:relative;width:100%;color:var(--cream);}
.eyebrow--ondark{color:color-mix(in srgb,var(--cream) 88%,transparent);text-shadow:0 1px 2px rgba(0,0,0,.5),0 1px 14px rgba(0,0,0,.6);}
.hero__title{color:#fff;max-width:22ch;margin-top:20px;text-shadow:0 1px 2px rgba(0,0,0,.38),0 2px 26px rgba(0,0,0,.45);}
.hero__title em{color:var(--dun);}
.hero__sub{max-width:46ch;margin:26px 0 0;font-size:clamp(16px,1.3vw,19px);color:color-mix(in srgb,var(--cream) 92%,transparent);line-height:1.6;}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px;}
.hero__trust{display:flex;flex-wrap:wrap;gap:14px 32px;list-style:none;margin:38px 0 0;padding:30px 0 0;border-top:1px solid color-mix(in srgb,#fff 22%,transparent);font-size:14px;letter-spacing:.02em;color:color-mix(in srgb,var(--cream) 85%,transparent);}
.hero__trust li{position:relative;}

/* ============================================================
   TAGLINE BAND
   ============================================================ */
.band{background:var(--green);color:var(--cream);padding:clamp(70px,9vw,120px) var(--gutter);text-align:center;}
/* Plain tagline band (index): white surface with green text per the white→green rule */
.band:not(.band--soft){background:var(--white);color:var(--green);border-top:1px solid color-mix(in srgb,var(--green) 14%,transparent);border-bottom:1px solid color-mix(in srgb,var(--green) 14%,transparent);}
.band:not(.band--soft) .eyebrow--onband{color:color-mix(in srgb,var(--green) 78%,transparent);}
.band:not(.band--soft) .band__tagline{color:var(--green);}
.eyebrow--onband{color:color-mix(in srgb,var(--cream) 80%,transparent);}
.band__tagline{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(37px,6vw,70px);line-height:1.05;margin:22px 0 0;color:var(--cream);}

/* Soft, lighter band variant (sage tint, dark type) */
.band--soft{background:color-mix(in srgb,var(--cambridge) 42%,#fff);color:var(--ink);}
.band--soft .band__tagline{color:var(--green);}
.band--soft .eyebrow--onband{color:var(--green-700);opacity:.8;}
.band--soft .band__body{color:var(--green)!important;}

/* ============================================================
   OUR VISION
   ============================================================ */
.vision{background:var(--white);}
.vision__grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(40px,6vw,96px);align-items:center;}
.vision__media{aspect-ratio:4/5;}
.vision__text{display:flex;flex-direction:column;gap:18px;}
.vision__text .h2{margin:6px 0 8px;}
.vision__text p{margin:0;max-width:50ch;}
.vision__text .eyebrow,.vision__text .h2,.vision__text p{color:var(--green);}

/* ============================================================
   SECTION HEADS
   ============================================================ */
.sechead{display:flex;flex-direction:column;gap:14px;max-width:760px;margin-bottom:clamp(44px,5vw,72px);}
.sechead .h2{margin-top:4px;}
.sechead .lead{margin:0;}

/* ============================================================
   WHY CHOOSE
   ============================================================ */
.why{background:var(--alabaster);}
.why__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,32px);}
.pcard{background:var(--white);border:var(--hairline);border-radius:var(--radius-card);padding:clamp(28px,3vw,40px);display:flex;flex-direction:column;gap:16px;transition:transform .4s cubic-bezier(.2,.7,.3,1),box-shadow .4s;}
.pcard:hover{transform:translateY(-4px);box-shadow:0 26px 50px -34px rgba(0,0,0,.5);}
.pcard__num{font-family:var(--serif);font-size:40px;font-weight:600;color:var(--beaver);line-height:1;}
.pcard__title{font-size:24px;font-weight:600;color:var(--ink-max);}
.pcard p{margin:0;font-size:16px;color:var(--ink-soft);}

/* ============================================================
   SERVICES
   ============================================================ */
.services{background:var(--white);}
.svc__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,1.6vw,22px);}
.svc{position:relative;background:var(--cream);border:var(--hairline);border-radius:var(--radius-card);padding:clamp(30px,3vw,42px);display:flex;flex-direction:column;gap:14px;transition:transform .4s cubic-bezier(.2,.7,.3,1),box-shadow .4s,background .4s;}
.svc::before{content:"";position:absolute;left:clamp(30px,3vw,42px);top:0;width:32px;height:2px;background:var(--cambridge);border-radius:2px;}
.svc:hover{transform:translateY(-4px);box-shadow:0 24px 46px -34px rgba(0,0,0,.5);}
.svc__title{font-size:clamp(23px,1.7vw,27px);font-weight:600;color:var(--ink-max);margin-top:6px;}
.svc p{margin:0;font-size:16px;color:var(--ink-soft);flex:1;}
.svc--feature{background:var(--white);border-color:color-mix(in srgb,var(--green) 26%,transparent);}
.svc--feature::before{background:var(--green);}
.svc__link{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin-top:4px;}
.svc__link .arrow{transition:transform .3s cubic-bezier(.2,.7,.3,1);}
.svc__link:hover .arrow{transform:translateX(4px);}

/* ============================================================
   FIRST VISIT
   ============================================================ */
.firstvisit{background:var(--alabaster);}
.firstvisit__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,88px);align-items:center;}
.firstvisit__text{display:flex;flex-direction:column;gap:32px;}
.firstvisit__text .eyebrow{color:var(--beaver-700);}
.firstvisit__intro{margin:14px 0 0;color:var(--ink-soft);}
.steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;}
.step{display:flex;gap:24px;padding:24px 0;border-top:1px solid color-mix(in srgb,var(--green-900) 16%,transparent);}
.step:last-child{border-bottom:1px solid color-mix(in srgb,var(--green-900) 16%,transparent);}
.step__num{font-family:var(--serif);font-size:22px;font-weight:600;color:var(--beaver-700);min-width:34px;line-height:1.4;}
.step__title{font-size:21px;font-weight:600;color:var(--ink-max);margin-bottom:4px;}
.step p{margin:0;font-size:16px;color:var(--ink-soft);}
.firstvisit__cta{display:flex;flex-wrap:wrap;gap:14px;}
.firstvisit__media{align-self:stretch;min-height:520px;}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:#51726F;color:color-mix(in srgb,var(--cream) 86%,transparent);padding:clamp(48px,5vw,72px) var(--gutter) 36px;}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:clamp(32px,4vw,64px);padding-bottom:clamp(28px,3vw,40px);border-bottom:1px solid color-mix(in srgb,#fff 12%,transparent);}
.footer__logo{height:51px;width:auto;}
.footer__blurb{margin:22px 0 0;max-width:36ch;font-size:15.5px;line-height:1.6;}
.footer__col h3{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--cambridge);margin:0 0 18px;}
.footer__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px;font-size:15.5px;}
.footer__col a{opacity:.88;transition:opacity .2s;}
.footer__col a:hover{opacity:1;}
.footer__contact li{line-height:1.5;}
.footer__addr{margin:0;font-size:15.5px;line-height:1.55;font-style:normal;color:color-mix(in srgb,var(--cream) 82%,transparent);max-width:30ch;}
.footer__contactblock{margin-top:26px;}
.footer__contactblock h3{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--cambridge);margin:0 0 14px;}
.footer__contactblock ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:13px;font-size:15.5px;line-height:1.5;}
.footer__contactblock li{display:flex;align-items:flex-start;gap:12px;}
.footer__contactblock li svg{flex:0 0 auto;width:17px;height:17px;margin-top:2px;color:var(--cambridge);}
.footer__contactblock address{font-style:normal;}
.footer__hourlist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px;font-size:15px;}
.footer__hourlist li{display:flex;justify-content:space-between;gap:18px;line-height:1.4;}
.footer__hourlist .day{color:color-mix(in srgb,var(--cream) 82%,transparent);}
.footer__hourlist .time{font-weight:600;color:var(--cream);font-variant-numeric:tabular-nums;white-space:nowrap;}
.footer__hourlist li.is-closed .time{font-weight:500;color:color-mix(in srgb,var(--cream) 55%,transparent);}
.footer__hours{margin-top:clamp(24px,2.5vw,32px);}
.footer__hours-title{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--cambridge);margin:0 0 18px;}
.hours{margin:0;display:flex;flex-wrap:wrap;}
.hours__row{flex:1;min-width:92px;display:flex;flex-direction:column;gap:7px;padding:2px 22px;border-left:1px solid color-mix(in srgb,var(--cream) 13%,transparent);}
.hours__row:first-child{border-left:none;padding-left:0;}
.hours dt{font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:color-mix(in srgb,var(--cream) 80%,transparent);}
.hours dd{margin:0;font-size:15px;font-weight:600;color:var(--cream);font-variant-numeric:tabular-nums;white-space:nowrap;}
@media (max-width:760px){
  .hours__row{flex:0 0 calc(50% - 22px);min-width:0;padding:8px 0;border-left:none;border-top:1px solid color-mix(in srgb,var(--cream) 13%,transparent);}
  .hours__row:first-child,.hours__row:nth-child(2){border-top:none;}
  .hours__row:nth-child(even){padding-left:22px;border-left:1px solid color-mix(in srgb,var(--cream) 13%,transparent);}
}
.footer__fine{margin-top:32px;display:flex;flex-direction:column;gap:16px;}
.footer__disclaimer{font-size:12.5px;line-height:1.6;color:color-mix(in srgb,var(--cream) 55%,transparent);max-width:90ch;margin:0;}
.footer__copy{font-size:12.5px;color:color-mix(in srgb,var(--cream) 55%,transparent);margin:0;}

/* ============================================================
   MOBILE STICKY BAR
   ============================================================ */
.stickybar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:40;padding:12px 16px calc(12px + env(safe-area-inset-bottom));gap:12px;background:color-mix(in srgb,var(--alabaster) 92%,transparent);backdrop-filter:blur(14px);box-shadow:0 -1px 0 color-mix(in srgb,var(--green) 16%,transparent);}
.stickybar__book{flex:1;justify-content:center;background:var(--green);color:var(--cream);height:52px;min-width:0;}
.stickybar__icon{flex:none;width:52px;height:52px;display:grid;place-items:center;border-radius:50%;background:var(--cream);border:1.5px solid color-mix(in srgb,var(--green) 24%,transparent);color:var(--green);cursor:pointer;transition:background .25s,border-color .25s,transform .2s cubic-bezier(.2,.7,.3,1);}
.stickybar__icon svg{width:22px;height:22px;}
.stickybar__icon:active{transform:scale(.94);}
.stickybar__icon:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--green) 40%,transparent);}
@media (prefers-reduced-motion:reduce){.stickybar__icon{transition:none;}.stickybar__icon:active{transform:none;}}

/* ---------- /book page enhancements (booking) — sticky bar scoped to .bookpage ---------- */
@media (max-width:980px){
  body.bookpage{padding-bottom:calc(80px + env(safe-area-inset-bottom));}
  body.bookpage .stickybar{display:flex;align-items:center;}
  body.bookpage .stickybar__book{white-space:nowrap;}
}
.booking__rt{display:flex;align-items:center;gap:9px;justify-content:center;margin:0 0 18px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--green);}
.booking__rt::before{content:"";width:8px;height:8px;border-radius:50%;background:#5fb98a;box-shadow:0 0 0 4px color-mix(in srgb,#5fb98a 22%,transparent);}
.booking__skeleton{height:620px;max-width:1000px;margin:0 auto;}
.booking__fallback{margin:18px auto 0;max-width:60ch;text-align:center;color:var(--ink-soft);font-size:15px;line-height:1.55;}
.bookrating{display:flex;flex-direction:column;align-items:center;gap:12px;}
.bookrating__stars{display:inline-flex;gap:3px;color:#e3b341;}
.bookrating__stars svg{width:20px;height:20px;}
.bookrating__label{font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--green);}
.bookrating__quote{max-width:56ch;text-align:center;font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.4vw,28px);line-height:1.36;color:var(--ink-max);margin:0;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .vision__grid,.firstvisit__grid{grid-template-columns:1fr;}
  .vision__media{aspect-ratio:16/10;}
  .firstvisit__media{min-height:420px;order:-1;}
  .why__grid{grid-template-columns:1fr;}
  .svc__grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:980px){
  .nav__links,.nav__cta{display:none;}
  .nav__burger{display:flex;}
}
@media (max-width:560px){
  .svc__grid{grid-template-columns:1fr;}
  .hero__cta .btn{flex:1;justify-content:center;}
  .footer__grid{grid-template-columns:1fr 1fr;}
  .footer__brand{grid-column:1/-1;}
}

/* ============================================================
   ============  INNER PAGES (shared components)  =============
   ============================================================ */

/* active nav link */
.nav__links a[aria-current="page"]{opacity:1;}
.nav__links a[aria-current="page"]::after{right:0;}

/* ---------- Inner hero ---------- */
.hero--inner{min-height:clamp(620px,70vh,760px);padding-top:clamp(56px,8vh,96px);}
.hero--inner .hero__title{max-width:18ch;font-size:clamp(42px,5.4vw,80px);}
.hero--inner .hero__sub{max-width:50ch;}
.hero__note{display:inline-flex;align-items:center;gap:10px;margin:22px 0 0;font-size:13.5px;letter-spacing:.01em;color:color-mix(in srgb,var(--cream) 88%,transparent);background:color-mix(in srgb,#000 18%,transparent);border:1px solid color-mix(in srgb,#fff 26%,transparent);padding:10px 16px;border-radius:999px;backdrop-filter:blur(6px);}
.hero__note::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--cambridge);flex:none;}

/* ---------- Light hero variant (for bright studio photos) ---------- */
.hero--light{background:var(--alabaster);}
.hero--light .hero__media{object-fit:contain;object-position:right center;-webkit-mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,0.35) 26%,#000 48%);mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,0.35) 26%,#000 48%);}
.hero--light .hero__scrim{display:none;}
.hero--light .hero__inner{color:#000;}
.hero--light .hero__title{color:#000;text-shadow:none;}
.hero--light .hero__title em{color:var(--beaver);}
.hero--light .eyebrow--ondark{color:var(--green);}
.hero--light .hero__sub{color:color-mix(in srgb,#000 78%,transparent);}
.hero--light .hero__note{color:color-mix(in srgb,#000 74%,transparent);background:color-mix(in srgb,#000 6%,transparent);border-color:color-mix(in srgb,#000 14%,transparent);}
.hero--light .btn--light{--bg:var(--green);--fg:#fff;}
.hero--light .btn--outline-light{--bg:transparent;--fg:var(--green);--bd:color-mix(in srgb,var(--green) 45%,transparent);}

/* ---------- Generic prose / lead ---------- */
.prose{max-width:68ch;display:flex;flex-direction:column;gap:18px;}
.prose p{margin:0;color:var(--ink-soft);font-size:clamp(16px,1.15vw,18px);}

/* ---------- Two-column split (text + image) ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,96px);align-items:center;}
.split--flip .split__media{order:-1;}
.split__text{display:flex;flex-direction:column;gap:18px;}
.split__text .h2{margin:6px 0 4px;}
.split__text p{margin:0;max-width:52ch;color:var(--ink-soft);}
.split__media{aspect-ratio:4/5;align-self:stretch;overflow:hidden;border-radius:var(--radius-lg);width:100%;height:auto;display:block;}
.split__media img{width:100%;height:100%;object-fit:cover;}
image-slot.reveal{display:block;height:auto;}
.split--wide .split__media{aspect-ratio:5/4;}

/* ---------- Centered section intro ---------- */
.lede{max-width:780px;}
.lede.center{margin-inline:auto;text-align:center;}
.lede.center .eyebrow{justify-content:center;}
.lede.center .eyebrow::before{display:none;}
.lede .h2{margin:14px 0 0;}
.lede p{margin:18px 0 0;color:var(--ink-soft);}

/* ---------- Benefit cards grid ---------- */
.bgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,26px);}
.bgrid--2{grid-template-columns:repeat(2,1fr);}
.bcard{position:relative;background:var(--white);border:var(--hairline);border-radius:var(--radius-card);padding:clamp(28px,2.6vw,38px);display:flex;flex-direction:column;gap:12px;transition:transform .4s cubic-bezier(.2,.7,.3,1),box-shadow .4s;}
.bcard:hover{transform:translateY(-4px);box-shadow:0 24px 46px -34px rgba(0,0,0,.5);}
.bcard__ico{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:color-mix(in srgb,var(--cambridge) 38%,transparent);color:var(--green-700);margin-bottom:4px;}
.bcard__ico svg{width:24px;height:24px;}
.bcard h3{font-size:clamp(20px,1.5vw,24px);font-weight:600;color:var(--ink-max);}
.bcard p{margin:0;font-size:15.5px;color:var(--ink-soft);}
.section--cream .bcard{background:var(--cream);}

/* ---------- Process / timeline ---------- */
.process{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,2.4vw,30px) clamp(36px,5vw,72px);}
.process--3{grid-template-columns:repeat(3,1fr);}
.pstep{position:relative;display:flex;flex-direction:column;gap:10px;padding-top:30px;border-top:2px solid color-mix(in srgb,var(--green) 22%,transparent);}
.pstep__num{font-family:var(--serif);font-weight:600;font-size:clamp(34px,3.2vw,46px);line-height:1;color:var(--beaver);}
.pstep h3{font-size:clamp(19px,1.4vw,23px);font-weight:600;color:var(--ink-max);}
.pstep p{margin:0;font-size:15.5px;color:var(--ink-soft);}
.section--white .pstep__num,.services .pstep__num,.vision .pstep__num,.bg-white .pstep__num,.bg-cream .pstep__num{color:var(--green);}
.section--cream .pstep__num,.firstvisit .pstep__num,.why .pstep__num,.bg-alabaster .pstep__num{color:var(--beaver);}

/* ---------- Compare two options ---------- */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.4vw,30px);}
.ccard{border-radius:var(--radius-lg);padding:clamp(30px,3vw,44px);display:flex;flex-direction:column;gap:20px;}
.ccard--a{background:var(--green);color:var(--cream);}
.ccard--b{background:var(--white);border:var(--hairline);color:var(--ink);}
.ccard h3{font-size:clamp(24px,2vw,32px);font-weight:600;color:inherit;}
.ccard--a h3{color:#fff;}
.ccard .checklist li{color:inherit;}
.ccard--a .checklist li::before{border-color:color-mix(in srgb,#fff 60%,transparent);color:var(--cream);}
.ccard__tag{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;opacity:.8;}

/* ---------- Checklist ---------- */
.checklist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px;}
.checklist li{position:relative;padding-left:38px;font-size:16px;line-height:1.5;color:var(--ink-soft);}
.checklist li::before{content:"";position:absolute;left:0;top:1px;width:22px;height:22px;border-radius:50%;border:1.5px solid color-mix(in srgb,var(--green) 45%,transparent);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2351726F' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12.5l4 4 10-10'/%3E%3C/svg%3E");background-size:13px;background-repeat:no-repeat;background-position:center;}
.ccard--a .checklist li::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12.5l4 4 10-10'/%3E%3C/svg%3E");}

/* ---------- Count list (why-choose 6-up) ---------- */
.countlist{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(2px,0,2px);border:var(--hairline);border-radius:var(--radius-lg);overflow:hidden;background:color-mix(in srgb,var(--green) 16%,transparent);}
.countlist li{list-style:none;background:var(--white);padding:clamp(26px,2.4vw,34px);display:flex;flex-direction:column;gap:8px;}
.countlist .ci-num{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--beaver);}
.countlist h3{font-size:19px;font-weight:600;color:var(--ink-max);}
.countlist p{margin:0;font-size:15px;color:var(--ink-soft);}
.section--cream .countlist li{background:var(--cream);}

/* ---------- FAQ accordion ---------- */
.faq{max-width:880px;margin:0;border-top:1px solid color-mix(in srgb,var(--green) 18%,transparent);}
.faq__item{border-bottom:1px solid color-mix(in srgb,var(--green) 18%,transparent);}
.faq__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:24px;text-align:left;background:none;border:none;cursor:pointer;padding:22px 4px;font-family:var(--sans);font-size:clamp(16px,1.25vw,18px);font-weight:600;color:var(--ink-max);line-height:1.4;transition:opacity .2s;}
.faq__q:hover{opacity:.72;}
.faq__icon{position:relative;flex:none;width:18px;height:18px;color:inherit;}
.faq__icon::before{content:"";position:absolute;left:50%;top:38%;width:9px;height:9px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:translate(-50%,-50%) rotate(45deg);transition:transform .3s cubic-bezier(.2,.7,.3,1);}
.faq__item.open .faq__icon::before,.faq__q[aria-expanded="true"] .faq__icon::before{transform:translate(-50%,-30%) rotate(225deg);}
.faq__a{overflow:hidden;height:0;transition:height .4s cubic-bezier(.2,.7,.3,1);}
.faq__a-inner{padding:0 4px 28px;max-width:74ch;color:var(--ink-soft);font-size:16px;line-height:1.65;}

/* ---------- CTA band ----------
   Its OWN full-bleed green section with an asymmetric editorial layout:
   an oversized headline on the left, supporting copy + actions on the right. */
.ctaband{background:var(--white);padding:clamp(52px,7vw,92px) var(--gutter);}
#referral{padding-bottom:clamp(72px,10vw,140px);}
.ctaband .ctaband__inner{background:var(--ash);color:var(--ink-max);border-radius:clamp(24px,3vw,36px);max-width:1000px;margin:0 auto;padding:clamp(48px,7vw,84px) clamp(28px,6vw,64px);}
.ctaband__text{display:flex;flex-direction:column;align-items:center;text-align:center;gap:15px;max-width:680px;margin:0 auto;}
.ctaband__text .eyebrow{color:var(--green);justify-content:center;}
.ctaband__text .eyebrow::before{background:color-mix(in srgb,var(--green) 55%,transparent);}
.ctaband h2{color:var(--green);margin:0;max-width:20ch;font-size:clamp(32px,3.8vw,54px);line-height:1.03;letter-spacing:-0.02em;}
.ctaband__sub{margin:0;max-width:48ch;color:var(--green);font-size:clamp(16px,1.2vw,19px);line-height:1.6;}
.ctaband__btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:8px;}
.ctaband__media{display:none;}
.referral__contact{display:flex;flex-wrap:wrap;justify-content:center;gap:12px 36px;margin-top:16px;}
.referral__contact a{display:inline-flex;align-items:center;gap:10px;color:var(--green);font-family:var(--sans);font-weight:600;font-size:clamp(15px,1.2vw,17px);text-decoration:none;transition:opacity .2s;}
.referral__contact a:hover{opacity:.7;}
.referral__contact svg{width:20px;height:20px;flex:none;}
.ctaband .btn--light{--bg:var(--green);--fg:var(--cream);}
.ctaband .btn--light:hover{box-shadow:0 14px 30px -16px rgba(0,0,0,.4);}
.ctaband .btn--outline-light{--bg:transparent;--fg:var(--green);--bd:color-mix(in srgb,var(--green) 45%,transparent);}

/* ---------- Forms ---------- */
.formwrap{background:var(--white);border:var(--hairline);border-radius:var(--radius-lg);padding:clamp(28px,3.2vw,48px);}
.form{display:flex;flex-direction:column;gap:20px;}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.field{display:flex;flex-direction:column;gap:8px;}
.field.full{grid-column:1/-1;}
.field label{font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--ink-soft);}
.field label .req{color:var(--beaver);}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:16px;color:var(--ink-max);background:var(--cream);border:1.5px solid color-mix(in srgb,var(--green) 16%,transparent);border-radius:12px;padding:14px 16px;transition:border-color .2s,box-shadow .2s,background .2s;width:100%;}
.field textarea{min-height:120px;resize:vertical;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);background:var(--white);box-shadow:0 0 0 4px color-mix(in srgb,var(--cambridge) 35%,transparent);}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2351726F' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;background-size:18px;padding-right:46px;}
.honeypot{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.form__note{font-size:13px;color:var(--ink-soft);opacity:.85;margin:0;}
.form__submit{align-self:flex-start;}
.fieldset{border:none;margin:0;padding:0;display:flex;flex-direction:column;gap:20px;}
.fieldset__legend{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--green);padding-top:8px;border-top:1px solid color-mix(in srgb,var(--green) 16%,transparent);}

/* form success state */
.form-success{display:none;flex-direction:column;align-items:center;text-align:center;gap:16px;padding:clamp(30px,4vw,56px) 10px;}
.formwrap.is-sent .form{display:none;}
.formwrap.is-sent .form-success{display:flex;}
.form-success__check{width:64px;height:64px;border-radius:50%;background:var(--green);color:var(--cream);display:grid;place-items:center;}
.form-success__check svg{width:32px;height:32px;}
.form-success h3{font-size:clamp(26px,2.4vw,36px);font-weight:600;color:var(--ink-max);}
.form-success p{margin:0;max-width:42ch;color:var(--ink-soft);}

/* ---------- Contact layout ---------- */
.contactgrid{display:grid;grid-template-columns:1.25fr .85fr;gap:clamp(28px,3vw,48px);align-items:start;}
.details{display:flex;flex-direction:column;gap:6px;}
.detail{display:flex;gap:18px;padding:22px 0;border-bottom:1px solid color-mix(in srgb,var(--green) 14%,transparent);}
.detail:first-child{padding-top:0;}
.detail__ico{flex:none;width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:color-mix(in srgb,var(--cambridge) 38%,transparent);color:var(--green-700);}
.detail__ico svg{width:22px;height:22px;}
.detail h4{font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin:0 0 6px;}
.detail p,.detail a{margin:0;font-size:16px;color:var(--ink-soft);line-height:1.5;}
.detail a{color:var(--green-700);text-decoration:underline;text-underline-offset:3px;text-decoration-color:color-mix(in srgb,var(--green) 35%,transparent);}
.detail a:hover{text-decoration-color:var(--green);}

/* ---------- Map ---------- */
.map{margin-top:0;border-radius:var(--radius-lg);overflow:hidden;border:var(--hairline);background:var(--cream);min-height:340px;}
.map iframe{display:block;width:100%;height:100%;min-height:340px;border:0;filter:grayscale(.25) contrast(.96);}
.map--full{height:clamp(340px,42vh,520px);}

/* ---------- Offer highlight (new patient) ---------- */
.pricetag{display:inline-flex;align-items:baseline;gap:10px;background:color-mix(in srgb,#000 16%,transparent);border:1px solid color-mix(in srgb,#fff 26%,transparent);border-radius:999px;padding:8px 18px;backdrop-filter:blur(6px);}
.pricetag b{font-family:var(--serif);font-size:22px;font-weight:600;color:#fff;}
.pricetag span{font-size:13px;letter-spacing:.04em;color:color-mix(in srgb,var(--cream) 85%,transparent);}
.included{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2vw,24px);}
.incard{background:var(--white);border:var(--hairline);border-radius:var(--radius-card);padding:clamp(26px,2.6vw,36px);display:flex;gap:18px;align-items:flex-start;}
.section--cream .incard{background:var(--cream);}
.incard__n{font-family:var(--serif);font-size:30px;font-weight:600;color:var(--beaver);line-height:1;flex:none;}
.incard h3{font-size:21px;font-weight:600;color:var(--ink-max);margin:2px 0 6px;}
.incard p{margin:0;font-size:15.5px;color:var(--ink-soft);}

/* ---------- Info strip (address/hours mini cards) ---------- */
.infostrip{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,24px);}
.infocard{background:var(--white);border:var(--hairline);border-radius:var(--radius-card);padding:clamp(22px,2.2vw,30px);display:flex;flex-direction:column;gap:8px;}
.section--cream .infocard{background:var(--cream);}
.infocard h4{font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin:0;}
.infocard p{margin:0;font-size:15.5px;color:var(--ink-soft);line-height:1.5;}

/* ---------- Contact panel (refer / direct contact) ---------- */
.contactpanel{display:grid;grid-template-columns:0.9fr 1.1fr;gap:clamp(32px,4vw,72px);align-items:center;background:color-mix(in srgb,var(--cambridge) 24%,#fff);border:var(--hairline);border-radius:var(--radius-lg);padding:clamp(30px,4vw,60px);}
.contactpanel__lead{margin:18px 0 0;font-size:clamp(16px,1.2vw,18.5px);line-height:1.62;color:var(--ink-soft);max-width:46ch;}
.contactpanel__cards{display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,1.6vw,20px);}
.ctcard{position:relative;display:flex;flex-direction:column;gap:7px;background:var(--white);border:var(--hairline);border-radius:var(--radius-card);padding:clamp(22px,2.2vw,28px);text-decoration:none;}
.ctcard__ico{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;background:color-mix(in srgb,var(--cambridge) 40%,transparent);color:var(--green-700);margin-bottom:8px;}
.ctcard__ico svg{width:23px;height:23px;}
.ctcard__label{font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--green);}
.ctcard__value{font-size:clamp(17px,1.4vw,20px);font-weight:400;color:var(--ink-max);line-height:1.25;letter-spacing:-0.01em;}
.ctcard__hint{font-size:14px;color:var(--ink-soft);line-height:1.45;}
.ctcard--span{grid-column:1 / -1;flex-direction:row;align-items:center;gap:16px;}
.ctcard--span .ctcard__ico{margin-bottom:0;}
.ctcard--span .ctcard__text{display:flex;flex-direction:column;gap:4px;}
@media (max-width:900px){
  .contactpanel{grid-template-columns:1fr;}
}
@media (max-width:520px){
  .contactpanel__cards{grid-template-columns:1fr;}
  .ctcard--span{flex-direction:row;}
}

/* ---------- Section bg helpers ---------- */
.section--white{background:var(--white);}
.section--cream{background:var(--alabaster);}
.section--dun{background:var(--dun);}
.section--tight{padding-top:clamp(40px,5vw,72px);}

/* ---------- Breadcrumb (under inner hero, optional) ---------- */
.crumbs{display:flex;flex-wrap:wrap;gap:8px;font-size:13px;color:color-mix(in srgb,var(--cream) 82%,transparent);margin-bottom:6px;}
.crumbs a{opacity:.85;}.crumbs a:hover{opacity:1;text-decoration:underline;}
.crumbs span{opacity:.5;}

/* ---------- Price / courtesy callout band ---------- */
.callout{background:var(--alabaster);color:#000;}
.callout__inner{display:grid;grid-template-columns:0.95fr 1.05fr;gap:clamp(24px,4vw,64px);align-items:center;}
.callout .eyebrow{color:var(--green);}
.callout h2{color:#000;margin-top:12px;}
.callout__body{margin:0;font-size:clamp(16px,1.2vw,18.5px);line-height:1.6;color:color-mix(in srgb,#000 80%,transparent);}
.callout--green{background:var(--green);color:var(--cream);}
.callout--green .eyebrow{color:color-mix(in srgb,var(--cream) 80%,transparent);}
.callout--green h2{color:var(--cream);}
.callout--green .callout__body{color:color-mix(in srgb,var(--cream) 90%,transparent);}
.callout__price{font-family:var(--serif);font-weight:600;font-size:clamp(48px,6vw,84px);line-height:1;color:var(--green);display:block;}
.callout--green .callout__price{color:var(--cream);}
.callout:not(.callout--green) .callout__price{color:var(--beaver);}
/* Price follows its surface color when used outside a .callout band */
.section--cream .callout__price,.firstvisit .callout__price{color:var(--beaver);}
.section--white .callout__price,.bg-white .callout__price,.bg-cream .callout__price{color:var(--green);}

/* ---------- Related links row ---------- */
.relrow{display:flex;flex-wrap:wrap;gap:12px;}
.relchip{display:inline-flex;align-items:center;gap:10px;font-size:14.5px;font-weight:500;color:var(--green-700);background:var(--white);border:1.5px solid color-mix(in srgb,var(--green) 22%,transparent);border-radius:999px;padding:12px 20px;transition:transform .25s cubic-bezier(.2,.7,.3,1),border-color .25s,background .25s;}
.relchip span{color:var(--green);transition:transform .3s cubic-bezier(.2,.7,.3,1);}
.relchip:hover{transform:translateY(-2px);border-color:var(--green);background:var(--cream);}
.relchip:hover span{transform:translateX(3px);}
.section--cream .relchip{background:var(--cream);}

/* ============================================================
   RESPONSIVE — inner pages
   ============================================================ */
@media (max-width:1000px){
  .split,.contactgrid,.callout__inner{grid-template-columns:1fr;}
  .split__media{aspect-ratio:16/10;order:-1;}
  .bgrid,.process--3{grid-template-columns:repeat(2,1fr);}
  .countlist{grid-template-columns:repeat(2,1fr);}
  .infostrip{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:680px){
  .bgrid,.bgrid--2,.process,.process--3,.compare,.included,.countlist,.infostrip{grid-template-columns:1fr;}
  .form__row{grid-template-columns:1fr;}
}

/* ============================================================
   SURFACE-BASED TEXT COLOR  (per request)
   - Text on WHITE surfaces (white sections + white cards) → green
   - Text on ALABASTER surfaces → beaver
   - Buttons and text over images/heroes keep their own colors.
   Uses :where() (zero specificity) + !important so the cascade is
   driven purely by SOURCE ORDER: alabaster sections, then white
   sections, then white cards (override the section they sit in),
   then colored containers re-assert their own legible text last.
   ============================================================ */

/* (A) ALABASTER surfaces → Beaver */
.section--cream :where(h1,h2,h3,h4,h5,h6,p,li,blockquote,figcaption,dt,dd,strong,em,.eyebrow,.lead,.faq__a-inner,.ccard__tag,.compare__sub,.pcard__num,.pcard__title,.svc__title,.incard__n,a:not(.btn)),
.firstvisit :where(h1,h2,h3,h4,h5,h6,p,li,blockquote,figcaption,dt,dd,strong,em,.eyebrow,.lead,.faq__a-inner,.ccard__tag,.compare__sub,.pcard__num,.pcard__title,.svc__title,.incard__n,a:not(.btn)),
.why :where(h1,h2,h3,h4,h5,h6,p,li,blockquote,figcaption,dt,dd,strong,em,.eyebrow,.lead,.faq__a-inner,.ccard__tag,.compare__sub,.pcard__num,.pcard__title,.svc__title,.incard__n,a:not(.btn)),
.bg-alabaster :where(h1,h2,h3,h4,h5,h6,p,li,blockquote,figcaption,dt,dd,strong,em,.eyebrow,.lead,.faq__a-inner,.ccard__tag,.compare__sub,.pcard__num,.pcard__title,.svc__title,.incard__n,a:not(.btn)),
.callout:not(.callout--green) :where(h1,h2,h3,h4,h5,h6,p,li,.eyebrow,.callout__body,a:not(.btn)){
  color:var(--beaver)!important;
}

/* (B) WHITE sections → Green */
.section--white :where(h1,h2,h3,h4,h5,h6,p,li,blockquote,figcaption,dt,dd,strong,em,.eyebrow,.lead,.faq__a-inner,.ccard__tag,.compare__sub,.pcard__num,.pcard__title,.svc__title,.incard__n,a:not(.btn):not(.ctcard)),
.services :where(h1,h2,h3,h4,h5,h6,p,li,blockquote,figcaption,dt,dd,strong,em,.eyebrow,.lead,.faq__a-inner,.ccard__tag,.compare__sub,.pcard__num,.pcard__title,.svc__title,.incard__n,a:not(.btn):not(.ctcard)),
.vision :where(h1,h2,h3,h4,h5,h6,p,li,blockquote,figcaption,dt,dd,strong,em,.eyebrow,.lead,.faq__a-inner,.ccard__tag,.compare__sub,.pcard__num,.pcard__title,.svc__title,.incard__n,a:not(.btn):not(.ctcard)),
.bg-white :where(h1,h2,h3,h4,h5,h6,p,li,blockquote,figcaption,dt,dd,strong,em,.eyebrow,.lead,.faq__a-inner,.ccard__tag,.compare__sub,.pcard__num,.pcard__title,.svc__title,.incard__n,a:not(.btn):not(.ctcard)),
.bg-cream :where(h1,h2,h3,h4,h5,h6,p,li,blockquote,figcaption,dt,dd,strong,em,.eyebrow,.lead,.faq__a-inner,.ccard__tag,.compare__sub,.pcard__num,.pcard__title,.svc__title,.incard__n,a:not(.btn):not(.ctcard)){
  color:var(--green)!important;
}

/* (C) WHITE cards → Green (override any alabaster section they sit in) */
.pcard :where(h1,h2,h3,h4,h5,h6,p,li,strong,em,.eyebrow,.lead,.pcard__num,.pcard__title),
.svc :where(h1,h2,h3,h4,h5,h6,p,li,strong,em,.svc__title),
.bcard :where(h1,h2,h3,h4,h5,h6,p,li,strong,em),
.ccard--b :where(h1,h2,h3,h4,h5,h6,p,li,strong,em,.ccard__tag),
.dcard :where(h1,h2,h3,h4,h5,h6,p,li,strong,em),
.compare__col :where(h1,h2,h3,h4,h5,h6,p,li,strong,em,.compare__sub),
.incard :where(h1,h2,h3,h4,h5,h6,p,li,strong,em,.incard__n),
.infocard :where(h1,h2,h3,h4,h5,h6,p,li,strong,em),
.relchip :where(span,strong,em),
.countlist li :where(h1,h2,h3,h4,h5,h6,p,strong,em),
.formcard :where(h1,h2,h3,h4,h5,h6,p,li,strong,em,label,legend),
.formwrap :where(h1,h2,h3,h4,h5,h6,p,li,strong,em,label,legend){
  color:var(--green)!important;
}
.relchip{color:var(--green)!important;}
.countlist li{color:var(--green)!important;}

/* (C2) White cards that sit INSIDE an alabaster section → Beaver
   (match the section; overrides (C) green for these cards only) */
:is(.section--cream,.firstvisit,.callout:not(.callout--green),.why,.bg-alabaster) :is(.pcard,.svc,.bcard,.ccard--b,.incard,.infocard,.dcard,.compare__col,.formcard,.formwrap,.countlist) :where(h1,h2,h3,h4,h5,h6,p,li,strong,em,.eyebrow,.lead,.pcard__num,.pcard__title,.svc__title,.compare__sub,.incard__n,.ccard__tag,a:not(.btn)){
  color:var(--beaver)!important;
}

/* (D) Colored containers keep their own legible text */
.ccard--a :where(h1,h2,h3,h4,h5,h6,p,li,span,.ccard__tag){color:var(--cream)!important;}
.callout--green :where(h1,h2,h3,h4,h5,h6,p,li,.eyebrow,.callout__body){color:var(--cream)!important;}
.costband :where(h1,h2,h3,h4,h5,h6,p,li,.h2){color:var(--cream)!important;}
.contactpanel :where(h1,h2,h3,h4,h5,h6,p,li,.eyebrow,.contactpanel__lead){color:var(--ink)!important;}
.contactpanel .ctcard :where(h1,h2,h3,h4,h5,h6,p,li,span,.ctcard__title){color:var(--green)!important;}

/* (E) FAQ — Lexend, question follows surface color, answers stay readable-dark */
.section--white .faq__q,.services .faq__q,.vision .faq__q,.bg-white .faq__q,.bg-cream .faq__q{color:var(--green)!important;}
.section--cream .faq__q,.firstvisit .faq__q,.why .faq__q,.bg-alabaster .faq__q,.callout:not(.callout--green) .faq__q{color:var(--beaver)!important;}
.faq__q{font-family:var(--sans)!important;}
.faq__a-inner,.faq__a-inner p,.faq__a-inner li{color:var(--ink-soft)!important;}


/* Footer SEO / service-area internal links */
.footer__seo{padding:26px 0 4px;margin-top:6px;}
.footer__seo h3{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--cambridge);margin:0 0 14px;}
.footer__seolinks{display:flex;flex-wrap:wrap;gap:8px 0;}
.footer__seolinks a{font-size:13px;color:color-mix(in srgb,var(--cream) 72%,transparent);text-decoration:none;transition:color .2s;padding-right:14px;margin-right:14px;border-right:1px solid color-mix(in srgb,#fff 20%,transparent);}
.footer__seolinks a:last-child{border-right:none;margin-right:0;padding-right:0;}
.footer__seolinks a:hover{color:var(--cream);}

/* ---------- Before / after comparison slider ---------- */
.ba{position:relative;width:100%;aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;touch-action:none;background:color-mix(in srgb,var(--green) 8%,transparent);--pos:50%;}
.ba__img{position:absolute;inset:0;width:100%;height:100%;}
.ba__img img{width:100%;height:100%;object-fit:cover;display:block;}
.ba__img--top{clip-path:inset(0 calc(100% - var(--pos)) 0 0);}
.ba__divider{position:absolute;top:0;bottom:0;left:var(--pos);width:2px;background:var(--cream);transform:translateX(-1px);pointer-events:none;box-shadow:0 0 0 1px rgba(0,0,0,.18);z-index:3;}
.ba__handle{position:absolute;top:50%;left:var(--pos);transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:var(--cream);color:var(--green);display:grid;place-items:center;box-shadow:0 6px 18px rgba(0,0,0,.28);pointer-events:none;z-index:4;}
.ba__handle svg{width:22px;height:22px;}
.ba__range{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;z-index:5;}
.ba__range:focus-visible + .ba__divider,.ba__range:focus-visible{outline:none;}
.ba__range:focus-visible ~ .ba__handle{box-shadow:0 0 0 3px color-mix(in srgb,var(--green) 55%,transparent),0 6px 18px rgba(0,0,0,.28);}
.ba__tag{position:absolute;bottom:14px;font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--cream);background:rgba(0,0,0,.45);padding:6px 12px;border-radius:999px;pointer-events:none;z-index:3;}
.ba__img--top{clip-path:inset(0 calc(100% - var(--pos)) 0 0);z-index:2;}
.ba__img--bottom{z-index:1;}
.ba__tag--before{left:14px;}
.ba__tag--after{right:14px;}


/* ===== Booking popup (modal) — re-added after v3 ingest (designer styles.css dropped it) ===== */
/* ===== Booking popup (modal) ===== */
body.book-open{overflow:hidden;}
.bookmodal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;}
.bookmodal[hidden]{display:none;}
.bookmodal__overlay{position:absolute;inset:0;background:color-mix(in srgb,#1a2422 70%,transparent);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);animation:bookfade .25s ease;}
.bookmodal__panel{position:relative;z-index:1;width:min(1000px,calc(100vw - 32px));max-height:calc(100dvh - 48px);background:var(--alabaster);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 30px 80px -24px rgba(0,0,0,.55);animation:bookpop .3s cubic-bezier(.2,.7,.3,1);}
.bookmodal__head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;background:var(--green);color:var(--cream);flex:none;}
.bookmodal__title{font-family:var(--serif);font-size:20px;letter-spacing:-0.01em;}
.bookmodal__close{appearance:none;border:0;background:color-mix(in srgb,#fff 14%,transparent);color:var(--cream);width:40px;height:40px;border-radius:50%;display:grid;place-items:center;cursor:pointer;transition:background .2s;}
.bookmodal__close:hover{background:color-mix(in srgb,#fff 26%,transparent);}
.bookmodal__close svg{width:20px;height:20px;}
.bookmodal__body{flex:1;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch;}
.bookmodal__body iframe{width:100%;min-height:620px;max-height:none;}
@keyframes bookfade{from{opacity:0;}to{opacity:1;}}
@keyframes bookpop{from{opacity:0;transform:translateY(16px) scale(.98);}to{opacity:1;transform:none;}}
@media (max-width:600px){
  .bookmodal__panel{width:100vw;height:100dvh;max-height:none;border-radius:0;}
  .bookmodal__body iframe{min-height:680px;}
}
@media (prefers-reduced-motion:reduce){
  .bookmodal__overlay,.bookmodal__panel{animation:none;}
}

/* ===== /book page embed layout (re-added after v3 ingest) ===== */
.booking__wrap{max-width:1040px;margin:0 auto;}
.booking__embed{width:100%;}
.booking__embed iframe{width:100%;max-width:1000px;min-height:620px;border:0;display:block;margin:0 auto;background:transparent;}
@media (max-width:560px){.booking__embed iframe{min-height:680px;}}

/* Inline content links (prose + FAQ answers) — visible, like .detail a (added 2026-06-11, new content standard). */
.prose a,.faq__a-inner a{color:var(--green-700);text-decoration:underline;text-underline-offset:3px;text-decoration-color:color-mix(in srgb,var(--green) 35%,transparent);transition:text-decoration-color .2s;}
.prose a:hover,.faq__a-inner a:hover{text-decoration-color:var(--green);}

/* ============================================================
   v3 SEO landing-page design system (integrated 2026-06-13)
   Scoped to body.seo-v2 + new component classes; no effect on other pages.
   ============================================================ */
/* ============================================================
   v2 SEO landing-page additions (staging-v2)
   ============================================================ */
/* FAQ question wrapped in a real <h3> for heading order; button keeps its styling */
.faq__qh{margin:0;font:inherit;color:inherit;}
.faq__qh .faq__q{width:100%;}

/* Generic prose extensions: lists, sub-headings, inline links */
.introlede{max-width:760px;}
.introlede p{font-size:clamp(18px,1.5vw,22px);line-height:1.55;margin:0;color:var(--ink-soft);}
.prose h3{font-size:clamp(19px,1.45vw,23px);font-weight:600;color:var(--ink-max);margin:8px 0 -4px;}
.prose ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:12px;}
.prose ul li{position:relative;padding-left:26px;color:var(--ink-soft);font-size:clamp(16px,1.15vw,18px);line-height:1.6;}
.prose ul li::before{content:"";position:absolute;left:4px;top:11px;width:7px;height:7px;border-radius:50%;background:var(--cambridge);}
.prose a:not(.btn){color:inherit;text-decoration:underline;text-underline-offset:3px;text-decoration-color:color-mix(in srgb,var(--green) 38%,transparent);transition:text-decoration-color .2s;}
.prose a:not(.btn):hover{text-decoration-color:var(--green);}

/* Restrained offer card (never a sales banner) */
.offercard{display:flex;flex-direction:column;gap:10px;background:var(--white);border:var(--hairline);border-radius:var(--radius-card);padding:clamp(24px,2.6vw,34px);max-width:580px;margin:6px 0 0;box-shadow:0 18px 40px -34px rgba(0,0,0,.5);}
.offercard .offercard__kicker{font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;margin:0;color:var(--green);}
.offercard .offercard__amt{font-family:var(--serif);font-weight:600;font-size:clamp(30px,3vw,40px);line-height:1;margin:0;color:var(--beaver);}
.offercard .offercard__body{margin:2px 0 0;font-size:15px;line-height:1.62;color:var(--ink-soft);}
.cost-disclaimer{font-size:14px;line-height:1.6;opacity:.9;max-width:64ch;}

/* Emergency 911 note */
.emergency-note{display:flex;gap:14px;align-items:flex-start;background:color-mix(in srgb,var(--dun) 30%,#fff);border:var(--hairline);border-left:3px solid var(--beaver);border-radius:var(--radius-card);padding:clamp(18px,2vw,24px);max-width:70ch;}
.emergency-note svg{flex:none;width:24px;height:24px;color:var(--beaver);margin-top:1px;}
.emergency-note p{margin:0;font-size:clamp(15px,1.1vw,17px);line-height:1.6;color:var(--ink-max);}

/* Visiting-us CTA row */
.visit-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px;}

/* Static before/after (illustrative) */
.bagrid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(12px,1.4vw,18px);max-width:560px;}
.bafig{position:relative;margin:0;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;background:color-mix(in srgb,var(--green) 8%,transparent);}
.bafig img{width:100%;height:100%;object-fit:cover;display:block;}
.bafig figcaption{position:absolute;bottom:12px;left:12px;font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--cream);background:rgba(0,0,0,.45);padding:6px 12px;border-radius:99px;}
.illus-caption{font-size:13.5px;font-style:italic;color:var(--ink-soft);opacity:.92;margin:2px 0 0;}

/* ============================================================
   v2 layout enrichment (centered heads, feature band, card glosses)
   ============================================================ */
.lead{margin:14px 0 0;color:var(--ink-soft);font-size:clamp(16px,1.2vw,18.5px);line-height:1.6;}
.sechead.center{text-align:center;max-width:760px;margin-inline:auto;}
.sechead.center .eyebrow{justify-content:center;}
.sechead.center .eyebrow::before{display:none;}
.sechead.center .lead{margin-inline:auto;max-width:62ch;}
.prose.center{margin-inline:auto;text-align:center;align-items:center;}
.prose.center ul{text-align:left;}
.offercard.center{margin-inline:auto;}
.svc p{margin:0;color:var(--ink-soft);font-size:15.5px;line-height:1.55;}
/* Green feature band, for one accented section per page */
.section--feature{background:var(--green);color:var(--cream);}
.section--feature .eyebrow{color:color-mix(in srgb,var(--cream) 84%,transparent);}
.section--feature .eyebrow::before{background:color-mix(in srgb,var(--cream) 50%,transparent);}
.section--feature .h2{color:var(--cream);}
.section--feature .prose p{color:color-mix(in srgb,var(--cream) 92%,transparent);}
.section--feature .prose a:not(.btn){color:var(--cream);text-decoration-color:color-mix(in srgb,var(--cream) 55%,transparent);}
.section--feature .prose a:not(.btn):hover{text-decoration-color:var(--cream);}

/* Headings follow their section's body-text colour (governance: green on white,
   beaver on cream) so each title matches its paragraph colour. The green feature
   band and the offer/contact panels keep their own legible colours below. */

/* Cost panel: bold offer block + organized facts list */
.costpanel{display:grid;grid-template-columns:1fr 1fr;border:var(--hairline);border-radius:var(--radius-lg);overflow:hidden;margin-top:clamp(28px,3vw,44px);background:var(--white);box-shadow:0 26px 50px -40px rgba(0,0,0,.5);}
.costpanel__offer{background:var(--green);color:var(--cream);padding:clamp(30px,3.6vw,52px);display:flex;flex-direction:column;gap:8px;justify-content:center;}
.costpanel__offer .offercard__kicker{color:color-mix(in srgb,var(--cream) 82%,transparent);margin:0;}
.costpanel__amt{font-family:var(--serif);font-weight:600;font-size:clamp(50px,6.5vw,84px);line-height:.92;color:var(--cream);margin:4px 0 0;}
.costpanel__lead{margin:0;font-size:clamp(16px,1.3vw,19px);color:color-mix(in srgb,var(--cream) 92%,transparent);}
.costpanel__note{margin:12px 0 0;font-size:13.5px;line-height:1.55;color:color-mix(in srgb,var(--cream) 80%,transparent);text-wrap:pretty;}
.costpanel__facts{list-style:none;margin:0;padding:clamp(26px,3vw,44px);display:flex;flex-direction:column;gap:clamp(18px,2vw,26px);justify-content:center;}
.costpanel__facts li{display:flex;gap:15px;align-items:flex-start;}
.costpanel__facts .ic{flex:none;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:color-mix(in srgb,var(--cambridge) 36%,transparent);color:var(--green);}
.costpanel__facts .ic svg{width:21px;height:21px;}
.costpanel__facts b{display:block;font-size:16.5px;color:var(--green);font-weight:600;}
.costpanel__facts p{margin:3px 0 0;font-size:14.5px;color:var(--green);line-height:1.5;}
@media(max-width:760px){.costpanel{grid-template-columns:1fr;}}

/* Keep the green offer block's text cream (beats governance rule B that greens all white-section text) */
body.seo-v2 .costpanel__offer :where(h1,h2,h3,h4,h5,h6,p,li,.h2,.costpanel__amt,.costpanel__lead){color:var(--cream)!important;}
body.seo-v2 .costpanel__offer .offercard__kicker{color:color-mix(in srgb,var(--cream) 82%,transparent)!important;}
body.seo-v2 .costpanel__offer .costpanel__note{color:color-mix(in srgb,var(--cream) 80%,transparent)!important;}

/* seo-v2: black contactpanel text → brand dark green (beats governance rule D) */
body.seo-v2 .contactpanel :where(h1,h2,h3,h4,h5,h6,p,li,.eyebrow,.contactpanel__lead){color:var(--green)!important;}

/* Cost-panel facts table: all text green (beats cream-section governance) */
body.seo-v2 .costpanel__facts :where(b,p){color:var(--green)!important;}

/* Editorial intro: single-column standfirst (kicker, large statement, body) */
.intro-ed{max-width:900px;}
.intro-ed__statement{font-family:var(--serif);font-weight:500;font-size:clamp(28px,3.4vw,46px);line-height:1.1;margin:14px 0 0;max-width:18ch;letter-spacing:-0.015em;text-wrap:balance;}
.intro-ed__body{display:flex;flex-direction:column;gap:14px;margin:24px 0 0;max-width:62ch;}
.intro-ed__body p{margin:0;}

/* Intro as a two-column split: title block on the left, body on the right */
.intro-split{display:grid;grid-template-columns:0.82fr 1.18fr;gap:clamp(28px,5vw,80px);align-items:end;}
.intro-split__head{}
.intro-split__head .eyebrow{margin-bottom:14px;}
.intro-split__head .h2{margin:0;}
.intro-split__body{display:flex;flex-direction:column;gap:16px;}
.intro-split__body p{margin:0;}
@media(max-width:860px){.intro-split{grid-template-columns:1fr;gap:18px;}.intro-split__head{position:static;}}

/* Visiting panel: equal 50/50 columns (text | image frame). Cells can shrink
   (min-width:0) so the split stays exact; CTAs wrap only if a column gets narrow. */
body.seo-v2 .contactpanel{grid-template-columns:1fr 1fr;}
body.seo-v2 .contactpanel > div{min-width:0;}
body.seo-v2 .contactpanel .visit-cta{flex-wrap:wrap;gap:10px;}
body.seo-v2 .contactpanel .visit-cta .btn{white-space:nowrap;padding-inline:clamp(15px,1.5vw,24px);}
@media(max-width:900px){body.seo-v2 .contactpanel{grid-template-columns:1fr;}}

/* Facts table (financing / insurance / consultation) for cost sections */
.factscard{list-style:none;margin:clamp(26px,3vw,40px) 0 0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);border:var(--hairline);border-radius:var(--radius-lg);overflow:hidden;background:var(--white);}
.factscard li{padding:clamp(22px,2.4vw,32px);display:flex;gap:14px;align-items:flex-start;border-right:var(--hairline);}
.factscard li:last-child{border-right:none;}
.factscard .ic{flex:none;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:color-mix(in srgb,var(--cambridge) 36%,transparent);color:var(--green);}
.factscard .ic svg{width:21px;height:21px;}
.factscard b{display:block;font-size:16.5px;color:var(--green);font-weight:600;}
.factscard p{margin:3px 0 0!important;font-size:14.5px;color:var(--ink-soft)!important;line-height:1.5;}
@media(max-width:760px){.factscard{grid-template-columns:1fr;}.factscard li{border-right:none;border-bottom:var(--hairline);}.factscard li:last-child{border-bottom:none;}}

/* v3 SEO heroes: strengthen the scrim so the cream/white hero text is legible
   over bright photos (left-anchored, subject stays visible). Scoped to .seo-v2. */
.seo-v2 .hero__scrim{background:
  linear-gradient(100deg, rgba(14,23,21,.72) 0%, rgba(14,23,21,.56) 30%, rgba(14,23,21,.30) 52%, rgba(14,23,21,.08) 74%, rgba(14,23,21,0) 90%);}
/* keep v3 SEO hero text within the darkened left zone (so it never runs into the bright photo) */
.seo-v2 .hero__title{max-width:13ch;}
.seo-v2 .hero__sub{max-width:34ch;}

/* ===== v3 full-site additions (pricing-first / brown cost sections / facts row) — 2026-06-14 ===== */
.costpanel__facts p{margin:3px 0 0;font-size:14.5px;color:var(--green);line-height:1.5;}
/* Facts text stays green even where section governance would tint it (beats !important rules) */
.costpanel__facts b,.costpanel__facts p,body.seo-v2 .section .costpanel__facts b,body.seo-v2 .section .costpanel__facts p{color:var(--green)!important;}
@media(max-width:760px){.costpanel{grid-template-columns:1fr;}}

/* Wisdom + cosmetic cost sections: all text + icons brown */
#wisdom-cost :where(.eyebrow,.h2,.lead,.costpanel__facts b,.costpanel__facts p,.cost-disclaimer),
#cosmetic-cost :where(.eyebrow,.h2,.lead,.costpanel__facts b,.costpanel__facts p,.cost-disclaimer){color:var(--beaver)!important;}
#wisdom-cost .costpanel__facts .ic,
#cosmetic-cost .costpanel__facts .ic{color:var(--beaver)!important;background:color-mix(in srgb,var(--beaver) 20%,transparent)!important;}
/* Emergency cost section: all text brown */
#emergency-cost :where(.eyebrow,.h2,h2,h3,p,li,b,strong,.lead,.cost-disclaimer,.costpanel__facts b,.costpanel__facts p){color:var(--beaver)!important;}
#emergency-cost .costpanel__facts .ic{color:var(--beaver)!important;background:color-mix(in srgb,var(--beaver) 20%,transparent)!important;}

/* Standalone facts table (outside the costpanel): 3-up horizontal row, evenly filling the width */
.costpanel__facts--row{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,36px);padding:0;}
.costpanel__facts--row li{align-items:flex-start;}
@media(max-width:720px){.costpanel__facts--row{grid-template-columns:1fr;gap:18px;}}

/* Brown variant of the standalone facts table (text + icons in beaver) */
body.seo-v2 .costpanel__facts.costpanel__facts--brown :where(b,p){color:var(--beaver)!important;}
.costpanel__facts--brown .ic{background:color-mix(in srgb,var(--beaver) 22%,transparent);color:var(--beaver);}

/* Keep the green offer block's text cream (beats governance rule B that greens all white-section text) */
body.seo-v2 .costpanel__offer :where(h1,h2,h3,h4,h5,h6,p,li,.h2,.costpanel__amt,.costpanel__lead){color:var(--cream)!important;}
body.seo-v2 .costpanel__offer .offercard__kicker{color:color-mix(in srgb,var(--cream) 82%,transparent)!important;}
body.seo-v2 .costpanel__offer .costpanel__note{color:color-mix(in srgb,var(--cream) 80%,transparent)!important;}
/* Offer block stays cream on every page type (incl. plain treatment hubs) */
.costpanel__offer .costpanel__amt,.costpanel__offer .costpanel__lead,.costpanel__offer .offercard__kicker,.costpanel__offer .costpanel__note{color:var(--cream)!important;}

/* seo-v2: black contactpanel text → brand dark green (beats governance rule D) */
body.seo-v2 .contactpanel :where(h1,h2,h3,h4,h5,h6,p,li,.eyebrow,.contactpanel__lead){color:var(--green)!important;}

/* Cost-panel facts table: all text green (beats cream-section governance) */
body.seo-v2 .costpanel__facts :where(b,p){color:var(--green)!important;}

/* Editorial intro: single-column standfirst (kicker, large statement, body) */
.intro-ed{max-width:900px;}
.intro-ed__statement{font-family:var(--serif);font-weight:500;font-size:clamp(28px,3.4vw,46px);line-height:1.1;margin:14px 0 0;max-width:18ch;letter-spacing:-0.015em;text-wrap:balance;}
.intro-ed__body{display:flex;flex-direction:column;gap:14px;margin:24px 0 0;max-width:62ch;}
.intro-ed__body p{margin:0;}

/* Intro as a two-column split: title block on the left, body on the right */
.intro-split{display:grid;grid-template-columns:0.82fr 1.18fr;gap:clamp(28px,5vw,80px);align-items:end;}
.intro-split__head{}
.intro-split__head .eyebrow{margin-bottom:14px;}
.intro-split__head .h2{margin:0;}
.intro-split__body{display:flex;flex-direction:column;gap:16px;}
.intro-split__body p{margin:0;}
@media(max-width:860px){.intro-split{grid-template-columns:1fr;gap:18px;}.intro-split__head{position:static;}}

/* Visiting panel: equal 50/50 columns (text | image frame). Cells can shrink
   (min-width:0) so the split stays exact; CTAs wrap only if a column gets narrow. */
body.seo-v2 .contactpanel{grid-template-columns:1fr 1fr;}
body.seo-v2 .contactpanel > div{min-width:0;}
body.seo-v2 .contactpanel .visit-cta{flex-wrap:wrap;gap:10px;}
body.seo-v2 .contactpanel .visit-cta .btn{white-space:nowrap;padding-inline:clamp(15px,1.5vw,24px);}
@media(max-width:900px){body.seo-v2 .contactpanel{grid-template-columns:1fr;}}

/* Facts table (financing / insurance / consultation) for cost sections */
.factscard{list-style:none;margin:clamp(26px,3vw,40px) 0 0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);border:var(--hairline);border-radius:var(--radius-lg);overflow:hidden;background:var(--white);}
.factscard li{padding:clamp(22px,2.4vw,32px);display:flex;gap:14px;align-items:flex-start;border-right:var(--hairline);}
.factscard li:last-child{border-right:none;}
.factscard .ic{flex:none;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:color-mix(in srgb,var(--cambridge) 36%,transparent);color:var(--green);}
.factscard .ic svg{width:21px;height:21px;}
.factscard b{display:block;font-size:16.5px;color:var(--green);font-weight:600;}
.factscard p{margin:3px 0 0!important;font-size:14.5px;color:var(--ink-soft)!important;line-height:1.5;}
@media(max-width:760px){.factscard{grid-template-columns:1fr;}.factscard li{border-right:none;border-bottom:var(--hairline);}.factscard li:last-child{border-bottom:none;}}
