/* ============================================================
   Sunrise Cleaners — compiled site stylesheet
   tokens (colors/type/spacing/elevation/base) + chrome + sections
   Warm editorial luxe · ivory / ink / brass · Fraunces + Inter
   ============================================================ */

/* ---------- TOKENS ---------- */
:root {
  --ivory-50:#FBF9F4; --ivory-100:#F7F3EC; --ivory-200:#EFE9DD; --ivory-300:#E5DCCB;
  --greige-400:#CBBDA6; --taupe-500:#9C8C74; --stone-600:#6E6353; --stone-700:#4A4338;
  --ink-800:#2A2622; --ink-900:#1A1A1A;
  --brass-200:#E7D8C0; --brass-300:#D6BF9C; --brass-400:#C2A074; --brass-500:#B08D57; --brass-600:#97743F; --brass-700:#6F5630;
  --white:#FFFFFF;
  --success-700:#4F6048; --success-100:#E4E9DE; --danger-700:#8A4B3A; --danger-100:#F0E0D9;

  --bg-page:var(--ivory-100); --bg-sunken:var(--ivory-200); --surface-card:var(--ivory-50);
  --surface-raised:var(--white); --surface-ink:var(--ink-900); --surface-brass:var(--brass-500);
  --text-strong:var(--ink-900); --text-body:var(--ink-800); --text-muted:var(--stone-600);
  --text-faint:var(--taupe-500); --text-on-ink:var(--ivory-100); --text-on-brass:var(--ivory-50); --text-accent:var(--brass-700);
  --border-subtle:var(--ivory-300); --border-strong:var(--greige-400); --border-ink:var(--ink-900); --divider:var(--ivory-300);
  --accent:var(--brass-500); --accent-hover:var(--brass-600); --accent-wash:var(--brass-200); --accent-line:var(--brass-400); --focus-ring:var(--brass-600);

  --font-display:'Fraunces','Times New Roman',serif;
  --font-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --fw-light:300; --fw-regular:400; --fw-medium:500; --fw-semibold:600;
  --fs-display:clamp(2.85rem,1.5rem + 5vw,5rem); --fs-h1:clamp(2.3rem,1.6rem + 2.4vw,3.25rem);
  --fs-h2:clamp(1.85rem,1.4rem + 1.6vw,2.4rem); --fs-h3:1.6rem; --fs-h4:1.25rem;
  --fs-lead:1.25rem; --fs-body:1.0625rem; --fs-sm:0.9375rem; --fs-xs:0.8125rem; --fs-eyebrow:0.75rem;
  --lh-display:1.02; --lh-heading:1.1; --lh-snug:1.3; --lh-body:1.6; --lh-relaxed:1.75;
  --ls-display:-0.02em; --ls-heading:-0.015em; --ls-body:0; --ls-eyebrow:0.18em; --ls-button:0.04em;

  --space-1:0.25rem; --space-2:0.5rem; --space-3:0.75rem; --space-4:1rem; --space-5:1.5rem;
  --space-6:2rem; --space-7:2.5rem; --space-8:3rem; --space-9:4rem; --space-10:5rem; --space-11:6.5rem; --space-12:8rem;
  --section-y:clamp(4rem,2rem + 8vw,8rem); --section-y-tight:clamp(3rem,2rem + 4vw,5rem);
  --container-max:1200px; --container-text:720px; --container-wide:1320px;
  --gutter:clamp(1.25rem,0.5rem + 3vw,3rem); --mobile-bar-h:4.5rem; --tap-min:2.75rem;

  --radius-xs:2px; --radius-sm:4px; --radius-md:8px; --radius-lg:12px; --radius-pill:999px;
  --border-hair:1px; --border-med:1.5px;
  --shadow-xs:0 1px 2px rgba(42,38,34,.06);
  --shadow-sm:0 2px 8px rgba(42,38,34,.06),0 1px 2px rgba(42,38,34,.05);
  --shadow-md:0 8px 24px rgba(42,38,34,.08),0 2px 6px rgba(42,38,34,.05);
  --shadow-lg:0 18px 48px rgba(42,38,34,.12),0 6px 14px rgba(42,38,34,.06);
  --shadow-brass:0 10px 28px rgba(151,116,63,.22);
  --lift:-4px; --ease-out:cubic-bezier(.22,.61,.36,1); --ease-inout:cubic-bezier(.65,.05,.36,1);
  --dur-fast:140ms; --dur-base:240ms; --dur-slow:480ms; --dur-reveal:720ms;
}
@media (prefers-reduced-motion: reduce){ :root{ --dur-fast:0ms; --dur-base:0ms; --dur-slow:0ms; --dur-reveal:0ms; --lift:0px; } }

