@import url("tokens.css");

*,*::before,*::after { 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; } }
section[id] { scroll-margin-top: 88px; }

body {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  line-height: var(--lh-body);
  color: var(--c-ink);
  background: var(--c-paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1,h2,h3 { font-family: var(--font-display); font-optical-sizing: auto; font-weight: var(--fw-display); line-height: var(--lh-heading); letter-spacing: var(--ls-heading); color: var(--c-brand-deep); }
h1 { font-size: var(--fs-h1); line-height: var(--lh-tight); letter-spacing: var(--ls-display); font-weight: var(--fw-display-hi); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); font-weight: var(--fw-display); }
h4 { font-family: var(--font-body); font-size: var(--fs-h4); font-weight: var(--fw-semibold); line-height: 1.3; color: var(--c-ink); }
p { margin: 0; }
a { color: var(--c-brand-deep); text-decoration: none; }
img { max-width: 100%; display: block; }
ul { list-style: none; }

:focus-visible { outline: none; box-shadow: var(--focus-ring); border-radius: var(--r-xs); }

.wrap { max-width: var(--w-content); margin-inline: auto; padding-inline: var(--gutter); }
.prose { max-width: var(--w-text); margin-inline: auto; }
.section { padding-block: var(--section-y); }
.section--lg { padding-block: var(--section-y-lg); }
.section--wash { background: var(--c-brand-wash); }
.section--surface2 { background: var(--c-surface-2); }
.center { text-align: center; }
.lead { font-size: var(--fs-lg); line-height: var(--lh-snug); color: var(--c-muted); max-width: 44rem; }
.center .lead { margin-inline: auto; }

/* Eyebrow pill (the signature section marker) */
.eyebrow, .pill { display: inline-flex; align-items: center; gap: 0.46rem; font-family: var(--font-body); font-size: var(--fs-pill); font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: var(--ls-label); color: var(--c-brand-deep); background: var(--c-accent-tint); border-radius: var(--r-pill); padding: 0.23rem 0.69rem; margin-bottom: var(--sp-4); }
.eyebrow::before, .pill::before { content: ""; width: 7px; height: 7px; background: var(--c-accent); border-radius: 0 50% 50% 50%; transform: rotate(45deg); flex: none; }
.band-deep .eyebrow, .band-deep .pill { background: rgba(255,255,255,.10); color: var(--c-accent-soft); }
.block-head { margin-bottom: var(--sp-7); }

.reveal { opacity: 0; transform: translateY(var(--reveal-shift)); transition: opacity var(--dur-reveal) var(--ease-emph), transform var(--dur-reveal) var(--ease-emph); }
.reveal.is-in { opacity: 1; transform: none; }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2); min-height: var(--btn-h); padding: var(--btn-pad-y) var(--btn-pad-x); border-radius: var(--btn-radius); font-family: var(--font-body); font-size: var(--btn-fs); font-weight: var(--btn-weight); line-height: 1; letter-spacing: 0.005em; border: 0; cursor: pointer; text-align: center; transition: background var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out); }
.btn--primary { background: var(--c-brand); color: var(--c-on-dark); box-shadow: var(--sh-sm); }
.btn--primary:hover { background: var(--c-brand-deep); transform: translateY(-2px); box-shadow: var(--sh-hover); }
.btn--accent { background: var(--c-accent); color: var(--c-on-accent); box-shadow: var(--sh-accent); }
.btn--accent:hover { background: var(--c-accent-strong); transform: translateY(-2px); }
.btn--on-accent { background: var(--c-surface); color: var(--c-on-accent); box-shadow: var(--sh-sm); }
.btn--on-accent:hover { background: var(--c-paper); transform: translateY(-2px); }
.btn--lg { min-height: var(--btn-h-lg); font-size: var(--btn-fs-lg); padding-inline: var(--btn-pad-x-lg); }
.btn--sm { min-height: var(--btn-h-sm); font-size: var(--btn-fs-sm); padding-inline: var(--btn-pad-x-sm); }
.btn:active { transform: translateY(0); transition-duration: var(--dur-instant); }
.btn--secondary { background: var(--c-surface); color: var(--c-brand-deep); border: var(--bw-med) solid var(--c-brand); }
.btn--secondary:hover { background: var(--c-brand-tint); border-color: var(--c-brand-deep); }
.btn--ghost-call { background: none; color: var(--c-brand-deep); min-height: 38px; width: 38px; padding: 0; border-radius: var(--r-sm); }
.btn--ghost-call svg { width: 19px; height: 19px; }
.btn--ghost-call:hover { background: var(--c-brand-tint); }
.btn--ghost { color: var(--c-brand-deep); background: none; min-height: auto; padding: var(--sp-2) 0; }
.btn--ghost .uline { background-image: linear-gradient(var(--c-accent),var(--c-accent)); background-size: 0 var(--bw-accent); background-position: 0 100%; background-repeat: no-repeat; transition: background-size var(--dur-base) var(--ease-out); padding-bottom: 2px; }
.btn--ghost:hover .uline { background-size: 100% var(--bw-accent); }
.btn[disabled] { background: var(--c-line-strong); color: var(--c-faint); box-shadow: none; cursor: not-allowed; transform: none; }
.btn--block { width: 100%; }
.on-dark .btn--secondary { background: transparent; color: var(--c-on-dark); border-color: var(--c-line-on-dark); }
.on-dark .btn--secondary:hover { background: rgba(255,255,255,.08); }
.cta-row { display: flex; flex-wrap: wrap; gap: var(--sp-3); }
.center .cta-row, .cta-row.center { justify-content: center; }
.ghost-link { color: var(--c-brand-deep); font-weight: var(--fw-semibold); text-decoration: underline; text-decoration-color: var(--c-accent); text-underline-offset: 3px; }
@media (max-width: 859px) {
  .btn--accent, .btn--primary, .btn--secondary, .btn--on-accent { min-height: var(--btn-h-touch); }
}

