/* ===========================================================================
   subzerorepairmilpitas.com - "Field Diagnostic Board" design system
   Prefix: .sz-milpitas* | Self-hosted Zilla Slab + Public Sans
   Genre: service-manual / diagnostic dashboard. Square, dense, bordered.
   =========================================================================== */

/* ---- Self-hosted fonts (latin subset, swap) ---- */
@font-face{font-family:"Public Sans";font-style:normal;font-weight:400;font-display:swap;
  src:url("/assets/fonts/public-sans-400.woff2") format("woff2")}
@font-face{font-family:"Public Sans";font-style:normal;font-weight:600;font-display:swap;
  src:url("/assets/fonts/public-sans-600.woff2") format("woff2")}
@font-face{font-family:"Public Sans";font-style:normal;font-weight:700;font-display:swap;
  src:url("/assets/fonts/public-sans-700.woff2") format("woff2")}
@font-face{font-family:"Zilla Slab";font-style:normal;font-weight:600;font-display:swap;
  src:url("/assets/fonts/zilla-slab-600.woff2") format("woff2")}
@font-face{font-family:"Zilla Slab";font-style:normal;font-weight:700;font-display:swap;
  src:url("/assets/fonts/zilla-slab-700.woff2") format("woff2")}

/* ---- Tokens ---- */
:root{
  --sz-ink:hsl(28,24%,14%);
  --sz-ink-soft:hsl(28,12%,34%);
  --sz-accent:hsl(18,42%,32%);       /* burnt sienna */
  --sz-accent-d:hsl(18,46%,24%);
  --sz-action:hsl(55,58%,46%);       /* signal yellow */
  --sz-action-d:hsl(48,62%,40%);
  --sz-surface:hsl(198,18%,96%);
  --sz-surface2:hsl(212,22%,90%);
  --sz-line:hsl(88,16%,76%);
  --sz-line-d:hsl(28,14%,62%);
  --sz-warning:hsl(130,65%,43%);
  --sz-bad:hsl(6,64%,44%);
  --sz-paper:#fff;
  --sz-board:hsl(28,18%,11%);        /* dark board background */
  --sz-mono:ui-monospace,"SFMono-Regular",Menlo,Consolas,"Liberation Mono",monospace;
  --sz-shell:1160px;
  --sz-r:2px;
}

/* ---- Reset / base ---- */
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{margin:0;background:var(--sz-surface);color:var(--sz-ink);
  font-family:"Public Sans",system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  font-size:17px;line-height:1.62;text-rendering:optimizeLegibility;overflow-x:hidden}
h1,h2,h3,h4{font-family:"Zilla Slab",Georgia,serif;line-height:1.16;
  color:var(--sz-ink);margin:0 0 .45em;font-weight:700;letter-spacing:-.01em}
h1{font-size:clamp(1.9rem,1.3rem + 2.4vw,2.7rem)}
h2{font-size:clamp(1.45rem,1.1rem + 1.4vw,1.95rem);margin-top:0}
h3{font-size:1.22rem;font-weight:600}
h4{font-size:1.02rem;font-weight:600}
p{margin:0 0 1em}
a{color:var(--sz-accent);text-underline-offset:2px}
a:hover{color:var(--sz-accent-d)}
img,svg{max-width:100%;height:auto}
main,section,div,p,h1,h2,h3,h4{min-width:0}
h1,h2,h3,h4,p,li,figcaption{overflow-wrap:break-word}
strong,b{font-weight:700}
:focus-visible{outline:3px solid var(--sz-action);outline-offset:2px}