/* ---------- BASE ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{ margin:0; background:var(--bg-page); color:var(--text-body); font-family:var(--font-body); font-size:var(--fs-body); line-height:var(--lh-body); -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
h1,h2,h3,h4{ font-family:var(--font-display); color:var(--text-strong); font-weight:var(--fw-light); line-height:var(--lh-heading); letter-spacing:var(--ls-heading); margin:0 0 var(--space-4); text-wrap:balance; }
h1{ font-size:var(--fs-h1); line-height:var(--lh-display); letter-spacing:var(--ls-display); }
h2{ font-size:var(--fs-h2); } h3{ font-size:var(--fs-h3); font-weight:var(--fw-regular); }
h4{ font-size:var(--fs-h4); font-weight:var(--fw-medium); font-family:var(--font-body); letter-spacing:0; }
p{ margin:0 0 var(--space-4); text-wrap:pretty; }
a{ color:var(--text-accent); text-decoration:none; text-underline-offset:.18em; transition:color var(--dur-fast) var(--ease-out); }
a:hover{ color:var(--brass-600); }
strong{ font-weight:var(--fw-semibold); color:var(--text-strong); }
img,picture,svg,video{ max-width:100%; display:block; }
::selection{ background:var(--brass-200); color:var(--ink-900); }
:focus-visible{ outline:var(--border-med) solid var(--focus-ring); outline-offset:2px; border-radius:var(--radius-xs); }

/* ---------- LAYOUT HELPERS ---------- */
.s-container{ max-width:var(--container-max); margin-inline:auto; padding-inline:var(--gutter); }
.s-wide{ max-width:var(--container-wide); margin-inline:auto; padding-inline:var(--gutter); }
.s-text{ max-width:var(--container-text); margin-inline:auto; padding-inline:var(--gutter); }
.s-section{ padding-block:var(--section-y); }
.s-section--tight{ padding-block:var(--section-y-tight); }
.band{ background:var(--surface-ink); color:var(--text-on-ink); }
.band-sunken{ background:var(--bg-sunken); border-top:1px solid var(--border-subtle); }
.eyebrow{ display:inline-block; font-family:var(--font-body); font-size:var(--fs-eyebrow); font-weight:var(--fw-semibold); letter-spacing:var(--ls-eyebrow); text-transform:uppercase; color:var(--text-accent); }
.eyebrow--ink{ color:var(--brass-400); }
.brass-rule{ width:2.5rem; height:2px; background:var(--accent); border:0; margin:.9rem 0 0; }

/* ---------- BUTTONS ---------- */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.5rem; font-family:var(--font-body); font-weight:600; font-size:1rem; letter-spacing:var(--ls-button); line-height:1; border-radius:var(--radius-sm); padding:.85rem 1.5rem; min-height:2.875rem; text-decoration:none; cursor:pointer; border:1.5px solid transparent; white-space:nowrap; transition:background var(--dur-base) var(--ease-out),color var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out); }
.btn--lg{ padding:1rem 2rem; font-size:var(--fs-body); min-height:3.25rem; }
.btn--sm{ padding:.5rem 1rem; font-size:.875rem; min-height:2.5rem; }
.btn--primary{ background:var(--accent); color:var(--text-on-brass); }
.btn--primary:hover{ background:var(--accent-hover); color:var(--text-on-brass); transform:translateY(-2px); box-shadow:var(--shadow-brass); }
.btn--secondary{ border-color:var(--ink-900); color:var(--text-strong); }
.btn--secondary:hover{ background:var(--ink-900); color:var(--ivory-100); transform:translateY(-2px); }
.btn--ghost{ color:var(--text-accent); padding-inline:.4rem; }
.btn--ghost:hover{ color:var(--brass-600); }
.btn--on-ink{ background:var(--ivory-100); color:var(--ink-900); }
.btn--on-ink:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn .arw{ font-size:1.1em; line-height:0; }