/* Header */
.site-header { position: sticky; top: 0; z-index: var(--z-header); background: rgba(250,246,238,.85); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); border-bottom: 1px solid transparent; transition: border-color var(--dur-base) var(--ease-out); }
.site-header.is-scrolled { border-bottom-color: var(--c-line); }
.nav { display: flex; align-items: center; gap: var(--sp-5); min-height: 64px; }
.brand { display: inline-flex; align-items: center; margin-right: auto; }
.brand-logo { height: 30px; width: auto; }
.nav-links { display: none; gap: var(--sp-5); align-items: center; }
.nav-links a { color: var(--c-ink); font-weight: var(--fw-medium); font-size: var(--fs-md); position: relative; padding-block: var(--sp-2); }
.nav-links a::after { content: ""; position: absolute; left: 0; bottom: 0; width: 0; height: var(--bw-accent); background: var(--c-accent); border-radius: var(--r-pill); transition: width var(--dur-base) var(--ease-out); }
.nav-links a:hover { color: var(--c-brand-deep); }
.nav-links a:hover::after, .nav-links a[aria-current]::after { width: 100%; }
.nav-actions { display: flex; align-items: center; gap: var(--sp-3); }
.nav-toggle { display: inline-flex; flex-direction: column; gap: 5px; width: 44px; height: 44px; align-items: center; justify-content: center; background: none; border: 0; cursor: pointer; }
.nav-toggle span { width: 22px; height: 2px; background: var(--c-brand-deep); border-radius: 2px; transition: transform var(--dur-base) var(--ease-out), opacity var(--dur-fast); }
.nav-call { display: none; }
.nav-book { display: none; }

/* Mobile nav sheet */
.nav-sheet { position: fixed; inset: 0 0 0 auto; width: min(88vw,360px); background: var(--c-paper); z-index: var(--z-modal); transform: translateX(100%); transition: transform var(--dur-slow) var(--ease-out); display: flex; flex-direction: column; padding: var(--sp-6) var(--gutter); padding-bottom: max(var(--sp-6), env(safe-area-inset-bottom)); box-shadow: var(--sh-xl); overflow-y: auto; }
.nav-sheet.is-open { transform: none; }
.nav-sheet .sheet-offer { align-self: flex-start; background: var(--c-accent-tint); color: var(--c-on-accent); font-size: var(--fs-sm); font-weight: var(--fw-semibold); border-radius: var(--r-pill); padding: var(--sp-2) var(--sp-4); margin-bottom: var(--sp-4); }
.nav-sheet .sheet-link { font-size: 1.2rem; font-weight: var(--fw-medium); color: var(--c-ink); padding: var(--sp-4) 0; min-height: 52px; display: flex; align-items: center; border-bottom: 1px solid var(--c-line); background: none; border-left: 0; border-right: 0; border-top: 0; text-align: left; cursor: pointer; font-family: var(--font-body); }
.nav-sheet .sheet-foot { margin-top: auto; display: grid; gap: var(--sp-3); padding-top: var(--sp-5); }
.nav-sheet .sheet-close { align-self: flex-end; width: 44px; height: 44px; background: none; border: 0; font-size: 1.6rem; color: var(--c-muted); cursor: pointer; }
.nav-backdrop { position: fixed; inset: 0; background: rgba(30,88,54,.45); z-index: var(--z-overlay); opacity: 0; visibility: hidden; transition: opacity var(--dur-base), visibility var(--dur-base); }
.nav-backdrop.is-open { opacity: 1; visibility: visible; }

/* Hero (left diagonal wedge, full-bleed photo) */
.hfb { position: relative; isolation: isolate; overflow: hidden; }
.hfb-bg { position: absolute; inset: 0; z-index: -2; }
.hfb-bg img { width: 100%; height: 100%; object-fit: cover; object-position: 60% 60%; }
.hfb .btn--accent { box-shadow: var(--sh-accent); }
.hfb-eyebrow { display: inline-flex; align-items: center; gap: 0.46rem; font-family: var(--font-body); font-size: var(--fs-pill); font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: var(--ls-label-sm); color: var(--c-accent-soft); background: rgba(20,46,28,.55); border: 1px solid rgba(255,255,255,.16); border-radius: var(--r-pill); padding: 0.23rem 0.69rem; margin-bottom: var(--sp-4); }
.hfb-eyebrow::before { content: ""; width: 7px; height: 7px; background: var(--c-accent); border-radius: 0 50% 50% 50%; transform: rotate(45deg); flex: none; }
.hfb h1 { color: var(--c-surface); margin: 0 0 var(--sp-3); max-width: none; font-size: calc(clamp(2.1rem, 1.45rem + 2.7vw, 3rem) * 1.21275); }
.hfb h1 span { display: block; }
@media (min-width: 701px) { .hfb h1 span { white-space: nowrap; } }
.hfb-sub { font-size: calc(var(--fs-lg) * 0.85); line-height: var(--lh-snug); margin: 0 0 var(--sp-5); max-width: 40ch; color: var(--c-hero-sub); }
.hfb-cta { display: flex; flex-direction: column; align-items: flex-start; gap: var(--sp-3); margin-bottom: var(--sp-6); }
.hfb-cta .btn { align-self: stretch; font-size: calc(var(--btn-fs-lg) * 0.95); min-height: calc(var(--btn-h-lg) * 0.95); padding-inline: calc(var(--btn-pad-x-lg) * 0.95); }
.hfb-call { display: inline-flex; align-items: center; gap: var(--sp-2); font-weight: var(--fw-medium); color: var(--c-hero-label); }
.hfb-call a { display: inline-flex; align-items: center; gap: 0.45rem; font-weight: var(--fw-bold); color: var(--c-accent-soft); text-decoration: none; }
.hfb-call a svg { width: 1.05em; height: 1.05em; flex: none; }
.hfb-call a:hover { text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(250,215,154,.5); }
@media (min-width: 560px) { .hfb-cta { flex-direction: row; align-items: center; gap: var(--sp-5); } .hfb-cta .btn { align-self: auto; min-width: 14rem; } }
.hfb-pills { display: inline-flex; align-items: stretch; max-width: 100%; background: rgba(20,46,28,.62); border: 1px solid rgba(255,255,255,.20); border-radius: var(--r-pill); backdrop-filter: blur(4px); overflow: hidden; }
.hfb-pill { display: inline-flex; align-items: center; gap: 0.46rem; white-space: nowrap; font-family: var(--font-body); font-size: var(--fs-pill); font-weight: var(--fw-semibold); color: var(--c-on-dark); padding: 0.46rem 0.69rem; }
.hfb-pill + .hfb-pill { border-left: 1px solid rgba(255,255,255,.18); }
.hfb-pill::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--c-accent); flex: none; }
.hfb-wedge { display: flex; align-items: center; min-height: clamp(28rem, 26rem + 14vw, 42rem); }
.hfb-wedge .hfb-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(102deg, rgba(15,40,24,.96) 0%, rgba(15,40,24,.95) 18%, rgba(17,44,26,.86) 30%, rgba(20,48,30,.45) 52%, rgba(20,48,30,.04) 70%), linear-gradient(0deg, rgba(15,40,24,.35), transparent 60%); }
.hfb-pad { padding-block: var(--sp-7); width: 100%; }
.hfb-col { max-width: 40rem; }
@media (min-width: 1200px) { .hfb-col { margin-left: -3rem; } }
@media (min-width: 1500px) { .hfb-col { margin-left: -5rem; } }
@media (max-width: 700px) {
  .hfb-wedge .hfb-bg::after { background: linear-gradient(0deg, rgba(15,40,24,.96) 0%, rgba(15,40,24,.9) 30%, rgba(17,44,26,.66) 58%, rgba(20,48,30,.2) 100%); }
  .hfb-wedge { align-items: flex-end; }
  .hfb-pills { display: flex; flex-wrap: wrap; gap: var(--sp-2); background: none; border: 0; backdrop-filter: none; overflow: visible; }
  .hfb-pill { font-size: var(--fs-pill); background: rgba(20,46,28,.62); border: 1px solid rgba(255,255,255,.20); border-radius: var(--r-pill); backdrop-filter: blur(4px); }
}

