/* Charlesworth Woodyard — heritage craft
   Mobile-first responsive system.
   Base styles = mobile (<720px). Tablet/desktop layered via min-width queries. */

:root {
  --c-primary: #1f3d2a;
  --c-cream: #f5f0e6;
  --c-ink: #1a1814;
  --c-line: rgba(26,24,20,.12);
  --c-soft: rgba(26,24,20,.55);
  --c-faint: rgba(26,24,20,.04);
  --c-gold: #c9a96a;
  --wrap: 1320px;
  --pad-x: 20px;
  --serif: "Newsreader", "Cormorant Garamond", Georgia, serif;
  --sans: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--c-cream);
  color: var(--c-ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }
h1, h2, h3, h4, p, ul, dl, dd, figure, blockquote { margin: 0; padding: 0; }
ul { list-style: none; }
em { font-style: italic; }

/* iOS Safari auto-zooms inputs below 16px */
input, textarea, select { font-size: max(16px, 1rem); }

.wrap {
  max-width: var(--wrap);
  margin: 0 auto;
  padding-left: var(--pad-x);
  padding-right: var(--pad-x);
}

.section { padding: 64px 0; }

.mono {
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--c-soft);
}

.eyebrow {
  display: inline-block;
  font-size: 12px;
  margin-bottom: 24px;
  color: var(--c-primary);
}

.display, .h-display {
  font-family: var(--serif);
  font-weight: 400;
  letter-spacing: -.015em;
  line-height: 1.06;
  color: var(--c-ink);
  text-wrap: balance;
}
.display    { font-size: clamp(40px, 6.5vw, 88px); line-height: 1.04; }
.h-display  { font-size: clamp(32px, 5vw, 60px); line-height: 1.06; }
.display em, .h-display em {
  font-style: italic;
  color: var(--c-primary);
  font-feature-settings: "ss01";
}

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 22px;
  border-radius: 999px;
  font-family: var(--sans);
  font-weight: 500;
  font-size: 14px;
  line-height: 1;
  border: 1px solid transparent;
  transition: transform .15s ease, background .15s ease, color .15s ease;
  cursor: pointer;
  white-space: nowrap;
  min-height: 44px;
}
.btn-lg { padding: 18px 30px; font-size: 15px; min-height: 52px; }
.btn-primary { background: var(--c-primary); color: var(--c-cream); }
.btn-primary:hover { transform: translateY(-1px); }
.btn-ghost { color: var(--c-ink); border-color: var(--c-line); background: transparent; }
.btn-ghost:hover { background: rgba(26,24,20,.04); }
.btn-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: currentColor; opacity: .85;
  box-shadow: 0 0 0 3px rgba(255,255,255,.12);
}

/* ── Top bar (mobile = phone only) ───────────────────────────────────────── */
.topbar {
  background: var(--c-primary);
  color: var(--c-cream);
  padding-left: max(env(safe-area-inset-left), 0px);
  padding-right: max(env(safe-area-inset-right), 0px);
}
.topbar .mono { color: rgba(245,240,230,.78); }
.topbar-inner {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 16px;
  padding: 10px 20px;
  font-size: 11px;
  white-space: nowrap;
}
/* Mobile: hide est. + hours, show only phone */
.topbar > .wrap > .topbar-inner > span { display: none; }
.topbar .link {
  padding: 6px 4px;
  min-height: 32px;
  display: inline-flex; align-items: center;
}
.topbar .link:hover { color: #fff; }

/* ── Nav (mobile = hamburger, desktop = inline links) ────────────────────── */
.nav {
  border-bottom: 1px solid var(--c-line);
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in oklab, var(--c-cream) 92%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 20px;
}
.brand {
  display: flex; align-items: center; gap: 12px;
  color: var(--c-primary);
  min-width: 0;
}
.brand-text { display: flex; flex-direction: column; line-height: 1; min-width: 0; }
.brand-name {
  font-family: var(--serif);
  font-size: clamp(20px, 4vw, 24px);
  letter-spacing: -.01em;
  color: var(--c-ink);
}
.brand-sub { font-size: 10px; margin-top: 4px; color: var(--c-soft); }

/* Mobile: hide inline links + nav-cta, show hamburger */
.nav-links { display: none; }
.nav-cta { display: none; }
.nav-mobile-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border: 1px solid var(--c-line);
  border-radius: 999px;
  background: transparent;
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--c-ink);
  cursor: pointer;
  min-height: 44px;
}
.nav-mobile-toggle .bars { display: inline-flex; flex-direction: column; gap: 3px; }
.nav-mobile-toggle .bars span {
  width: 16px; height: 1.5px; background: currentColor;
  transition: transform .2s ease, opacity .2s ease;
}
.nav.is-menu-open .nav-mobile-toggle .bars span:nth-child(1) { transform: translateY(4.5px) rotate(45deg); }
.nav.is-menu-open .nav-mobile-toggle .bars span:nth-child(2) { opacity: 0; }
.nav.is-menu-open .nav-mobile-toggle .bars span:nth-child(3) { transform: translateY(-4.5px) rotate(-45deg); }