/* ---------- HEADER ---------- */
.site-nav{ position:sticky; top:0; z-index:40; background:rgba(247,243,236,.85); backdrop-filter:blur(10px); border-bottom:1px solid var(--border-subtle); }
.site-nav__in{ max-width:var(--container-wide); margin:0 auto; padding:0 var(--gutter); height:5rem; display:flex; align-items:center; justify-content:space-between; gap:1.5rem; }
.site-nav__logo{ display:flex; align-items:center; }
.site-nav__logo img{ height:3rem; width:auto; }
.site-nav__links{ display:flex; align-items:center; gap:1.8rem; }
.site-nav__links a{ font-size:var(--fs-sm); font-weight:500; color:var(--text-body); text-decoration:none; }
.site-nav__links a:hover{ color:var(--brass-600); }
.site-nav__actions{ display:flex; align-items:center; gap:.9rem; }
.site-nav__phone{ font-size:var(--fs-sm); font-weight:600; color:var(--text-strong); white-space:nowrap; }
.site-nav__burger{ display:none; background:none; border:0; cursor:pointer; font-size:1.6rem; line-height:1; color:var(--ink-900); padding:.25rem; }
.site-nav__mobile{ display:none; flex-direction:column; gap:.25rem; padding:.5rem var(--gutter) 1.25rem; border-top:1px solid var(--border-subtle); background:var(--bg-page); }
.site-nav__mobile a{ font-family:var(--font-display); font-size:1.3rem; color:var(--text-strong); padding:.5rem 0; }
.site-nav.is-open .site-nav__mobile{ display:flex; }

/* ---------- HERO ---------- */
.s-hero{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(2rem,4vw,4.5rem); align-items:center; padding-block:var(--space-9) var(--space-10); }
.s-hero__photo{ position:relative; }
.s-hero__photo img{ width:100%; height:auto; aspect-ratio:4/3; max-height:560px; object-fit:cover; border-radius:var(--radius-md); box-shadow:var(--shadow-lg); }
.s-hero__badge{ position:absolute; bottom:-1.4rem; left:-1.4rem; background:var(--surface-raised); border:1px solid var(--border-subtle); border-radius:var(--radius-md); box-shadow:var(--shadow-md); padding:1rem 1.2rem; display:flex; align-items:center; gap:.8rem; }
.s-hero__badge b{ font-family:var(--font-display); font-weight:300; font-size:2.2rem; line-height:1; color:var(--brass-600); }
.s-hero__badge span{ font-size:var(--fs-xs); line-height:1.4; color:var(--text-muted); }
.s-display{ font-family:var(--font-display); font-weight:300; font-size:var(--fs-display); line-height:var(--lh-display); letter-spacing:var(--ls-display); color:var(--text-strong); margin:1.4rem 0 0; }
.s-lead{ font-family:var(--font-body); font-size:var(--fs-lead); line-height:1.7; color:var(--text-body); max-width:34rem; margin:1.5rem 0 0; }
.s-actions{ display:flex; gap:.9rem; margin-top:2.2rem; flex-wrap:wrap; }

/* ---------- TRUST / STATS ---------- */
.s-trust{ border-top:1px solid var(--border-subtle); border-bottom:1px solid var(--border-subtle); background:var(--surface-card); }
.s-trust__in{ max-width:var(--container-max); margin:0 auto; padding:var(--space-7) var(--gutter); display:grid; grid-template-columns:repeat(4,1fr); gap:2rem; }
.s-stat__value{ font-family:var(--font-display); font-weight:300; font-size:clamp(2.5rem,1.5rem + 3vw,3.5rem); line-height:1; letter-spacing:-.02em; color:var(--brass-600); }
.s-stat__label{ font-family:var(--font-body); font-size:var(--fs-xs); font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--text-muted); margin-top:.6rem; }
.band .s-stat__value{ color:var(--brass-300); } .band .s-stat__label{ color:var(--ivory-200); }