/* Hero media: rounded photo plate with branded fallback (service pages) */
.hero-figure { position: relative; border-radius: inherit; overflow: hidden; box-shadow: var(--sh-lg); background: linear-gradient(150deg, var(--c-brand-tint), var(--c-brand-wash)); }
.hero-img { display: block; width: 100%; height: 100%; object-fit: cover; transform: scale(1.05); transition: transform 1200ms var(--ease-soft); }
.hero-figure.is-loaded .hero-img { transform: scale(1); }
.hero-fallback { position: absolute; inset: 0; display: none; flex-direction: column; align-items: center; justify-content: center; gap: var(--sp-3); color: var(--c-brand); text-align: center; }
.hero-figure.is-empty { box-shadow: var(--sh-inset); }
.hero-figure.is-empty .hero-fallback { display: flex; }
.hero-fallback svg { width: 64px; height: 64px; opacity: .9; }
.hero-fallback span { font-family: var(--font-display); font-weight: var(--fw-display); font-size: var(--fs-h4); color: var(--c-brand-deep); letter-spacing: var(--ls-heading); }
.hero-figure.is-empty::after { content: ""; position: absolute; inset: 0; background-image: radial-gradient(circle at 30% 25%, rgba(242,169,59,.14), transparent 55%); pointer-events: none; }
@media (max-width: 859px) { .hero-figure { max-height: 56vw; } }
@media (prefers-reduced-motion: reduce) { .hero-img { transform: none; transition: none; } }

/* Image slots */
.img-slot { position: relative; aspect-ratio: 4/3; background: linear-gradient(150deg, var(--c-brand-tint), var(--c-brand-wash)); border-radius: inherit; display: grid; place-items: center; overflow: hidden; }
.ratio-16x9 { aspect-ratio: 16/9; }
.ratio-4x3 { aspect-ratio: 4/3; }
.ratio-3x2 { aspect-ratio: 3/2; }
.img-slot::before { content: ""; position: absolute; inset: 0; background-image: radial-gradient(circle at 30% 20%, rgba(242,169,59,.12), transparent 55%); }
.img-slot svg { width: 56px; height: 56px; color: var(--c-brand-bright); opacity: .55; }
.img-slot .img-label { position: absolute; bottom: var(--sp-3); left: var(--sp-3); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-label-sm); color: var(--c-muted); background: rgba(250,246,238,.85); padding: var(--sp-1) var(--sp-3); border-radius: var(--r-pill); }
.ba-pair { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }

/* Card grids */
.grid { display: grid; gap: var(--gap-card); }
.grid--3 { grid-template-columns: 1fr; }
.grid--2 { grid-template-columns: 1fr; }
.card { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--r-lg); box-shadow: var(--sh-sm); padding: var(--sp-6); transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out); }
a.card { color: inherit; display: block; }
a.card:hover { transform: translateY(-4px); box-shadow: var(--sh-hover); }
.card h3 { margin-bottom: var(--sp-2); color: var(--c-brand-deep); }
.card p { color: var(--c-muted); }

