/*
Theme Name: Slater Chiropractic
Theme URI: https://www.slaterchiropractic.ca/
Description: Editorial child theme for Dr. Savannah Slater's chiropractic practice. Hand-coded child theme of GeneratePress with ACF-driven content fields, two-clinic LocalBusiness schema, and brand-specific typography (Cormorant Garamond + Jost). Built for WordPress hosting on GoHighLevel.
Author: Keller Visuals
Author URI: https://kellervisuals.com/
Template: generatepress
Version: 1.1.5
Requires at least: 6.4
Requires PHP: 8.1
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: slater-chiro
Tags: editorial, healthcare, chiropractic, local-business, custom-colors, custom-fonts
*/

/* ============ TOKENS ============ */
:root {
  --slate:#4F6269;
  --slate-deep:#394A51;
  --slate-ink:#263339;
  --slate-soft:#89979D;
  --bronze:#A76A3E;
  --bronze-light:#BF8659;
  --bronze-pale:#E2C8AD;
  --beige:#E5D8C9;
  --beige-light:#EFE6D9;
  --off-white:#FAF6F0;
  --paper:#F1E9DC;
  --white:#FFFFFF;
  --rule:rgba(38,51,57,0.14);
  --rule-soft:rgba(38,51,57,0.08);

  --f-serif:'Cormorant Garamond', Georgia, serif;
  --f-sans:'Jost', 'Helvetica Neue', sans-serif;
  --f-mono: ui-monospace, 'SF Mono', Menlo, monospace;

  --container:1280px;
  --gutter:clamp(20px, 4vw, 56px);
}

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body.slater {
  font-family:var(--f-sans);
  background:var(--off-white);
  color:var(--slate-ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.slater img { max-width:100%; display:block; }
.slater a { color:inherit; text-decoration:none; }
.slater ul, .slater ol { list-style:none; }
.slater button { font:inherit; cursor:pointer; border:0; background:none; color:inherit; }
.slater ::selection { background:var(--bronze); color:var(--off-white); }

/* ============ TYPE ============ */
.slater h1, .slater h2, .slater h3, .slater h4 {
  font-family:var(--f-serif);
  font-weight:400;
  color:var(--slate-deep);
  letter-spacing:-0.005em;
  line-height:1.05;
}
.slater .display { font-family:var(--f-serif); font-weight:400; line-height:0.98; letter-spacing:-0.015em; }
.slater .display em { font-style:italic; color:var(--bronze); font-weight:400; }
.slater .eyebrow { font-family:var(--f-sans); font-size:11px; font-weight:500; letter-spacing:0.22em; text-transform:uppercase; color:var(--bronze); }
.slater .micro { font-family:var(--f-mono); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--slate-soft); }
.slater .lede { font-family:var(--f-serif); font-size:clamp(20px,2.1vw,26px); line-height:1.5; color:var(--slate-deep); font-weight:300; letter-spacing:-0.005em; }

/* ============ SHELL ============ */
.slater .wrap { max-width:var(--container); margin:0 auto; padding:0 var(--gutter); }
.slater .rule { height:1px; background:var(--rule); border:0; }

/* ============ BUTTONS ============ */
.slater .btn { display:inline-flex; align-items:center; gap:10px; font-family:var(--f-sans); font-size:13px; font-weight:500; letter-spacing:0.1em; text-transform:uppercase; padding:16px 28px; border:1px solid transparent; transition:all .25s ease; white-space:nowrap; }
.slater .btn--primary { background:var(--bronze); color:var(--off-white); }
.slater .btn--primary:hover { background:var(--slate-deep); }
.slater .btn--ghost { border-color:currentColor; color:var(--slate-deep); }
.slater .btn--ghost:hover { background:var(--slate-deep); color:var(--off-white); }
.slater .btn--ghost-light { border-color:rgba(255,255,255,.6); color:var(--off-white); }
.slater .btn--ghost-light:hover { background:var(--off-white); color:var(--slate-deep); border-color:var(--off-white); }
.slater .btn--bare { padding:0; letter-spacing:0.16em; color:var(--slate-deep); border-bottom:1px solid var(--slate-deep); padding-bottom:4px; text-transform:uppercase; font-size:11px; font-weight:500; }
.slater .btn--bare:hover { color:var(--bronze); border-color:var(--bronze); }

/* ============ NAV ============ */
.slater .nav { position:fixed; top:0; left:0; right:0; z-index:100; padding:22px 0; transition:padding .3s ease, background .3s ease, backdrop-filter .3s ease; color:var(--slate-deep); }
.slater .nav.is-scrolled { padding:12px 0; background:rgba(250,248,245,0.92); backdrop-filter:saturate(120%) blur(14px); -webkit-backdrop-filter:saturate(120%) blur(14px); color:var(--slate-deep); border-bottom:1px solid var(--rule-soft); }
.slater .nav-inner { max-width:var(--container); margin:0 auto; padding:0 var(--gutter); display:flex; align-items:center; justify-content:space-between; gap:32px; }
.slater .brand { display:flex; align-items:center; gap:14px; }
.slater .brand-mark { width:36px; height:36px; position:relative; flex:none; }
.slater .brand-mark img { width:100%; height:100%; object-fit:contain; }
.slater .brand-type { display:flex; flex-direction:column; line-height:1.05; gap:6px; }
.slater .brand-name { font-family:var(--f-serif); font-size:24px; letter-spacing:0.02em; white-space:nowrap; }
.slater .brand-tag { font-size:10px; letter-spacing:0.28em; text-transform:uppercase; color:var(--bronze); white-space:nowrap; }
.slater .nav-menu { display:flex; align-items:center; gap:36px; }
.slater .nav-menu a { font-size:12px; letter-spacing:0.15em; text-transform:uppercase; font-weight:500; padding:8px 0; position:relative; opacity:0.88; transition:opacity .2s; }
.slater .nav-menu a:hover { opacity:1; }
.slater .nav-menu a.nav-cta { padding:12px 22px; background:var(--bronze); color:var(--off-white); opacity:1; letter-spacing:0.12em; white-space:nowrap; }
.slater .nav-menu a.nav-cta:hover { background:var(--slate-deep); }
.slater .nav-toggle { display:none; width:32px; height:32px; flex-direction:column; justify-content:center; gap:4px; }
.slater .nav-toggle span { display:block; height:1px; background:currentColor; }

/* ============ HERO ============ */
.slater .hero { position:relative; min-height:100vh; color:var(--slate-deep); overflow:hidden; display:flex; flex-direction:column; justify-content:flex-end; padding:160px 0 80px; background: radial-gradient(ellipse 1200px 800px at 85% 20%, rgba(232,213,192,0.55) 0%, transparent 60%), radial-gradient(ellipse 900px 700px at 10% 90%, rgba(216,200,179,0.4) 0%, transparent 55%), linear-gradient(180deg, var(--off-white) 0%, var(--paper) 100%); }
.slater .hero-grain { position:absolute; inset:0; z-index:1; pointer-events:none; opacity:0.5; background-image:radial-gradient(circle at 1px 1px, rgba(46,56,64,0.06) 1px, transparent 0); background-size:18px 18px; mix-blend-mode:multiply; }
.slater .hero-grid { position:absolute; inset:0; z-index:0; pointer-events:none; max-width:var(--container); margin:0 auto; padding:0 var(--gutter); display:grid; grid-template-columns:repeat(12, 1fr); }
.slater .hero-grid span { border-left:1px solid rgba(46,56,64,0.04); }
.slater .hero-grid span:first-child { border-left:0; }
.slater .hero-sprig { position:absolute; z-index:1; pointer-events:none; }
.slater .hero-sprig--r { top:18%; right:4%; width:clamp(180px,22vw,340px); opacity:0.85; transform:rotate(14deg); }
.slater .hero-sprig--l { bottom:6%; left:2%; width:clamp(120px,14vw,200px); opacity:0.5; transform:rotate(-160deg); }
.slater .hero-sprig img { width:100%; height:auto; display:block; }
/* Hero-top index block was decorative editorial filigree; it overlapped with the
   hero eyebrow vertically (both in y=130-185) and made the top of the page look
   cluttered with two competing horizontal text strips. Hidden site-wide. */
.slater .hero-top { display:none; }
.slater .hero-index { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; align-items:flex-start; padding-top:18px; border-top:1px solid var(--rule-soft); }
.slater .hero-index .cell { font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--slate); opacity:0.85; line-height:1.55; min-width:0; }
.slater .hero-index .cell strong { font-weight:500; color:var(--bronze); display:block; margin-bottom:4px; }
.slater .hero-content { position:relative; z-index:2; max-width:var(--container); margin:0 auto; padding:0 var(--gutter); width:100%; }
.slater .hero-eyebrow { display:flex; align-items:center; gap:14px; margin-bottom:48px; color:var(--bronze); }
.slater .hero-eyebrow .tick { width:48px; height:1px; background:currentColor; display:inline-block; }
.slater .hero-eyebrow span { font-size:11px; letter-spacing:0.26em; text-transform:uppercase; font-weight:500; }
.slater .hero-h1 { font-family:var(--f-serif); font-size:clamp(64px,11.5vw,196px); letter-spacing:-0.025em; line-height:0.9; color:var(--slate-deep); font-weight:400; margin:0; }
.slater .hero-h1 .l1 { display:block; }
.slater .hero-h1 .l2 { display:block; color:var(--bronze); font-style:italic; font-weight:400; position:relative; padding-left:0.08em; }
.slater .hero-tagline { font-size:13px; letter-spacing:0.32em; text-transform:uppercase; color:var(--slate); margin-top:40px; display:flex; align-items:center; gap:18px; font-weight:500; }
.slater .hero-tagline::before { content:""; width:56px; height:1px; background:var(--bronze); }
.slater .hero-tagline em { color:var(--bronze); font-style:italic; font-family:var(--f-serif); letter-spacing:0.04em; text-transform:none; font-size:18px; font-weight:400; }
.slater .hero-bottom { display:grid; grid-template-columns:1fr auto; align-items:end; gap:48px; margin-top:96px; padding-top:32px; border-top:1px solid var(--rule); }
.slater .hero-lede { max-width:52ch; font-family:var(--f-serif); font-size:clamp(19px,1.7vw,24px); line-height:1.5; color:var(--slate-deep); font-weight:300; }
.slater .hero-lede em { color:var(--bronze); font-style:italic; }
.slater .hero-actions { display:flex; gap:14px; flex-wrap:wrap; }
.slater .hero-actions .btn--ghost-light { color:var(--slate-deep); border-color:var(--slate-deep); }
.slater .hero-actions .btn--ghost-light:hover { background:var(--slate-deep); color:var(--off-white); }
.slater .hero-scroll { position:absolute; bottom:28px; left:var(--gutter); z-index:3; display:flex; align-items:center; gap:10px; font-family:var(--f-mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--slate); opacity:0.7; }
.slater .hero-scroll .line { width:1px; height:40px; background:var(--slate); display:inline-block; animation:slaterScrollPulse 2.4s ease-in-out infinite; }
@keyframes slaterScrollPulse { 0%,100% { transform:scaleY(0.3); transform-origin:top; opacity:0.4; } 50% { transform:scaleY(1); opacity:1; } }
.slater .hero-plaque { position:absolute; right:var(--gutter); bottom:28px; z-index:3; text-align:right; font-family:var(--f-mono); font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--slate); opacity:0.7; line-height:1.7; }
.slater .hero-plaque strong { color:var(--bronze); font-weight:500; display:block; }