/* ---------- SECTION HEADING ---------- */
.s-head{ max-width:40rem; }
.s-head--center{ margin-inline:auto; text-align:center; }
.s-head--center .brass-rule{ margin-inline:auto; }
.s-head h2{ margin:.7rem 0 0; }
.band .s-head h2{ color:var(--ivory-100); }
.s-head .s-lead{ margin-top:1rem; }

/* ---------- STEPS ---------- */
.s-steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:2.2rem; margin-top:2.8rem; }
.s-step__top{ display:flex; align-items:center; gap:.7rem; }
.s-step__n{ font-family:var(--font-display); font-weight:300; font-size:1.6rem; line-height:1; color:var(--brass-600); }
.band .s-step__n{ color:var(--brass-300); }
.s-step__rule{ flex:1; height:1px; background:var(--border-strong); }
.band .s-step__rule{ background:var(--stone-700); }
.s-step h4{ margin:.6rem 0 .3rem; font-family:var(--font-display); font-weight:400; font-size:1.25rem; color:var(--text-strong); }
.band .s-step h4{ color:var(--ivory-100); }
.s-step p{ font-size:var(--fs-sm); line-height:1.55; color:var(--text-muted); margin:0; }
.band .s-step p{ color:var(--ivory-200); }

/* ---------- SERVICE CARDS ---------- */
.s-services{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; margin-top:2.8rem; }
.s-card{ display:flex; flex-direction:column; background:var(--surface-card); border:1px solid var(--border-subtle); border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out); text-decoration:none; }
.s-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.s-card__media{ position:relative; overflow:hidden; }
.s-card__media img{ width:100%; aspect-ratio:4/3; object-fit:cover; transition:transform var(--dur-slow) var(--ease-out); }
.s-card:hover .s-card__media img{ transform:scale(1.04); }
.s-card__tag{ position:absolute; top:.8rem; left:.8rem; background:var(--ink-900); color:var(--ivory-100); font-size:.6875rem; font-weight:600; letter-spacing:.06em; padding:.28rem .6rem; border-radius:var(--radius-pill); }
.s-card__body{ padding:1.3rem 1.4rem 1.5rem; display:flex; flex-direction:column; flex:1; }
.s-card__body h3{ font-family:var(--font-display); font-weight:400; font-size:1.375rem; line-height:1.15; color:var(--text-strong); margin:0 0 .4rem; }
.s-card__body p{ font-size:var(--fs-sm); line-height:1.55; color:var(--text-muted); margin:0; }
.s-card__more{ margin-top:auto; padding-top:1.1rem; display:inline-flex; align-items:center; gap:.45rem; font-size:var(--fs-sm); font-weight:600; color:var(--text-accent); }
.s-card:hover .s-card__more{ color:var(--brass-600); }
.s-card:hover .s-card__more .arw{ transform:translateX(3px); }
.s-card__more .arw{ transition:transform var(--dur-base) var(--ease-out); }

/* ---------- LOCATIONS ---------- */
.s-split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,4vw,4rem); align-items:center; }
.s-loccard{ display:flex; gap:1.2rem; background:var(--surface-card); border:1px solid var(--border-subtle); border-radius:var(--radius-md); box-shadow:var(--shadow-sm); overflow:hidden; text-decoration:none; transition:box-shadow var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out); }
.s-loccard:hover{ box-shadow:var(--shadow-md); transform:translateY(-2px); }
.s-loccard__media{ flex:0 0 9rem; }
.s-loccard__media img{ width:100%; height:100%; min-height:9rem; object-fit:cover; }
.s-loccard__body{ padding:1.1rem 1.2rem 1.1rem 0; display:flex; flex-direction:column; gap:.3rem; }
.s-loccard__body h3{ font-family:var(--font-display); font-weight:400; font-size:1.4rem; color:var(--text-strong); margin:0; }
.s-tag{ display:inline-flex; align-items:center; font-size:.6875rem; font-weight:600; letter-spacing:.04em; padding:.2rem .55rem; border-radius:var(--radius-pill); background:var(--success-100); color:var(--success-700); border:1px solid var(--success-700); width:max-content; }
.s-loccard__formerly{ font-size:var(--fs-xs); color:var(--text-faint); }
.s-loccard__addr{ font-size:var(--fs-sm); color:var(--text-muted); }
.s-loccard__phone{ font-size:var(--fs-sm); font-weight:600; color:var(--text-accent); margin-top:.2rem; }