/* Services bento (2-3-1 rhythm) */
.svc2-bento { display: grid; gap: var(--gap-card); margin-top: var(--sp-7); grid-template-columns: repeat(6, 1fr); }
.svc2-tile { position: relative; display: block; min-height: 230px; border-radius: var(--r-lg); overflow: hidden; text-decoration: none; box-shadow: var(--sh-sm); isolation: isolate; transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out); }
.svc2-tile:hover { transform: translateY(-3px); box-shadow: var(--sh-hover); }
.svc2-tile img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease-out); }
.svc2-tile:hover img { transform: scale(1.05); }
.svc2-scrim { position: absolute; inset: 0; z-index: 1; background: linear-gradient(to top, rgba(30,88,54,.90) 0%, rgba(30,88,54,.38) 48%, rgba(30,88,54,0) 80%); }
.svc2-stretch { position: absolute; inset: 0; z-index: 2; }
.svc2-inner { position: absolute; inset: 0; z-index: 3; display: flex; flex-direction: column; justify-content: flex-end; padding: var(--sp-5); gap: var(--sp-2); pointer-events: none; }
.svc2-inner > * { pointer-events: auto; }
.svc2-inner h3 { font-family: var(--font-display); font-weight: var(--fw-semibold); font-size: var(--fs-h4); color: var(--c-on-dark); margin: 0; letter-spacing: var(--ls-heading); }
.svc2-inner p { font-size: var(--fs-sm); line-height: var(--lh-snug); color: var(--c-on-dark-soft); margin: 0; }
.svc2-price { align-self: flex-start; margin-top: var(--sp-1); display: inline-flex; align-items: baseline; gap: 0.25em; font-family: var(--font-display); font-weight: var(--fw-semibold); background: rgba(250,246,238,.92); color: var(--c-brand-deep); padding: var(--sp-1) var(--sp-3); border-radius: var(--r-pill); font-size: var(--fs-sm); white-space: nowrap; backdrop-filter: blur(4px); }
.svc2-price b { font-weight: var(--fw-bold); }
.svc2-quote { align-self: flex-start; margin-top: var(--sp-1); display: inline-flex; align-items: center; gap: 0.35em; background: none; border: 0; padding: 0; cursor: pointer; font-family: var(--font-body); font-weight: var(--fw-semibold); font-size: var(--fs-sm); color: var(--c-accent-soft); text-decoration: none; }
.svc2-quote:hover { color: var(--c-accent); }
.svc2-quote svg { width: 1em; height: 1em; transition: transform var(--dur-fast) var(--ease-out); }
.svc2-quote:hover svg { transform: translateX(3px); }
.svc2-flag { position: absolute; top: var(--sp-5); left: var(--sp-5); z-index: 4; font-family: var(--font-body); font-weight: var(--fw-bold); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-label); background: var(--c-accent); color: var(--c-on-accent); padding: var(--sp-1) var(--sp-3); border-radius: var(--r-pill); pointer-events: none; }
.svc2-hero { grid-column: span 4; min-height: 340px; }
.svc2-hero .svc2-scrim { background: linear-gradient(to top, rgba(30,88,54,.92) 0%, rgba(30,88,54,.46) 42%, rgba(30,88,54,.05) 78%); }
.svc2-hero h3 { font-size: var(--fs-h2); letter-spacing: var(--ls-display); }
.svc2-hero p { font-size: var(--fs-md); max-width: 40ch; }
.svc2-tall { grid-column: span 2; min-height: 340px; }
.svc2-third { grid-column: span 2; }
.svc2-wide { grid-column: span 6; min-height: 220px; }
.svc2-wide .svc2-scrim { background: linear-gradient(90deg, rgba(30,88,54,.90) 0%, rgba(30,88,54,.55) 45%, rgba(30,88,54,.08) 90%); }
.svc2-wide .svc2-inner { justify-content: center; max-width: 52ch; }
.svc2-wide h3 { font-size: var(--fs-h3); }
.svc2-foot { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; text-align: center; gap: var(--sp-4); margin-top: var(--sp-6); }
.svc2-foot p { margin: 0; font-size: var(--fs-sm); color: var(--c-muted); }
@media (max-width: 880px) {
  .svc2-bento { grid-template-columns: repeat(2, 1fr); }
  .svc2-hero { grid-column: span 2; min-height: 300px; }
  .svc2-tall { grid-column: span 2; min-height: 240px; }
  .svc2-third { grid-column: span 1; }
  .svc2-wide { grid-column: span 2; }
}
@media (max-width: 560px) {
  .svc2-bento { grid-template-columns: 1fr; }
  .svc2-hero, .svc2-tall, .svc2-third, .svc2-wide { grid-column: span 1; min-height: 240px; }
}

/* Why people pick us (two-column ledger panel) */
.wledger-panel { margin-top: var(--sp-8); max-width: 1000px; margin-inline: auto; background: var(--c-surface); border: var(--bw-med) solid var(--c-line-strong); border-radius: var(--r-xl); box-shadow: var(--sh-lg); overflow: hidden; }
.wledger-cols { display: grid; grid-template-columns: 1fr 1fr; }
.wledger-col { padding: clamp(1.5rem, 1rem + 2vw, 2.5rem); }
.wledger-col--them { background: var(--c-surface-2); }
.wledger-col--us { background: var(--c-surface); border-left: var(--bw-hair) solid var(--c-line); position: relative; }
.wledger-col--us::before { content: ""; position: absolute; inset: 0 auto 0 -1px; width: var(--bw-accent); background: var(--c-brand); }
.wledger-col-label { font-family: var(--font-body); text-transform: uppercase; letter-spacing: var(--ls-label); font-size: var(--fs-xs); font-weight: var(--fw-bold); margin: 0 0 var(--sp-2); }
.wledger-col--them .wledger-col-label { color: var(--c-faint); }
.wledger-col--us .wledger-col-label { color: var(--c-brand); }
.wledger-col-title { font-family: var(--font-display); font-weight: var(--fw-display); font-size: var(--fs-h4); line-height: var(--lh-heading); margin: 0 0 var(--sp-4); }
.wledger-col--them .wledger-col-title { color: var(--c-muted); }
.wledger-col--us .wledger-col-title { color: var(--c-ink); }
.wledger-list { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--sp-4); }
.wledger-list li { display: flex; gap: var(--sp-3); align-items: flex-start; font-size: var(--fs-md); line-height: var(--lh-snug); }
.wledger-mk { flex: 0 0 auto; width: 22px; height: 22px; margin-top: 1px; }
.wledger-col--them li { color: var(--c-muted); }
.wledger-col--them .wledger-mk { color: var(--c-warm); }
.wledger-col--us li { color: var(--c-ink); }
.wledger-col--us .wledger-mk { color: var(--c-brand); }
.wledger-col--us strong { font-weight: var(--fw-semibold); }
.wledger-seal-bar { background: var(--c-brand-deep); color: var(--c-on-dark); padding: clamp(1.25rem, 1rem + 1.5vw, 1.75rem) clamp(1.5rem, 1rem + 2vw, 2.5rem); display: flex; align-items: center; gap: var(--sp-5); flex-wrap: wrap; }
.wledger-seal { flex: 0 0 auto; width: 54px; height: 54px; border-radius: var(--r-pill); background: var(--c-accent); color: var(--c-on-accent); display: grid; place-items: center; box-shadow: var(--sh-accent); }
.wledger-seal svg { width: 30px; height: 30px; }
.wledger-txt { flex: 1 1 320px; }
.wledger-g-eyebrow { font-family: var(--font-body); text-transform: uppercase; letter-spacing: var(--ls-label); font-size: var(--fs-xs); font-weight: var(--fw-bold); color: var(--c-accent-soft); }
.wledger-seal-bar p { margin: 0.2rem 0 0; font-family: var(--font-display); font-weight: var(--fw-medium); font-size: var(--fs-h4); line-height: var(--lh-snug); color: var(--c-paper); }
.wledger-cta { margin-left: auto; }
@media (max-width: 760px) {
  .wledger-cols { grid-template-columns: 1fr; }
  .wledger-col--us { border-left: 0; border-top: var(--bw-hair) solid var(--c-line); }
  .wledger-col--us::before { inset: -1px 0 auto 0; width: auto; height: var(--bw-accent); }
  .wledger-cta { margin-left: 0; width: 100%; }
  .wledger-cta .btn { width: 100%; }
}