/* ============ TICKER ============ */
.slater .ticker { background:var(--slate-deep); color:var(--off-white); padding:20px 0; overflow:hidden; border-bottom:1px solid rgba(255,255,255,0.06); }
.slater .ticker-track { display:flex; gap:64px; animation:slaterTicker 38s linear infinite; white-space:nowrap; width:max-content; }
.slater .ticker-item { display:flex; align-items:center; gap:16px; font-size:13px; letter-spacing:0.14em; text-transform:uppercase; font-weight:400; color:rgba(250,248,245,0.85); }
.slater .ticker-item .dot { width:5px; height:5px; background:var(--bronze-light); border-radius:50%; flex:none; }
.slater .ticker-item em { color:var(--bronze-light); font-style:italic; font-family:var(--f-serif); text-transform:none; letter-spacing:0; font-size:15px; }
@keyframes slaterTicker { to { transform:translateX(-50%); } }

/* ============ SECTION ============ */
.slater .section { padding:clamp(60px,7vw,110px) 0; position:relative; }
.slater .section--paper { background:var(--paper); }
.slater .section--slate { background:var(--slate-deep); color:var(--off-white); }
.slater .section--slate h2, .slater .section--slate h3 { color:var(--off-white); }
.slater .section-head { display:grid; grid-template-columns:1fr 2fr; gap:48px; margin-bottom:72px; align-items:end; }
.slater .section-head .label { display:flex; align-items:flex-start; gap:14px; }
.slater .section-head .num { font-family:var(--f-mono); font-size:12px; letter-spacing:0.08em; color:var(--bronze); padding-top:4px; }
.slater .section-head .label-stack { display:flex; flex-direction:column; gap:6px; }
.slater .section-head .label-stack .kicker { font-size:11px; letter-spacing:0.22em; text-transform:uppercase; font-weight:500; color:var(--slate-soft); }
.slater .section-head h2 { font-size:clamp(36px,4.8vw,72px); line-height:1; letter-spacing:-0.015em; max-width:18ch; }
.slater .section-head h2 em { color:var(--bronze); font-style:italic; }
.slater .section--slate .section-head .label-stack .kicker { color:rgba(250,248,245,0.5); }