.nav-mobile-panel {
  display: none;
  flex-direction: column;
  border-top: 1px solid var(--c-line);
  padding: 8px 20px 24px;
  background: var(--c-cream);
}
.nav.is-menu-open .nav-mobile-panel { display: flex; }
.nav-mobile-panel a {
  padding: 18px 0;
  font-family: var(--serif);
  font-size: 28px;
  color: var(--c-ink);
  border-bottom: 1px solid var(--c-line);
  display: flex; justify-content: space-between; align-items: center;
  min-height: 44px;
}
.nav-mobile-panel a:last-child { border-bottom: 0; }
.nav-mobile-panel a span { font-family: var(--sans); font-size: 18px; color: var(--c-soft); }
.nav-mobile-panel a.is-active { color: var(--c-primary); }

/* ── Page hero (inner pages) ─────────────────────────────────────────────── */
.page-hero {
  padding: 40px 0 28px;
  border-bottom: 1px solid var(--c-line);
}
.page-hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  align-items: end;
}
.page-hero-text { padding-bottom: 0; }
.page-crumb {
  display: inline-flex;
  align-items: center;
  margin-bottom: 24px;
  padding: 6px 0;
  color: var(--c-soft);
  font-size: 11px;
  transition: color .15s ease;
  min-height: 32px;
}
.page-crumb:hover { color: var(--c-primary); }
.page-hero-title {
  font-size: clamp(40px, 8vw, 96px);
  line-height: 1.08;
  margin-bottom: 24px;
  letter-spacing: -.02em;
}
.page-hero-title em { color: var(--c-primary); }
.page-hero-lede {
  font-size: clamp(16px, 2vw, 19px);
  line-height: 1.5;
  color: rgba(26,24,20,.72);
  max-width: 52ch;
}
.page-hero-photo {
  height: clamp(240px, 50vw, 460px);
  align-self: stretch;
}

/* ── Photo wrapper ──────────────────────────────────────────────────────── */
.photo {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: #d9cdb6;
  border-radius: 2px;
}
.photo svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.photo img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.photo-tag {
  position: absolute;
  left: 14px; bottom: 14px;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 12px;
  background: rgba(26,24,20,.78);
  color: rgba(245,240,230,.92);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .06em;
  text-transform: uppercase;
  border-radius: 999px;
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
}
.photo-tag i {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--c-gold);
  display: inline-block;
}

