/* ============================================================
   My Dog House Grooming — Richmond, VA
   Design tokens + base + components
   Mobile-first. Themes applied via :root vars (JS overrides them).
   ============================================================ */

/* ---------- Tokens (default = "Forest & Clay") ---------- */
:root{
  --bg:        #F6F1E7;
  --bg-2:      #EFE7D6;
  --surface:   #FCFAF4;
  --ink:       #23271F;
  --ink-soft:  #585C4F;
  --primary:   #2F4A37;
  --primary-deep:#22382A;
  --on-primary:#F4EFE2;
  --accent:    #C96F47;
  --accent-soft:#E6B79B;
  --line:      rgba(35,39,31,.13);
  --line-soft: rgba(35,39,31,.07);

  --font-display:'Fraunces', Georgia, serif;
  --font-body:   'Hanken Grotesque', system-ui, sans-serif;
  --font-serif:  'Source Serif 4', Georgia, serif;

  --maxw: 1240px;
  --pad: clamp(20px, 5vw, 64px);
  --radius: 18px;
  --radius-lg: 30px;

  --shadow-sm: 0 1px 2px rgba(35,39,31,.05), 0 4px 14px rgba(35,39,31,.05);
  --shadow-md: 0 4px 12px rgba(35,39,31,.07), 0 18px 40px rgba(35,39,31,.10);
  --shadow-lg: 0 10px 30px rgba(35,39,31,.10), 0 40px 80px rgba(35,39,31,.14);

  --ease: cubic-bezier(.22,.61,.36,1);
  --reveal-dur: .8s;
}

/* Theme: Charcoal & Honey */
:root[data-theme="charcoal"]{
  --bg:#F4F1EC; --bg-2:#EBE5DA; --surface:#FCFAF6;
  --ink:#1E1C18; --ink-soft:#56524A;
  --primary:#2B2924; --primary-deep:#1C1A16; --on-primary:#F3EEE2;
  --accent:#C68F38; --accent-soft:#E6CB95;
  --line:rgba(30,28,24,.13); --line-soft:rgba(30,28,24,.07);
}

/* Theme: Slate & Blush */
:root[data-theme="slate"]{
  --bg:#F1F1F4; --bg-2:#E7E7EC; --surface:#FCFCFD;
  --ink:#1F232B; --ink-soft:#565C68;
  --primary:#3A4654; --primary-deep:#2A3441; --on-primary:#EEF1F5;
  --accent:#BE8581; --accent-soft:#E2BFBC;
  --line:rgba(31,35,43,.13); --line-soft:rgba(31,35,43,.07);
}