/* How it works (deep-green band, frosted step strip) */
.hiw { background: var(--c-brand-deep); color: var(--c-on-dark); position: relative; overflow: hidden; }
.hiw .pill { background: rgba(255,255,255,.10); color: var(--c-accent-soft); }
.hiw h2 { color: var(--c-on-dark); }
.hiw-lede { color: var(--c-on-dark-soft); font-size: var(--fs-lg); line-height: var(--lh-snug); margin: var(--sp-3) 0 0; max-width: 46ch; }
.hiw-ico { flex: none; display: grid; place-items: center; width: 54px; height: 54px; background: var(--c-accent); border-radius: var(--r-md); box-shadow: var(--sh-accent); }
.hiw-ico svg { width: 26px; height: 26px; stroke: var(--c-on-accent); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.hiw h3 { font-family: var(--font-display); font-weight: var(--fw-display); font-size: var(--fs-h4); color: var(--c-on-dark); margin: 0 0 var(--sp-1); }
.hiw .step-copy { color: var(--c-on-dark-soft); font-size: var(--fs-md); line-height: var(--lh-snug); margin: 0; }
.hiw-ord { font-family: var(--font-display); font-weight: var(--fw-display-hi); font-size: var(--fs-sm); color: var(--c-accent-soft); letter-spacing: var(--ls-label); text-transform: uppercase; display: block; margin-bottom: var(--sp-1); }
.hiw2 { padding: 0; }
.hiw2-stage { position: relative; isolation: isolate; padding-block: var(--section-y-lg); background-image: linear-gradient(to right, rgba(30,88,54,.92), rgba(30,88,54,.62)), url("../img/services/garden-tidy-ups.jpg"); background-size: cover; background-position: center; }
.hiw2-head { max-width: 30rem; margin-bottom: var(--sp-7); }
.hiw2-strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); }
.hiw2-card { background: rgba(250,246,238,.12); -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px); border: var(--bw-hair) solid rgba(255,255,255,.18); border-radius: var(--r-lg); padding: var(--sp-6) var(--sp-5); }
.hiw2-card .hiw-ico { margin-bottom: var(--sp-4); }
@media (max-width: 760px) {
  .hiw2-strip { grid-template-columns: 1fr; gap: var(--sp-3); }
  .hiw2-stage { background-image: linear-gradient(to bottom, rgba(30,88,54,.86), rgba(30,88,54,.9)), url("../img/services/garden-tidy-ups.jpg"); }
}

.band-deep { background: var(--c-brand-deep); color: var(--c-on-dark); }
.band-deep h2, .band-deep h3 { color: var(--c-surface); }
.band-deep .lead, .band-deep p { color: var(--c-on-dark-soft); }
.band-deep[data-foot-cta] { padding-block: clamp(2.25rem, 1.5rem + 2.4vw, 3.75rem); }
.band-deep[data-foot-cta] .lead { margin-bottom: var(--sp-5); }

/* Section divider, sprout ornament on a dark seam */
.leaf-divider { background: var(--c-brand-deep); padding-block: var(--sp-4); }
.leaf-divider .ld-inner { max-width: var(--w-content); margin-inline: auto; padding-inline: var(--gutter); display: flex; align-items: center; gap: var(--sp-4); }
.leaf-divider .ld-inner::before, .leaf-divider .ld-inner::after { content: ""; flex: 1; height: 1px; background: rgba(250,215,154,.30); }
.leaf-divider svg { flex: none; width: 26px; height: 26px; color: var(--c-accent-soft); }

/* Offer-led panel */
.offer-panel { background: var(--c-accent-tint); padding-block: clamp(2.75rem, 2rem + 3vw, 4.5rem); }
.offer-panel .wrap { text-align: center; }
.op-inner { max-width: 640px; margin-inline: auto; }
.op-eyebrow { display: inline-block; font-size: 0.74rem; font-weight: var(--fw-bold); letter-spacing: var(--ls-label); text-transform: uppercase; color: var(--c-warm); margin-bottom: var(--sp-3); }
.op-big { font-family: var(--font-display); font-weight: var(--fw-display-hi); color: var(--c-brand-deep); font-size: clamp(2rem, 1.5rem + 2vw, 2.9rem); line-height: var(--lh-tight); letter-spacing: var(--ls-heading); margin-bottom: var(--sp-2); }
.op-big em { font-style: normal; color: var(--c-accent-strong); }
.op-sub { color: var(--c-muted); font-size: 1.05rem; margin-bottom: var(--sp-6); }