/* ── Hero full (homepage) ────────────────────────────────────────────────── */
.hero-full {
  position: relative;
  isolation: isolate;
  overflow: clip;          /* contains content overflow without breaking sticky */
}
.hero-full .hero-photo {
  border-radius: 0;
  min-height: 480px;
  height: 75vh;
  height: 75svh;
  max-height: 720px;
}
.hero-full .hero-photo .photo-tag { left: auto; right: 16px; bottom: 16px; }
.hero-overlay {
  position: absolute;
  left: 0; right: 0; top: 0; bottom: 0;
  background:
    linear-gradient(180deg, rgba(26,24,20,.0) 20%, rgba(26,24,20,.55) 65%, rgba(26,24,20,.85) 100%),
    linear-gradient(90deg, rgba(26,24,20,.5) 0%, rgba(26,24,20,0) 65%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding-top: 32px;
  padding-bottom: 32px;
  overflow: hidden;        /* if content is too tall for a short viewport, crop bottom not top */
}
.hero-content { color: var(--c-cream); max-width: 920px; }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  margin-bottom: 20px;
  color: rgba(255,255,255,.86);
  border: 1px solid rgba(255,255,255,.28);
  padding: 8px 14px; border-radius: 999px;
  font-size: 10.5px;
}
.hero-eyebrow span:first-child { color: rgba(255,255,255,.7); }
.hero-full .display,
.hero-full .display em { color: #ffffff !important; }
.hero-lede {
  margin-top: 20px;
  max-width: 620px;
  font-size: clamp(15px, 2vw, 17px);
  line-height: 1.55;
  color: rgba(255,255,255,.86);
}
.hero-cta {
  margin-top: 28px;
  display: flex; gap: 12px; flex-wrap: wrap;
}
.hero-full .btn-ghost {
  color: var(--c-cream);
  border-color: rgba(245,240,230,.32);
}
.hero-full .btn-ghost:hover { background: rgba(245,240,230,.08); }

/* Hero meta — mobile: flows as a band BELOW the photo (fork decision)
   Desktop: re-pinned to absolute over the photo via @media block. */
.hero-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  background: var(--c-ink);
  color: rgba(245,240,230,.92);
  max-width: none;
  margin: 0;
  padding: 0;
}
.meta-col {
  padding: 16px 20px;
  display: flex; align-items: baseline; gap: 12px;
  color: rgba(245,240,230,.92);
  font-size: 13px;
  border-right: 1px solid rgba(245,240,230,.12);
  border-top: 1px solid rgba(245,240,230,.12);
}
.meta-col:nth-child(odd) { border-right: 1px solid rgba(245,240,230,.12); }
.meta-col:nth-child(even) { border-right: 0; }
.meta-col:nth-child(-n+2) { border-top: 0; }
.meta-col .mono { color: rgba(255,255,255,.7); font-size: 11px; }

/* ── Marquee ─────────────────────────────────────────────────────────────── */
.marquee {
  background: var(--c-ink);
  color: var(--c-cream);
  overflow: hidden;
  padding: 14px 0;
  border-block: 1px solid rgba(245,240,230,.06);
}
.marquee-track {
  display: flex;
  gap: 36px;
  white-space: nowrap;
  animation: marquee 50s linear infinite;
}
.marquee-item {
  display: inline-flex; align-items: center; gap: 12px;
  color: rgba(245,240,230,.62);
  font-size: 11px;
}
.marquee-item span { color: var(--c-gold); }
@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .marquee-track { animation: none; }
}

/* ── Story ───────────────────────────────────────────────────────────────── */
.story { background: var(--c-cream); }
.story-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  align-items: center;
}
.story-photos {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 12px;
}
.story-photos > .photo:first-child { grid-column: 1 / span 2; }
.story-photo-b { grid-column: 1 / span 2; margin-left: 12%; }
.story-text p {
  margin-top: 20px;
  font-size: clamp(15px, 2vw, 17px);
  line-height: 1.65;
  color: rgba(26,24,20,.78);
  max-width: 56ch;
}
.ring-card {
  margin-top: 32px;
  display: flex; align-items: center; gap: 18px;
  padding: 20px 22px;
  background: var(--c-primary);
  color: var(--c-cream);
  border-radius: 4px;
  flex-wrap: wrap;
}
.ring-label { color: var(--c-gold); }
.ring-line {
  margin-top: 6px;
  font-family: var(--serif);
  font-size: clamp(18px, 2.4vw, 22px);
  line-height: 1.3;
  max-width: 38ch;
}