/* ---------- Reset ---------- */
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:none; background:none; color:inherit; }
::selection{ background:var(--accent); color:#fff; }

/* ---------- Layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
section{ position:relative; }
.section-pad{ padding-block:clamp(64px,10vw,140px); }

/* ---------- Type ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.04; letter-spacing:-.015em; }
h2.section-title{ font-style:italic; }
.eyebrow{
  font-family:var(--font-body); font-weight:600;
  font-size:.78rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent); display:inline-flex; align-items:center; gap:.6em;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--accent); border-radius:2px; }
.serif-it{ font-family:var(--font-serif); font-style:italic; font-weight:400; letter-spacing:0; }
.lede{ font-size:clamp(1.05rem,1.6vw,1.3rem); color:var(--ink-soft); max-width:65ch; text-wrap:pretty; }

h2.section-title{ font-size:clamp(2.1rem,6vw,3.6rem); max-width:16ch; text-wrap:balance; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  padding:.95em 1.6em; border-radius:999px; font-weight:700; font-size:1rem;
  letter-spacing:-.01em; transition:transform .25s var(--ease), background .25s, box-shadow .25s, color .25s;
  will-change:transform; white-space:nowrap;
}
.btn:active{ transform:translateY(1px) scale(.99); }
.btn-primary{ background:var(--primary); color:var(--on-primary); box-shadow:var(--shadow-sm); }
.btn-primary:hover{ background:var(--primary-deep); box-shadow:var(--shadow-md); transform:translateY(-2px); }
.btn-accent{ background:var(--accent); color:#fff; box-shadow:var(--shadow-sm); }
.btn-accent:hover{ filter:brightness(1.05); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-ghost{ background:transparent; color:var(--ink); border:1.5px solid var(--line); }
.btn-ghost:hover{ border-color:var(--ink); background:rgba(35,39,31,.03); }
.btn .arrow{ transition:transform .3s var(--ease); }
.btn:hover .arrow{ transform:translateX(3px); }

/* ---------- Placeholder (drop real photos here) ---------- */
.ph{
  position:relative; overflow:hidden; border-radius:var(--radius);
  background:
    repeating-linear-gradient(45deg, var(--line-soft) 0 1px, transparent 1px 13px),
    var(--bg-2);
  display:grid; place-items:center; color:var(--ink-soft);
}
.ph .ph-tag{
  font-family:'Hanken Grotesque', monospace;
  font-size:.7rem; letter-spacing:.08em; text-transform:uppercase;
  font-weight:600;
  background:var(--surface); color:var(--ink-soft);
  padding:.5em .9em; border-radius:999px; border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:80;
  transition:background .35s var(--ease), box-shadow .35s, padding .35s var(--ease), backdrop-filter .35s;
  padding-block:18px;
}
.nav.scrolled{
  background:color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter:blur(14px) saturate(1.4);
  box-shadow:0 1px 0 var(--line-soft), 0 8px 30px rgba(35,39,31,.06);
  padding-block:10px;
}
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; gap:20px; }
.brand{ display:flex; align-items:center; gap:11px; font-family:var(--font-display); font-weight:800; font-size:1.18rem; letter-spacing:-.02em; }
.brand .mark{ width:38px; height:38px; flex:none; }
.brand small{ display:block; font-family:var(--font-body); font-weight:600; font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-top:1px; }
.nav-links{ display:none; align-items:center; gap:6px; }
.nav-links a{ padding:.5em .9em; border-radius:999px; font-weight:600; font-size:.96rem; color:var(--ink-soft); transition:color .2s, background .2s; }
.nav-links a:hover{ color:var(--ink); background:rgba(35,39,31,.05); }
.nav-cta{ display:none; }
.nav-burger{ display:inline-flex; flex-direction:column; gap:5px; width:44px; height:44px; align-items:center; justify-content:center; border-radius:12px; border:1.5px solid var(--line); }
.nav-burger span{ width:20px; height:2px; background:var(--ink); border-radius:2px; transition:transform .3s var(--ease), opacity .25s; }
.nav-burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-burger.open span:nth-child(2){ opacity:0; }
.nav-burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile menu sheet */
.mobile-menu{
  position:fixed; inset:0; z-index:79; background:var(--bg);
  display:flex; flex-direction:column; justify-content:center; gap:8px;
  padding:var(--pad);
  transform:translateY(-100%); transition:transform .5s var(--ease);
  visibility:hidden;
}
.mobile-menu.open{ transform:translateY(0); visibility:visible; }
.mobile-menu a{ font-family:var(--font-display); font-weight:700; font-size:clamp(2rem,11vw,3rem); letter-spacing:-.03em; padding-block:.12em; color:var(--ink); border-bottom:1px solid var(--line-soft); }
.mobile-menu a:last-of-type{ border-bottom:none; }
.mobile-menu .mm-cta{ margin-top:24px; }
.mobile-menu .mm-foot{ margin-top:auto; padding-top:24px; color:var(--ink-soft); font-size:.95rem; display:flex; flex-direction:column; gap:4px; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ padding-top:clamp(110px,22vw,150px); padding-bottom:clamp(40px,8vw,80px); position:relative; overflow:hidden; }
.hero-blob{
  position:absolute; z-index:0; pointer-events:none;
  width:min(80vw,620px); aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle at 35% 35%, var(--accent-soft), transparent 62%);
  opacity:.5; filter:blur(8px);
  top:-8%; right:-18%;
}
.hero .wrap{ position:relative; z-index:1; }
.hero-grid{ display:grid; gap:clamp(34px,6vw,60px); }
.hero-copy{ max-width:680px; }
.hero h1{
  font-family:var(--font-display);
  font-style:italic; font-weight:700;
  font-size:clamp(2rem,5.3vw,4rem);
  line-height:1.14; letter-spacing:-.02em;
  margin-top:26px;
}
.hero h1 .l{ display:block; white-space:nowrap; }
.hero h1 .em{ color:var(--primary); }
.hero h1 .swash{ color:var(--accent); }
.hero-sub{ margin-top:22px; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:12px; margin-top:30px; }
.hero-trust{ display:flex; align-items:center; gap:16px; margin-top:28px; flex-wrap:wrap; }
.stars{ color:var(--accent); letter-spacing:2px; font-size:1.05rem; }
.hero-trust .t-txt{ font-size:.95rem; color:var(--ink-soft); }
.hero-trust .t-txt strong{ color:var(--ink); }
.avatars{ display:flex; }
.avatars .av{ width:34px; height:34px; border-radius:50%; border:2.5px solid var(--bg); margin-left:-10px;
  background:linear-gradient(135deg, var(--accent-soft), var(--accent)); }