/* ---------- ZIP CHECKER ---------- */
.s-zipwrap{ background:var(--surface-raised); border:1px solid var(--border-subtle); border-radius:var(--radius-md); box-shadow:var(--shadow-sm); padding:1.4rem 1.5rem; max-width:30rem; margin-top:1.8rem; }
.s-zip{ display:flex; gap:.6rem; align-items:flex-end; flex-wrap:wrap; }
.s-zip__field{ display:flex; flex-direction:column; gap:.4rem; flex:1 1 11rem; }
.s-zip label{ font-size:var(--fs-sm); font-weight:500; color:var(--text-strong); }
.s-zip input{ font-family:var(--font-body); font-size:1rem; color:var(--text-strong); background:var(--surface-raised); border:1.5px solid var(--border-strong); border-radius:var(--radius-sm); outline:none; padding:.7rem .9rem; transition:border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out); }
.s-zip input:focus{ border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-wash); }
.s-zip__result{ margin:.9rem 0 0; font-size:var(--fs-sm); }
.s-zip__result--yes{ color:var(--success-700); font-weight:500; }
.s-zip__result--no{ color:var(--text-muted); }

/* ---------- TESTIMONIAL ---------- */
.s-quote{ max-width:52rem; margin:0 auto; text-align:center; }
.s-stars{ color:var(--brass-400); font-size:1.4rem; letter-spacing:.2em; margin-bottom:1.4rem; }
.s-quote blockquote{ font-family:var(--font-display); font-weight:300; font-size:clamp(1.5rem,1rem + 2vw,2.2rem); line-height:1.3; letter-spacing:-.01em; color:var(--text-strong); margin:0; text-wrap:balance; }
.s-quote__by{ font-size:var(--fs-sm); color:var(--text-muted); margin-top:1.6rem; letter-spacing:.04em; }

/* ---------- CTA ---------- */
.cta{ text-align:center; }
.cta h2{ font-family:var(--font-display); font-weight:300; font-size:var(--fs-h1); color:var(--ivory-100); margin:0 0 1.2rem; letter-spacing:-.02em; }
.cta p{ font-size:var(--fs-lead); color:var(--ivory-200); max-width:32rem; margin:0 auto 2rem; }

/* ---------- INFO STRIP (location/service) ---------- */
.s-info{ background:var(--surface-card); border-top:1px solid var(--border-subtle); border-bottom:1px solid var(--border-subtle); }
.s-info__in{ max-width:var(--container-max); margin:0 auto; padding:var(--space-7) var(--gutter); display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.s-info__k{ font-size:var(--fs-xs); font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--brass-600); margin-bottom:.7rem; }
.s-info__v{ font-size:var(--fs-body); line-height:1.6; color:var(--text-body); }

/* ---------- INCLUDES LIST (service) ---------- */
.s-includes{ display:grid; grid-template-columns:repeat(2,1fr); gap:0; }
.s-inc{ display:flex; gap:1.1rem; padding:1.6rem 1.8rem 1.6rem 0; border-bottom:1px solid var(--border-subtle); }
.s-inc__n{ font-family:var(--font-display); font-weight:300; font-size:1.3rem; color:var(--brass-600); }
.s-inc h4{ font-family:var(--font-display); font-weight:400; font-size:1.25rem; color:var(--text-strong); margin:0 0 .3rem; }
.s-inc p{ font-size:var(--fs-sm); line-height:1.55; color:var(--text-muted); margin:0; }