/* ── Section heads ──────────────────────────────────────────────────────── */
.section-head { max-width: 720px; margin-bottom: 40px; }
.section-head-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: end;
  max-width: none;
}
.section-lede {
  margin-top: 16px;
  font-size: clamp(15px, 2vw, 17px);
  color: rgba(26,24,20,.72);
  max-width: 56ch;
}

/* ── Inline CTA link ─────────────────────────────────────────────────────── */
.cta-link {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-top: 40px;
  padding: 14px 0;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--c-primary);
  border-top: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
  align-self: flex-start;
  width: max-content;
  max-width: 100%;
  transition: gap .18s ease;
  min-height: 44px;
}
.cta-link span { font-family: var(--sans); font-size: 14px; }
.cta-link:hover { gap: 18px; }
.cta-link-light { color: #d8b574; border-color: rgba(245,240,230,.2); }
.cta-link-dark  { color: var(--c-primary); }

/* ── Services preview (homepage) ─────────────────────────────────────────── */
.services-preview { background: var(--c-cream); }
.sp-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: var(--c-line);
  border: 1px solid var(--c-line);
}
.sp-card {
  background: var(--c-cream);
  display: flex; flex-direction: column;
  transition: background .18s ease;
}
.sp-card:hover { background: rgba(255,255,255,.4); }
.sp-card .photo { border-radius: 0; aspect-ratio: 4/3; }
.sp-body {
  padding: 24px 20px;
  display: flex; flex-direction: column;
  gap: 6px;
  position: relative;
  flex: 1;
}
.sp-n { color: var(--c-primary); margin-bottom: 4px; }
.sp-title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(24px, 4vw, 30px);
  letter-spacing: -.01em;
  line-height: 1.05;
  color: var(--c-ink);
}
.sp-sub {
  font-size: 13.5px;
  color: var(--c-soft);
  margin-top: 4px;
}
.sp-arrow {
  position: absolute;
  right: 20px; bottom: 24px;
  font-size: 18px;
  color: var(--c-primary);
  transition: transform .18s ease;
}
.sp-card:hover .sp-arrow { transform: translateX(4px); }

/* ── Values grid (about) ────────────────────────────────────────────────── */
.values { background: var(--c-cream); border-top: 1px solid var(--c-line); }
.val-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: var(--c-line);
  border: 1px solid var(--c-line);
}
.val-card {
  background: var(--c-cream);
  padding: 32px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 200px;
}
.val-n { color: var(--c-primary); font-size: 12px; margin-bottom: 12px; }
.val-t {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(22px, 3.4vw, 30px);
  letter-spacing: -.01em;
  line-height: 1.15;
  color: var(--c-ink);
}
.val-d {
  font-size: 15px;
  line-height: 1.55;
  color: rgba(26,24,20,.72);
  max-width: 44ch;
}

/* ── Visit preview (home) ─────────────────────────────────────────────── */
.visit-preview { background: var(--c-cream); border-top: 1px solid var(--c-line); }
.vp-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  align-items: stretch;
}
.vp-text p {
  margin-top: 16px;
  font-size: clamp(15px, 2vw, 17px);
  color: rgba(26,24,20,.72);
  max-width: 48ch;
}
.vp-info {
  margin: 28px 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  padding-block: 24px;
  border-block: 1px solid var(--c-line);
}
.vp-info > div { display: flex; flex-direction: column; gap: 8px; }
.vp-big {
  font-family: var(--serif);
  font-size: clamp(24px, 5vw, 32px);
  color: var(--c-primary);
  letter-spacing: -.01em;
}
.vp-line { font-size: 15px; color: rgba(26,24,20,.78); }
.vp-map {
  position: relative;
  min-height: 320px;
  border: 1px solid var(--c-line);
  border-radius: 2px;
  overflow: hidden;
}