/* ---- Shell ---- */
.sz-shell{width:100%;max-width:var(--sz-shell);margin-inline:auto;padding-inline:20px}
.sz-band{padding:46px 0}
.sz-band--tight{padding:30px 0}
.sz-band--surface2{background:var(--sz-surface2)}
.sz-band--ink{background:var(--sz-board);color:#e9e3d8}
.sz-band--ink h2,.sz-band--ink h3{color:#fff}

/* ---- Mono status / data labels ---- */
.sz-tag{font-family:var(--sz-mono);font-size:.66rem;font-weight:700;letter-spacing:.13em;
  text-transform:uppercase;display:inline-block;padding:2px 7px;border:1px solid var(--sz-line-d);
  border-radius:var(--sz-r);background:var(--sz-paper);color:var(--sz-ink-soft);line-height:1.5}
.sz-tag--ok{color:#1c5c2e;border-color:var(--sz-warning);background:hsl(130,55%,95%)}
.sz-tag--warn{color:#8a5a00;border-color:var(--sz-action-d);background:hsl(48,80%,93%)}
.sz-tag--bad{color:#8a2018;border-color:var(--sz-bad);background:hsl(6,70%,95%)}
.sz-tag--accent{color:#fff;background:var(--sz-accent);border-color:var(--sz-accent-d)}
.sz-kicker{font-family:var(--sz-mono);font-size:.72rem;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--sz-accent);margin:0 0 .7em;display:block}

/* ---- Top route / availability strip ---- */
.sz-strip{background:var(--sz-board);color:#cfc7b8;font-family:var(--sz-mono);
  font-size:.74rem;letter-spacing:.04em}
.sz-strip .sz-shell{display:flex;flex-wrap:wrap;gap:6px 22px;align-items:center;padding-block:7px}
.sz-strip span{min-width:0;overflow-wrap:anywhere}
.sz-strip b{color:#fff;font-weight:700}
.sz-strip .sz-dot{width:7px;height:7px;border-radius:50%;background:var(--sz-warning);
  display:inline-block;margin-right:6px;box-shadow:0 0 0 3px hsl(130,65%,43%,.25)}

/* ---- Header ---- */
.sz-head{background:var(--sz-paper);border-bottom:2px solid var(--sz-ink)}
.sz-head .sz-shell{display:flex;align-items:center;justify-content:space-between;
  gap:14px;padding-block:13px;flex-wrap:wrap}
.sz-brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--sz-ink)}
.sz-brand__mark{width:42px;height:42px;flex:none;border:2px solid var(--sz-accent);
  border-radius:var(--sz-r);display:grid;place-items:center;background:#fff;overflow:hidden}
.sz-brand__mark img{width:100%;height:100%;display:block;object-fit:cover}
.sz-brand__name{font-family:"Zilla Slab",serif;font-weight:700;font-size:1.12rem;line-height:1.05}
.sz-brand__sub{display:block;font-family:var(--sz-mono);font-size:.62rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--sz-ink-soft);font-weight:700}
.sz-head__actions{display:flex;align-items:center;gap:9px;flex-wrap:wrap;justify-content:flex-end}
.sz-head__actions .sz-btn{padding:9px 13px;font-size:.96rem}

/* ---- Nav ---- */
.sz-nav{background:var(--sz-board)}
.sz-nav .sz-shell{display:flex;flex-wrap:wrap;gap:0;padding:0}
.sz-nav a{font-family:var(--sz-mono);font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;
  font-weight:600;color:#cfc7b8;text-decoration:none;padding:11px 14px;border-right:1px solid #2c2620}
.sz-nav a:hover{background:#2c2620;color:#fff}
.sz-nav a[aria-current="page"]{color:var(--sz-board);background:var(--sz-action)}

/* ---- Buttons ---- */
.sz-btn{display:inline-flex;align-items:center;gap:.5em;font-family:"Zilla Slab",serif;
  font-weight:700;font-size:1.02rem;text-decoration:none;padding:12px 20px;border-radius:var(--sz-r);
  border:2px solid transparent;cursor:pointer;line-height:1.1;transition:filter .12s;min-width:0}
.sz-btn:hover{filter:brightness(1.05)}
.sz-btn--call{background:var(--sz-accent);color:#fff;border-color:var(--sz-accent-d)}
.sz-btn--book{background:var(--sz-action);color:var(--sz-board);border-color:var(--sz-action-d)}
.sz-btn--ghost{background:transparent;color:var(--sz-ink);border-color:var(--sz-ink)}
.sz-btn--ghost:hover{background:var(--sz-ink);color:#fff;filter:none}
.sz-btn--block{width:100%;justify-content:center}
.sz-btn--disabled{opacity:.62;cursor:not-allowed;filter:grayscale(.25)}
.sz-btn--disabled:hover{filter:grayscale(.25)}

/* ---- Icons ---- */
.sz-ic{width:1.05em;height:1.05em;flex:none;vertical-align:-.15em;stroke-width:2}

/* ---- HERO: diagnostic dashboard (no full-screen, ~560px top) ---- */
.sz-hero{background:
  linear-gradient(180deg,var(--sz-surface),var(--sz-surface2));
  border-bottom:1px solid var(--sz-line)}
.sz-hero .sz-shell{display:grid;grid-template-columns:1.35fr .95fr;gap:30px;
  padding-block:36px;align-items:start}
.sz-hero .sz-shell > *{min-width:0}
.sz-hero__lead{max-width:60ch;min-width:0}
.sz-hero h1{margin-bottom:.35em}
.sz-hero__answer{font-size:1.08rem;color:var(--sz-ink)}
.sz-hero__cta{display:flex;flex-wrap:wrap;gap:11px;margin-top:18px;align-items:center}
.sz-hero__fineprint{font-family:var(--sz-mono);font-size:.72rem;color:var(--sz-ink-soft);
  margin-top:12px;letter-spacing:.02em}

/* Right-rail diagnostic panel */
.sz-panel{background:var(--sz-board);color:#e9e3d8;border-radius:var(--sz-r);
  border:1px solid #000;overflow:hidden;box-shadow:0 14px 34px rgba(28,20,12,.22)}
.sz-panel__bar{display:flex;align-items:center;justify-content:space-between;
  background:#23201b;padding:9px 13px;border-bottom:1px solid #000}
.sz-panel__bar span{font-family:var(--sz-mono);font-size:.66rem;letter-spacing:.14em;
  text-transform:uppercase;color:#b9b0a0;font-weight:700}
.sz-panel__body{padding:14px 15px}
.sz-readout{display:flex;justify-content:space-between;align-items:baseline;gap:10px;
  font-family:var(--sz-mono);font-size:.82rem;padding:7px 0;border-bottom:1px dashed #3a342c}
.sz-readout:last-of-type{border-bottom:0}
.sz-readout .k{color:#a59c8c}
.sz-readout .v{color:#fff;font-weight:700}
.sz-readout .v.ok{color:hsl(130,55%,62%)}
.sz-readout .v.warn{color:hsl(48,90%,62%)}
.sz-panel__fee{margin-top:12px;padding:12px 13px;background:#1a1712;border:1px solid #34302a;
  border-radius:var(--sz-r);text-align:center}
.sz-panel__fee b{display:block;font-family:"Zilla Slab",serif;font-size:1.7rem;color:var(--sz-action)}
.sz-panel__fee small{font-family:var(--sz-mono);font-size:.66rem;letter-spacing:.08em;
  text-transform:uppercase;color:#a59c8c}
.sz-panel__phone{display:flex;flex-direction:column;align-items:center;margin-top:12px;
  text-decoration:none}
.sz-panel__phone b{font-family:"Zilla Slab",serif;color:#fff;font-size:1.5rem;line-height:1}
.sz-panel__phone small{font-family:var(--sz-mono);font-size:.62rem;letter-spacing:.12em;
  text-transform:uppercase;color:#a59c8c;margin-top:3px}

/* ---- Breadcrumbs ---- */
.sz-crumbs{font-family:var(--sz-mono);font-size:.72rem;color:var(--sz-ink-soft);
  padding:10px 0;letter-spacing:.03em}
.sz-crumbs a{color:var(--sz-ink-soft);text-decoration:none}
.sz-crumbs a:hover{color:var(--sz-accent)}
.sz-crumbs span{margin:0 7px;color:var(--sz-line-d)}

/* ---- Prose ---- */
.sz-prose{max-width:72ch}
.sz-prose h2{margin-top:1.6em}
.sz-prose h3{margin-top:1.4em;color:var(--sz-accent-d)}
.sz-prose ul,.sz-prose ol{padding-left:1.25em;margin:0 0 1em}
.sz-prose li{margin:.3em 0}
.sz-lead{font-size:1.14rem;color:var(--sz-ink)}

/* ---- Symptom router / fault cards ---- */
.sz-grid{display:grid;gap:14px}
.sz-grid > *,.sz-split > *,.sz-figrow > *{min-width:0}
.sz-grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}
.sz-grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}
.sz-fault{background:var(--sz-paper);border:1px solid var(--sz-line-d);border-left:4px solid var(--sz-accent);
  border-radius:var(--sz-r);padding:15px 16px;display:flex;flex-direction:column;gap:7px}
.sz-fault h3{font-size:1.08rem;margin:0;font-family:"Zilla Slab",serif}
.sz-fault p{margin:0;font-size:.95rem}
.sz-fault .sz-means{font-size:.92rem}
.sz-fault .sz-dont{font-size:.88rem;color:var(--sz-bad)}
.sz-fault a{font-family:var(--sz-mono);font-size:.74rem;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;margin-top:auto;text-decoration:none;display:inline-flex;align-items:center;gap:5px}
.sz-fault a:hover{text-decoration:underline}

/* ---- Technician note (bordered callout) ---- */
.sz-note{border:1px solid var(--sz-line-d);border-top:3px solid var(--sz-action);
  background:var(--sz-paper);border-radius:var(--sz-r);padding:14px 16px;margin:18px 0}
.sz-note::before{content:"TECH NOTE";font-family:var(--sz-mono);font-size:.66rem;font-weight:700;
  letter-spacing:.14em;color:var(--sz-accent);display:block;margin-bottom:6px}
.sz-note p:last-child{margin-bottom:0}
.sz-note--noguess{border-top-color:var(--sz-bad)}
.sz-note--noguess::before{content:"WE DON'T GUESS";color:var(--sz-bad)}

/* ---- LLM citation / answer-first blocks ---- */
.sz-direct{background:var(--sz-paper);border:2px solid var(--sz-ink);border-left:6px solid var(--sz-accent);
  border-radius:var(--sz-r);padding:18px 20px;box-shadow:6px 6px 0 var(--sz-line)}
.sz-direct p{font-size:1.05rem;margin-bottom:.75em}
.sz-direct .sz-kicker{margin-bottom:.45em}
.sz-answer-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:18px}
.sz-answer-card{background:var(--sz-paper);border:1px solid var(--sz-line-d);border-top:4px solid var(--sz-accent);
  border-radius:var(--sz-r);padding:15px 16px;display:flex;flex-direction:column;gap:8px}
.sz-answer-card h3{margin:0;font-size:1.08rem}
.sz-answer-card p{font-size:.94rem;margin:0}
.sz-answer-card a{font-family:var(--sz-mono);font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.04em;text-decoration:none;margin-top:auto}
.sz-updated{font-family:var(--sz-mono);font-size:.72rem;color:var(--sz-ink-soft);letter-spacing:.04em;
  text-transform:uppercase;margin-top:10px}
.sz-related{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 0;padding:0;list-style:none}
.sz-related a{display:inline-block;border:1px solid var(--sz-line-d);background:var(--sz-paper);
  border-radius:var(--sz-r);padding:6px 10px;text-decoration:none;font-family:var(--sz-mono);
  font-size:.72rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase}
.sz-related a:hover{background:var(--sz-board);color:#fff}
.sz-mini{background:var(--sz-paper);border:1px solid var(--sz-line-d);border-radius:var(--sz-r);padding:16px 17px}
.sz-mini h3{margin-top:0}
.sz-mini p:last-child{margin-bottom:0}
.sz-statgrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:16px 0}
.sz-panel .sz-statgrid{grid-template-columns:repeat(2,minmax(0,1fr))}
.sz-stat{background:var(--sz-paper);border:1px solid var(--sz-line-d);border-radius:var(--sz-r);padding:12px}
.sz-stat b{display:block;font-family:"Zilla Slab",serif;font-size:1.2rem;color:var(--sz-accent-d)}
.sz-stat span{font-family:var(--sz-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--sz-ink-soft)}
.sz-contact-note{border:1px dashed var(--sz-line-d);background:var(--sz-surface);padding:10px 12px;
  border-radius:var(--sz-r);font-size:.88rem;color:var(--sz-ink-soft)}

/* ---- Review trust layer ---- */
.sz-google-badge{display:inline-flex;align-items:center;gap:10px;max-width:100%;
  border:1px solid var(--sz-line-d);background:var(--sz-paper);border-radius:var(--sz-r);
  padding:8px 10px;text-decoration:none;color:var(--sz-ink);box-shadow:3px 3px 0 var(--sz-line)}
.sz-google-badge:hover{color:var(--sz-ink);filter:brightness(1.02)}
.sz-google-badge--pending{box-shadow:none}
.sz-google-badge__copy{display:grid;gap:1px;min-width:0}
.sz-google-badge__copy b{font-family:"Zilla Slab",serif;font-size:1rem;line-height:1;color:var(--sz-ink)}
.sz-google-badge__copy span{font-family:var(--sz-mono);font-size:.64rem;letter-spacing:.07em;
  text-transform:uppercase;color:var(--sz-ink-soft);white-space:normal}
.sz-google-g{width:36px;height:36px;flex:none;border-radius:50%;display:grid;place-items:center;
  background:conic-gradient(#4285f4 0 24%,#34a853 0 48%,#fbbc05 0 72%,#ea4335 0 100%)}
.sz-google-g__b{width:27px;height:27px;border-radius:50%;display:grid;place-items:center;
  background:#fff;color:#2b2b2b;font-family:Arial,Helvetica,sans-serif;font-weight:700;font-size:1.12rem}
.sz-stars{font-size:.82rem;letter-spacing:.04em;color:#fbbc05;white-space:nowrap}
.sz-stars--muted{color:#b6aa86}
.sz-review-band{background:linear-gradient(180deg,var(--sz-surface2),var(--sz-surface))}
.sz-review-head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:14px}
.sz-review-head h2{margin:0}
.sz-review-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.sz-review-card{background:var(--sz-paper);border:1px solid var(--sz-line-d);border-top:4px solid var(--sz-warning);
  border-radius:var(--sz-r);padding:14px 15px}
.sz-review-card h3{font-size:1.04rem;margin:.35em 0 .35em}
.sz-review-card p{font-size:.92rem;margin:0;color:var(--sz-ink-soft)}
.sz-review-note{font-family:var(--sz-mono);font-size:.69rem;letter-spacing:.04em;color:var(--sz-ink-soft);
  margin:12px 0 0;text-transform:uppercase}

/* ---- Compact diagnostic tables ---- */
.sz-table-wrap{overflow-x:auto;max-width:100%;border:1px solid var(--sz-line-d);border-radius:var(--sz-r);margin:16px 0}
table.sz-table{width:100%;border-collapse:collapse;font-size:.92rem;min-width:540px}
.sz-table th,.sz-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--sz-line);
  vertical-align:top}
.sz-table thead th{background:var(--sz-board);color:#fff;font-family:var(--sz-mono);
  font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;border-bottom:0}
.sz-table tbody tr:nth-child(even){background:var(--sz-surface)}
.sz-table td:first-child{font-weight:600}

/* ---- Diagnostic sequence (numbered steps) ---- */
.sz-seq{list-style:none;padding:0;margin:18px 0;counter-reset:s;
  display:grid;gap:0;border:1px solid var(--sz-line-d);border-radius:var(--sz-r)}
.sz-seq li{counter-increment:s;display:grid;grid-template-columns:auto 1fr;gap:14px;
  padding:13px 15px;border-bottom:1px solid var(--sz-line);background:var(--sz-paper)}
.sz-seq li:last-child{border-bottom:0}
.sz-seq li::before{content:counter(s,decimal-leading-zero);font-family:var(--sz-mono);font-weight:700;
  color:var(--sz-accent);font-size:.95rem;background:var(--sz-surface2);border-radius:var(--sz-r);
  width:34px;height:34px;display:grid;place-items:center}
.sz-seq b{font-family:"Zilla Slab",serif}

/* ---- Figures / media ---- */
.sz-fig{margin:18px 0;background:var(--sz-paper);border:1px solid var(--sz-line-d);
  border-radius:var(--sz-r);overflow:hidden}
.sz-fig__media{background:var(--sz-surface2);display:block;line-height:0}
.sz-photo{display:block;width:100%;aspect-ratio:4/3;object-fit:cover;background:var(--sz-surface2)}
.sz-photo--wide{aspect-ratio:16/9}
.sz-panel__image{display:block;width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--sz-r);
  border:1px solid #34302a;background:#111}
.sz-fig figcaption{font-size:.86rem;color:var(--sz-ink-soft);padding:9px 13px;
  border-top:1px solid var(--sz-line);line-height:1.5}
.sz-fig figcaption b{color:var(--sz-ink)}
.sz-figrow{display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr))}
.sz-figrow--2{grid-template-columns:repeat(2,minmax(0,1fr))}

/* image slot for real photos to be dropped in later */
.sz-slot{aspect-ratio:4/3;display:grid;place-items:center;background:
  repeating-linear-gradient(45deg,var(--sz-surface2),var(--sz-surface2) 11px,var(--sz-surface) 11px,var(--sz-surface) 22px);
  color:var(--sz-ink-soft);font-family:var(--sz-mono);font-size:.74rem;text-align:center;padding:14px}

/* ---- Split / sidebar layouts ---- */
.sz-split{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(0,.95fr);gap:30px;align-items:start}
.sz-split--rev{grid-template-columns:minmax(0,.95fr) minmax(0,1.55fr)}
.sz-aside{background:var(--sz-paper);border:1px solid var(--sz-line-d);border-radius:var(--sz-r);
  padding:16px 17px;position:sticky;top:16px}
.sz-aside h3{margin-top:0;font-size:1.05rem}
.sz-aside ul{list-style:none;padding:0;margin:0}
.sz-aside li{padding:7px 0;border-bottom:1px dashed var(--sz-line);font-size:.92rem}
.sz-aside li:last-child{border-bottom:0}

/* ---- Checklists ---- */
.sz-checks{list-style:none;padding:0;margin:0 0 1em}
.sz-checks li{display:flex;gap:.6em;align-items:flex-start;margin:8px 0}
.sz-checks .sz-ic{color:var(--sz-warning);margin-top:.22em}

/* ---- Evidence chips row ---- */
.sz-evid{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0;padding:0;list-style:none}
.sz-evid li{font-family:var(--sz-mono);font-size:.72rem;font-weight:600;letter-spacing:.03em;
  border:1px solid var(--sz-line-d);border-radius:var(--sz-r);padding:5px 10px;background:var(--sz-paper)}

/* ---- FAQ ---- */
.sz-faq details{background:var(--sz-paper);border:1px solid var(--sz-line-d);border-radius:var(--sz-r);
  margin:9px 0;padding:0 15px}
.sz-faq summary{cursor:pointer;font-family:"Zilla Slab",serif;font-weight:600;font-size:1.05rem;
  padding:13px 0;list-style:none;display:flex;justify-content:space-between;gap:12px;align-items:center}
.sz-faq summary::-webkit-details-marker{display:none}
.sz-faq summary::after{content:"+";font-family:var(--sz-mono);color:var(--sz-accent);font-size:1.3rem}
.sz-faq details[open] summary::after{content:"-"}
.sz-faq details p{margin:0 0 14px;font-size:.96rem}

/* ---- CTA band (after proof) ---- */
.sz-cta{background:var(--sz-board);color:#e9e3d8;border-radius:var(--sz-r);
  padding:26px 24px;display:grid;grid-template-columns:1.4fr auto;gap:22px;align-items:center}
.sz-cta h2{color:#fff;margin:0 0 .3em}
.sz-cta p{margin:0;color:#cfc7b8}
.sz-cta__act{display:flex;flex-direction:column;gap:10px;min-width:230px}

.sz-contact-panel{background:var(--sz-paper);border:1px solid var(--sz-line-d);border-radius:var(--sz-r);padding:18px}
.sz-contact-panel__actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:12px 0 0}
.sz-foot__actions{display:grid;gap:8px;margin-top:14px;max-width:280px}

/* ---- Map ---- */
.sz-map{border:1px solid var(--sz-line-d);border-radius:var(--sz-r);overflow:hidden;background:var(--sz-surface2)}
.sz-map iframe{display:block;width:100%;height:340px;border:0;filter:grayscale(.15) contrast(1.02)}

/* ---- Neighborhood notes ---- */
.sz-hoods{display:grid;gap:14px;grid-template-columns:repeat(2,1fr)}
.sz-hood{border:1px solid var(--sz-line);border-radius:var(--sz-r);padding:14px 16px;background:var(--sz-paper)}
.sz-hood h3{font-size:1.05rem;margin:0 0 .3em}
.sz-hood h3 .sz-tag{margin-left:6px;vertical-align:middle}
.sz-hood p{margin:0;font-size:.93rem}

/* ---- Sticky mobile call bar ---- */
.sz-stickybar{display:none}

/* ---- Footer (distinct DOM) ---- */
.sz-foot{background:var(--sz-board);color:#b9b0a0;margin-top:40px;
  font-size:.92rem;border-top:4px solid var(--sz-accent)}
.sz-foot .sz-shell{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:26px;padding-block:34px}
.sz-foot h4{color:#fff;font-family:var(--sz-mono);font-size:.74rem;letter-spacing:.12em;
  text-transform:uppercase;margin:0 0 12px}
.sz-foot a{color:#cfc7b8;text-decoration:none}
.sz-foot a:hover{color:#fff;text-decoration:underline}
.sz-foot ul{list-style:none;padding:0;margin:0}
.sz-foot li{padding:4px 0}
.sz-foot__phone{font-family:"Zilla Slab",serif;font-size:1.4rem;color:#fff;font-weight:700;text-decoration:none}
.sz-foot__locality{font-family:var(--sz-mono);font-size:.66rem;letter-spacing:.06em;
  text-transform:uppercase;color:#8a8175;margin:.2em 0 1em}
.sz-foot__legal{border-top:1px solid #2c2620;font-size:.78rem;color:#8a8175;
  padding:16px 0 26px;line-height:1.6}
.sz-foot__legal .sz-shell{display:block;padding-block:0}

/* ---- Utilities ---- */
.sz-mt0{margin-top:0}.sz-mb0{margin-bottom:0}
.sz-muted{color:var(--sz-ink-soft);font-size:.9rem}
.sz-divider{border:0;border-top:1px solid var(--sz-line);margin:34px 0}
.sz-sr{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ===========================================================================
   Responsive
   =========================================================================== */
@media(max-width:900px){
  .sz-hero .sz-shell{grid-template-columns:1fr;padding-block:26px}
  .sz-split,.sz-split--rev{grid-template-columns:1fr}
  .sz-aside{position:static}
  .sz-cta{grid-template-columns:1fr}
  .sz-grid--3,.sz-figrow{grid-template-columns:repeat(2,1fr)}
  .sz-answer-grid{grid-template-columns:1fr}
  .sz-review-grid{grid-template-columns:1fr}
  .sz-review-head{align-items:flex-start;flex-direction:column}
  .sz-statgrid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:620px){
  body{font-size:16px}
  h1{font-size:1.72rem;line-height:1.18}
  h2{font-size:1.36rem}
  .sz-shell{padding-inline:16px}
  .sz-strip .sz-shell{display:grid;gap:3px}
  .sz-grid--2,.sz-grid--3,.sz-figrow,.sz-figrow--2,.sz-hoods{grid-template-columns:1fr}
  .sz-statgrid{grid-template-columns:1fr}
  .sz-contact-panel__actions{grid-template-columns:1fr}
  .sz-head .sz-shell{align-items:flex-start}
  .sz-head__actions{width:100%;justify-content:flex-start}
  .sz-head__actions .sz-btn{padding:9px 11px;font-size:.92rem}
  .sz-hero__lead,.sz-hero__cta,.sz-panel{width:100%;max-width:100%}
  .sz-hero__cta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .sz-hero__cta .sz-btn{width:100%;justify-content:center;padding-inline:10px;white-space:normal}
  .sz-hero__cta .sz-btn--ghost{grid-column:1 / -1}
  .sz-panel__bar{gap:10px}
  .sz-panel__bar span{overflow-wrap:anywhere}
  .sz-nav .sz-shell{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}
  .sz-nav .sz-shell::-webkit-scrollbar{display:none}
  .sz-nav a{white-space:nowrap;flex:0 0 auto}
  /* sticky mobile call bar */
  .sz-stickybar{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));position:fixed;left:0;right:0;bottom:0;z-index:50;
    background:var(--sz-board);border-top:2px solid var(--sz-accent);padding:8px;gap:8px}
  .sz-stickybar .sz-btn{flex:1 1 0;width:auto;min-width:0;justify-content:center;font-size:.9rem;padding:11px 8px}
  body{padding-bottom:64px}
}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

.sz-review-card .sz-stars{display:block;margin-bottom:8px}
.sz-review-by{display:block;margin-top:10px;font-style:normal;font-family:var(--sz-mono);font-size:.7rem;letter-spacing:.04em;text-transform:uppercase;color:var(--sz-ink-soft)}