/* ============ ABOUT ============ */
.slater .about-grid { display:grid; grid-template-columns:5fr 7fr; gap:clamp(40px,6vw,96px); align-items:start; }
.slater .about-portrait { position:relative; aspect-ratio:4/5; background:transparent; overflow:hidden; }
.slater .about-portrait img { width:100%; height:100%; object-fit:cover; filter:none; }
.slater .about-portrait .tag { position:absolute; top:20px; left:20px; background:var(--off-white); color:var(--slate-deep); font-family:var(--f-mono); font-size:10px; letter-spacing:0.15em; text-transform:uppercase; padding:8px 14px; }
.slater .about-portrait .badge { position:absolute; bottom:24px; right:24px; background:var(--off-white); color:var(--slate-deep); padding:18px 22px; max-width:220px; line-height:1.4; }
.slater .about-portrait .badge .q { font-family:var(--f-serif); font-style:italic; font-size:18px; line-height:1.35; }
.slater .about-portrait .badge .attr { margin-top:10px; font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--slate-soft); }
.slater .about-body .eyebrow { margin-bottom:16px; }
.slater .about-body h2 { font-size:clamp(40px,5vw,72px); line-height:1; letter-spacing:-0.015em; margin-bottom:28px; }
.slater .about-body h2 em { color:var(--bronze); font-style:italic; }
.slater .about-body .lede { margin-bottom:20px; }
.slater .about-body p.body { font-size:15px; line-height:1.75; color:var(--slate); margin-bottom:20px; max-width:55ch; }
.slater .creds { display:grid; grid-template-columns:1fr 1fr; gap:28px 40px; margin:40px 0; padding:32px 0; border-top:1px solid var(--rule); border-bottom:1px solid var(--rule); }
.slater .cred .num { font-family:var(--f-mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--bronze); margin-bottom:10px; display:block; }
.slater .cred h4 { font-family:var(--f-serif); font-size:22px; line-height:1.25; margin-bottom:6px; color:var(--slate-deep); }
.slater .cred p { font-size:13.5px; color:var(--slate); line-height:1.6; }
.slater .about-cta { display:flex; gap:18px; align-items:center; flex-wrap:wrap; margin-top:12px; }
.slater .about-cta .sig { font-family:var(--f-serif); font-style:italic; font-size:22px; color:var(--bronze); padding-left:20px; border-left:1px solid var(--rule); }

/* ============ SERVICES ============ */
.slater .services-intro { display:grid; grid-template-columns:1fr 1fr; gap:48px; margin-bottom:60px; }
.slater .services-intro .sub { font-family:var(--f-serif); font-size:19px; line-height:1.55; color:var(--slate); border-left:1px solid var(--rule); padding-left:24px; }
.slater .services-table { border-top:1px solid var(--rule); }
.slater .svc-row { display:grid; grid-template-columns:60px minmax(0,1.8fr) minmax(0,2fr) 110px 48px; gap:32px; padding:32px 0; border-bottom:1px solid var(--rule); align-items:baseline; position:relative; transition:padding .3s ease; }
.slater .svc-row:hover { padding-left:16px; }
.slater .svc-row::before { content:""; position:absolute; left:0; top:0; bottom:0; width:0; background:var(--bronze); transition:width .3s ease; }
.slater .svc-row:hover::before { width:4px; }
.slater .svc-num { font-family:var(--f-mono); font-size:11px; letter-spacing:0.08em; color:var(--bronze); }
.slater .svc-name { font-family:var(--f-serif); font-size:clamp(26px,2.8vw,38px); line-height:1.05; color:var(--slate-deep); letter-spacing:-0.01em; }
.slater .svc-desc { font-size:14px; line-height:1.65; color:var(--slate); max-width:48ch; }
.slater .svc-desc .svc-duration { display:inline-block; font-family:var(--f-mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--bronze); margin-bottom:10px; }
.slater .svc-desc .tags { display:flex; flex-wrap:wrap; gap:6px; margin-top:14px; }
.slater .svc-desc .tag { font-family:var(--f-mono); font-size:10px; letter-spacing:0.1em; text-transform:uppercase; padding:4px 10px; border:1px solid var(--rule); color:var(--slate); }
.slater .svc-price { font-family:var(--f-serif); font-size:32px; line-height:1; color:var(--slate-deep); text-align:right; }
.slater .svc-price .c { font-size:14px; color:var(--slate-soft); vertical-align:top; margin-right:2px; }
.slater .svc-price .u { font-size:10px; letter-spacing:0.15em; color:var(--slate-soft); display:block; margin-top:6px; text-transform:uppercase; }
.slater .svc-cta { justify-self:end; width:40px; height:40px; border:1px solid var(--rule); display:grid; place-items:center; transition:all .25s ease; color:var(--slate-deep); }
.slater .svc-cta:hover { background:var(--bronze); border-color:var(--bronze); color:var(--off-white); }
.slater .svc-cta::after { content:""; width:10px; height:10px; border-top:1px solid currentColor; border-right:1px solid currentColor; transform:rotate(45deg); }
.slater .svc-footnote { margin-top:40px; font-family:var(--f-mono); font-size:11px; letter-spacing:0.1em; color:var(--slate-soft); text-transform:uppercase; display:flex; gap:24px; flex-wrap:wrap; }
.slater .svc-footnote span { display:flex; align-items:center; gap:10px; }
.slater .svc-footnote .bullet { width:4px; height:4px; background:var(--bronze); border-radius:50%; }

/* ============ CONDITIONS ============ */
.slater .cond-grid { display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid var(--rule); border-left:1px solid var(--rule); }
.slater .cond-item { padding:32px 28px; border-right:1px solid var(--rule); border-bottom:1px solid var(--rule); display:flex; flex-direction:column; gap:14px; min-height:170px; position:relative; transition:background .3s ease; }
.slater .cond-item:hover { background:var(--paper); }
.slater .cond-num { font-family:var(--f-mono); font-size:10px; letter-spacing:0.12em; color:var(--bronze); }
.slater .cond-name { font-family:var(--f-serif); font-size:22px; line-height:1.15; color:var(--slate-deep); letter-spacing:-0.005em; }
.slater .cond-meta { margin-top:auto; font-size:11px; color:var(--slate-soft); letter-spacing:0.08em; text-transform:uppercase; }
.slater .cond-note { font-family:var(--f-serif); font-style:italic; font-size:18px; line-height:1.6; color:var(--slate); margin-top:48px; max-width:62ch; padding-top:24px; border-top:1px solid var(--rule); }

/* ============ JOURNEY ============ */
.slater .journey { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; background:var(--rule-soft); border:1px solid var(--rule-soft); }
.slater .step { background:var(--off-white); padding:40px 32px 36px; display:flex; flex-direction:column; gap:14px; min-height:280px; position:relative; }
.slater .step .big { font-family:var(--f-serif); font-size:64px; line-height:1; color:var(--bronze); font-weight:300; }
.slater .step h3 { font-size:22px; line-height:1.2; color:var(--slate-deep); }
.slater .step p { font-size:13.5px; color:var(--slate); line-height:1.65; }
.slater .step .meta { margin-top:auto; font-family:var(--f-mono); font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--slate-soft); padding-top:16px; border-top:1px solid var(--rule-soft); }