/* Reviews */
.promise-panel { background: var(--c-accent-tint); border-radius: var(--r-lg); box-shadow: var(--sh-sm); padding: var(--sp-7) var(--sp-6); max-width: var(--w-narrow); margin-inline: auto; }
.promise-panel h3 { color: var(--c-brand-deep); margin-bottom: var(--sp-3); }
.promise-panel p { color: var(--c-ink); margin-bottom: var(--sp-4); }
.promise-panel .stars { color: var(--c-accent-strong); font-size: 1.4rem; letter-spacing: 2px; display: block; margin-bottom: var(--sp-3); }
.promise-guarantee { font-weight: var(--fw-semibold); }
.review-grid { margin-top: var(--sp-5); }
.review-card { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--r-lg); padding: var(--sp-6); box-shadow: var(--sh-sm); }
.review-card .qmark { font-family: var(--font-display); font-size: 2.4rem; color: var(--c-accent); line-height: 0.8; }
.review-card blockquote { font-size: var(--fs-md); color: var(--c-ink); margin: var(--sp-2) 0 var(--sp-4); }
.review-card .stars { color: var(--c-accent-strong); letter-spacing: 2px; }
.review-card figcaption { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); margin-top: var(--sp-3); }
.review-card cite { font-style: normal; font-size: var(--fs-sm); text-transform: uppercase; letter-spacing: var(--ls-label-sm); color: var(--c-muted); }
.review-card .src-tag { font-size: var(--fs-xs); font-weight: var(--fw-semibold); color: var(--c-brand-deep); background: var(--c-brand-tint); border-radius: var(--r-pill); padding: var(--sp-1) var(--sp-3); }
.rating-badge { display: inline-flex; align-items: center; gap: var(--sp-2); background: var(--c-accent-tint); color: var(--c-brand-deep); border-radius: var(--r-pill); padding: var(--sp-2) var(--sp-5); font-weight: var(--fw-semibold); margin: 0 auto var(--sp-5); }
.rating-badge .stars { color: var(--c-accent-strong); letter-spacing: 1px; }
.holding-note { background: var(--c-accent-tint); border-radius: var(--r-lg); padding: var(--sp-6); color: var(--c-ink); }

/* Guarantee callout */
.guarantee { background: var(--c-accent-tint); color: var(--c-on-accent); border-radius: var(--r-lg); padding: var(--sp-5) var(--sp-6); max-width: var(--w-narrow); margin: var(--sp-6) auto 0; font-weight: var(--fw-medium); }

/* FAQ accordion */
.faq { max-width: var(--w-text); margin-inline: auto; }
.faq-item { border-bottom: 1px solid var(--c-line); }
.faq-q { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: var(--sp-4); text-align: left; background: none; border: 0; cursor: pointer; padding: var(--sp-5) 0; font-family: var(--font-body); font-size: var(--fs-md); font-weight: var(--fw-semibold); color: var(--c-ink); }
.faq-q .chev { flex: none; color: var(--c-accent-strong); transition: transform var(--dur-base) var(--ease-soft); }
.faq-q[aria-expanded="true"] .chev { transform: rotate(180deg); }
.faq-a { display: grid; grid-template-rows: 0fr; visibility: hidden; transition: grid-template-rows var(--dur-base) var(--ease-soft), visibility var(--dur-base) var(--ease-soft); }
.faq-q[aria-expanded="true"] + .faq-a { grid-template-rows: 1fr; visibility: visible; }
.faq-a > div { overflow: hidden; }
.faq-a p { color: var(--c-muted); padding-bottom: var(--sp-5); }

/* Forms */
.field { margin-bottom: var(--sp-4); }
.field label { display: block; font-weight: var(--fw-medium); font-size: var(--fs-sm); margin-bottom: var(--sp-2); color: var(--c-ink); }
.field .helper { font-size: var(--fs-sm); color: var(--c-muted); margin-top: var(--sp-2); }
.input, .select, .textarea { width: 100%; font-family: var(--font-body); font-size: var(--fs-base); color: var(--c-ink); background: var(--c-surface-2); border: 1px solid var(--c-line-strong); border-radius: var(--r-md); padding: var(--sp-3) var(--sp-4); min-height: 48px; transition: border-color var(--dur-fast), box-shadow var(--dur-fast); }
.textarea { min-height: 110px; resize: vertical; }
.input:focus, .select:focus, .textarea:focus { outline: none; border-color: var(--c-brand-bright); box-shadow: var(--focus-ring); }
.field.has-error .input, .field.has-error .select, .field.has-error .textarea { border-color: var(--c-error); background: var(--c-error-bg); }
.field-error { color: var(--c-error); font-size: var(--fs-sm); margin-top: var(--sp-2); display: none; }
.field.has-error .field-error { display: block; }
.hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

/* Modal + bottom sheet */
.modal-backdrop { position: fixed; inset: 0; background: rgba(30,88,54,.45); backdrop-filter: blur(3px); z-index: var(--z-overlay); opacity: 0; visibility: hidden; transition: opacity var(--dur-base), visibility var(--dur-base); }
.modal-backdrop.is-open { opacity: 1; visibility: visible; }
.modal { position: fixed; inset: 0; z-index: var(--z-modal); display: grid; place-items: center; padding: var(--gutter); pointer-events: none; }
.modal-panel { pointer-events: auto; position: relative; display: flex; flex-direction: column; background: var(--c-surface); border-radius: var(--r-lg); box-shadow: var(--sh-xl); width: 100%; max-width: var(--w-modal); max-height: none; overflow: visible; opacity: 0; transform: translateY(16px) scale(.96); transition: opacity var(--dur-slow) var(--ease-emph), transform var(--dur-slow) var(--ease-emph); }
.modal.is-open .modal-panel { opacity: 1; transform: none; }
.modal[hidden] { display: none; }
.modal-head { padding: var(--sp-5) var(--sp-6) var(--sp-3); flex: none; }
.modal-body { padding: var(--sp-2) var(--sp-6) var(--sp-5); overflow: visible; flex: 1 1 auto; }
.modal-foot { padding: var(--sp-4) var(--sp-6); padding-bottom: max(var(--sp-4), env(safe-area-inset-bottom)); flex: none; border-top: 1px solid var(--c-line); background: var(--c-surface); display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-2) var(--sp-3); }
.modal-foot .btn { flex: 1 1 auto; }
.modal-foot .btn--secondary { flex: 0 0 auto; }
.modal-close { position: absolute; top: var(--sp-3); right: var(--sp-3); width: 44px; height: 44px; border: 0; background: var(--c-surface-2); font-size: 1.5rem; line-height: 1; color: var(--c-muted); cursor: pointer; border-radius: var(--r-pill); z-index: 2; }
.modal-close:hover { background: var(--c-brand-tint); color: var(--c-ink); }
.modal-head h3 { margin-bottom: var(--sp-1); color: var(--c-brand-deep); }
.modal .reassure { color: var(--c-muted); font-size: var(--fs-sm); }
.modal-head .reassure { margin-bottom: var(--sp-3); }
.modal-head .pill { margin-bottom: var(--sp-2); }
.modal .or-call { flex: 1 1 100%; text-align: center; margin-top: 0; font-size: var(--fs-sm); color: var(--c-muted); }
.modal-success { padding: var(--sp-7) var(--sp-6); text-align: center; }
.modal-success .tick { width: 56px; height: 56px; border-radius: var(--r-pill); background: var(--c-success-bg); color: var(--c-success); display: grid; place-items: center; margin: 0 auto var(--sp-4); }
.modal-success h3 { color: var(--c-brand-deep); margin-bottom: var(--sp-2); }
.consent { font-size: var(--fs-sm); color: var(--c-muted); margin: var(--sp-3) 0; }