.avatars .av:first-child{ margin-left:0; }

.hero-media{ position:relative; }
.hero-photo{ aspect-ratio:4/5; box-shadow:var(--shadow-lg); border-radius:var(--radius-lg); }
.hero-badge{
  position:absolute; left:-14px; bottom:28px;
  background:var(--surface); border:1px solid var(--line); border-radius:18px;
  padding:14px 16px; box-shadow:var(--shadow-md); display:flex; align-items:center; gap:12px;
  max-width:230px;
}
.hero-badge .bdot{ width:42px; height:42px; border-radius:12px; background:var(--primary); color:var(--on-primary); display:grid; place-items:center; font-family:var(--font-display); font-weight:800; flex:none; }
.hero-badge .bt{ font-size:.82rem; line-height:1.35; color:var(--ink-soft); }
.hero-badge .bt strong{ display:block; color:var(--ink); font-size:.95rem; font-family:var(--font-display); }

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust{ background:var(--primary); color:var(--on-primary); }
.trust .wrap{ display:grid; grid-template-columns:repeat(2,1fr); gap:30px 20px; padding-block:clamp(40px,7vw,64px); }
.stat{ text-align:center; }
.stat .num{ font-family:var(--font-display); font-weight:800; font-size:clamp(2.4rem,8vw,3.6rem); line-height:1; letter-spacing:-.03em; }
.stat .num .u{ color:var(--accent-soft); }
.stat .lbl{ margin-top:8px; font-size:.86rem; letter-spacing:.04em; color:color-mix(in srgb,var(--on-primary) 72%, transparent); text-transform:uppercase; }

/* ============================================================
   SERVICES
   ============================================================ */
.svc-head{ display:flex; flex-direction:column; gap:18px; margin-bottom:clamp(36px,6vw,56px); }
.svc-grid{ display:grid; gap:18px; grid-template-columns:1fr; }
.svc-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:30px 26px 26px; transition:transform .4s var(--ease), box-shadow .4s, border-color .4s;
  position:relative; overflow:hidden;
}
.svc-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:transparent; }
.svc-card .no{ font-family:var(--font-serif); font-style:italic; color:var(--accent); font-size:1.05rem; }
.svc-card h3{ font-size:1.5rem; margin-top:10px; }
.svc-card p{ color:var(--ink-soft); font-size:.98rem; margin-top:10px; }
.svc-card .price{ margin-top:18px; font-weight:700; display:flex; align-items:baseline; gap:6px; }
.svc-card .price .f{ font-size:.78rem; color:var(--ink-soft); font-weight:600; text-transform:uppercase; letter-spacing:.06em; }
.svc-card .price .p{ font-family:var(--font-display); font-size:1.5rem; }
.svc-card .ic{ position:absolute; top:26px; right:26px; width:40px; height:40px; border-radius:11px; background:var(--bg-2); display:grid; place-items:center; color:var(--primary); }