/* ============ LOCATIONS ============ */
.slater .loc-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; }
.slater .loc-card { background:rgba(255,255,255,0.03); padding:40px; display:flex; flex-direction:column; gap:24px; border:1px solid rgba(255,255,255,0.1); position:relative; color:var(--off-white); }
.slater .loc-head { display:flex; justify-content:space-between; align-items:flex-start; padding-bottom:24px; border-bottom:1px solid rgba(255,255,255,0.1); }
.slater .loc-head .loc-num { font-family:var(--f-mono); font-size:11px; letter-spacing:0.18em; color:var(--bronze-light); text-transform:uppercase; }
.slater .loc-head .status { font-family:var(--f-mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:rgba(250,248,245,0.6); display:flex; align-items:center; gap:8px; }
.slater .loc-head .status .dot { width:6px; height:6px; border-radius:50%; background:#7EC49B; box-shadow:0 0 0 3px rgba(126,196,155,0.2); }
.slater .loc-card h3 { font-family:var(--f-serif); font-size:clamp(28px,3vw,40px); line-height:1.05; letter-spacing:-0.01em; }
.slater .loc-card h3 em { color:var(--bronze-light); font-style:italic; }
.slater .loc-detail { display:grid; grid-template-columns:110px 1fr; gap:16px; padding:14px 0; border-bottom:1px solid rgba(255,255,255,0.06); font-size:14px; }
.slater .loc-detail:last-of-type { border-bottom:0; }
.slater .loc-detail .k { font-family:var(--f-mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:rgba(250,248,245,0.5); padding-top:3px; }
.slater .loc-detail .v { color:rgba(250,248,245,0.88); line-height:1.55; }
.slater .loc-detail .v a { color:var(--bronze-light); border-bottom:1px solid currentColor; padding-bottom:2px; }
.slater .loc-map { aspect-ratio:16/10; overflow:hidden; border:1px solid rgba(255,255,255,0.08); }
.slater .loc-map img { width:100%; height:100%; object-fit:cover; }
.slater .loc-sub { font-family:var(--f-mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:rgba(250,248,245,0.6); margin-top:-8px; }

/* ============ TESTIMONIALS ============ */
.slater .quote-wrap { position:relative; padding:20px 0 0; }
.slater .quote-mark { font-family:var(--f-serif); font-size:clamp(140px,14vw,220px); line-height:0.8; color:var(--bronze); opacity:0.25; position:absolute; top:-40px; left:-12px; pointer-events:none; }
.slater .quote-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--rule-soft); border:1px solid var(--rule-soft); }
.slater .qcard { background:var(--off-white); padding:40px 36px 32px; display:flex; flex-direction:column; gap:20px; min-height:320px; }
.slater .qcard .stars { display:flex; gap:4px; }
.slater .qcard .stars .s { width:14px; height:14px; display:inline-block; background:var(--bronze); clip-path:polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%); }
.slater .qcard blockquote { font-family:var(--f-serif); font-size:20px; line-height:1.5; color:var(--slate-deep); font-weight:300; flex:1; }
.slater .qcard .src { display:flex; align-items:center; gap:14px; padding-top:18px; border-top:1px solid var(--rule); }
.slater .qcard .src .init { width:38px; height:38px; border-radius:50%; overflow:hidden; flex:none; background:var(--beige-light); }
.slater .qcard .src .init img { width:100%; height:100%; object-fit:cover; }
.slater .qcard .src .who strong { display:block; font-size:13px; letter-spacing:0.04em; color:var(--slate-deep); font-weight:500; }
.slater .qcard .src .who span { font-family:var(--f-mono); font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--slate-soft); }
.slater .testimonial-disclaimer { margin-top:32px; padding:20px 28px; border:1px solid var(--rule); font-size:12px; line-height:1.65; color:var(--slate); font-family:var(--f-sans); display:flex; gap:16px; align-items:flex-start; }
.slater .testimonial-disclaimer .i { flex:none; width:24px; height:24px; border-radius:50%; border:1px solid var(--slate-soft); color:var(--slate-soft); display:grid; place-items:center; font-family:var(--f-serif); font-style:italic; font-size:13px; }
.slater .testimonial-disclaimer a { color:var(--bronze); border-bottom:1px solid currentColor; }

/* ============ FAQ ============ */
.slater .faq-grid { display:grid; grid-template-columns:1fr 2fr; gap:clamp(40px,6vw,96px); align-items:start; }
.slater .faq-aside { position:sticky; top:100px; padding-right:20px; }
.slater .faq-aside h2 { font-size:clamp(36px,4.8vw,64px); line-height:1; margin-bottom:20px; }
.slater .faq-aside h2 em { color:var(--bronze); font-style:italic; }
.slater .faq-aside p { font-size:15px; color:var(--slate); line-height:1.65; margin-bottom:28px; }
.slater .faq-list { border-top:1px solid var(--rule); }
.slater .faq-item { border-bottom:1px solid var(--rule); }
.slater .faq-q { width:100%; padding:28px 0; display:grid; grid-template-columns:auto 1fr auto; gap:28px; align-items:center; text-align:left; font-family:var(--f-serif); font-size:clamp(20px,2vw,26px); line-height:1.3; color:var(--slate-deep); }
.slater .faq-q .n { font-family:var(--f-mono); font-size:11px; letter-spacing:0.08em; color:var(--bronze); padding-top:4px; }
.slater .faq-q .plus { width:24px; height:24px; position:relative; flex:none; transition:transform .3s ease; }
.slater .faq-q .plus::before, .slater .faq-q .plus::after { content:""; position:absolute; background:var(--slate-deep); top:50%; left:50%; transform:translate(-50%,-50%); }
.slater .faq-q .plus::before { width:14px; height:1px; }
.slater .faq-q .plus::after { width:1px; height:14px; transition:transform .3s ease; }
.slater .faq-item[open] .plus::after { transform:translate(-50%,-50%) rotate(90deg); }
.slater .faq-a { padding:0 0 28px calc(11px + 28px); font-size:15px; line-height:1.75; color:var(--slate); max-width:60ch; }
.slater .faq-a .tag { display:inline-block; margin-top:14px; font-family:var(--f-mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--bronze); }
.slater details.faq-item summary { list-style:none; cursor:pointer; }
.slater details.faq-item summary::-webkit-details-marker { display:none; }

/* ============ CTA ============ */
.slater .cta-band { position:relative; background:var(--slate-deep); color:var(--off-white); padding:clamp(60px,7vw,110px) 0; overflow:hidden; }
.slater .subpage-hero + section.section,
.slater .about-hero + section.section { padding-top:clamp(48px,5vw,80px); }
.slater section.section + section.section { padding-top:clamp(40px,4vw,72px); }
.slater section.section + section.cta-band,
.slater header.about-hero + section.section + section.cta-band { padding-top:clamp(60px,7vw,110px); }
.slater .cta-band::before { content:""; position:absolute; inset:0; background: radial-gradient(ellipse at 15% 50%, rgba(168,114,80,0.25) 0%, transparent 50%), radial-gradient(ellipse at 85% 30%, rgba(168,114,80,0.15) 0%, transparent 50%); }
.slater .cta-inner { position:relative; z-index:1; display:grid; grid-template-columns:1fr auto; gap:48px; align-items:end; }
.slater .cta-inner h2 { font-family:var(--f-serif); font-size:clamp(48px,7vw,108px); line-height:0.98; letter-spacing:-0.02em; color:var(--off-white); max-width:14ch; }
.slater .cta-inner h2 em { color:var(--bronze-light); font-style:italic; }
.slater .cta-right { display:flex; flex-direction:column; gap:24px; align-items:flex-end; }
.slater .cta-right p { max-width:36ch; text-align:right; font-family:var(--f-serif); font-size:19px; line-height:1.5; color:rgba(250,248,245,0.8); }
.slater .cta-actions { display:flex; gap:14px; flex-wrap:wrap; justify-content:flex-end; }