@media (min-width: 561px) {
  .modal { overflow-y: auto; padding-block: var(--sp-6); }
  .modal-panel { max-height: calc(100dvh - var(--sp-7)); overflow: auto; }
}

@media (max-width: 560px) {
  .modal { padding: 0; place-items: end stretch; overflow: hidden; }
  .modal-panel { max-width: 100%; max-height: 92dvh; border-radius: var(--r-lg) var(--r-lg) 0 0; transform: translateY(100%); overflow-y: auto; -webkit-overflow-scrolling: touch; overscroll-behavior: contain; }
  .modal.is-open .modal-panel { transform: none; }
  .modal-body { overflow: visible; }
  .modal-foot { position: sticky; bottom: 0; }
}

/* Booking wizard */
.wizard { max-width: var(--w-narrow); margin-inline: auto; }
.wizard.modal-panel, #booking .modal-panel { max-width: var(--w-modal); }
.progress { display: flex; align-items: center; gap: var(--sp-1); margin: var(--sp-2) 0 var(--sp-1); }
.progress .dot { flex: 1; height: 4px; border-radius: var(--r-pill); background: var(--c-line-strong); transition: background var(--dur-base); }
.progress .dot.is-done, .progress .dot.is-active { background: var(--c-accent); }
.progress-label { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-label-sm); color: var(--c-muted); margin: var(--sp-2) 0 0; }
.step { display: none; border: 0; padding: var(--sp-3) 0; }
.step.is-active { display: block; }
.step-title { font-family: var(--font-display); font-size: var(--fs-h3); font-weight: var(--fw-display); color: var(--c-brand-deep); margin-bottom: var(--sp-1); }
.step .reassure { color: var(--c-muted); font-size: var(--fs-sm); margin-bottom: var(--sp-4); }
.choice-grid { display: grid; gap: var(--sp-2); grid-template-columns: 1fr 1fr; margin-bottom: var(--sp-4); }
.choice { position: relative; }
.choice input { position: absolute; opacity: 0; }
.choice label { display: flex; align-items: center; justify-content: center; text-align: center; height: 100%; min-height: 48px; background: var(--c-surface); border: 1.5px solid var(--c-line-strong); border-radius: var(--r-sm); padding: var(--sp-3); cursor: pointer; font-size: var(--fs-sm); font-weight: var(--fw-semibold); line-height: 1.2; transition: border-color var(--dur-fast), background var(--dur-fast); }
.choice input:checked + label { border-color: var(--c-brand); background: var(--c-brand-tint); }
.choice input:focus-visible + label { box-shadow: var(--focus-ring); }
@media (min-width: 480px) { .choice-grid { grid-template-columns: 1fr 1fr 1fr; } }
.choice-grid--multi .choice input:checked + label { padding-left: var(--sp-5); }
.choice-grid--multi .choice input:checked + label::before { content: ""; position: absolute; left: var(--sp-3); top: 50%; width: 14px; height: 8px; margin-top: -6px; border-left: 2px solid var(--c-brand); border-bottom: 2px solid var(--c-brand); transform: rotate(-45deg); }
.choice-grid--multi .choice label { position: relative; }
.choice--svc label { flex-direction: column; gap: var(--sp-2); min-height: 88px; padding-block: var(--sp-4); }
.choice-ico { display: grid; place-items: center; color: var(--c-brand); }
.choice-ico svg { width: 28px; height: 28px; }
.choice--svc input:checked + label .choice-ico { color: var(--c-brand-deep); }
.choice-grid--multi .choice--svc input:checked + label { padding-left: var(--sp-3); }
.choice-grid--multi .choice--svc input:checked + label::before { left: auto; right: var(--sp-3); top: var(--sp-3); margin-top: 0; }
.svc-badge { display: grid; place-items: center; width: 56px; height: 56px; border-radius: var(--r-pill); background: var(--c-brand-tint); color: var(--c-brand); margin-bottom: var(--sp-4); }
.svc-badge svg { width: 30px; height: 30px; }
.flex-choice { display: flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--c-ink); cursor: pointer; }
.flex-choice input { width: 20px; height: 20px; accent-color: var(--c-brand); cursor: pointer; }
.wizard-nav .btn[hidden] { display: none; }

/* Sticky mobile bar */
.sticky-bar { position: fixed; left: 0; right: 0; bottom: 0; z-index: var(--z-sticky-bar); display: grid; grid-template-columns: 1fr 1.3fr; gap: var(--sp-3); padding: var(--sp-3) var(--gutter); padding-bottom: max(var(--sp-3), env(safe-area-inset-bottom)); background: var(--c-paper); border-top: 1px solid var(--c-line); box-shadow: 0 -4px 20px rgba(30,88,54,.10); transform: translateY(110%); transition: transform var(--dur-slow) var(--ease-out); }
.sticky-bar.is-shown { transform: none; }
.sticky-bar .btn { min-height: 52px; }
@media (min-width: 860px) { .sticky-bar { display: none; } }

/* Toast */
.toast { position: fixed; top: var(--sp-5); right: var(--sp-5); left: var(--sp-5); z-index: var(--z-toast); background: var(--c-brand-deep); color: var(--c-on-dark); padding: var(--sp-4) var(--sp-5); border-radius: var(--r-md); box-shadow: var(--sh-lg); opacity: 0; transform: translateY(-12px); transition: opacity var(--dur-base), transform var(--dur-base); }
.toast.is-shown { opacity: 1; transform: none; }