/* ============================================================
   EXPERIENCE (timeline)
   ============================================================ */
.exp{ background:var(--bg-2); }
.exp-head{ text-align:center; max-width:640px; margin:0 auto clamp(40px,7vw,64px); display:flex; flex-direction:column; gap:16px; align-items:center; }
.steps{ display:grid; gap:26px; counter-reset:step; }
.step{ display:grid; grid-template-columns:auto 1fr; gap:20px; align-items:start; position:relative; }
.step .dot{
  width:52px; height:52px; border-radius:50%; flex:none; background:var(--surface); border:1.5px solid var(--line);
  display:grid; place-items:center; font-family:var(--font-display); font-weight:800; color:var(--primary); font-size:1.2rem;
  position:relative; z-index:2;
}
.step:not(:last-child) .dot::after{ content:""; position:absolute; top:52px; left:50%; transform:translateX(-50%); width:2px; height:calc(100% + 26px); background:var(--line); }
.step h3{ font-size:1.3rem; }
.step p{ color:var(--ink-soft); font-size:.98rem; margin-top:6px; max-width:46ch; }
.step .photo{ margin-top:14px; aspect-ratio:16/10; }

/* ============================================================
   PRICING
   ============================================================ */
.price-head{ display:flex; flex-direction:column; gap:16px; margin-bottom:30px; }
.size-tabs{ display:inline-flex; gap:4px; padding:5px; background:var(--bg-2); border-radius:999px; border:1px solid var(--line); align-self:flex-start; }
.size-tabs button{ padding:.6em 1.3em; border-radius:999px; font-weight:700; font-size:.95rem; color:var(--ink-soft); transition:color .25s; position:relative; }
.size-tabs button.active{ color:var(--on-primary); }
.size-tabs .pill{ position:absolute; inset:5px auto 5px 5px; background:var(--primary); border-radius:999px; z-index:0; transition:transform .4s var(--ease), width .4s var(--ease); }
.size-tabs button span{ position:relative; z-index:1; }
.price-grid{ display:grid; gap:18px; grid-template-columns:1fr; margin-top:10px; }
.plan{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:30px 26px; display:flex; flex-direction:column; }
.plan.feat{ background:var(--primary); color:var(--on-primary); border-color:transparent; }
.plan.feat .pll, .plan.feat .amt small{ color:color-mix(in srgb,var(--on-primary) 70%, transparent); }
.plan .pll{ font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); font-weight:700; }
.plan .pname{ font-family:var(--font-display); font-size:1.6rem; margin-top:8px; font-weight:800; }
.plan .amt{ margin-top:16px; display:flex; align-items:baseline; gap:6px; }
.plan .amt .v{ font-family:var(--font-display); font-size:2.8rem; font-weight:800; line-height:1; letter-spacing:-.03em; }
.plan .amt small{ color:var(--ink-soft); font-size:.85rem; }
.plan ul{ list-style:none; margin-top:20px; display:flex; flex-direction:column; gap:11px; flex:1; }
.plan li{ display:flex; gap:10px; align-items:flex-start; font-size:.96rem; }
.plan li .ck{ color:var(--accent); flex:none; margin-top:3px; }
.plan.feat li .ck{ color:var(--accent-soft); }
.plan .btn{ margin-top:24px; width:100%; }
.plan.feat .btn-primary{ background:var(--accent); color:#fff; }
.price-note{ margin-top:22px; font-size:.9rem; color:var(--ink-soft); text-align:center; }

/* ============================================================
   GALLERY
   ============================================================ */
.gal{ background:var(--primary-deep); color:var(--on-primary); overflow:hidden; }
.gal-head{ display:flex; flex-direction:column; gap:16px; margin-bottom:34px; }
.gal-head .eyebrow{ color:var(--accent-soft); }
.gal-head .eyebrow::before{ background:var(--accent-soft); }
.gal-head h2{ color:var(--on-primary); }
.gal-head p{ color:color-mix(in srgb,var(--on-primary) 75%, transparent); }
.gal-grid{ display:grid; gap:12px; grid-template-columns:repeat(2,1fr); }
.gal-grid .ph{ background:
    repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 1px, transparent 1px 13px),
    rgba(255,255,255,.06); border-radius:14px; }