/* ============ FOOTER ============ */
.slater .footer { background:var(--slate-ink); color:rgba(250,248,245,0.7); padding:88px 0 32px; font-size:13px; }
.slater .footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; padding-bottom:56px; border-bottom:1px solid rgba(255,255,255,0.08); }
.slater .footer .brand-name { color:var(--off-white); font-size:26px; }
.slater .footer .brand-tag { color:var(--bronze-light); }
.slater .footer h5 { font-family:var(--f-mono); font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:rgba(250,248,245,0.5); margin-bottom:20px; }
.slater .footer ul li { margin-bottom:10px; }
.slater .footer ul li a { color:rgba(250,248,245,0.8); font-size:13.5px; transition:color .2s; }
.slater .footer ul li a:hover { color:var(--bronze-light); }
.slater .footer-brand-desc { margin-top:16px; max-width:38ch; line-height:1.65; color:rgba(250,248,245,0.55); font-size:13px; }
.slater .footer-social { display:flex; gap:12px; margin-top:24px; }
.slater .footer-social a { width:36px; height:36px; border:1px solid rgba(255,255,255,0.15); display:grid; place-items:center; font-family:var(--f-serif); font-size:14px; transition:all .25s ease; }
.slater .footer-social a:hover { background:var(--bronze); border-color:var(--bronze); color:var(--off-white); }
.slater .footer-legal { padding-top:24px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px; font-family:var(--f-mono); font-size:11px; letter-spacing:0.1em; color:rgba(250,248,245,0.4); text-transform:uppercase; }
.slater .footer-legal .links { display:flex; gap:24px; }
.slater .footer-legal .links a:hover { color:var(--bronze-light); }
.slater .footer-ccoa { color:rgba(250,248,245,0.4); line-height:1.7; margin-top:8px; font-size:12px; }
.slater .footer-ccoa a { color:var(--bronze-light); border-bottom:1px solid currentColor; }

/* ============ BREADCRUMB ============ */
.slater .breadcrumb { font-family:var(--f-mono); font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--slate-soft); }
.slater .breadcrumb ol { list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap; gap:0; align-items:center; }
.slater .breadcrumb li { display:flex; align-items:center; }
.slater .breadcrumb li + li::before { content:"/"; padding:0 10px; color:var(--slate-soft); }
.slater .breadcrumb a { color:var(--slate); text-decoration:none; transition:color .2s; }
.slater .breadcrumb a:hover { color:var(--bronze); }
.slater .breadcrumb [aria-current="page"] { color:var(--bronze); }

/* ============ ABOUT PAGE ============ */
.slater .about-hero { padding:140px 0 80px; background:var(--off-white); position:relative; overflow:hidden; }
.slater .about-hero .wrap { position:relative; z-index:2; }
.slater .about-hero-grid { display:grid; grid-template-columns:5fr 7fr; gap:clamp(40px,6vw,96px); align-items:end; }
.slater .about-portrait-lg { position:relative; aspect-ratio:4/5; background:linear-gradient(135deg, var(--beige), var(--beige-light)); overflow:hidden; }
.slater .about-portrait-lg img { width:100%; height:100%; object-fit:cover; filter:saturate(0.92); }
.slater .about-portrait-lg .tag { position:absolute; top:20px; left:20px; background:var(--off-white); color:var(--slate-deep); font-family:var(--f-mono); font-size:10px; letter-spacing:0.15em; text-transform:uppercase; padding:8px 14px; }
.slater .about-hero-text .display { margin-bottom:32px; font-size:clamp(40px,5.6vw,80px); line-height:1.02; letter-spacing:-0.02em; color:var(--slate-deep); font-family:var(--f-serif); font-weight:400; }
.slater .about-hero-text .display em { color:var(--bronze); font-style:italic; font-weight:400; }
.slater .about-hero-text .lede { font-family:var(--f-serif); font-size:clamp(20px,2.1vw,26px); line-height:1.5; color:var(--slate-deep); font-weight:300; max-width:42ch; }
.slater .about-hero-meta { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:40px; padding-top:32px; border-top:1px solid var(--rule); }
.slater .about-hero-meta .cell { font-family:var(--f-mono); font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--slate); line-height:1.6; }
.slater .about-hero-meta .cell strong { color:var(--bronze); display:block; font-weight:500; margin-bottom:4px; }

.slater .narrative { background:var(--paper); }
.slater .narrative-inner { max-width:780px; margin:0 auto; }
.slater .narrative h2 { font-family:var(--f-serif); font-weight:300; font-size:clamp(36px,4.5vw,64px); line-height:1.05; letter-spacing:-0.015em; color:var(--slate-deep); margin:48px 0 24px; }
.slater .narrative h2:first-child { margin-top:0; }
.slater .narrative h2 em { color:var(--bronze); font-style:italic; }
.slater .narrative p { font-family:var(--f-serif); font-size:20px; line-height:1.65; color:var(--slate-deep); margin-bottom:20px; font-weight:300; }
.slater .narrative p.lede { font-size:24px; line-height:1.55; color:var(--slate-deep); font-weight:400; border-left:1px solid var(--bronze); padding-left:24px; margin-bottom:32px; }
.slater .narrative p em { color:var(--bronze); font-style:italic; }

.slater .pull-stat-row { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin:64px 0; padding:48px 0; border-top:1px solid var(--rule); border-bottom:1px solid var(--rule); }
.slater .pull-stat .num-lg { font-family:var(--f-serif); font-size:56px; font-weight:300; color:var(--bronze); line-height:1; letter-spacing:-0.02em; }
.slater .pull-stat .num-lg sup { font-size:24px; vertical-align:top; margin-left:2px; }
.slater .pull-stat .label { font-family:var(--f-mono); font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--slate-soft); margin-top:14px; line-height:1.5; }

.slater .creds-page { display:grid; grid-template-columns:repeat(2,1fr); gap:40px 48px; margin-top:48px; }
.slater .creds-page .cred { padding-top:28px; border-top:1px solid var(--rule); }
.slater .creds-page .cred .num { font-family:var(--f-mono); font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--bronze); display:block; margin-bottom:14px; }
.slater .creds-page .cred h4 { font-family:var(--f-serif); font-weight:400; font-size:24px; line-height:1.2; color:var(--slate-deep); margin-bottom:10px; letter-spacing:-0.005em; }
.slater .creds-page .cred p { font-size:15px; line-height:1.65; color:var(--slate); font-family:var(--f-sans); font-weight:400; margin:0; }

.slater .principles { background:var(--off-white); }
.slater .principles-list { margin-top:48px; counter-reset:principle; }
.slater .principle { display:grid; grid-template-columns:120px 1fr 1.4fr; gap:48px; align-items:start; padding:40px 0; border-top:1px solid var(--rule); }
.slater .principle:last-child { border-bottom:1px solid var(--rule); }
.slater .principle .num-block { font-family:var(--f-mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--bronze); padding-top:8px; }
.slater .principle h3 { font-family:var(--f-serif); font-weight:400; font-size:clamp(24px,2.4vw,32px); line-height:1.15; color:var(--slate-deep); letter-spacing:-0.01em; }
.slater .principle h3 em { color:var(--bronze); font-style:italic; }
.slater .principle p { font-size:16px; line-height:1.7; color:var(--slate); }