/* ── CTA band (bottom of inner pages) ──────────────────────────────────── */
.cta-band {
  background: var(--c-primary);
  color: var(--c-cream);
  padding: 56px 0;
}
.cta-band-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  align-items: center;
}
.cta-heading {
  color: var(--c-cream);
  font-size: clamp(28px, 5vw, 56px);
  line-height: 1.08;
}
.cta-lede {
  margin-top: 16px;
  font-size: clamp(15px, 2vw, 17px);
  color: rgba(245,240,230,.78);
  max-width: 48ch;
}
.cta-actions {
  display: flex; gap: 12px; flex-wrap: wrap;
  justify-content: flex-start;
}
.cta-band .btn-primary { background: var(--c-cream); color: var(--c-primary); }
.cta-band .btn-ghost {
  color: var(--c-cream);
  border-color: rgba(245,240,230,.32);
}
.cta-band .btn-ghost:hover { background: rgba(245,240,230,.08); }

/* ── Services (full) ───────────────────────────────────────────────────── */
.services { background: var(--c-cream); border-top: 1px solid var(--c-line); }
.svc-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: var(--c-line);
  border: 1px solid var(--c-line);
}
.svc-card {
  display: grid;
  grid-template-columns: 1fr;
  background: var(--c-cream);
  gap: 0;
}
.svc-card .photo { border-radius: 0; aspect-ratio: 4/3; min-height: 0; }
.svc-body {
  padding: 32px 24px;
  display: flex; flex-direction: column;
  gap: 16px;
}
.svc-head { display: flex; flex-direction: column; gap: 4px; }
.svc-n { color: var(--c-primary); }
.svc-title {
  font-family: var(--serif);
  font-size: clamp(28px, 5vw, 38px);
  font-weight: 400;
  letter-spacing: -.01em;
  color: var(--c-ink);
  margin-top: 4px;
  line-height: 1.1;
}
.svc-sub { font-size: 14px; color: var(--c-soft); margin-top: 2px; }
.svc-text {
  color: rgba(26,24,20,.78);
  font-size: 15px;
  line-height: 1.6;
}
.svc-points { display: flex; flex-direction: column; gap: 8px; }
.svc-points li {
  display: flex; align-items: baseline; gap: 12px;
  font-size: 14px;
  padding: 8px 0;
  border-top: 1px dashed var(--c-line);
}
.svc-points li:first-child { border-top: 0; padding-top: 0; }
.svc-points span { color: var(--c-primary); font-family: var(--mono); }
.svc-cta {
  margin-top: auto;
  font-size: 14px;
  color: var(--c-primary);
  font-weight: 500;
  align-self: flex-start;
  padding: 6px 0;
  border-bottom: 1px solid currentColor;
  min-height: 32px;
}