.gal-grid .ph .ph-tag{ background:rgba(0,0,0,.25); color:var(--on-primary); border-color:rgba(255,255,255,.18); }
.gal-grid .g1{ aspect-ratio:1; } .gal-grid .g2{ aspect-ratio:1; }
.gal-grid .tall{ grid-row:span 2; aspect-ratio:auto; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi-head{ text-align:center; margin-bottom:clamp(36px,6vw,52px); display:flex; flex-direction:column; gap:14px; align-items:center; }
.testi-grid{ display:grid; gap:18px; grid-template-columns:1fr; }
.quote{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:30px 28px; display:flex; flex-direction:column; }
.quote .stars{ margin-bottom:14px; }
.quote blockquote{ font-family:var(--font-serif); font-style:italic; font-size:1.22rem; line-height:1.5; color:var(--ink); text-wrap:pretty; }
.quote .who{ margin-top:20px; display:flex; align-items:center; gap:12px; }
.quote .who .pic{ width:46px; height:46px; border-radius:50%; flex:none; background:linear-gradient(135deg,var(--accent-soft),var(--accent)); }
.quote .who .n{ font-weight:700; } .quote .who .d{ font-size:.86rem; color:var(--ink-soft); }

/* ============================================================
   VISIT / BOOK
   ============================================================ */
.visit{ background:var(--bg-2); }
.visit-grid{ display:grid; gap:24px; grid-template-columns:1fr; }
.visit-info{ display:flex; flex-direction:column; gap:14px; }
.visit-info h2{ font-size:clamp(2rem,6vw,3.2rem); max-width:14ch; }
.info-rows{ display:flex; flex-direction:column; gap:2px; margin-top:8px; }
.info-row{ display:grid; grid-template-columns:120px 1fr; gap:16px; padding:16px 0; border-top:1px solid var(--line); align-items:start; }
.info-row .k{ font-weight:700; font-size:.82rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); }
.info-row .v{ font-size:1.02rem; }
.info-row .v a{ color:var(--primary); font-weight:600; text-decoration:underline; text-decoration-color:var(--line); text-underline-offset:3px; }
.hours-line{ display:flex; justify-content:space-between; gap:16px; max-width:280px; }
.hours-line.closed{ color:var(--ink-soft); }
.visit-map{ aspect-ratio:4/3; min-height:280px; }
.visit-cta{ margin-top:8px; display:flex; flex-wrap:wrap; gap:12px; }

/* ============================================================
   FINAL CTA
   ============================================================ */