/* ---------- PROSE (FAQ / legal / about) ---------- */
.prose{ max-width:var(--container-text); margin:0 auto; padding:0 var(--gutter) var(--space-10); }
.prose section{ padding-top:var(--space-7); }
.prose h2{ font-family:var(--font-display); font-weight:400; font-size:var(--fs-h3); color:var(--text-strong); margin:0 0 .4rem; letter-spacing:-.01em; }
.prose h2 .num{ color:var(--brass-500); font-weight:300; margin-right:.6rem; }
.prose h3{ font-family:var(--font-body); font-weight:600; font-size:1.05rem; color:var(--text-strong); margin:1.4rem 0 .3rem; }
.prose p,.prose li{ font-size:var(--fs-body); line-height:1.7; color:var(--text-body); }
.prose ul{ margin:.6rem 0; padding-left:1.2rem; } .prose li{ margin:.3rem 0; } .prose li::marker{ color:var(--brass-500); }
.faq-item{ border-bottom:1px solid var(--border-subtle); padding:1.3rem 0; }
.faq-item summary{ font-family:var(--font-display); font-weight:400; font-size:1.2rem; color:var(--text-strong); cursor:pointer; list-style:none; display:flex; justify-content:space-between; gap:1rem; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:"+"; color:var(--brass-500); font-size:1.4rem; line-height:1; }
.faq-item[open] summary::after{ content:"–"; }
.faq-item p{ margin:.8rem 0 0; }

/* ---------- PAGE HEAD ---------- */
.page-head{ max-width:var(--container-max); margin:0 auto; padding:var(--space-9) var(--gutter) var(--space-7); }
.page-head--center{ text-align:center; } .page-head--center .brass-rule{ margin-inline:auto; }
.page-title{ font-family:var(--font-display); font-weight:300; font-size:var(--fs-h1); line-height:1.05; letter-spacing:-.02em; color:var(--text-strong); margin:1.2rem 0 0; }
.page-lead{ font-size:var(--fs-lead); line-height:1.7; color:var(--text-body); max-width:40rem; margin:1.2rem 0 0; }
.page-head--center .page-lead{ margin-inline:auto; }

/* ---------- FOOTER ---------- */
.site-foot{ background:var(--surface-ink); color:var(--ivory-100); padding:var(--space-9) 0 var(--space-7); }
.site-foot__in{ max-width:var(--container-wide); margin:0 auto; padding:0 var(--gutter); }
.site-foot__cols{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2.5rem; align-items:start; }
.site-foot img{ height:3.25rem; width:auto; margin-bottom:1.1rem; }
.site-foot p{ font-size:var(--fs-sm); line-height:1.6; color:var(--ivory-200); max-width:22rem; margin:0; }
.site-foot h4{ font-family:var(--font-body); font-size:var(--fs-xs); font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--brass-400); margin:0 0 1.1rem; }
.site-foot__col a{ display:block; font-size:var(--fs-sm); color:var(--ivory-200); text-decoration:none; margin-bottom:.7rem; }
.site-foot__col a:hover{ color:var(--brass-300); }
.site-foot__legal{ border-top:1px solid var(--stone-700); margin-top:var(--space-7); padding-top:var(--space-5); display:flex; justify-content:space-between; flex-wrap:wrap; gap:.8rem; font-size:var(--fs-xs); color:var(--taupe-500); }

/* ---------- MOBILE STICKY BAR ---------- */
.s-mobilebar{ position:fixed; left:0; right:0; bottom:0; z-index:50; display:none; gap:.7rem; padding:.7rem var(--gutter); padding-bottom:calc(.7rem + env(safe-area-inset-bottom)); background:rgba(247,243,236,.94); backdrop-filter:blur(12px); border-top:1px solid var(--border-subtle); }
.s-mobilebar .btn{ flex:1; }
.s-mobilebar__call{ flex:0 0 auto; min-width:3rem; }

