/* ==========================================================================
   Santa Clara Bathtub Refinishing — style.css
   Persona #8: Corporate trustworthy (2016)
   Deep blue #0B4F8A · silver #C0C7CF · bg #F1F5F9 · ink #1E293B
   Merriweather (serif headings) + Lato (body)
   Two-row header · trust/guarantee badges · 4px deep-blue buttons
   Mobile-first, single file, no frameworks.
   ========================================================================== */

/* ----- Design tokens ----- */
:root{
  --blue:#0B4F8A;
  --blue-dark:#083d6c;
  --blue-darker:#062f54;
  --silver:#C0C7CF;
  --silver-light:#dde2e8;
  --bg:#F1F5F9;
  --ink:#1E293B;
  --ink-soft:#475569;
  --white:#ffffff;
  --line:#d8dfe6;
  --gold:#C8932B;            /* used sparingly on stars/seal */
  --shadow:0 1px 3px rgba(15,23,42,.10), 0 6px 18px rgba(15,23,42,.06);
  --shadow-sm:0 1px 2px rgba(15,23,42,.08);
  --radius:4px;              /* persona: 4px buttons / cards */
  --maxw:1140px;
  --gut:20px;
  --serif:"Merriweather", Georgia, "Times New Roman", serif;
  --sans:"Lato", "Helvetica Neue", Arial, sans-serif;
}

/* ----- Reset ----- */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--blue);}
a:hover{color:var(--blue-dark);}
h1,h2,h3,h4{font-family:var(--serif);color:var(--ink);line-height:1.25;margin:0 0 .5em;font-weight:700;}
h1{font-size:1.85rem;}
h2{font-size:1.5rem;}
h3{font-size:1.18rem;}
p{margin:0 0 1em;}
ul,ol{margin:0 0 1em;padding-left:1.25em;}
table{border-collapse:collapse;width:100%;}

.skip{position:absolute;left:-9999px;top:0;background:var(--blue);color:#fff;padding:10px 16px;z-index:2000;}
.skip:focus{left:8px;top:8px;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);}

/* ==========================================================================
   HEADER — two rows: contact bar (top) + main nav (bottom)
   ========================================================================== */
.site-header{position:sticky;top:0;z-index:1000;background:var(--white);box-shadow:var(--shadow-sm);}

