/* =========================================================================
   Concord Bathtub Resurfacing — style.css
   Persona #9: Suburban friendly 2013
   Palette: green #2E7D32 / light #A5D6A7 / bg #F1F8E9 / ink #455A64
   Fonts:   Montserrat (headings) + Open Sans (body)
   Signature: rounded everything, neighborly tone, green gradient hero,
              toggle-button before/after.
   Mobile-first. Vanilla CSS. No frameworks.
   ========================================================================= */

/* ---------- Design tokens ---------- */
:root{
  --green:#2E7D32;
  --green-dark:#1B5E20;
  --green-darker:#14431A;
  --light:#A5D6A7;
  --light-soft:#C8E6C9;
  --bg:#F1F8E9;
  --bg-card:#FFFFFF;
  --ink:#455A64;
  --ink-soft:#607D8B;
  --ink-faint:#90A4AE;
  --line:#DCE7D2;
  --amber:#F9A825;
  --shadow-sm:0 2px 6px rgba(38,50,40,.08);
  --shadow-md:0 6px 18px rgba(38,50,40,.12);
  --shadow-lg:0 14px 36px rgba(38,50,40,.16);
  --radius:14px;
  --radius-lg:22px;
  --radius-pill:999px;
  --maxw:1140px;
  --gap:clamp(1rem,3vw,2rem);
  --head:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --body:'Open Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  font-size:17px;
  line-height:1.7;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--green-dark);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--head);color:#324048;line-height:1.18;margin:0 0 .5em;font-weight:700}