/* ---------- SCHEDULE MODAL ---------- */
.s-modal{ position:fixed; inset:0; z-index:100; background:rgba(26,26,26,.5); backdrop-filter:blur(3px); display:none; align-items:center; justify-content:center; padding:1.5rem; }
.s-modal.is-open{ display:flex; }
.s-modal__panel{ width:min(34rem,100%); background:var(--surface-raised); border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); overflow:hidden; max-height:90vh; overflow-y:auto; }
.s-modal__head{ padding:1.4rem 1.6rem; border-bottom:1px solid var(--border-subtle); display:flex; justify-content:space-between; align-items:center; }
.s-modal__head h3{ font-family:var(--font-display); font-weight:400; font-size:1.3rem; margin:0; }
.s-modal__close{ background:none; border:0; cursor:pointer; font-size:1.4rem; color:var(--text-muted); line-height:1; }
.s-form{ padding:1.6rem; display:flex; flex-direction:column; gap:1rem; }
.s-field{ display:flex; flex-direction:column; gap:.4rem; }
.s-field label{ font-size:var(--fs-sm); font-weight:500; color:var(--text-strong); }
.s-field input,.s-field select,.s-field textarea{ font-family:var(--font-body); font-size:1rem; color:var(--text-strong); background:var(--surface-raised); border:1.5px solid var(--border-strong); border-radius:var(--radius-sm); outline:none; padding:.7rem .9rem; transition:border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out); }
.s-field input:focus,.s-field select:focus,.s-field textarea:focus{ border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-wash); }
.s-field--hp{ position:absolute; left:-9999px; }
.s-form__row{ display:grid; grid-template-columns:1fr 1fr; gap:.9rem; }
.s-notice{ background:var(--success-100); color:var(--success-700); border:1px solid var(--success-700); border-radius:var(--radius-sm); padding:.8rem 1rem; font-size:var(--fs-sm); }

/* ---------- RESPONSIVE ---------- */
@media (max-width:980px){
  .s-hero{ grid-template-columns:1fr; }
  .s-hero__photo{ order:-1; }
  .s-hero__photo img{ aspect-ratio:16/11; }
  .s-hero__badge{ left:auto; right:1rem; bottom:1rem; }
  .s-trust__in{ grid-template-columns:repeat(2,1fr); row-gap:2.4rem; }
  .s-steps{ grid-template-columns:repeat(2,1fr); row-gap:2.4rem; }
  .s-services{ grid-template-columns:repeat(2,1fr); }
  .s-split{ grid-template-columns:1fr; }
  .s-info__in{ grid-template-columns:1fr; gap:1.5rem; }
  .s-includes{ grid-template-columns:1fr; }
  .site-foot__cols{ grid-template-columns:1fr 1fr; row-gap:2.4rem; }
}
@media (max-width:680px){
  .site-nav__links,.site-nav__actions{ display:none; }
  .site-nav__burger{ display:block; }
  .s-services{ grid-template-columns:1fr; }
  .s-services-2{ grid-template-columns:1fr; }
  .site-foot__cols{ grid-template-columns:1fr; }
  .s-mobilebar{ display:flex; }
  .s-form__row{ grid-template-columns:1fr; }
  body.has-mobilebar{ padding-bottom:var(--mobile-bar-h); }
}


/* ---------- CALL POPOVER (both locations) ---------- */
.call-wrap{ position:relative; }
.call-toggle{ display:inline-flex; align-items:center; gap:.35rem; background:none; border:0; cursor:pointer; font-family:var(--font-body); font-size:var(--fs-sm); font-weight:600; color:var(--text-strong); }
.call-toggle .caret{ font-size:.7em; color:var(--brass-600); }
.call-menu{ position:absolute; right:0; top:calc(100% + .6rem); min-width:210px; background:var(--surface-raised); border:1px solid var(--border-subtle); border-radius:var(--radius-md); box-shadow:var(--shadow-md); padding:.4rem; display:none; z-index:70; }
.call-wrap.is-open .call-menu{ display:block; }
.call-menu a{ display:block; padding:.6rem .8rem; border-radius:var(--radius-sm); text-decoration:none; }
.call-menu a:hover{ background:var(--ivory-200); }
.call-menu a span{ display:block; font-weight:600; color:var(--text-strong); font-size:var(--fs-sm); }
.call-menu a small{ color:var(--text-accent); font-size:var(--fs-sm); }
.s-mobilebar .call-wrap{ flex:0 0 auto; }
.s-mobilebar .call-toggle{ border:1.5px solid var(--ink-900); border-radius:var(--radius-sm); min-height:2.875rem; padding:0 1rem; }
.s-mobilebar .call-menu{ right:auto; left:0; top:auto; bottom:calc(100% + .6rem); }