/* ── Products (timber) ─────────────────────────────────────────────────── */
.products { background: var(--c-ink); color: var(--c-cream); }
.products .h-display { color: var(--c-cream); }
.products .h-display em { color: #d8b574; }
.products .eyebrow { color: var(--c-gold); }
.products .section-lede { color: rgba(245,240,230,.7); }

.prod-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: rgba(245,240,230,.14);
  border: 1px solid rgba(245,240,230,.14);
}
.prod-card {
  background: var(--c-ink);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 240px;
  transition: background .18s ease;
  position: relative;
  overflow: hidden;
}
.prod-card:hover { background: #221e18; }
.prod-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.prod-kind {
  display: inline-flex; align-items: center; gap: 10px;
  color: rgba(245,240,230,.7);
  font-size: 10.5px;
}
.prod-swatch {
  width: 10px; height: 10px;
  border-radius: 50%;
  box-shadow: 0 0 0 1px rgba(245,240,230,.18);
}
.prod-n { color: rgba(245,240,230,.4); }
.prod-name {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(32px, 7vw, 44px);
  line-height: 1;
  letter-spacing: -.015em;
  color: var(--c-cream);
  margin-top: 6px;
}
.prod-body {
  color: rgba(245,240,230,.74);
  font-size: 14.5px;
  line-height: 1.55;
  max-width: 36ch;
}
.prod-cta {
  margin-top: auto;
  font-size: 13px;
  color: #d8b574;
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .06em;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.prod-cta .arrow { transition: transform .18s ease; font-family: var(--sans); }
.prod-card:hover .prod-cta .arrow { transform: translateX(4px); }

.prod-foot {
  margin-top: 28px;
  padding: 20px;
  border: 1px dashed rgba(245,240,230,.2);
  font-size: 14px;
  color: rgba(245,240,230,.7);
}
.prod-foot .mono { color: var(--c-gold); margin-right: 8px; }

/* ── Gallery (mobile = 2-col uniform per fork decision) ───────────────── */
.gallery { background: var(--c-cream); }
.gal-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  grid-auto-rows: auto;
}
.gal-grid .photo {
  border-radius: 0;
  aspect-ratio: 1 / 1;
  height: auto;
}
/* Reset desktop spans for mobile — every tile is 1×1 */
.g, .g1, .g2, .g3, .g4, .g5, .g6 {
  grid-column: span 1;
  grid-row: span 1;
}

/* ── Reviews ─────────────────────────────────────────────────────────────── */
.reviews { background: var(--c-cream); border-top: 1px solid var(--c-line); }
.rev-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
.rev {
  padding: 28px 24px;
  border: 1px solid var(--c-line);
  background: rgba(255,255,255,.4);
  border-radius: 2px;
  display: flex; flex-direction: column; gap: 18px;
}
.rev-stars { color: var(--c-gold); letter-spacing: 2px; font-size: 16px; }
.rev-text {
  font-family: var(--serif);
  font-size: clamp(18px, 2.6vw, 22px);
  line-height: 1.35;
  color: var(--c-ink);
}
.rev-cap {
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px dashed var(--c-line);
  display: flex; flex-direction: column; gap: 4px;
}
.rev-name { font-size: 14px; font-weight: 500; }
.rev-place { font-size: 10.5px; }

/* ── Visit / map ─────────────────────────────────────────────────────────── */
.visit { background: var(--c-cream); border-top: 1px solid var(--c-line); }
.visit-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  align-items: stretch;
}
.visit-text p {
  margin-top: 16px;
  font-size: clamp(15px, 2vw, 17px);
  color: rgba(26,24,20,.72);
  max-width: 50ch;
}
.visit-dl {
  margin: 32px 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  padding: 24px 0;
  border-block: 1px solid var(--c-line);
}
.visit-dl dt { color: var(--c-soft); margin-bottom: 8px; font-size: 10.5px; }
.visit-dl dd { font-size: 16px; line-height: 1.5; }
.visit-dl a { border-bottom: 1px solid var(--c-line); }
.visit-dl a:hover { border-color: var(--c-primary); }
.visit-actions { display: flex; gap: 12px; flex-wrap: wrap; }

.visit-map {
  position: relative;
  min-height: 340px;
  border: 1px solid var(--c-line);
  background: #ece4d2;
  border-radius: 2px;
  overflow: hidden;
}
.map-canvas { position: absolute; inset: 0; }
.map-canvas svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.map-pin {
  position: absolute;
  left: 56%; top: 60%;
  display: flex; align-items: center; gap: 12px;
  transform: translate(-50%, -50%);
}
.map-pin-dot {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--c-primary);
  box-shadow:
    0 0 0 6px rgba(31,61,42,.18),
    0 0 0 16px rgba(31,61,42,.08);
  animation: pulse 2.2s ease-out infinite;
}
@media (prefers-reduced-motion: reduce) {
  .map-pin-dot { animation: none; }
}
@keyframes pulse {
  0% { box-shadow: 0 0 0 6px rgba(31,61,42,.25), 0 0 0 8px rgba(31,61,42,.15); }
  100% { box-shadow: 0 0 0 22px rgba(31,61,42,0), 0 0 0 44px rgba(31,61,42,0); }
}
.map-pin-label {
  background: var(--c-cream);
  border: 1px solid var(--c-line);
  padding: 10px 14px;
  border-radius: 4px;
  display: flex; flex-direction: column; gap: 2px;
  box-shadow: 0 6px 24px rgba(26,24,20,.12);
  max-width: calc(100vw - 80px);
}
.map-pin-label strong {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 16px;
}