@media (max-width:1040px) {
  .slater .about-hero-grid { grid-template-columns:1fr; gap:48px; align-items:start; }
  .slater .pull-stat-row { grid-template-columns:repeat(2,1fr); }
  .slater .creds-page { grid-template-columns:1fr; gap:32px; }
  .slater .principle { grid-template-columns:1fr; gap:16px; padding:32px 0; }
  .slater .principle .num-block { padding-top:0; }
}
@media (max-width:640px) {
  .slater .about-hero-meta { grid-template-columns:1fr; gap:18px; }
  .slater .pull-stat-row { grid-template-columns:1fr 1fr; gap:18px; padding:32px 0; }
  .slater .pull-stat .num-lg { font-size:42px; }
}

/* ============ SERVICES TEASER (homepage) ============ */
.slater .svc-teaser { border-top:1px solid var(--rule); border-bottom:1px solid var(--rule); }
.slater .svc-teaser-row { display:grid; grid-template-columns:60px minmax(0,1fr) auto 32px; align-items:center; gap:32px; padding:24px 0; border-bottom:1px solid var(--rule); text-decoration:none; color:inherit; position:relative; transition:padding .3s ease, background-color .25s ease; }
.slater .svc-teaser-row:last-child { border-bottom:none; }
.slater .svc-teaser-row::before { content:""; position:absolute; left:0; top:0; bottom:0; width:0; background:var(--bronze); transition:width .3s ease; }
.slater .svc-teaser-row:hover { padding-left:16px; }
.slater .svc-teaser-row:hover::before { width:4px; }
.slater .svc-teaser-row .svc-num { font-family:var(--f-mono); font-size:11px; letter-spacing:0.18em; color:var(--bronze); text-transform:uppercase; }
.slater .svc-teaser-row .svc-name { font-family:var(--f-serif); font-size:22px; line-height:1.25; color:var(--slate-ink); font-weight:400; }
.slater .svc-teaser-row .svc-learn { font-family:var(--f-mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--bronze); white-space:nowrap; transition:color .25s ease; }
.slater .svc-teaser-row:hover .svc-learn { color:var(--slate-ink); }
.slater .svc-teaser-row .svc-arrow { font-family:var(--f-serif); font-size:22px; color:var(--slate-soft); transition:transform .25s ease, color .25s ease; text-align:right; }
.slater .svc-teaser-row:hover .svc-arrow { color:var(--bronze); transform:translateX(6px); }
.slater .svc-teaser-foot { margin-top:48px; display:flex; justify-content:space-between; align-items:flex-end; gap:32px; flex-wrap:wrap; }
.slater .svc-teaser-note { font-family:var(--f-serif); font-style:italic; font-size:17px; line-height:1.55; color:var(--slate); max-width:520px; margin:0; }

/* ============ LOCATIONS TEASER (homepage) ============ */
.slater .loc-teaser-grid { display:grid; grid-template-columns:1fr 1fr; gap:0; border-top:1px solid rgba(250,248,245,0.18); border-bottom:1px solid rgba(250,248,245,0.18); }
.slater .loc-teaser-card { display:flex; flex-direction:column; gap:16px; padding:48px 40px; text-decoration:none; color:var(--off-white); position:relative; border-right:1px solid rgba(250,248,245,0.18); transition:background-color .25s ease; }
.slater .loc-teaser-card:last-child { border-right:none; }
.slater .loc-teaser-card::before { content:""; position:absolute; left:0; top:0; bottom:0; width:0; background:var(--bronze-light); transition:width .3s ease; }
.slater .loc-teaser-card:hover { background:rgba(250,248,245,0.04); }
.slater .loc-teaser-card:hover::before { width:4px; }
.slater .loc-teaser-num { font-family:var(--f-mono); font-size:11px; letter-spacing:0.18em; color:var(--bronze-light); text-transform:uppercase; }
.slater .loc-teaser-card h3 { font-family:var(--f-serif); font-weight:400; font-size:34px; line-height:1.1; margin:0; color:var(--off-white); }
.slater .loc-teaser-card h3 em { font-style:italic; color:var(--bronze-light); }
.slater .loc-teaser-meta { font-family:var(--f-mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:rgba(250,248,245,0.6); margin:0; }
.slater .loc-teaser-addr { font-family:var(--f-serif); font-size:17px; line-height:1.55; color:rgba(250,248,245,0.85); font-style:normal; margin:0; }
.slater .loc-teaser-cta { font-family:var(--f-mono); font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--bronze-light); margin-top:auto; padding-top:8px; transition:transform .25s ease; display:inline-block; }
.slater .loc-teaser-card:hover .loc-teaser-cta { transform:translateX(6px); }
.slater .loc-teaser-foot { margin-top:48px; display:flex; justify-content:flex-end; }
@media (max-width:880px) { .slater .loc-teaser-grid { grid-template-columns:1fr; } .slater .loc-teaser-card { border-right:none; border-bottom:1px solid rgba(250,248,245,0.18); } .slater .loc-teaser-card:last-child { border-bottom:none; } }

/* ============ SUBPAGE HERO (shared between Conditions / Services detail) ============ */
.slater .subpage-hero { position:relative; padding:clamp(110px,14vh,170px) var(--gutter) clamp(60px,7vh,90px); background:var(--paper); border-bottom:1px solid var(--rule-soft); overflow:hidden; }
.slater .subpage-hero .wrap { max-width:var(--container); margin:0 auto; }
.slater .subpage-hero-grid { display:grid; grid-template-columns:220px 1fr; gap:clamp(24px,4vw,64px); align-items:start; padding-top:28px; }
.slater .subpage-hero-label { display:flex; align-items:flex-start; gap:18px; border-top:1px solid var(--rule); padding-top:14px; }
.slater .subpage-hero-label .num { font-family:var(--f-mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--slate-soft); flex-shrink:0; }
.slater .subpage-hero-label .label-stack { display:flex; flex-direction:column; gap:4px; }
.slater .subpage-hero-label .kicker { font-family:var(--f-serif); font-size:22px; line-height:1; color:var(--slate-deep); font-weight:400; }
.slater .subpage-hero-label .micro { font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.18em; text-transform:uppercase; color:var(--slate-soft); }
.slater .subpage-hero-body h1.display { font-family:var(--f-serif); font-weight:300; font-size:clamp(40px,6.5vw,84px); line-height:1.02; letter-spacing:-0.01em; color:var(--slate-deep); margin:0 0 22px; text-wrap:balance; }
.slater .subpage-hero-body h1.display em { font-style:italic; color:var(--bronze); font-weight:400; }
.slater .subpage-hero-body .lede { font-family:var(--f-sans); font-weight:300; font-size:clamp(16px,1.4vw,19px); line-height:1.55; color:var(--slate); max-width:60ch; margin:0; }
@media (max-width:880px) { .slater .subpage-hero-grid { grid-template-columns:1fr; gap:24px; } }