/* ---------- REVIEWS (real Google) ---------- */
.s-reviews{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:1rem; }
.s-reviews .s-stars{ margin:0; }
.s-rating-num{ font-family:var(--font-display); font-weight:300; font-size:2.4rem; line-height:1; color:var(--brass-600); }
.s-rating-meta{ font-size:var(--fs-sm); color:var(--text-muted); }
.g-badge{ display:inline-flex; align-items:center; gap:.5rem; background:var(--surface-card); border:1px solid var(--border-subtle); border-radius:var(--radius-pill); padding:.5rem 1rem; font-size:var(--fs-sm); font-weight:600; color:var(--text-strong); text-decoration:none; box-shadow:var(--shadow-sm); }
.g-badge:hover{ box-shadow:var(--shadow-md); color:var(--brass-700); }

/* prevent horizontal overflow on mobile */
html, body { overflow-x: clip; max-width: 100
/* prevent horizontal overflow on mobile */
html, body { overflow-x: clip; max-width: 100%; }

/* ---------- AWARD BADGE + TRUSTED-BY ---------- */
.award-card{ display:inline-flex; align-items:center; gap:1rem; background:var(--ink-900); color:var(--ivory-100); border:1px solid var(--brass-700); border-radius:var(--radius-md); padding:1rem 1.4rem; box-shadow:var(--shadow-md); text-align:left; }
.award-card .award-stars{ color:var(--brass-400); letter-spacing:.1em; font-size:1.05rem; line-height:1; }
.award-card strong{ display:block; font-family:var(--font-display); font-weight:400; font-size:1.2rem; color:var(--ivory-100); }
.award-card span{ font-size:var(--fs-xs); color:var(--brass-300); letter-spacing:.04em; }
.trusted{ display:flex; flex-wrap:wrap; gap:.9rem 1.8rem; align-items:center; justify-content:center; }
.trusted .name{ font-family:var(--font-display); font-weight:400; font-size:1.4rem; color:var(--text-strong); opacity:.82; }

/* QA fix: prose pages — align heading with 720 reading column */
.page-head--prose{ max-width: var(--container-text); }

/* QA fix: collapse nav to hamburger + show mobile bar earlier (was 680) to avoid tablet nav overflow */
@media (max-width: 1024px){
  .site-nav__links, .site-nav__actions { display: none; }
  .site-nav__burger { display: block; }
  .s-mobilebar { display: flex; }
  body.has-mobilebar { padding-bottom: var(--mobile-bar-h); }
}

/* QA fix: prevent card/flex/grid children overflowing on narrow mobile (min-width:auto -> 0) */
.s-split > *, .s-loccard__body, .s-card__body, .s-zip__field, .s-inc > div,
.s-step, .s-stat, .s-info__in > div, .s-includes > *, .trusted, .award-card > div { min-width: 0; }
.s-loccard__body { overflow-wrap: anywhere; }
.s-loccard__body > div:first-child { flex-wrap: wrap; }
.s-zip input { width: 100%; }
.award-card { max-width: 100%; }
@media (max-width: 560px){
  .s-loccard { flex-direction: column; }
  .s-loccard__media { flex: 0 0 auto; width: 100%; }
  .s-loccard__media img { width: 100%; height: auto; min-height: 0; aspect-ratio: 16/9; }
  .s-loccard__body { padding: 1.1rem 1.2rem 1.3rem; }
}

/* QA fix: brass rule should sit tight under its heading (was 22px gap) */
.brass-rule { margin-top: 0.8rem; }
.brass-rule + h1, .brass-rule + h2, .brass-rule + h3 { margin-top: 0.5rem !important; }
.s-head .brass-rule, .page-head .brass-rule { margin-bottom: 0; }

/* Brass rule: tuck tight under the eyebrow, space before heading (user choice) */
.brass-rule { margin: 0.45rem 0 1.3rem !important; }
.brass-rule + h1, .brass-rule + h2, .brass-rule + h3 { margin-top: 0 !important; }

/* Fix: center the brass rule in centered headings (overrides the !important margin reset) */
.page-head--center .brass-rule, .s-head--center .brass-rule { margin-left: auto !important; margin-right: auto !important; }

/* Larger logos (header + footer) */
.site-nav__logo img { height: 3.6rem; }
.site-foot img { height: 4rem; }