/* ── Footer ──────────────────────────────────────────────────────────────── */
.footer {
  background: var(--c-primary);
  color: var(--c-cream);
  padding: 56px 0 24px;
  padding-bottom: max(24px, env(safe-area-inset-bottom));
}
.footer-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  align-items: start;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(245,240,230,.14);
}
.footer-brand { display: flex; gap: 16px; align-items: center; flex-wrap: wrap; }
.footer-name { font-family: var(--serif); font-size: clamp(28px, 5vw, 36px); line-height: 1; }
.footer-sub { color: rgba(245,240,230,.55); margin-top: 6px; }
.footer-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
.footer-h {
  color: var(--c-gold);
  margin-bottom: 14px;
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.footer-cols a {
  display: block;
  padding: 8px 0;
  font-size: 14px;
  color: rgba(245,240,230,.78);
  transition: color .15s ease;
  min-height: 32px;
}
.footer-cols a:hover { color: var(--c-cream); }
.footer-bottom {
  margin-top: 20px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 8px 24px;
  color: rgba(245,240,230,.5);
  font-size: 10.5px;
}


/* ════════════════════════════════════════════════════════════════════════
   TABLET — 600px+
   Grids that benefit from 2 columns appear here.
   ════════════════════════════════════════════════════════════════════════ */
@media (min-width: 600px) {
  :root { --pad-x: 28px; }

  .section { padding: 80px 0; }
  .page-hero { padding: 56px 0 36px; }

  .sp-grid     { grid-template-columns: repeat(2, 1fr); }
  .val-grid    { grid-template-columns: repeat(2, 1fr); }
  .rev-grid    { grid-template-columns: repeat(2, 1fr); }
  .prod-grid,
  .prod-grid-3 { grid-template-columns: repeat(2, 1fr); }
  .visit-dl    { grid-template-columns: 1fr 1fr; }
  .vp-info     { grid-template-columns: 1fr 1fr; }
  .footer-cols { grid-template-columns: repeat(3, 1fr); }

  /* Topbar: show the est. + hours back */
  .topbar > .wrap > .topbar-inner > span { display: inline-flex; }
  .topbar-inner {
    justify-content: flex-start;
    gap: 20px;
    padding: 10px 28px;
  }
  .topbar .dot::before { content: "·"; margin-right: 12px; opacity: .5; }
  .topbar .link { margin-left: auto; }

  /* Gallery: stay 2-col but add a couple of tall feature tiles */
  .gal-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
  }
  .g1, .g4 { grid-column: span 2; grid-row: span 2; }
  .g2, .g5 { grid-column: span 2; grid-row: span 1; }
  .g3, .g6 { grid-column: span 1; grid-row: span 1; }
}


/* ════════════════════════════════════════════════════════════════════════
   NAV — 860px+
   Inline nav links return, hamburger hides.
   ════════════════════════════════════════════════════════════════════════ */
@media (min-width: 860px) {
  .nav-mobile-toggle { display: none; }
  .nav-links {
    display: flex;
    gap: 20px;
    font-size: 13.5px;
    color: var(--c-ink);
  }
  .nav-links a {
    position: relative;
    padding: 10px 0;
    opacity: .8;
    transition: opacity .15s ease;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
  }
  .nav-links a:hover { opacity: 1; }
  .nav-links a::after {
    content: "";
    position: absolute; left: 0; right: 0; bottom: 4px;
    height: 1px; background: var(--c-primary);
    transform: scaleX(0); transform-origin: left;
    transition: transform .2s ease;
  }
  .nav-links a:hover::after,
  .nav-links a.is-active::after { transform: scaleX(1); }
  .nav-links a.is-active { opacity: 1; }
  .nav-cta { display: inline-flex; }
}


/* ════════════════════════════════════════════════════════════════════════
   DESKTOP — 1100px+
   Full multi-column page layouts.
   ════════════════════════════════════════════════════════════════════════ */