.cta{ background:var(--primary); color:var(--on-primary); text-align:center; overflow:hidden; position:relative; }
.cta .wrap{ position:relative; z-index:1; display:flex; flex-direction:column; align-items:center; gap:22px; }
.cta h2{ color:var(--on-primary); font-size:clamp(2.4rem,8vw,4.6rem); max-width:16ch; }
.cta p{ color:color-mix(in srgb,var(--on-primary) 78%, transparent); max-width:48ch; font-size:1.1rem; }
.cta .btn-accent{ font-size:1.1rem; padding:1.1em 2em; }
.cta-paw{ position:absolute; inset:0; opacity:.06; z-index:0;
  background-image:radial-gradient(circle at 20% 30%, var(--on-primary) 0 8px, transparent 9px),
  radial-gradient(circle at 80% 70%, var(--on-primary) 0 8px, transparent 9px);
  background-size:240px 240px; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ background:var(--bg); padding-block:clamp(48px,7vw,72px) 32px; }
.foot-top{ display:grid; gap:32px; grid-template-columns:1fr; }
.foot .brand{ font-size:1.3rem; }
.foot-col h4{ font-family:var(--font-body); font-weight:700; font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:14px; }
.foot-col a, .foot-col p{ display:block; color:var(--ink-soft); font-size:.96rem; padding-block:5px; transition:color .2s; }
.foot-col a:hover{ color:var(--ink); }
.foot-cols{ display:grid; grid-template-columns:1fr 1fr; gap:28px; }
.foot-bottom{ margin-top:40px; padding-top:24px; border-top:1px solid var(--line); display:flex; flex-wrap:wrap; gap:12px; justify-content:space-between; align-items:center; color:var(--ink-soft); font-size:.86rem; }
.foot-blurb{ color:var(--ink-soft); font-size:.96rem; margin-top:14px; max-width:34ch; }

/* ============================================================
   REVEAL ANIMATION
   Base state is VISIBLE — entrance is a pure enhancement applied
   via .in (added by JS only once the tab is confirmed ticking).
   This guarantees content is never trapped invisible in throttled
   / non-painting contexts (capture tools, background tabs, export).
   ============================================================ */
.reveal, .reveal-scale{ opacity:1; transform:none; }
@keyframes mdh-rise{ from{ opacity:0; transform:translateY(26px); } to{ opacity:1; transform:none; } }
@keyframes mdh-scale{ from{ opacity:0; transform:scale(.94); } to{ opacity:1; transform:none; } }
.reveal.in{ animation:mdh-rise var(--reveal-dur) var(--ease) var(--d,0ms) both; }
.reveal-scale.in{ animation:mdh-scale var(--reveal-dur) var(--ease) var(--d,0ms) both; }

:root[data-motion="off"] .reveal,
:root[data-motion="off"] .reveal-scale{ animation:none !important; opacity:1 !important; transform:none !important; }
@media (prefers-reduced-motion: reduce){
  .reveal,.reveal-scale{ animation:none !important; opacity:1 !important; transform:none !important; }
}

/* ============================================================
   OWNER-TO-SUPPLY TAG (reused across draft slots)
   ============================================================ */
.supply{
  display:inline-flex; align-items:center; gap:.5em;
  font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;
  font-size:.68rem; letter-spacing:.13em; text-transform:uppercase; font-weight:500;
  color:var(--ink-soft); border:1px dashed var(--line); border-radius:7px;
  padding:.45em .7em; white-space:nowrap; line-height:1;
}
.supply::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--accent); flex:none; }

/* ============================================================
   TRUST — honest single statement (confirmed facts only)
   ============================================================ */