/* ============ CONDITION DETAIL ============ */
.slater a.cond-item { text-decoration:none; color:inherit; cursor:pointer; display:flex; flex-direction:column; gap:6px; }
.slater a.cond-item:hover .cond-name { color:var(--bronze); }
.slater a.cond-item:hover .cond-num { color:var(--slate-deep); }

.slater .cond-detail { display:grid; grid-template-columns:1fr 320px; gap:clamp(40px,5vw,80px); align-items:start; }
.slater .cond-detail-main h2 { font-family:var(--f-serif); font-weight:400; font-size:clamp(28px,3vw,40px); color:var(--slate-deep); margin:48px 0 18px; letter-spacing:-0.005em; }
.slater .cond-detail-main h2:first-child { margin-top:0; }
.slater .cond-detail-main h2 em { font-style:italic; color:var(--bronze); font-weight:400; }
.slater .cond-detail-main h3 { font-family:var(--f-serif); font-weight:400; font-size:clamp(22px,2vw,26px); color:var(--slate-deep); margin:28px 0 10px; letter-spacing:-0.005em; }
.slater .cond-detail-main p { font-family:var(--f-sans); font-weight:300; font-size:17px; line-height:1.65; color:var(--slate); margin:0 0 18px; max-width:65ch; }
.slater .cond-detail-main ul { font-family:var(--f-sans); font-weight:300; font-size:17px; line-height:1.7; color:var(--slate); list-style:none; padding-left:0; margin:0 0 24px; max-width:60ch; }
.slater .cond-detail-main ul li { position:relative; padding-left:28px; margin-bottom:10px; }
.slater .cond-detail-main ul li::before { content:""; position:absolute; left:0; top:14px; width:14px; height:1px; background:var(--bronze); }
.slater .cond-detail-main blockquote { font-family:var(--f-serif); font-style:italic; font-weight:400; font-size:clamp(20px,2vw,26px); line-height:1.5; color:var(--slate-deep); border-left:2px solid var(--bronze); padding:4px 0 4px 24px; margin:32px 0; max-width:60ch; }

.slater .cond-aside { position:sticky; top:110px; align-self:start; }
.slater .cond-aside-card { background:var(--off-white); border:1px solid var(--rule-soft); padding:28px; margin-bottom:20px; }
.slater .cond-aside-card .eyebrow { font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.18em; text-transform:uppercase; color:var(--slate-soft); display:block; margin-bottom:14px; }
.slater .cond-aside-card h3 { font-family:var(--f-serif); font-weight:400; font-size:22px; color:var(--slate-deep); margin:0 0 18px; letter-spacing:-0.005em; line-height:1.2; }
.slater .cond-aside-card .svc-rec { display:block; text-decoration:none; color:inherit; border-top:1px solid var(--rule-soft); padding:14px 0; transition:padding-left .25s ease; }
.slater .cond-aside-card .svc-rec:hover { padding-left:6px; }
.slater .cond-aside-card .svc-rec:last-child { padding-bottom:0; }
.slater .cond-aside-card .svc-rec .nm { font-family:var(--f-serif); font-size:18px; color:var(--slate-deep); display:block; margin-bottom:4px; transition:color .2s; }
.slater .cond-aside-card .svc-rec:hover .nm { color:var(--bronze); }
.slater .cond-aside-card .svc-rec .pr { font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--slate-soft); }
.slater .cond-aside-card .svc-rec .pr em { color:var(--bronze); font-style:normal; }

.slater .cond-disclaimer { border:1px solid var(--rule-soft); padding:22px; font-family:var(--f-sans); font-size:13px; line-height:1.55; color:var(--slate); }
.slater .cond-disclaimer .eyebrow { font-family:var(--f-mono); font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--bronze); display:block; margin-bottom:8px; }

.slater .related-services { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:32px; }
.slater .related-card { display:block; text-decoration:none; color:inherit; border:1px solid var(--rule-soft); padding:22px; background:var(--off-white); transition:border-color .2s, transform .25s; }
.slater .related-card:hover { border-color:var(--bronze); transform:translateY(-2px); }
.slater .related-card .num { font-family:var(--f-mono); font-size:11px; letter-spacing:0.18em; color:var(--bronze); margin-bottom:12px; display:block; }
.slater .related-card h4 { font-family:var(--f-serif); font-weight:400; font-size:22px; color:var(--slate-deep); margin:0 0 6px; letter-spacing:-0.005em; line-height:1.2; }
.slater .related-card .arrow { display:inline-block; margin-top:14px; color:var(--bronze); font-family:var(--f-mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; }

.slater .symptom-list { display:grid; grid-template-columns:repeat(2,1fr); gap:14px 28px; margin:0 0 24px; padding:0; list-style:none; }
.slater .symptom-list li { font-family:var(--f-sans); font-size:15.5px; color:var(--slate); padding:12px 0 12px 24px; border-top:1px solid var(--rule-soft); position:relative; }
.slater .symptom-list li::before { content:""; position:absolute; left:0; top:19px; width:8px; height:8px; border:1px solid var(--bronze); background:transparent; }

@media (max-width:980px) {
  .slater .cond-detail { grid-template-columns:1fr; }
  .slater .cond-aside { position:static; }
}
@media (max-width:880px) { .slater .related-services { grid-template-columns:1fr; } }
@media (max-width:720px) { .slater .symptom-list { grid-template-columns:1fr; } }

/* ============ LOCATIONS PAGE (single-clinic layout) ============ */
.slater .loc-page-grid { display:grid; grid-template-columns:1.1fr 1fr; gap:64px; align-items:start; }
.slater .loc-page-map { aspect-ratio:1/1; background:linear-gradient(135deg, var(--beige), var(--beige-light)); position:relative; overflow:hidden; }
.slater .loc-page-embed { aspect-ratio:1/1; position:relative; overflow:hidden; border:1px solid var(--rule); background:var(--beige-light); }
.slater .loc-page-embed iframe { width:100%; height:100%; border:0; display:block; }
.slater .loc-page-map .pin { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); text-align:center; }
.slater .loc-page-map .pin .dot { width:14px; height:14px; border-radius:50%; background:var(--bronze); margin:0 auto 12px; box-shadow:0 0 0 6px rgba(167,106,62,0.25), 0 0 0 16px rgba(167,106,62,0.08); }
.slater .loc-page-map .pin .lbl { font-family:var(--f-serif); font-size:18px; color:var(--slate-deep); margin-bottom:4px; }
.slater .loc-page-map .pin .addr { font-family:var(--f-mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--slate); }
.slater .loc-page-map .compass { position:absolute; top:20px; right:24px; font-family:var(--f-mono); font-size:11px; letter-spacing:0.18em; color:var(--bronze); padding:6px 10px; border:1px solid var(--rule); background:var(--off-white); }
.slater .loc-page-map .grid-lines { position:absolute; inset:0; background-image: linear-gradient(to right, rgba(38,51,57,0.06) 1px, transparent 1px), linear-gradient(to bottom, rgba(38,51,57,0.06) 1px, transparent 1px); background-size:48px 48px; }
.slater .loc-info h2 { font-family:var(--f-serif); font-weight:300; font-size:clamp(36px,4.5vw,56px); line-height:1.05; letter-spacing:-0.015em; color:var(--slate-deep); margin:0 0 32px; }
.slater .loc-info h2 em { color:var(--bronze); font-style:italic; }
.slater .loc-block { padding:28px 0; border-top:1px solid var(--rule); }
.slater .loc-block:last-of-type { border-bottom:1px solid var(--rule); }
.slater .loc-block .lbl { font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.18em; text-transform:uppercase; color:var(--slate-soft); display:block; margin-bottom:12px; }
.slater .loc-block .val { font-family:var(--f-serif); font-size:22px; line-height:1.4; color:var(--slate-deep); }
.slater .loc-block .val em { color:var(--bronze); font-style:italic; }
.slater .loc-block .meta { font-size:14px; color:var(--slate); margin-top:8px; line-height:1.6; max-width:55ch; }
.slater .hours-table { width:100%; border-collapse:collapse; margin-bottom:14px; font-family:var(--f-mono); }
.slater .hours-table td { padding:8px 0; font-size:13px; letter-spacing:0.12em; text-transform:uppercase; color:var(--slate); border-bottom:1px solid var(--rule-soft); }
.slater .hours-table td:last-child { text-align:right; }
.slater .hours-table td.closed { color:var(--slate-soft); }
.slater .hours-note { font-style:italic; font-size:13px; color:var(--slate-soft); line-height:1.5; max-width:55ch; }
.slater .loc-actions { display:flex; gap:14px; flex-wrap:wrap; margin-top:32px; }