@media (min-width: 1100px) {
  :root { --pad-x: 40px; }

  .section { padding: 120px 0; }
  .page-hero { padding: 80px 0 56px; }

  /* Multi-column grids restored */
  .sp-grid          { grid-template-columns: repeat(4, 1fr); }
  .prod-grid        { grid-template-columns: repeat(3, 1fr); }
  .prod-grid-3      { grid-template-columns: repeat(3, 1fr); }
  .rev-grid         { grid-template-columns: repeat(3, 1fr); }
  .svc-grid         { grid-template-columns: repeat(2, 1fr); }
  .svc-card         { grid-template-columns: 1fr 1.2fr; gap: 0; }
  .svc-card .photo  { aspect-ratio: auto; height: 100%; min-height: 360px; }
  .svc-body         { padding: 40px; gap: 18px; }

  .story-grid       { grid-template-columns: .9fr 1.1fr; gap: 96px; }
  .story-photos     { grid-template-columns: 1fr 1fr; gap: 16px; }
  .story-photo-b    { transform: translateY(-24px); margin-left: 18%; }

  .visit-grid       { grid-template-columns: 1fr 1.1fr; gap: 80px; }
  .visit-map        { min-height: 540px; }
  .vp-grid          { grid-template-columns: 1fr 1fr; gap: 64px; }
  .vp-map           { min-height: 420px; }

  .cta-band         { padding: 88px 0; }
  .cta-band-inner   { grid-template-columns: 1.2fr 1fr; gap: 64px; }
  .cta-actions      { justify-content: flex-end; }

  .section-head-row { grid-template-columns: 1fr 1fr; gap: 80px; }
  .section-head     { margin-bottom: 72px; }

  .page-hero-grid   { grid-template-columns: 1.05fr 1fr; gap: 64px; }
  .page-hero-photo  { height: 460px; }
  .page-hero-title  { margin-bottom: 36px; }

  .footer-inner     { grid-template-columns: 1fr 2fr; gap: 80px; padding-bottom: 64px; }
  .footer-cols      { grid-template-columns: repeat(3, 1fr); gap: 40px; }
  .footer          { padding: 80px 0 28px; }

  /* Hero: taller, with the meta strip pinned absolute over the photo */
  .hero-full .hero-photo {
    min-height: 640px;
    height: 80vh;
    height: 80svh;
    max-height: 880px;
  }
  .hero-overlay {
    padding-top: 56px;
    padding-bottom: 104px;       /* reserve space for the absolute meta strip below */
  }
  .hero-meta {
    position: absolute;
    left: 0; right: 0; bottom: 0;
    grid-template-columns: repeat(4, 1fr);
    background: rgba(26,24,20,.55);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    border-top: 1px solid rgba(245,240,230,.18);
    padding: 0;
    margin: 0;
    max-width: none;
  }
  .meta-col {
    padding: 20px clamp(20px, 2vw, 28px);
    border-top: 0;
    font-size: 14px;
    border-right: 1px solid rgba(245,240,230,.12);
  }
  .meta-col:nth-child(odd),
  .meta-col:nth-child(even) { border-right: 1px solid rgba(245,240,230,.12); border-top: 0; }
  .meta-col:last-child { border-right: 0; }

  /* Story photo "lift" only works with enough space */
  .story-photo-b { margin-left: 18%; }

  /* Gallery — restore the 12-col editorial mosaic */
  .gal-grid {
    grid-template-columns: repeat(12, 1fr);
    gap: 16px;
    grid-auto-rows: 120px;
  }
  .g1 { grid-column: span 4; grid-row: span 4; }
  .g2 { grid-column: span 5; grid-row: span 3; }
  .g3 { grid-column: span 3; grid-row: span 3; }
  .g4 { grid-column: span 4; grid-row: span 3; }
  .g5 { grid-column: span 5; grid-row: span 3; }
  .g6 { grid-column: span 3; grid-row: span 3; }
  .gal-grid .photo { aspect-ratio: auto; height: 100%; }
}