.trust .wrap.trust-statement{ display:block; text-align:center; padding-block:clamp(44px,7vw,72px); }
.trust-statement p{
  font-family:var(--font-serif); font-style:italic; font-weight:400;
  font-size:clamp(1.35rem,3.4vw,2.2rem); line-height:1.4; letter-spacing:-.01em;
  max-width:24ch; margin-inline:auto; color:var(--on-primary); text-wrap:balance;
}
.trust-statement strong{ font-weight:600; font-style:normal; color:#fff; }
.trust-statement .star{ color:var(--accent-soft); font-style:normal; }

/* ============================================================
   SERVICES — 5 owner-to-supply cards, vertical-rule dividers,
   em-dash separators, Source Serif italic, NO tilt, NO prices
   ============================================================ */
.svc-band{ display:grid; grid-template-columns:1fr; }
.svc-item{ padding:22px 0; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:14px; }
.svc-item:first-child{ border-top:none; }
.svc-item .srow{ display:flex; align-items:baseline; gap:.5em; flex-wrap:wrap; }
.svc-item .sname{
  font-family:var(--font-serif); font-style:italic; font-weight:500;
  font-size:clamp(1.65rem,5vw,2.1rem); line-height:1.05; letter-spacing:-.01em; color:var(--ink);
}
.svc-item .sep{ color:var(--ink-soft); opacity:.5; font-size:1.3rem; line-height:1; }
.svc-item .sdrop{ aspect-ratio:5/3; }
.svc-num{ font-family:'Hanken Grotesque',monospace; font-size:.72rem; letter-spacing:.14em; color:var(--accent); font-weight:600; }

/* ============================================================
   VISIT — real embedded map
   ============================================================ */
.visit-map{ aspect-ratio:4/3; min-height:300px; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow-sm); }
.visit-map iframe{ width:100%; height:100%; border:0; display:block; filter:grayscale(.2) contrast(1.02); }

/* ============================================================
   DRAFT FRAMING (unsolicited proposal honesty)
   ============================================================ */
.draft-tag{
  display:inline-flex; align-items:center; gap:.6em; align-self:flex-start;
  font-family:'Hanken Grotesque',sans-serif; font-size:.74rem; font-weight:600;
  letter-spacing:.04em; color:var(--ink-soft);
  background:var(--surface); border:1px solid var(--line); border-radius:999px;
  padding:.5em .85em; margin-top:8px;
}
.draft-tag .dot{ width:7px; height:7px; border-radius:50%; background:var(--accent); flex:none; }
.foot-credit{ display:flex; flex-direction:column; gap:6px; }
.foot-credit a{ color:var(--primary); font-weight:600; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (min-width:720px){
  .nav-links{ display:flex; }
  .nav-cta{ display:inline-flex; }
  .nav-burger{ display:none; }
  .svc-grid{ grid-template-columns:repeat(2,1fr); }
  .trust .wrap{ grid-template-columns:repeat(4,1fr); }
  .testi-grid{ grid-template-columns:repeat(2,1fr); }
  .gal-grid{ grid-template-columns:repeat(3,1fr); grid-auto-rows:1fr; }
  .foot-top{ grid-template-columns:1.4fr 1fr; }
  .price-grid{ grid-template-columns:repeat(3,1fr); }
}
@media (min-width:960px){
  .hero-grid{ grid-template-columns:1.12fr .88fr; align-items:center; gap:clamp(48px,5vw,72px); }
  .hero-media{ order:2; }
  .svc-grid{ grid-template-columns:repeat(3,1fr); }
  .steps{ grid-template-columns:repeat(4,1fr); gap:20px; }
  .step{ grid-template-columns:1fr; }
  .step:not(:last-child) .dot::after{ top:50%; left:52px; transform:translateY(-50%); width:calc(100% + 20px - 52px); height:2px; }
  .step .dot{ margin-bottom:6px; }
  .visit-grid{ grid-template-columns:1fr 1fr; align-items:start; gap:48px; }
  .testi-grid{ grid-template-columns:repeat(3,1fr); }
  .foot-cols{ grid-template-columns:repeat(3,1fr); }
  .svc-band{ grid-template-columns:repeat(5,1fr); }
  .svc-item{ border-top:none; border-left:1px solid var(--line); padding:4px 0 4px 24px; }
  .svc-item:first-child{ border-left:none; padding-left:0; }
  .svc-item .srow{ flex-direction:column; gap:6px; align-items:flex-start; }
  .svc-item .sep{ display:none; }
}
@media (min-width:720px) and (max-width:959px){
  .testi-grid .quote:last-child{ grid-column:1 / -1; }
}