h1{font-size:clamp(1.9rem,5.2vw,3.1rem);letter-spacing:-.01em}
h2{font-size:clamp(1.5rem,3.6vw,2.2rem)}
h3{font-size:clamp(1.12rem,2.2vw,1.35rem)}
p{margin:0 0 1.1em}
ul,ol{margin:0 0 1.1em;padding-left:1.3em}
li{margin:.35em 0}
strong{color:#37474F}

/* ---------- Layout helpers ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1rem,4vw,2rem)}
section{padding-block:clamp(2.4rem,6vw,4.2rem)}
.section-tint{background:var(--bg-card)}
.lead{font-size:1.12rem;color:var(--ink-soft)}
.quick-answer{
  font-size:1.1rem;line-height:1.55;color:#2C3A42;
  background:var(--light-soft);border-left:4px solid var(--green);
  border-radius:var(--radius);padding:.85rem 1.1rem;margin:0 0 1.1em;
}
.quick-answer strong{color:#243038}
.hero .quick-answer{
  color:#fff;background:rgba(255,255,255,.16);
  border-left-color:#fff;max-width:48ch;
}
.hero .quick-answer strong{color:#fff}

/* ---------- Skip link ---------- */
.skip{
  position:absolute;left:-999px;top:0;z-index:200;
  background:var(--green-dark);color:#fff;padding:.7rem 1.1rem;border-radius:0 0 var(--radius) 0;
}
.skip:focus{left:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--head);font-weight:700;font-size:1rem;
  padding:.85rem 1.6rem;border-radius:var(--radius-pill);
  border:2px solid transparent;cursor:pointer;text-align:center;
  transition:transform .12s ease,box-shadow .18s ease,background .18s ease,color .18s ease;
  line-height:1.1;
}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-primary{
  background:linear-gradient(180deg,#43A047,var(--green));
  color:#fff;box-shadow:var(--shadow-md);
}
.btn-primary:hover{background:linear-gradient(180deg,#388E3C,var(--green-dark));color:#fff;box-shadow:var(--shadow-lg)}
.btn-ghost{
  background:#fff;color:var(--green-dark);border-color:var(--light);
  box-shadow:var(--shadow-sm);
}
.btn-ghost:hover{background:var(--bg);border-color:var(--green);color:var(--green-dark)}
.btn-block{display:flex;width:100%}
.btn-lg{font-size:1.1rem;padding:1rem 2.2rem}

/* ---------- Header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.96);
  backdrop-filter:saturate(140%) blur(6px);
  border-bottom:1px solid var(--line);
  box-shadow:0 1px 0 rgba(165,214,167,.5);
}
.header-inner{
  display:flex;align-items:center;gap:.75rem;
  max-width:var(--maxw);margin-inline:auto;
  padding:.65rem clamp(1rem,4vw,2rem);
}
.brand{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--head);font-weight:700;font-size:1.12rem;color:var(--green-dark);
  margin-right:auto;line-height:1.1;
}
.brand:hover{text-decoration:none}
.brand-mark{
  display:grid;place-items:center;
  width:40px;height:40px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#66BB6A,var(--green));
  color:#fff;font-weight:700;font-size:1.05rem;flex:none;
  box-shadow:var(--shadow-sm);
}
.brand-text small{display:block;font-family:var(--body);font-weight:600;font-size:.7rem;color:var(--ink-faint);letter-spacing:.02em}
.nav{display:none}
.nav a{
  font-family:var(--head);font-weight:500;font-size:.95rem;color:var(--ink);
  padding:.45rem .7rem;border-radius:var(--radius-pill);
}
.nav a:hover{background:var(--light-soft);color:var(--green-dark);text-decoration:none}
.nav a[aria-current="page"]{background:var(--light);color:var(--green-dark)}
.header-cta{display:none;gap:.5rem;align-items:center}
.cta-call{
  font-family:var(--head);font-weight:700;color:var(--green-dark);
  white-space:nowrap;border-radius:var(--radius-pill);padding:.5rem .9rem;
  background:var(--light-soft);
}
.cta-call:hover{text-decoration:none;background:var(--light)}
.nav-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:46px;height:46px;font-size:1.4rem;line-height:1;
  background:var(--green);color:#fff;border:none;border-radius:50%;
  cursor:pointer;flex:none;box-shadow:var(--shadow-sm);
}
.nav-toggle:focus-visible{outline:3px solid var(--amber);outline-offset:2px}

/* Mobile drawer */
.mobile-nav{
  display:none;
  border-top:1px solid var(--line);
  background:#fff;padding:.6rem clamp(1rem,4vw,2rem) 1.2rem;
}
.mobile-nav.open{display:block}
.mobile-nav a{
  display:block;font-family:var(--head);font-weight:500;color:var(--ink);
  padding:.7rem .4rem;border-bottom:1px solid var(--bg);border-radius:8px;
}
.mobile-nav a:hover{background:var(--light-soft);text-decoration:none}
.mobile-nav .btn{margin-top:.8rem}

/* ---------- Hero ---------- */
.hero{
  background:
    radial-gradient(120% 90% at 85% -10%,rgba(165,214,167,.55),transparent 60%),
    linear-gradient(150deg,var(--green) 0%,#388E3C 45%,var(--green-dark) 100%);
  color:#fff;position:relative;overflow:hidden;
  padding-block:clamp(2.6rem,7vw,4.6rem);
}
.hero::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:42px;
  background:var(--bg);
  border-radius:50% 50% 0 0 / 100% 100% 0 0;
}
.hero .wrap{position:relative;z-index:2}
.hero-grid{display:grid;gap:clamp(1.4rem,4vw,2.6rem);align-items:center}
.hero h1{color:#fff;text-shadow:0 1px 0 rgba(0,0,0,.12)}
.hero .eyebrow{
  display:inline-block;font-family:var(--head);font-weight:700;font-size:.78rem;
  letter-spacing:.08em;text-transform:uppercase;
  background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.35);
  padding:.35rem .85rem;border-radius:var(--radius-pill);margin-bottom:1rem;
}
.hero .sub{font-size:1.15rem;color:#EAF6E9;max-width:46ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin:1.4rem 0 .8rem}
.hero .hours{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.95rem;color:#EAF6E9;background:rgba(0,0,0,.12);
  padding:.45rem .9rem;border-radius:var(--radius-pill);
}
.hero-card{
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);
  border-radius:var(--radius-lg);padding:.6rem;box-shadow:var(--shadow-lg);
}
.hero-card .ph,.hero-card img{border-radius:calc(var(--radius-lg) - 8px)}
.hero .btn-ghost{background:#fff;color:var(--green-dark)}

/* ---------- Image placeholder ---------- */
.ph{
  background:
    repeating-linear-gradient(45deg,#E3EFD8,#E3EFD8 12px,#DCE9CF 12px,#DCE9CF 24px);
  color:var(--ink-soft);position:relative;width:100%;
  border-radius:var(--radius);min-height:160px;
  display:flex;align-items:center;justify-content:center;
}
.ph::after{
  content:attr(alt);
  position:absolute;inset:auto .5rem .5rem .5rem;
  font-family:var(--head);font-size:.66rem;font-weight:600;line-height:1.3;
  color:var(--ink-soft);background:rgba(255,255,255,.78);
  padding:.3rem .5rem;border-radius:8px;
  max-height:60%;overflow:hidden;
}

/* ---------- Direct answer ---------- */
.direct-answer{background:var(--bg-card)}
.direct-answer .wrap{
  max-width:840px;background:#fff;border:1px solid var(--line);
  border-left:6px solid var(--green);border-radius:var(--radius-lg);
  padding:clamp(1.4rem,4vw,2.4rem);box-shadow:var(--shadow-sm);
}
.direct-answer h2{color:var(--green-dark)}
.direct-answer h3{margin-top:1.3rem;color:#37474F}
.direct-answer h3:first-of-type{margin-top:.4rem}
.direct-answer p{margin-bottom:.6rem}

/* ---------- Citable facts ---------- */
.citable-facts .wrap{max-width:920px}
.citable-facts h2{text-align:center}
.facts-list{
  list-style:none;padding:0;margin:1.4rem 0 0;
  display:grid;gap:.8rem;
}
.facts-list li{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:.95rem 1.1rem .95rem 3rem;position:relative;box-shadow:var(--shadow-sm);
  font-size:1rem;margin:0;
}
.facts-list li::before{
  content:"✓";position:absolute;left:.95rem;top:50%;transform:translateY(-50%);
  width:26px;height:26px;border-radius:50%;background:var(--green);color:#fff;
  display:grid;place-items:center;font-size:.85rem;font-weight:700;
}

/* ---------- Services grid ---------- */
.services h2{text-align:center;margin-bottom:.3rem}
.services .lead{text-align:center;max-width:60ch;margin-inline:auto}
.svc-grid{
  list-style:none;padding:0;margin:1.8rem 0 0;
  display:grid;gap:1.1rem;grid-template-columns:1fr;
}
.svc-grid li{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:1.4rem;box-shadow:var(--shadow-sm);margin:0;
  transition:transform .14s ease,box-shadow .18s ease,border-color .18s ease;
}
.svc-grid li:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--light)}
.svc-grid h3{margin:.2rem 0 .4rem}
.svc-grid h3 a{color:var(--green-dark)}
.svc-grid p{margin:0;color:var(--ink-soft);font-size:.97rem}
.svc-icon{
  width:48px;height:48px;border-radius:50%;background:var(--light-soft);
  display:grid;place-items:center;font-size:1.4rem;margin-bottom:.7rem;
}
.svc-grid .more{
  display:inline-block;margin-top:.7rem;font-family:var(--head);
  font-weight:600;font-size:.9rem;color:var(--green);
}

/* ---------- Before / After (toggle button — persona signature) ---------- */
.before-after{background:var(--bg-card)}
.before-after h2{text-align:center}
.ba-card{
  max-width:760px;margin:1.6rem auto 0;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:.7rem;box-shadow:var(--shadow-md);
}
.ba-stage{position:relative;border-radius:var(--radius);overflow:hidden}
.ba-stage img,.ba-stage .ph{border-radius:var(--radius);width:100%;aspect-ratio:4/3;object-fit:cover}
.ba-stage .ba-after{display:none}
.ba-card[data-state="after"] .ba-before{display:none}
.ba-card[data-state="after"] .ba-after{display:flex}
.ba-tag{
  position:absolute;top:.7rem;left:.7rem;z-index:3;
  font-family:var(--head);font-weight:700;font-size:.72rem;letter-spacing:.06em;
  text-transform:uppercase;color:#fff;padding:.3rem .8rem;border-radius:var(--radius-pill);
  background:var(--ink);
}
.ba-card[data-state="after"] .ba-tag{background:var(--green)}
.ba-toggle{
  display:inline-flex;margin:.9rem auto 0;background:var(--bg);
  border:1px solid var(--line);border-radius:var(--radius-pill);padding:.25rem;
  gap:.25rem;
}
.ba-toggle{display:flex;justify-content:center;width:max-content;margin-inline:auto}
.ba-btn{
  font-family:var(--head);font-weight:700;font-size:.92rem;
  border:none;background:transparent;color:var(--ink-soft);cursor:pointer;
  padding:.55rem 1.4rem;border-radius:var(--radius-pill);transition:all .16s ease;
}
.ba-btn[aria-pressed="true"]{background:var(--green);color:#fff;box-shadow:var(--shadow-sm)}
.ba-caption{text-align:center;color:var(--ink-soft);font-size:.95rem;margin:.9rem 0 .3rem}

/* ---------- Pricing table ---------- */
.pricing h2{text-align:center}
.price-wrap{max-width:680px;margin:1.6rem auto 0}
.price-table{
  width:100%;border-collapse:separate;border-spacing:0;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--shadow-sm);
}
.price-table th,.price-table td{padding:.95rem 1.1rem;text-align:left}
.price-table thead th{
  background:var(--green);color:#fff;font-family:var(--head);font-size:.95rem;
}
.price-table tbody tr+tr td{border-top:1px solid var(--line)}
.price-table tbody tr:nth-child(even) td{background:var(--bg)}
.price-table td:last-child,.price-table th:last-child{text-align:right;font-weight:700;white-space:nowrap}
.price-table td:last-child{color:var(--green-dark)}
.price-note{text-align:center;color:var(--ink-soft);margin-top:1rem;font-size:.97rem}
/* Reglaze-vs-replace comparison table */
.compare-wrap{max-width:760px}
.compare-table th[scope="row"]{font-family:var(--head);color:#37474F;background:var(--bg);white-space:normal}
.compare-table td{vertical-align:top}
.compare-table td:last-child,.compare-table th:last-child{text-align:left;font-weight:400;color:var(--ink);white-space:normal}
.compare-table tbody td:nth-child(2){color:var(--green-dark);font-weight:600}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.warranty-badge{
  display:inline-flex;align-items:center;gap:.5rem;margin:1rem auto 0;
  background:var(--light-soft);color:var(--green-dark);border-radius:var(--radius-pill);
  padding:.5rem 1.1rem;font-family:var(--head);font-weight:700;font-size:.9rem;
}

/* ---------- Process ---------- */
.process h2{text-align:center}
.process-list{
  list-style:none;counter-reset:step;padding:0;margin:1.8rem auto 0;max-width:820px;
  display:grid;gap:1rem;
}
.process-list li{
  counter-increment:step;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:1.1rem 1.2rem 1.1rem 4rem;position:relative;
  box-shadow:var(--shadow-sm);margin:0;
}
.process-list li::before{
  content:counter(step);position:absolute;left:1.1rem;top:1.05rem;
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(180deg,#43A047,var(--green));color:#fff;
  display:grid;place-items:center;font-family:var(--head);font-weight:700;
}
.process-list li strong{display:block;font-family:var(--head);color:#37474F;margin-bottom:.2rem}

/* ---------- Routing table ---------- */
.routing h2{text-align:center}
.routing .table-scroll{overflow-x:auto;margin-top:1.6rem;border-radius:var(--radius-lg)}
.routing table{
  width:100%;min-width:560px;border-collapse:separate;border-spacing:0;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.routing th,.routing td{padding:.85rem 1rem;text-align:left;vertical-align:top;font-size:.96rem}
.routing thead th{background:var(--ink);color:#fff;font-family:var(--head)}
.routing tbody tr+tr td{border-top:1px solid var(--line)}
.routing tbody tr:nth-child(even) td{background:var(--bg)}

/* ---------- Areas / neighborhoods ---------- */
.areas .wrap{max-width:860px}
.areas h2{text-align:center}
.areas p{font-size:1.06rem}
.zip-row{
  display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:1.1rem;
}
.zip-chip{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-pill);
  padding:.35rem .9rem;font-family:var(--head);font-weight:600;font-size:.85rem;color:var(--ink-soft);
}

/* ---------- Reviews ---------- */
.reviews{background:var(--bg-card)}
.reviews h2{text-align:center}
.reviews .stars{text-align:center;color:var(--amber);font-size:1.2rem;letter-spacing:.1em;margin-bottom:.2rem}
.reviews .rating-line{text-align:center;color:var(--ink-soft);font-size:.95rem;margin-bottom:1.6rem}
.review-grid{display:grid;gap:1.1rem;grid-template-columns:1fr}
.reviews blockquote{
  margin:0;background:var(--bg);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:1.3rem 1.4rem;position:relative;
  box-shadow:var(--shadow-sm);
}
.reviews blockquote::before{
  content:"“";font-family:var(--head);font-size:3rem;color:var(--light);
  position:absolute;top:-.2rem;left:.6rem;line-height:1;
}
.reviews blockquote p{margin:.6rem 0 .8rem;font-size:1rem}
.reviews cite{
  display:block;font-style:normal;font-family:var(--head);font-weight:700;
  font-size:.9rem;color:var(--green-dark);
}
.reviews .qstars{color:var(--amber);font-size:.9rem;letter-spacing:.08em}

/* ---------- FAQ ---------- */
.faq .wrap{max-width:840px}
.faq h2{text-align:center}
.faq-item{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  margin-top:.9rem;padding:1.1rem 1.3rem;box-shadow:var(--shadow-sm);
}
.faq-item h3{margin:0 0 .4rem;color:var(--green-dark);font-size:1.08rem}
.faq-item p{margin:0;color:var(--ink-soft)}

/* ---------- Related ---------- */
.related{background:var(--bg-card)}
.related h2{text-align:center}
.related-grid{
  display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;margin-top:1.3rem;
}
.related-grid a{
  background:#fff;border:1px solid var(--light);border-radius:var(--radius-pill);
  padding:.6rem 1.2rem;font-family:var(--head);font-weight:600;font-size:.92rem;
  color:var(--green-dark);box-shadow:var(--shadow-sm);
}
.related-grid a:hover{background:var(--light-soft);text-decoration:none}

/* ---------- Final CTA ---------- */
.final-cta{
  background:
    radial-gradient(100% 120% at 0% 0%,rgba(165,214,167,.4),transparent 55%),
    linear-gradient(150deg,var(--green),var(--green-dark));
  color:#fff;text-align:center;
}
.final-cta h2{color:#fff}
.final-cta p{color:#EAF6E9}
.final-cta .btns{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center;margin-top:1.2rem}
.final-cta .btn-ghost{background:#fff;color:var(--green-dark);border-color:#fff}
.final-cta .btn-ghost:hover{background:var(--bg);color:var(--green-dark)}

/* ---------- Footer ---------- */
.site-footer{
  background:#2C3A40;color:#CFD8DC;padding-block:clamp(2.2rem,5vw,3.2rem);font-size:.95rem;
}
.site-footer a{color:#A5D6A7}
.site-footer .footer-grid{display:grid;gap:1.6rem}
.site-footer .nap strong{color:#fff;font-family:var(--head);font-size:1.05rem}
.site-footer .nap a{font-weight:700}
.footer-nav{display:flex;flex-wrap:wrap;gap:.4rem 1.1rem}
.footer-nav a{font-family:var(--head);font-weight:500}
.site-footer .copyright{color:#90A4AE;font-size:.85rem;border-top:1px solid #3B4A50;padding-top:1.2rem;margin-top:.4rem}
.licensed{display:inline-block;color:#B0BEC5}

/* ---------- Breadcrumb (inner pages) ---------- */
.breadcrumb{background:var(--bg-card);border-bottom:1px solid var(--line)}
.breadcrumb ol{
  list-style:none;display:flex;flex-wrap:wrap;gap:.4rem;margin:0;padding:.8rem clamp(1rem,4vw,2rem);
  max-width:var(--maxw);margin-inline:auto;font-size:.86rem;color:var(--ink-faint);
}
.breadcrumb li{margin:0;display:flex;align-items:center;gap:.4rem}
.breadcrumb li+li::before{content:"›";color:var(--ink-faint)}
.breadcrumb a{color:var(--ink-soft)}

/* ---------- Generic prose section (inner pages) ---------- */
.prose .wrap{max-width:820px}
.prose h2{margin-top:1.4rem}

/* =========================================================================
   Responsive breakpoints
   ========================================================================= */
@media (min-width:600px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .review-grid{grid-template-columns:repeat(2,1fr)}
  .facts-list{grid-template-columns:repeat(2,1fr)}
  .site-footer .footer-grid{grid-template-columns:1.4fr 1fr}
}

@media (min-width:860px){
  .hero-grid{grid-template-columns:1.05fr .95fr}
  .svc-grid{grid-template-columns:repeat(3,1fr)}
  .nav{display:flex;align-items:center;gap:.15rem}
  .header-cta{display:inline-flex}
  .nav-toggle{display:none}
  .mobile-nav{display:none !important}
}

@media (min-width:1000px){
  body{font-size:18px}
  .review-grid{grid-template-columns:repeat(3,1fr)}
}

/* ---------- Quote form (contact + compact home) ---------- */
.quote-form{
  max-width:600px;margin:1.6rem auto 0;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(1.3rem,4vw,2rem);box-shadow:var(--shadow-md);
  display:grid;gap:1rem;
}
.quote-form .field{display:grid;gap:.35rem}
.quote-form label{
  font-family:var(--head);font-weight:600;font-size:.92rem;color:#37474F;
}
.quote-form label .req{color:var(--green-dark)}
.quote-form .opt{font-weight:500;color:var(--ink-faint);font-size:.85rem}
.quote-form input,
.quote-form select,
.quote-form textarea{
  font-family:var(--body);font-size:1rem;color:var(--ink);
  width:100%;padding:.7rem .9rem;background:var(--bg);
  border:1px solid var(--line);border-radius:var(--radius);
  transition:border-color .16s ease,box-shadow .16s ease,background .16s ease;
}
.quote-form input:focus,
.quote-form select:focus,
.quote-form textarea:focus{
  outline:none;border-color:var(--green);background:#fff;
  box-shadow:0 0 0 3px rgba(46,125,50,.15);
}
.quote-form textarea{resize:vertical;min-height:110px}
.quote-form .form-note{
  margin:0;font-size:.9rem;color:var(--ink-soft);text-align:center;
}
.quote-form .btn{justify-self:stretch}
/* Compact home version sits inside the green final-cta */
.cta-form-section .quote-form{text-align:left}
.cta-form-section .quote-form .form-note{color:var(--ink-soft)}
@media (min-width:560px){
  .quote-form .row-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
  .quote-form .row-2 .field{margin:0}
}

/* ---------- Booking panel (replaces native quote forms) ---------- */
.booking-panel{
  max-width:600px;margin:1.6rem auto 0;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(1.4rem,4vw,2.2rem);box-shadow:var(--shadow-md);
  display:grid;gap:1.1rem;text-align:center;
}
.booking-panel p{margin:0;font-size:1.05rem;color:var(--ink)}
.booking-panel .btn{justify-self:center}
.booking-panel .hours{font-size:.92rem;color:var(--ink-soft)}
.cta-form-section .booking-panel{text-align:center}

/* ---------- Sticky mobile call-bar (persona #9: rounded, green) ---------- */
.mobile-callbar{
  position:fixed;bottom:0;left:0;right:0;z-index:999;
  display:flex;gap:.5rem;padding:.5rem;
  background:rgba(255,255,255,.97);
  backdrop-filter:saturate(140%) blur(6px);
  border-top:1px solid var(--line);
  box-shadow:0 -4px 18px rgba(38,50,40,.14);
}
.mobile-callbar a{
  flex:1 1 0;min-height:48px;
  display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  font-family:var(--head);font-weight:700;font-size:1rem;
  border-radius:var(--radius-pill);text-decoration:none;line-height:1.1;
}
.mobile-callbar a:hover{text-decoration:none}
.mobile-callbar .cb-call{
  background:linear-gradient(180deg,#43A047,var(--green));color:#fff;
  box-shadow:var(--shadow-sm);
}
.mobile-callbar .cb-book{
  background:#fff;color:var(--green-dark);border:2px solid var(--light);
}
body{padding-bottom:64px}
@media (min-width:768px){
  .mobile-callbar{display:none}
  body{padding-bottom:0}
}

/* ---------- Accessibility / motion ---------- */
:focus-visible{outline:3px solid var(--amber);outline-offset:2px;border-radius:4px}
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto !important}
}
/* Brand logo mark asset */
.brand-logo-mark{width:44px;height:44px;object-fit:contain;display:inline-block;vertical-align:middle;flex:0 0 44px;background:transparent!important;border:0!important;border-radius:0!important;box-shadow:none!important;padding:0!important;color:transparent!important;margin-right:.55rem;}
.footer-brand .brand-logo-mark{width:30px;height:30px;flex-basis:30px;margin-right:.35rem;}
@media (max-width:640px){.brand-logo-mark{width:38px;height:38px;flex-basis:38px;margin-right:.45rem;}}