.slater .nearby { background:var(--paper); }
.slater .nearby-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:32px; margin-top:48px; }
.slater .nearby-card { padding:32px 28px; background:var(--off-white); border:1px solid var(--rule-soft); }
.slater .nearby-card .dist { font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.18em; text-transform:uppercase; color:var(--bronze); display:block; margin-bottom:14px; }
.slater .nearby-card h4 { font-family:var(--f-serif); font-weight:400; font-size:24px; line-height:1.2; color:var(--slate-deep); margin:0 0 10px; letter-spacing:-0.005em; }
.slater .nearby-card p { font-size:14px; line-height:1.65; color:var(--slate); margin:0; }

@media (max-width:1040px) {
  .slater .loc-page-grid { grid-template-columns:1fr; gap:40px; }
  .slater .nearby-grid { grid-template-columns:1fr; gap:20px; }
}

/* ============ SECTION RHYTHM RESET ============
   GeneratePress applies margin-bottom:20px to many elements via .entry-content
   and base typography styles. Strip it from our top-level layout elements so
   sections butt up against each other and section padding controls spacing. */
body.slater main > *,
body.slater main > section,
body.slater main > header,
body.slater main > article,
body.slater main > div { margin-top:0 !important; margin-bottom:0 !important; }
body.slater .footer { margin:0 !important; }

/* ============ REVIEWS WIDGET (Reputation Hub iframe) ============ */
.slater .reviews-block { max-width:900px; margin:0 auto; }
.slater .lc_reviews_widget { display:block; width:100%; min-width:100%; min-height:600px; border:0; }

/* ============ ANIMATIONS ============
   Progressive enhancement: content is always visible by default.
   Animation only kicks in when JS adds .has-anim to <body> AND IntersectionObserver
   has tagged the element with .is-in. If JS fails to load, the page stays usable. */
.slater .reveal { transition:opacity .8s ease, transform .8s ease; }
body.has-anim .slater .reveal { opacity:0; transform:translateY(20px); }
body.has-anim .slater .reveal.is-in { opacity:1; transform:translateY(0); }
@media (prefers-reduced-motion: reduce) {
  .slater .reveal,
  body.has-anim .slater .reveal { transition:none; opacity:1 !important; transform:none !important; }
}

/* ============ RESPONSIVE ============ */
@media (max-width:1040px) {
  .slater .about-grid { grid-template-columns:1fr; gap:48px; }
  .slater .section-head { grid-template-columns:1fr; gap:24px; }
  .slater .services-intro { grid-template-columns:1fr; gap:20px; }
  .slater .svc-row { grid-template-columns:40px 1fr 100px 40px; gap:20px; }
  .slater .svc-desc { grid-column:2 / 4; margin-top:8px; }
  .slater .cond-grid { grid-template-columns:repeat(2,1fr); }
  .slater .quote-grid { grid-template-columns:1fr 1fr; }
  .slater .qcard:nth-child(3) { grid-column:1 / -1; }
  .slater .journey { grid-template-columns:1fr 1fr; }
  .slater .loc-grid { grid-template-columns:1fr; }
  .slater .faq-grid { grid-template-columns:1fr; }
  .slater .faq-aside { position:static; }
  .slater .cta-inner { grid-template-columns:1fr; }
  .slater .cta-right { align-items:flex-start; }
  .slater .cta-right p { text-align:left; }
  .slater .cta-actions { justify-content:flex-start; }
  .slater .footer-grid { grid-template-columns:1fr 1fr; gap:40px; }
}
/* Switch to mobile/hamburger nav earlier — avoids overflow on narrow widths
   like Safari split-view, iPad portrait, smaller laptops at half-width. */
@media (max-width:960px) {
  .slater .nav-menu { position:fixed; inset:72px 0 0 0; background:var(--off-white); flex-direction:column; gap:0; padding:32px var(--gutter); align-items:stretch; transform:translateX(100%); transition:transform .35s ease; color:var(--slate-deep); z-index:99; }
  .slater .nav-menu.is-open { transform:translateX(0); }
  .slater .nav-menu a { padding:16px 0; border-bottom:1px solid var(--rule); font-size:14px; }
  .slater .nav-menu a.nav-cta { margin-top:24px; justify-content:center; padding:18px; }
  .slater .nav-toggle { display:flex; }
  .slater .brand-name { font-size:18px; }
  .slater .brand-tag { display:none; }
}

@media (max-width:640px) {
  .slater .nav-menu { position:fixed; inset:72px 0 0 0; background:var(--off-white); flex-direction:column; gap:0; padding:32px var(--gutter); align-items:stretch; transform:translateX(100%); transition:transform .35s ease; color:var(--slate-deep); }
  .slater .nav-menu.is-open { transform:translateX(0); }
  .slater .nav-menu a { padding:16px 0; border-bottom:1px solid var(--rule); font-size:14px; }
  .slater .nav-menu a.nav-cta { margin-top:24px; justify-content:center; padding:18px; }
  .slater .nav-toggle { display:flex; }
  .slater .hero-index { display:none; }
  .slater .hero-bottom { grid-template-columns:1fr; gap:28px; }
  .slater .cond-grid { grid-template-columns:1fr; }
  .slater .quote-grid { grid-template-columns:1fr; }
  .slater .journey { grid-template-columns:1fr; }
  .slater .creds { grid-template-columns:1fr; }
  .slater .footer-grid { grid-template-columns:1fr; }
  .slater .svc-row { grid-template-columns:40px 1fr 40px; gap:14px; }
  .slater .svc-desc, .slater .svc-price { grid-column:2 / 3; }
  .slater .svc-price { text-align:left; margin-top:8px; }
  .slater .about-portrait .badge { position:static; max-width:100%; margin-top:12px; }
}