.topbar{background:var(--blue-darker);color:#dbe6f1;font-size:.82rem;}
.topbar .wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:6px 18px;padding-top:7px;padding-bottom:7px;}
.topbar a{color:#fff;text-decoration:none;font-weight:700;}
.topbar a:hover{color:var(--silver);}
.topbar .tb-left{display:flex;flex-wrap:wrap;gap:6px 18px;align-items:center;}
.topbar .tb-item{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;}
.topbar .tb-item svg{width:14px;height:14px;fill:var(--silver);flex:0 0 auto;}

.navrow .wrap{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:64px;}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--ink);}
.brand .mark{width:40px;height:40px;border-radius:var(--radius);background:linear-gradient(150deg,var(--blue),var(--blue-darker));color:#fff;display:grid;place-items:center;font-family:var(--serif);font-weight:700;font-size:1.15rem;flex:0 0 auto;box-shadow:var(--shadow-sm);}
.brand .bn{display:flex;flex-direction:column;line-height:1.05;}
.brand .bn b{font-family:var(--serif);font-size:1.06rem;}
.brand .bn span{font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;}

.nav{display:none;}
.nav ul{display:flex;gap:2px;list-style:none;margin:0;padding:0;align-items:center;}
.nav a{display:block;padding:10px 12px;text-decoration:none;color:var(--ink);font-weight:700;font-size:.93rem;border-radius:var(--radius);}
.nav a:hover,.nav a[aria-current="page"]{background:var(--bg);color:var(--blue);}

.nav-actions{display:none;align-items:center;gap:10px;}

.nav-toggle{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--blue);color:#fff;border:0;border-radius:var(--radius);
  padding:9px 14px;font-family:var(--sans);font-weight:700;font-size:.95rem;cursor:pointer;
}
.nav-toggle .bars{display:inline-block;width:18px;height:2px;background:#fff;position:relative;}
.nav-toggle .bars::before,.nav-toggle .bars::after{content:"";position:absolute;left:0;width:18px;height:2px;background:#fff;}
.nav-toggle .bars::before{top:-6px;}
.nav-toggle .bars::after{top:6px;}

/* Mobile dropdown panel */
.mobile-nav{display:none;border-top:1px solid var(--line);background:var(--white);}
.mobile-nav.open{display:block;}
.mobile-nav ul{list-style:none;margin:0;padding:8px var(--gut) 14px;}
.mobile-nav a{display:block;padding:11px 6px;text-decoration:none;color:var(--ink);font-weight:700;border-bottom:1px solid var(--line);}
.mobile-nav a:last-child{border-bottom:0;}
.mobile-nav .m-cta{display:flex;gap:10px;padding:6px var(--gut) 16px;flex-wrap:wrap;}
.mobile-nav .m-cta .btn{flex:1 1 auto;text-align:center;}

/* ==========================================================================
   BUTTONS — persona: radius 4px, deep blue primary; silver secondary
   ========================================================================== */
.btn{
  display:inline-block;text-decoration:none;cursor:pointer;
  font-family:var(--sans);font-weight:700;font-size:1rem;line-height:1.2;
  padding:13px 22px;border-radius:var(--radius);border:2px solid transparent;
  transition:background .15s,border-color .15s,color .15s;
}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue);}
.btn-primary:hover{background:var(--blue-dark);border-color:var(--blue-dark);color:#fff;}
.btn-ghost{background:var(--silver-light);color:var(--blue-darker);border-color:var(--silver);}
.btn-ghost:hover{background:var(--silver);color:var(--blue-darker);}
.btn-block{display:block;width:100%;text-align:center;}
.btn-lg{font-size:1.1rem;padding:16px 30px;}

/* ==========================================================================
   GENERIC SECTION RHYTHM
   ========================================================================== */
section{padding:42px 0;}
.section-alt{background:var(--white);}
.section-blue{background:var(--blue-darker);color:#eaf1f8;}
.section-blue h2,.section-blue h3{color:#fff;}
.section-blue a{color:#fff;}
.lead{font-size:1.12rem;color:var(--ink-soft);max-width:62ch;}
.eyebrow{display:inline-block;font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;color:var(--blue);margin-bottom:8px;}
.section-blue .eyebrow{color:var(--silver);}

/* ==========================================================================
   HERO — corporate blue with trust badges + image
   ========================================================================== */
.hero{
  background:
    linear-gradient(180deg, rgba(8,61,108,.92), rgba(6,47,84,.94)),
    url("/assets/images/home-hero.webp") center/cover no-repeat;
  color:#fff;padding:48px 0 40px;
}
.hero .wrap{display:grid;gap:26px;}
.hero h1{color:#fff;font-size:2rem;margin-bottom:.35em;}
.hero .sub{color:#dbe6f1;font-size:1.1rem;max-width:54ch;margin-bottom:1.1em;}
.quick-answer{font-size:1.12rem;line-height:1.5;max-width:60ch;margin:.2em 0 .9em;}
.quick-answer strong{font-weight:700;}
.hero .quick-answer{color:#fff;border-left:4px solid var(--silver);padding-left:14px;}
.page-head .quick-answer{color:var(--ink);border-left:4px solid var(--blue);padding-left:14px;}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:14px;}
.hero .hours{color:var(--silver);font-weight:700;font-size:.95rem;margin:0;}
.hero-figure{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:4px solid rgba(255,255,255,.12);}
.hero-figure img{width:100%;aspect-ratio:16/10;object-fit:cover;}

/* Trust badge row (signature detail) */
.trust-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px;}
.trust-badges .badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);
  color:#fff;border-radius:var(--radius);padding:8px 12px;font-size:.84rem;font-weight:700;
}
.trust-badges .badge svg{width:18px;height:18px;fill:var(--silver);flex:0 0 auto;}

/* ==========================================================================
   DIRECT ANSWER — the cited block
   ========================================================================== */
.direct-answer{background:var(--white);}
.direct-answer .wrap{max-width:880px;}
.da-card{
  background:var(--white);border:1px solid var(--line);border-left:5px solid var(--blue);
  border-radius:var(--radius);padding:24px 24px 8px;box-shadow:var(--shadow-sm);
}
.direct-answer h3{margin-top:1em;color:var(--blue-dark);}
.direct-answer h3:first-of-type{margin-top:.3em;}
.direct-answer p{color:var(--ink);}

/* ==========================================================================
   CITABLE FACTS
   ========================================================================== */
.citable-facts .wrap{max-width:920px;}
.citable-facts ul{list-style:none;padding:0;margin:0;display:grid;gap:12px;}
.citable-facts li{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:14px 16px 14px 46px;position:relative;box-shadow:var(--shadow-sm);font-size:.98rem;
}
.citable-facts li::before{
  content:"";position:absolute;left:15px;top:50%;transform:translateY(-50%);
  width:18px;height:18px;border-radius:50%;
  background:var(--blue) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/13px no-repeat;
}

/* ==========================================================================
   SERVICES GRID
   ========================================================================== */
.svc-grid{list-style:none;padding:0;margin:0;display:grid;gap:16px;}
.svc-grid li{
  background:var(--white);border:1px solid var(--line);border-top:3px solid var(--blue);
  border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);transition:box-shadow .15s,transform .15s;
}
.svc-grid li:hover{box-shadow:var(--shadow);transform:translateY(-2px);}
.svc-grid h3{margin-bottom:.35em;}
.svc-grid h3 a{text-decoration:none;color:var(--ink);}
.svc-grid h3 a:hover{color:var(--blue);}
.svc-grid p{margin:0;color:var(--ink-soft);font-size:.96rem;}
.svc-grid .price-tag{display:inline-block;margin-top:10px;font-weight:700;color:var(--blue-dark);font-size:.9rem;}

/* ==========================================================================
   BEFORE / AFTER — JS DRAG-SLIDER (persona component)
   ========================================================================== */
.before-after .wrap{max-width:900px;}
.ba-slider{
  position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;
  border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--line);
  user-select:none;touch-action:none;background:var(--silver-light);
}
.ba-slider img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none;}
.ba-img-after{z-index:1;}
.ba-img-before{z-index:2;clip-path:inset(0 50% 0 0);}    /* clipped by JS via --pos */
.ba-slider[style] .ba-img-before{clip-path:inset(0 calc(100% - var(--pos,50%)) 0 0);}
.ba-label{position:absolute;top:12px;z-index:4;background:rgba(6,47,84,.85);color:#fff;font-weight:700;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;padding:5px 10px;border-radius:var(--radius);}
.ba-label.before{left:12px;}
.ba-label.after{right:12px;}
.ba-handle{
  position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;z-index:5;transform:translateX(-50%);
  box-shadow:0 0 0 1px rgba(6,47,84,.3);
}
.ba-handle::after{
  content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:42px;height:42px;border-radius:50%;background:var(--white);border:3px solid var(--blue);
  box-shadow:var(--shadow);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%230B4F8A' d='M8 7 3 12l5 5V7zm8 0v10l5-5-5-5z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;background-size:24px;
}
.ba-range{position:absolute;inset:0;z-index:6;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;}
.ba-pair figcaption,.before-after figcaption{margin-top:12px;color:var(--ink-soft);font-size:.92rem;font-style:italic;text-align:center;}

/* ==========================================================================
   PRICING TABLE
   ========================================================================== */
.pricing .wrap{max-width:780px;}
.price-table,.routing table{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);
}
.price-table th,.price-table td,.routing th,.routing td{
  text-align:left;padding:13px 16px;border-bottom:1px solid var(--line);font-size:.97rem;
}
.price-table thead th,.routing thead th{background:var(--blue-darker);color:#fff;font-family:var(--sans);font-weight:700;}
.price-table tbody tr:last-child td,.routing tbody tr:last-child td{border-bottom:0;}
.price-table tbody tr:nth-child(even) td,.routing tbody tr:nth-child(even) td{background:#f7fafc;}
.price-table td:last-child{font-weight:700;color:var(--blue-dark);white-space:nowrap;}
.price-note{margin-top:14px;color:var(--ink-soft);font-size:.95rem;}

/* ==========================================================================
   PROCESS LIST
   ========================================================================== */
.process .wrap{max-width:880px;}
.process ol{list-style:none;counter-reset:step;padding:0;margin:0;display:grid;gap:14px;}
.process li{
  position:relative;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 18px 16px 64px;box-shadow:var(--shadow-sm);
}
.process li::before{
  counter-increment:step;content:counter(step);
  position:absolute;left:14px;top:14px;width:36px;height:36px;border-radius:50%;
  background:var(--blue);color:#fff;display:grid;place-items:center;
  font-family:var(--serif);font-weight:700;font-size:1.05rem;
}
.process li b{display:block;font-family:var(--serif);}

/* ==========================================================================
   ROUTING TABLE (material -> method)
   ========================================================================== */
.routing .wrap{max-width:1000px;}
.routing .table-scroll{overflow-x:auto;}

/* ==========================================================================
   GUARANTEE STRIP (persona signature: guarantee badges)
   ========================================================================== */
.guarantee .wrap{display:grid;gap:18px;}
.guarantee .seal{
  flex:0 0 auto;width:120px;height:120px;border-radius:50%;display:grid;place-items:center;text-align:center;
  background:radial-gradient(circle at 50% 38%,#fff,#eef3f8);
  border:3px solid var(--blue);box-shadow:var(--shadow);
  color:var(--blue-darker);font-family:var(--serif);font-weight:700;line-height:1.05;
}
.guarantee .seal b{font-size:1.7rem;display:block;color:var(--blue);}
.guarantee .seal span{font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);}
.guarantee .g-list{list-style:none;padding:0;margin:0;display:grid;gap:10px;}
.guarantee .g-list li{padding-left:28px;position:relative;}
.guarantee .g-list li::before{content:"";position:absolute;left:0;top:4px;width:18px;height:18px;border-radius:var(--radius);background:var(--blue) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/13px no-repeat;}

/* ==========================================================================
   REVIEWS
   ========================================================================== */
.reviews .wrap{max-width:1000px;}
.review-grid{display:grid;gap:16px;}
.reviews blockquote{
  margin:0;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow-sm);
}
.reviews blockquote .stars{color:var(--gold);letter-spacing:2px;font-size:1rem;margin-bottom:8px;}
.reviews blockquote p{font-style:italic;margin:0 0 12px;}
.reviews cite{font-style:normal;font-weight:700;color:var(--blue-dark);font-size:.92rem;}
.rating-summary{display:flex;align-items:center;gap:14px;margin-bottom:22px;flex-wrap:wrap;}
.rating-summary .big{font-family:var(--serif);font-size:2.4rem;font-weight:700;color:var(--blue);line-height:1;}
.rating-summary .stars{color:var(--gold);font-size:1.2rem;letter-spacing:2px;}
.rating-summary .meta{color:var(--ink-soft);font-size:.92rem;}

/* ==========================================================================
   FAQ
   ========================================================================== */
.faq .wrap{max-width:840px;}
.faq .qa{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;margin-bottom:12px;box-shadow:var(--shadow-sm);}
.faq .qa h3{margin:0 0 .4em;font-size:1.08rem;color:var(--blue-dark);}
.faq .qa p{margin:0;color:var(--ink);}

/* ==========================================================================
   RELATED
   ========================================================================== */
.related .wrap{max-width:1000px;}
.related .rel-grid{display:flex;flex-wrap:wrap;gap:10px;}
.related a{
  display:inline-block;background:var(--white);border:1px solid var(--silver);
  border-radius:var(--radius);padding:10px 16px;text-decoration:none;color:var(--blue-dark);font-weight:700;font-size:.94rem;
}
.related a:hover{background:var(--blue);color:#fff;border-color:var(--blue);}

/* ==========================================================================
   FINAL CTA
   ========================================================================== */
.final-cta{background:linear-gradient(150deg,var(--blue),var(--blue-darker));color:#fff;text-align:center;}
.final-cta h2{color:#fff;}
.final-cta p{color:#dbe6f1;}
.final-cta .hero-cta{justify-content:center;}
.final-cta .btn-ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.5);}
.final-cta .btn-ghost:hover{background:rgba(255,255,255,.22);}

/* ==========================================================================
   FOOTER (NAP)
   ========================================================================== */
.site-footer{background:#06243f;color:#c4d2e2;padding:38px 0 26px;font-size:.94rem;}
.site-footer .wrap{display:grid;gap:24px;}
.site-footer a{color:#fff;text-decoration:none;}
.site-footer a:hover{color:var(--silver);text-decoration:underline;}
.site-footer .nap strong{color:#fff;font-family:var(--serif);font-size:1.08rem;}
.footer-nav{display:flex;flex-wrap:wrap;gap:6px 18px;}
.footer-nav a{font-weight:700;}
.footer-badges{display:flex;flex-wrap:wrap;gap:10px;}
.footer-badges span{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius);padding:6px 11px;font-size:.8rem;font-weight:700;}
.copyright{color:#7e95ad;font-size:.82rem;margin:0;}

/* ==========================================================================
   BREADCRUMB (inner pages)
   ========================================================================== */
.breadcrumb{background:var(--white);border-bottom:1px solid var(--line);}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:6px;margin:0;padding:11px var(--gut);max-width:var(--maxw);margin:0 auto;font-size:.86rem;}
.breadcrumb li{color:var(--ink-soft);}
.breadcrumb li+li::before{content:"›";margin-right:6px;color:var(--silver);}
.breadcrumb a{text-decoration:none;color:var(--blue);}
.page-head{background:var(--bg);padding:34px 0 8px;}
.page-head h1{font-size:1.9rem;}

/* ==========================================================================
   IMAGE PLACEHOLDER (.ph) — neutral block w/ filename until real WebP exists
   ========================================================================== */
.ph{
  background:
    repeating-linear-gradient(45deg,#e6ecf2 0 12px,#dde4ec 12px 24px);
  color:var(--ink-soft);position:relative;min-height:120px;
}
.ph::after{
  content:attr(data-img);position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  background:rgba(255,255,255,.9);border:1px solid var(--silver);border-radius:var(--radius);
  padding:5px 10px;font-family:var(--sans);font-size:.72rem;font-weight:700;color:var(--ink-soft);
  white-space:nowrap;letter-spacing:.02em;
}

/* ==========================================================================
   RESPONSIVE BREAKPOINTS
   ========================================================================== */
@media (min-width:560px){
  .citable-facts ul{grid-template-columns:1fr 1fr;}
  .svc-grid{grid-template-columns:1fr 1fr;}
  .review-grid{grid-template-columns:1fr 1fr;}
}

@media (min-width:880px){
  body{font-size:18px;}
  h1{font-size:2.2rem;}
  h2{font-size:1.75rem;}
  .hero{padding:64px 0 56px;}
  .hero .wrap{grid-template-columns:1.05fr .95fr;align-items:center;}
  .hero h1{font-size:2.5rem;}
  .svc-grid{grid-template-columns:1fr 1fr 1fr;}
  .guarantee .wrap{grid-template-columns:auto 1fr;align-items:center;gap:30px;}
  .guarantee .g-list{grid-template-columns:1fr 1fr;gap:10px 26px;}
  .site-footer .wrap{grid-template-columns:1.4fr 1fr;align-items:start;}

  /* Show desktop nav, hide toggle */
  .nav{display:block;}
  .nav-actions{display:flex;}
  .nav-toggle{display:none;}
  .mobile-nav{display:none !important;}
}

@media (min-width:1024px){
  .citable-facts ul{grid-template-columns:1fr 1fr 1fr;}
}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important;transition:none !important;}
}

/* ==========================================================================
   QUOTE FORM (contact page + compact homepage version) — persona #8
   ========================================================================== */
.quote-form{
  background:var(--white);border:1px solid var(--line);border-top:3px solid var(--blue);
  border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);
}
.quote-form .field{display:grid;gap:6px;margin-bottom:16px;}
.quote-form label{font-weight:700;font-size:.92rem;color:var(--ink);}
.quote-form .req{color:var(--blue-dark);}
.quote-form .opt{font-weight:400;color:var(--ink-soft);font-size:.85rem;}
.quote-form input,
.quote-form select,
.quote-form textarea{
  font-family:var(--sans);font-size:1rem;color:var(--ink);background:var(--white);
  border:1px solid var(--silver);border-radius:var(--radius);padding:11px 13px;width:100%;
}
.quote-form input:focus,
.quote-form select:focus,
.quote-form textarea:focus{outline:2px solid var(--blue);outline-offset:1px;border-color:var(--blue);}
.quote-form textarea{min-height:110px;resize:vertical;}
.quote-form .btn{margin-top:4px;}
.quote-form .form-note{margin:12px 0 0;font-size:.9rem;color:var(--ink-soft);}
.quote-form .form-note a{font-weight:700;}

/* Compact homepage form: one-line fields where space allows */
.quote-compact{background:var(--white);}
.quote-compact .wrap{max-width:880px;}
.quote-form.compact{display:grid;gap:14px;}
@media (min-width:680px){
  .quote-form.compact{grid-template-columns:1fr 1fr;align-items:end;}
  .quote-form.compact .field{margin-bottom:0;}
  .quote-form.compact .field-full,
  .quote-form.compact .form-submit{grid-column:1 / -1;}
  .quote-form.compact .form-note{grid-column:1 / -1;margin-top:0;}
}

/* Booking CTA panel (replaces the old quote forms) */
.booking-panel{
  background:var(--silver-light);border:1px solid var(--silver);
  border-radius:var(--radius);padding:26px 24px;text-align:center;
  max-width:560px;margin:6px auto 0;
}
.booking-panel p{margin:0 0 16px;font-size:1.05rem;color:var(--ink);}
.booking-panel .btn-lg{min-width:200px;}
.booking-panel .hours{margin:16px 0 0;font-size:.95rem;color:var(--ink-soft);}
.booking-panel .hours a{font-weight:700;}

/* ==========================================================================
   STICKY MOBILE CALL-BAR (injected by main.js) — persona #8
   ========================================================================== */
.mobile-callbar{
  position:fixed;bottom:0;left:0;right:0;display:flex;z-index:999;
  box-shadow:0 -2px 10px rgba(6,36,63,.28);
}
.mobile-callbar a{
  flex:1 1 0;display:flex;align-items:center;justify-content:center;gap:8px;
  min-height:52px;padding:10px 12px;text-decoration:none;
  font-family:var(--sans);font-weight:700;font-size:1rem;line-height:1.1;
}
.mobile-callbar .cb-call{background:var(--blue);color:#fff;}
.mobile-callbar .cb-call:active{background:var(--blue-dark);}
.mobile-callbar .cb-book{background:var(--silver-light);color:var(--blue-darker);border-left:1px solid var(--silver);}
.mobile-callbar .cb-book:active{background:var(--silver);}
.mobile-callbar svg{width:18px;height:18px;flex:0 0 auto;}
.mobile-callbar .cb-call svg{fill:#fff;}
.mobile-callbar .cb-book svg{fill:var(--blue-darker);}
@media (min-width:768px){
  .mobile-callbar{display:none;}
}
@media (max-width:767px){
  body{padding-bottom:64px;}
}
/* 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;}}