/* Cookie consent */
.cookie-bar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 80; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: var(--sp-3) var(--sp-5); padding: var(--sp-4) var(--gutter); padding-bottom: max(var(--sp-4), env(safe-area-inset-bottom)); background: var(--c-paper); border-top: 1px solid var(--c-line); box-shadow: 0 -4px 20px rgba(30,88,54,.10); transform: translateY(110%); transition: transform var(--dur-slow) var(--ease-out); }
.cookie-bar.is-shown { transform: none; }
.cookie-txt { margin: 0; font-size: var(--fs-sm); color: var(--c-ink); max-width: 60ch; }
.cookie-txt a { color: var(--c-brand-deep); text-decoration: underline; text-underline-offset: 2px; }
.cookie-btns { display: flex; gap: var(--sp-3); flex: none; }

/* Footer */
.site-footer { background: var(--c-brand-deep); color: var(--c-on-dark); padding-block: var(--sp-8) var(--sp-6); margin-bottom: 80px; }
.footer-grid { display: grid; gap: var(--sp-6); grid-template-columns: 1fr; }
.footer-brand .brand { margin-bottom: var(--sp-3); }
.footer-brand .brand-logo { height: 40px; background: var(--c-surface); border-radius: var(--r-md); padding: var(--sp-1) var(--sp-2); }
.footer-brand p { color: var(--c-on-dark-soft); font-size: var(--fs-sm); }
.footer-area { color: var(--c-on-dark-soft); font-size: var(--fs-sm); margin-top: var(--sp-3); }
.footer-col h4 { color: var(--c-on-dark); font-size: var(--fs-sm); text-transform: uppercase; letter-spacing: var(--ls-label-sm); margin-bottom: var(--sp-4); }
.footer-col ul { display: grid; gap: var(--sp-2); }
.footer-col a, .footer-col li { color: var(--c-on-dark-soft); font-size: var(--fs-sm); }
.footer-col a:hover { color: var(--c-surface); }
.footer-phone { font-family: var(--font-display); font-size: 1.4rem; color: var(--c-surface); display: inline-block; margin-bottom: var(--sp-2); }
.footer-bottom { border-top: 1px solid var(--c-line-on-dark); margin-top: var(--sp-7); padding-top: var(--sp-5); font-size: var(--fs-sm); color: var(--c-on-dark-soft); display: flex; flex-wrap: wrap; gap: var(--sp-3); justify-content: space-between; }
.footer-bottom a { color: var(--c-on-dark-soft); text-decoration: underline; text-underline-offset: 2px; }
.footer-bottom a:hover { color: var(--c-surface); }
@media (min-width: 860px) { .site-footer { margin-bottom: 0; } }

/* Service page */
.svc-hero { background: linear-gradient(170deg, var(--c-brand-wash), var(--c-paper)); padding-block: var(--section-y); }
.svc-lead { margin-top: var(--sp-7); border-radius: var(--r-xl); overflow: hidden; box-shadow: var(--sh-lg); }
.svc-layout { display: grid; gap: var(--sp-7); }
.incl-list { display: grid; gap: var(--sp-3); }
.incl-list li { display: flex; gap: var(--sp-3); align-items: flex-start; color: var(--c-muted); }
.incl-list svg { flex: none; width: 20px; height: 20px; color: var(--c-brand); margin-top: 2px; }
.quote-card { background: var(--c-surface); border: 1px solid var(--c-line); border-top: var(--bw-accent) solid var(--c-accent); border-radius: var(--r-lg); box-shadow: var(--sh-md); padding: var(--sp-6); }
.quote-card .price-from { font-family: var(--font-display); font-size: var(--fs-h3); font-weight: var(--fw-display); color: var(--c-brand-deep); margin-bottom: var(--sp-2); }
.quote-card .cta-row { flex-direction: column; }
.quote-card .btn { width: 100%; }
.related-grid { display: grid; gap: var(--sp-4); grid-template-columns: 1fr; }

/* Blog */
.post { padding-block: var(--section-y); }
.post-body { max-width: var(--w-text); margin-inline: auto; }
.post-body p { margin-bottom: var(--sp-5); line-height: var(--lh-loose); }
.post-body h2 { font-size: var(--fs-h3); margin: var(--sp-6) 0 var(--sp-3); color: var(--c-brand-deep); }
.post-body ul.dash { margin: 0 0 var(--sp-5) var(--sp-5); list-style: disc; color: var(--c-muted); }
.post-body ul.dash li { margin-bottom: var(--sp-2); }
.post-meta { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-label-sm); color: var(--c-faint); margin-bottom: var(--sp-5); }
.post-cta { background: var(--c-accent-tint); border-radius: var(--r-lg); padding: var(--sp-6); margin-top: var(--sp-7); text-align: center; }
.blog-card { display: block; background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-sm); color: inherit; transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out); }
.blog-card:hover { transform: translateY(-4px); box-shadow: var(--sh-hover); }
.blog-card .img-slot { aspect-ratio: 16/9; }
.blog-card img { display: block; width: 100%; height: auto; aspect-ratio: 16/9; object-fit: cover; }
.post-hero { display: block; width: 100%; height: auto; border-radius: var(--r-xl); margin-bottom: 2rem; }
.blog-card .body { padding: var(--sp-5); }
.blog-card h3 { font-size: var(--fs-h4); font-family: var(--font-display); margin-bottom: var(--sp-2); color: var(--c-brand-deep); }
.blog-card p { color: var(--c-muted); font-size: var(--fs-sm); }

/* Responsive up */
@media (min-width: 600px) {
  .grid--2 { grid-template-columns: 1fr 1fr; }
  .related-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1.6fr 1fr 1.2fr; }
}
@media (min-width: 860px) {
  .nav-links { display: flex; }
  .nav-book { display: inline-flex; }
  .nav-call { display: inline-flex; }
  .nav-actions { margin-left: var(--sp-6); }
  .nav-toggle { display: none; }
  .grid--3 { grid-template-columns: repeat(3,1fr); }
  .svc-layout { grid-template-columns: 1fr 360px; align-items: start; }
  .svc-aside { position: sticky; top: 92px; }
}
