/* squared-roots-farm-alsea · design-a · Opinionated Counsel × Hipcamp
   BODY ONLY — below the injected hero. All selectors scoped to [data-design="a"].
   MOTION GATE: only transform / opacity / clip-path / stroke-dashoffset animate.
   PERF-6: header is sticky with solid translucent background — NO backdrop-filter:blur.
   TRIAD-2: exactly ONE data-bl-feature on the handoff photo; body-life.js owns --bl-py.
   Windowed-center: EVERY content wrapper has max-width + margin-inline:auto. */

/* ── Token system (OC adapted for campground warmth) ───────────────────────── */
[data-design="a"] {
  /* Palette — paper canvas, near-black ink, sapphire stamp, one warm moss accent */
  --oc-canvas:     #F5F5F4;
  --oc-paper:      #FFFFFF;
  --oc-ink:        #171717;
  --oc-ink-2:      #3F3F3E;
  --oc-muted:      #7A7A78;
  --oc-rule:       #1A1A1A;
  --oc-soft:       #E5E4E1;
  --oc-stamp:      #1A47B8;
  --oc-stamp-deep: #102E78;
  --oc-stamp-on:   #FFFFFF;
  /* Hipcamp-specific warm accent — moss green for amenity bullets & labels */
  --oc-moss:       #3D6B3A;
  --oc-moss-on:    #FFFFFF;

  /* Typography */
  --oc-font-display: "Söhne Breit","Inter Display",-apple-system,BlinkMacSystemFont,"SF Pro Display",system-ui,sans-serif;
  --oc-font-body:    "Söhne","Inter",-apple-system,BlinkMacSystemFont,"SF Pro Text",system-ui,sans-serif;
  --oc-font-mono:    "JetBrains Mono","IBM Plex Mono",ui-monospace,Menlo,monospace;

  /* Spacing */
  --oc-space-hair:  2px;
  --oc-space-tick:  4px;
  --oc-space-bite:  8px;
  --oc-space-gap:   12px;
  --oc-space-stub:  16px;
  --oc-space-block: 24px;
  --oc-space-tile:  32px;
  --oc-space-bay:   48px;
  --oc-space-deck:  80px;
  --oc-space-yard:  128px;

  /* Motion */
  --oc-dur-snap:    120ms;
  --oc-dur-stamp:   220ms;
  --oc-dur-settle:  360ms;
  --oc-dur-breathe: 4400ms;
  --oc-dur-scrub:   22000ms;
  --oc-ease-decide: cubic-bezier(.22,.61,.36,1);
  --oc-ease-stamp:  cubic-bezier(.34,1.42,.64,1);
  --oc-ease-bite:   cubic-bezier(.55,.06,.68,.19);
  --oc-ease-scrub:  cubic-bezier(.65,.05,.35,.95);

  /* Radius */
  --oc-radius-0:     0;
  --oc-radius-sm:    4px;
  --oc-radius-md:    8px;
  --oc-radius-lg:    12px;
  --oc-radius-stamp: 2px;

  /* Elevation */
  --oc-elev-flat:  none;
  --oc-elev-rule:  inset 0 0 0 2px var(--oc-rule);
  --oc-elev-stamp: 0 4px 0 0 var(--oc-rule);

  background: var(--oc-canvas);
  color: var(--oc-ink);
  font-family: var(--oc-font-body);
  font-size: 17px;
  line-height: 1.6;
}

/* ── Windowed-center wrapper — EVERY content column centers here ── */
/* SELF-CHECK: each of these has max-width + margin-inline:auto */
[data-design="a"] .oc-place-story__inner,
[data-design="a"] .oc-facts__inner,
[data-design="a"] .oc-stays__inner,
[data-design="a"] .oc-gallery__inner,
[data-design="a"] .oc-nearby__inner,
[data-design="a"] .oc-host__inner,
[data-design="a"] .oc-closing__inner,
[data-design="a"] .oc-footer__inner,
[data-design="a"] .oc-header__bar,
[data-design="a"] .oc-drawer__bar,
[data-design="a"] .oc-drawer__nav {
  box-sizing: border-box;
  max-width: 1280px;
  margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
}

/* ── Screen-reader only utility ── */
[data-design="a"] .oc-sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ── Pointer — hero→body eye-handoff (PTR-3: exactly one, not a button) ──
   Sits at the seam; a pulsing chevron drawing the eye down into the place-story.
   opacity > 0.1 (gate: pointer_invisible); height ≥ 24px; z-index: 1 (never above hero). */
[data-design="a"] .oc-pointer {
  display: flex;
  justify-content: center;
  align-items: center;
  padding-block: var(--oc-space-block);
  background: var(--oc-canvas);
  /* not a button, not display:none — visible wayfinding element */
  z-index: 1;
  position: relative;
}
[data-design="a"] .oc-pointer__chevron {
  width: 28px;
  height: 28px;
  color: var(--oc-muted);
  opacity: 0.55;
  animation: oc-ptr-bob 1800ms var(--oc-ease-decide) infinite;
  will-change: transform;
}
@keyframes oc-ptr-bob {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(6px); }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .oc-pointer__chevron {
    animation: none;
    opacity: 0.55;
  }
}

/* ── Kicker chip (mono label) ── */
[data-design="a"] .oc-kicker {
  font-family: var(--oc-font-mono);
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--oc-muted);
  margin: 0 0 var(--oc-space-gap);
}

/* ── CTA Button — styled, never bare <a> (contract: zero class-less CTAs) ── */
[data-design="a"] .oc-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--oc-space-gap);
  font-family: var(--oc-font-display);
  font-weight: 800;
  font-size: clamp(16px, 1.5vw, 19px);
  letter-spacing: -0.015em;
  padding: 16px 26px;
  min-height: 52px;
  background: var(--oc-stamp);
  color: var(--oc-stamp-on);
  text-decoration: none;
  border-radius: var(--oc-radius-md);
  border: 2px solid var(--oc-rule);
  box-shadow: var(--oc-elev-stamp);
  transform: translateY(0);
  transition:
    transform var(--oc-dur-snap) var(--oc-ease-decide),
    box-shadow var(--oc-dur-snap) var(--oc-ease-decide),
    background var(--oc-dur-snap) var(--oc-ease-decide);
  animation: oc-cta-breath var(--oc-dur-breathe) var(--oc-ease-decide) infinite;
  cursor: pointer;
}
[data-design="a"] .oc-cta__arrow {
  display: inline-block;
  transition: transform var(--oc-dur-snap) var(--oc-ease-decide);
}
[data-design="a"] .oc-cta--large {
  font-size: clamp(17px, 1.8vw, 21px);
  padding: 20px 36px;
  min-height: 60px;
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .oc-cta:hover {
    background: var(--oc-stamp-deep);
    box-shadow: 0 6px 0 0 var(--oc-rule);
    transform: translateY(-2px);
    animation-play-state: paused;
  }
  [data-design="a"] .oc-cta:hover .oc-cta__arrow {
    transform: translateX(6px);
  }
}
[data-design="a"] .oc-cta:focus-visible {
  outline: none;
  background: var(--oc-stamp-deep);
  box-shadow: 0 6px 0 0 var(--oc-rule), 0 0 0 3px rgba(26,71,184,0.32);
  transform: translateY(-2px);
  animation-play-state: paused;
}
[data-design="a"] .oc-cta:focus-visible .oc-cta__arrow {
  transform: translateX(6px);
}
[data-design="a"] .oc-cta:active {
  transform: translateY(4px);
  box-shadow: 0 0 0 0 var(--oc-rule);
  transition-timing-function: var(--oc-ease-bite);
}
@keyframes oc-cta-breath {
  0%, 100% { box-shadow: var(--oc-elev-stamp), 0 0 0 0 rgba(26,71,184,0); }
  50%       { box-shadow: var(--oc-elev-stamp), 0 0 0 8px rgba(26,71,184,0.18); }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .oc-cta { animation: none; }
  [data-design="a"] .oc-cta__arrow { transition: none; }
}

/* ── Element 1: Header ── */
/* PERF-6 HARD: sticky header uses solid translucent bg — NO backdrop-filter:blur */
/* z-index capped at 20 — hero sits ABOVE body; no body element may overlap it */
[data-design="a"] .oc-header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(245,245,244,0.97); /* solid translucent — NOT blur */
  border-bottom: 2px solid var(--oc-rule);
}
[data-design="a"] .oc-header__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: var(--oc-space-stub);
  gap: var(--oc-space-stub);
}
[data-design="a"] .oc-logo {
  text-decoration: none;
  color: var(--oc-ink);
}
[data-design="a"] .oc-logo__mark {
  font-family: var(--oc-font-display);
  font-weight: 800;
  font-size: clamp(18px, 2.2vw, 24px);
  letter-spacing: -0.015em;
  line-height: 1;
}
[data-design="a"] .oc-hamburger {
  appearance: none;
  background: transparent;
  border: 2px solid var(--oc-rule);
  border-radius: var(--oc-radius-sm);
  padding: 10px 12px;
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  cursor: pointer;
  min-width: 44px;
  min-height: 44px;
  justify-content: center;
  align-items: center;
  transition:
    background var(--oc-dur-snap) var(--oc-ease-decide),
    transform var(--oc-dur-snap) var(--oc-ease-bite);
}
[data-design="a"] .oc-hamburger__bar {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--oc-ink);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .oc-hamburger:hover { background: var(--oc-soft); }
}
[data-design="a"] .oc-hamburger:active { transform: translateY(1px); }
[data-design="a"] .oc-hamburger[aria-expanded="true"] {
  background: var(--oc-ink);
  border-color: var(--oc-ink);
}
[data-design="a"] .oc-hamburger[aria-expanded="true"] .oc-hamburger__bar {
  background: var(--oc-canvas);
}

/* Header scrubber — slow 22s cycle, transform only, NOT on fixed/sticky layer itself */
[data-design="a"] .oc-scrubber {
  position: relative;
  height: 2px;
  background: var(--oc-soft);
  overflow: hidden;
}
[data-design="a"] .oc-scrubber__head {
  position: absolute;
  inset: 0 auto 0 0;
  width: 18%;
  background: linear-gradient(90deg, transparent 0%, var(--oc-ink) 22%, var(--oc-stamp) 60%, var(--oc-stamp) 78%, transparent 100%);
  animation: oc-header-scrub var(--oc-dur-scrub) var(--oc-ease-scrub) infinite;
  will-change: transform;
}
@keyframes oc-header-scrub {
  0%   { transform: translateX(-30%); }
  100% { transform: translateX(620%); }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .oc-scrubber__head { animation: none; transform: translateX(40%); }
}

/* Drawer — full-viewport overlay sliding down */
/* z-index: 30 — capped below hero; drawer is body-only UI */
[data-design="a"] .oc-drawer {
  position: fixed;
  inset: 0;
  background: var(--oc-canvas);
  z-index: 30;
  display: flex;
  flex-direction: column;
  transform: translateY(-100%);
  transition: transform var(--oc-dur-settle) var(--oc-ease-decide);
}
[data-design="a"] .oc-drawer[data-open="true"] { transform: translateY(0); }
[data-design="a"] .oc-drawer__bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-block: var(--oc-space-stub);
  border-bottom: 2px solid var(--oc-rule);
}
[data-design="a"] .oc-drawer__brand {
  font-family: var(--oc-font-display);
  font-weight: 800;
  font-size: 22px;
  letter-spacing: -0.015em;
  color: var(--oc-ink);
}
[data-design="a"] .oc-drawer__close {
  background: transparent;
  border: 0;
  font-size: 36px;
  line-height: 1;
  color: var(--oc-ink);
  cursor: pointer;
  padding: 0 8px;
  min-width: 44px;
  min-height: 44px;
}
[data-design="a"] .oc-drawer__nav {
  display: flex;
  flex-direction: column;
  padding-block: var(--oc-space-bay);
  gap: var(--oc-space-stub);
  box-sizing: border-box;
}
[data-design="a"] .oc-nav-link {
  font-family: var(--oc-font-display);
  font-weight: 800;
  font-size: clamp(32px, 6vw, 52px);
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--oc-ink);
  text-decoration: none;
  position: relative;
  padding-bottom: 6px;
  width: max-content;
  max-width: 100%;
}
[data-design="a"] .oc-nav-link::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  height: 4px; width: 100%;
  background: var(--oc-stamp);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--oc-dur-settle) var(--oc-ease-decide);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .oc-nav-link:hover { color: var(--oc-stamp); }
  [data-design="a"] .oc-nav-link:hover::after { transform: scaleX(1); }
}
[data-design="a"] .oc-nav-link:focus-visible { outline: none; color: var(--oc-stamp); }
[data-design="a"] .oc-nav-link:focus-visible::after { transform: scaleX(1); }
[data-design="a"] .oc-drawer__book {
  margin-top: var(--oc-space-block);
  width: max-content;
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .oc-drawer { transition: none; }
  [data-design="a"] .oc-nav-link::after { transition: none; }
}
@media (max-width: 560px) {
  [data-design="a"] .oc-header__bar { padding-block: 12px; }
}

/* ── Place Story ── */
[data-design="a"] .oc-place-story {
  padding-block: var(--oc-space-deck);
  border-bottom: 2px solid var(--oc-rule);
}
[data-design="a"] .oc-place-story__headline {
  font-family: var(--oc-font-display);
  font-weight: 800;
  font-size: clamp(32px, 5vw, 56px);
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--oc-ink);
  margin: var(--oc-space-gap) 0 var(--oc-space-block);
  max-width: 24ch;
}
[data-design="a"] .oc-place-story__body {
  display: grid;
  gap: var(--oc-space-block);
  max-width: 65ch;
  margin-inline: auto 0; /* left-align reading col within centered container */
}
[data-design="a"] .oc-place-story__body p {
  font-size: 18px;
  line-height: 1.65;
  color: var(--oc-ink-2);
  margin: 0;
}
/* Feature photo — TRIAD-2 handoff; body-life.js sets --bl-py, clip-path uses it */
[data-design="a"] .oc-place-story__feature {
  margin: var(--oc-space-deck) 0 0;
  border-radius: var(--oc-radius-lg);
  overflow: hidden;
  box-shadow: var(--oc-elev-stamp);
  position: relative;
}
[data-design="a"] .oc-place-story__feature-img {
  display: block;
  width: 100%;
  height: clamp(280px, 46vw, 540px);
  object-fit: cover;
}
[data-design="a"] .oc-place-story__feature-cap {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  margin: 0;
  font-family: var(--oc-font-mono);
  font-size: 13px;
  letter-spacing: 0.04em;
  color: var(--oc-stamp-on);
  padding: var(--oc-space-block) var(--oc-space-tile) var(--oc-space-stub);
  background: linear-gradient(180deg, transparent, rgba(23,23,23,0.72));
}

/* ── Key Facts ── */
[data-design="a"] .oc-facts {
  padding-block: var(--oc-space-deck);
  border-bottom: 2px solid var(--oc-rule);
}
[data-design="a"] .oc-facts__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0;
}
[data-design="a"] .oc-fact {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: var(--oc-space-block);
  padding: var(--oc-space-block) 0;
  border-bottom: 2px solid var(--oc-soft);
  align-items: baseline;
  /* scroll-reveal start state */
  opacity: 0;
  transform: translateY(16px) scale(0.98);
  transition:
    opacity var(--oc-dur-settle) var(--oc-ease-decide),
    transform var(--oc-dur-settle) var(--oc-ease-stamp);
}
[data-design="a"] .oc-fact[data-visible] {
  opacity: 1;
  transform: translateY(0) scale(1);
}
[data-design="a"] .oc-fact:last-child { border-bottom: 0; }
[data-design="a"] .oc-fact__label {
  font-family: var(--oc-font-mono);
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--oc-muted);
}
[data-design="a"] .oc-fact__value {
  font-family: var(--oc-font-body);
  font-size: 17px;
  line-height: 1.55;
  color: var(--oc-ink-2);
  max-width: 65ch;
}
@media (max-width: 600px) {
  [data-design="a"] .oc-fact { grid-template-columns: 1fr; gap: var(--oc-space-bite); }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .oc-fact { opacity: 1; transform: none; transition: none; }
}

/* ── Stays Selector (INT-1) ── */
[data-design="a"] .oc-stays {
  padding-block: var(--oc-space-deck);
  border-bottom: 2px solid var(--oc-rule);
}
[data-design="a"] .oc-stays__heading {
  font-family: var(--oc-font-display);
  font-weight: 800;
  font-size: clamp(32px, 5vw, 52px);
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--oc-ink);
  margin: var(--oc-space-gap) 0 var(--oc-space-bay);
  max-width: 22ch;
}
/* Tab row */
[data-design="a"] .oc-stays__tablist {
  display: flex;
  gap: var(--oc-space-stub);
  flex-wrap: wrap;
  margin-bottom: var(--oc-space-bay);
  border-bottom: 2px solid var(--oc-rule);
  padding-bottom: 0;
}
[data-design="a"] .oc-stays__tab {
  font-family: var(--oc-font-display);
  font-weight: 800;
  font-size: clamp(15px, 1.4vw, 18px);
  letter-spacing: -0.01em;
  padding: 12px 20px;
  min-height: 44px;
  background: transparent;
  color: var(--oc-muted);
  border: 2px solid var(--oc-soft);
  border-bottom: none;
  border-radius: var(--oc-radius-sm) var(--oc-radius-sm) 0 0;
  cursor: pointer;
  transition:
    background var(--oc-dur-snap) var(--oc-ease-decide),
    color var(--oc-dur-snap) var(--oc-ease-decide),
    transform var(--oc-dur-snap) var(--oc-ease-stamp);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .oc-stays__tab:hover {
    background: var(--oc-soft);
    color: var(--oc-ink);
    transform: translateY(-2px);
  }
}
[data-design="a"] .oc-stays__tab--active,
[data-design="a"] .oc-stays__tab[aria-selected="true"] {
  background: var(--oc-paper);
  color: var(--oc-stamp);
  border-color: var(--oc-rule);
  position: relative;
  transform: translateY(2px);
}
[data-design="a"] .oc-stays__tab--active::after,
[data-design="a"] .oc-stays__tab[aria-selected="true"]::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 2px;
  background: var(--oc-paper);
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .oc-stays__tab { transition: none; }
}

/* Panel area */
[data-design="a"] .oc-stays__panels {
  background: var(--oc-paper);
  border: 2px solid var(--oc-rule);
  border-radius: 0 var(--oc-radius-lg) var(--oc-radius-lg) var(--oc-radius-lg);
  overflow: hidden;
}
[data-design="a"] .oc-stays__panel {
  display: none;
  animation: oc-panel-in var(--oc-dur-settle) var(--oc-ease-stamp);
}
[data-design="a"] .oc-stays__panel--active,
[data-design="a"] .oc-stays__panel:not([hidden]) {
  display: block;
}
@keyframes oc-panel-in {
  from { opacity: 0; transform: translateX(16px) scale(0.99); }
  to   { opacity: 1; transform: translateX(0) scale(1); }
}
[data-design="a"] .oc-stays__panel-layout {
  display: grid;
  gap: 0;
}
@media (min-width: 768px) {
  [data-design="a"] .oc-stays__panel-layout {
    grid-template-columns: 1fr 1fr;
  }
}
[data-design="a"] .oc-stays__panel-img-wrap {
  overflow: hidden;
  min-height: 260px;
}
[data-design="a"] .oc-stays__panel-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 260px;
  transition: transform var(--oc-dur-settle) var(--oc-ease-decide);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .oc-stays__panel-img-wrap:hover .oc-stays__panel-img {
    transform: scale(1.03);
  }
}
[data-design="a"] .oc-stays__panel-body {
  padding: var(--oc-space-tile);
  display: grid;
  gap: var(--oc-space-block);
  align-content: start;
}
[data-design="a"] .oc-stays__panel-name {
  font-family: var(--oc-font-display);
  font-weight: 800;
  font-size: clamp(22px, 3vw, 30px);
  letter-spacing: -0.015em;
  line-height: 1.05;
  color: var(--oc-ink);
  margin: 0;
}
[data-design="a"] .oc-stays__panel-desc {
  font-size: 17px;
  line-height: 1.6;
  color: var(--oc-ink-2);
  margin: 0;
  max-width: 60ch;
}
[data-design="a"] .oc-stays__amenities {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--oc-space-bite);
}
[data-design="a"] .oc-stays__amenities li {
  font-family: var(--oc-font-body);
  font-size: 15px;
  line-height: 1.5;
  color: var(--oc-ink-2);
  padding-left: 20px;
  position: relative;
}
[data-design="a"] .oc-stays__amenities li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.5em;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--oc-moss);
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .oc-stays__panel { animation: none; }
  [data-design="a"] .oc-stays__panel-img { transition: none; }
}

/* ── Gallery (Element 5 — scroll-reveal + lightbox) ── */
[data-design="a"] .oc-gallery {
  padding-block: var(--oc-space-deck);
  border-bottom: 2px solid var(--oc-rule);
}
[data-design="a"] .oc-gallery__heading {
  font-family: var(--oc-font-display);
  font-weight: 800;
  font-size: clamp(32px, 5vw, 52px);
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--oc-ink);
  margin: var(--oc-space-gap) 0 var(--oc-space-bay);
  max-width: 22ch;
}
[data-design="a"] .oc-gallery__sequence {
  display: grid;
  gap: var(--oc-space-deck);
}
/* Each gallery frame — scroll-reveal start state */
[data-design="a"] .oc-gallery__frame {
  margin: 0;
  opacity: 0;
  transform: translateY(20px) scale(0.97);
  transition:
    opacity var(--oc-dur-settle) var(--oc-ease-decide),
    transform var(--oc-dur-settle) var(--oc-ease-stamp);
}
[data-design="a"] .oc-gallery__frame[data-visible] {
  opacity: 1;
  transform: translateY(0) scale(1);
}
[data-design="a"] .oc-gallery__img-wrap {
  overflow: hidden;
  border-radius: var(--oc-radius-lg);
  box-shadow: var(--oc-elev-stamp);
  cursor: pointer;
  position: relative;
}
[data-design="a"] .oc-gallery__img-wrap::after {
  content: "↗";
  position: absolute;
  top: var(--oc-space-stub);
  right: var(--oc-space-stub);
  font-family: var(--oc-font-mono);
  font-size: 14px;
  color: #fff;
  background: rgba(23,23,23,0.7);
  border-radius: var(--oc-radius-sm);
  padding: 4px 8px;
  opacity: 0;
  transition: opacity var(--oc-dur-snap) var(--oc-ease-decide);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .oc-gallery__img-wrap:hover::after { opacity: 1; }
  [data-design="a"] .oc-gallery__img-wrap:hover img { transform: scale(1.03); }
}
[data-design="a"] .oc-gallery__img-wrap img {
  display: block;
  width: 100%;
  height: clamp(220px, 38vw, 460px);
  object-fit: cover;
  transition: transform var(--oc-dur-settle) var(--oc-ease-decide);
}
[data-design="a"] .oc-gallery__caption {
  font-family: var(--oc-font-mono);
  font-size: 13px;
  letter-spacing: 0.04em;
  line-height: 1.6;
  color: var(--oc-muted);
  margin: var(--oc-space-block) 0 0;
  max-width: 70ch;
}
[data-design="a"] .oc-gallery__book-row {
  display: flex;
  justify-content: center;
  margin-top: var(--oc-space-deck);
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .oc-gallery__frame {
    opacity: 1;
    transform: none;
    transition: none;
  }
  [data-design="a"] .oc-gallery__img-wrap img { transition: none; }
}

/* Lightbox */
/* z-index: 35 — above drawer (30) but body-scoped; capped below hero */
[data-design="a"] .oc-lightbox {
  position: fixed;
  inset: 0;
  z-index: 35;
  background: rgba(23,23,23,0.96);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--oc-space-stub);
  padding: var(--oc-space-bay);
  box-sizing: border-box;
  /* animate on open; pointer-events:none when closed so hidden lightbox never intercepts clicks */
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--oc-dur-settle) var(--oc-ease-decide);
}
[data-design="a"] .oc-lightbox[data-open="true"] { opacity: 1; pointer-events: auto; }
[data-design="a"] .oc-lightbox__close {
  position: absolute;
  top: var(--oc-space-stub);
  right: var(--oc-space-stub);
  background: transparent;
  border: 2px solid rgba(255,255,255,0.25);
  border-radius: var(--oc-radius-sm);
  color: #fff;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  padding: 6px 14px;
  min-width: 44px; min-height: 44px;
}
[data-design="a"] .oc-lightbox__stage {
  max-width: 1100px;
  width: 100%;
  margin-inline: auto;
}
[data-design="a"] .oc-lightbox__img {
  display: block;
  width: 100%;
  max-height: 75vh;
  object-fit: contain;
  border-radius: var(--oc-radius-md);
}
[data-design="a"] .oc-lightbox__caption {
  font-family: var(--oc-font-mono);
  font-size: 13px;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.65);
  text-align: center;
  margin: 0;
  max-width: 70ch;
  margin-inline: auto;
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .oc-lightbox { opacity: 1; transition: none; }
}

/* ── What's Nearby ── */
[data-design="a"] .oc-nearby {
  padding-block: var(--oc-space-deck);
  border-bottom: 2px solid var(--oc-rule);
}
[data-design="a"] .oc-nearby__heading {
  font-family: var(--oc-font-display);
  font-weight: 800;
  font-size: clamp(28px, 4.5vw, 48px);
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--oc-ink);
  margin: var(--oc-space-gap) 0 var(--oc-space-bay);
  max-width: 22ch;
}
[data-design="a"] .oc-nearby__list {
  list-style: none;
  padding: 0;
  margin: 0;
}
[data-design="a"] .oc-nearby__item {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--oc-space-bay);
  align-items: baseline;
  padding: var(--oc-space-block) 0;
  border-bottom: 2px solid var(--oc-soft);
  opacity: 0;
  transform: translateX(-12px) scale(0.98);
  transition:
    opacity var(--oc-dur-settle) var(--oc-ease-decide),
    transform var(--oc-dur-settle) var(--oc-ease-stamp);
}
[data-design="a"] .oc-nearby__item[data-visible] {
  opacity: 1;
  transform: translateX(0) scale(1);
}
[data-design="a"] .oc-nearby__item:last-child { border-bottom: 0; }
[data-design="a"] .oc-nearby__num {
  font-family: var(--oc-font-display);
  font-weight: 800;
  font-size: 28px;
  letter-spacing: -0.02em;
  color: var(--oc-ink);
  display: inline-block;
  padding: 4px 8px;
  border: 2px solid var(--oc-rule);
  border-radius: var(--oc-radius-stamp);
  line-height: 1;
  text-align: center;
  min-width: 48px;
  transition:
    background var(--oc-dur-stamp) var(--oc-ease-stamp),
    color var(--oc-dur-stamp) var(--oc-ease-stamp),
    transform var(--oc-dur-stamp) var(--oc-ease-stamp);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .oc-nearby__item:hover .oc-nearby__num {
    background: var(--oc-stamp);
    color: var(--oc-stamp-on);
    border-color: var(--oc-stamp);
    transform: scale(1.06);
  }
}
[data-design="a"] .oc-nearby__detail {
  display: grid;
  gap: var(--oc-space-bite);
}
[data-design="a"] .oc-nearby__name {
  font-family: var(--oc-font-display);
  font-weight: 700;
  font-size: clamp(18px, 2.2vw, 24px);
  letter-spacing: -0.01em;
  color: var(--oc-ink);
}
[data-design="a"] .oc-nearby__desc {
  font-size: 17px;
  line-height: 1.6;
  color: var(--oc-ink-2);
  max-width: 60ch;
}
@media (max-width: 560px) {
  [data-design="a"] .oc-nearby__item { grid-template-columns: 56px 1fr; gap: var(--oc-space-stub); }
  [data-design="a"] .oc-nearby__num { font-size: 20px; min-width: 44px; }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .oc-nearby__item { opacity: 1; transform: none; transition: none; }
  [data-design="a"] .oc-nearby__num { transition: none; }
}

/* ── Host ── */
[data-design="a"] .oc-host {
  padding-block: var(--oc-space-deck);
  border-bottom: 2px solid var(--oc-rule);
}
[data-design="a"] .oc-host__inner {
  background: var(--oc-paper);
  border: 2px solid var(--oc-rule);
  border-radius: var(--oc-radius-lg);
  padding: var(--oc-space-tile);
  display: grid;
  gap: var(--oc-space-block);
  align-content: start;
  /* scroll-reveal start state */
  opacity: 0;
  transform: translateY(16px) scale(0.98);
  transition:
    opacity var(--oc-dur-settle) var(--oc-ease-decide),
    transform var(--oc-dur-settle) var(--oc-ease-stamp);
}
[data-design="a"] .oc-host__inner[data-visible] {
  opacity: 1;
  transform: translateY(0) scale(1);
}
[data-design="a"] .oc-host__heading {
  font-family: var(--oc-font-display);
  font-weight: 800;
  font-size: clamp(28px, 4vw, 44px);
  letter-spacing: -0.02em;
  line-height: 1.05;
  color: var(--oc-ink);
  margin: 0;
}
[data-design="a"] .oc-host__bio {
  font-size: 17px;
  line-height: 1.65;
  color: var(--oc-ink-2);
  margin: 0;
  max-width: 65ch;
}
[data-design="a"] .oc-host__ig { margin: 0; }
[data-design="a"] .oc-host__ig-link {
  font-family: var(--oc-font-mono);
  font-size: 14px;
  letter-spacing: 0.04em;
  color: var(--oc-stamp);
  text-decoration: underline;
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .oc-host__inner { opacity: 1; transform: none; transition: none; }
}

/* ── Closing CTA ── */
[data-design="a"] .oc-closing {
  padding-block: var(--oc-space-yard) var(--oc-space-deck);
  background: var(--oc-stamp);
}
[data-design="a"] .oc-closing .oc-kicker { color: rgba(255,255,255,0.7); }
[data-design="a"] .oc-closing__headline {
  font-family: var(--oc-font-display);
  font-weight: 800;
  font-size: clamp(28px, 4.5vw, 48px);
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--oc-stamp-on);
  margin: var(--oc-space-gap) 0 var(--oc-space-stub);
  max-width: 24ch;
}
[data-design="a"] .oc-closing__sub {
  font-size: 17px;
  line-height: 1.55;
  color: rgba(255,255,255,0.8);
  margin: 0 0 var(--oc-space-bay);
  max-width: 52ch;
}
[data-design="a"] .oc-closing .oc-cta {
  background: var(--oc-paper);
  color: var(--oc-stamp);
  border-color: var(--oc-paper);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .oc-closing .oc-cta:hover {
    background: var(--oc-canvas);
    color: var(--oc-stamp-deep);
    border-color: var(--oc-canvas);
  }
}

/* ── Footer ── */
[data-design="a"] .oc-footer {
  padding-block: var(--oc-space-deck);
  border-top: 2px solid var(--oc-rule);
  background: var(--oc-canvas);
}
[data-design="a"] .oc-footer__brand {
  font-family: var(--oc-font-display);
  font-weight: 800;
  font-size: clamp(22px, 3vw, 36px);
  letter-spacing: -0.02em;
  color: var(--oc-ink);
  display: block;
  margin-bottom: var(--oc-space-bite);
}
[data-design="a"] .oc-footer__loc {
  font-family: var(--oc-font-mono);
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--oc-muted);
  margin: 0 0 var(--oc-space-block);
}
[data-design="a"] .oc-footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--oc-space-block);
}
[data-design="a"] .oc-footer__link {
  font-family: var(--oc-font-body);
  font-size: 15px;
  color: var(--oc-stamp);
  text-decoration: underline;
}

/* ── Mobile no-h-scroll floor (contract-mandated, appended last) ── */
[data-design="a"].dq-design,
[data-design="a"] .dq-design { max-width: 100%; overflow-x: clip; }
[data-design="a"].dq-design * { min-width: 0; }
[data-design="a"].dq-design img { max-width: 100%; height: auto; }
/* Restore object-fit cover heights clobbered by height:auto */
[data-design="a"].dq-design .oc-place-story__feature-img { height: clamp(280px, 46vw, 540px); }
[data-design="a"].dq-design .oc-gallery__img-wrap img { height: clamp(220px, 38vw, 460px); }
[data-design="a"].dq-design .oc-stays__panel-img { height: auto; min-height: 260px; }

/* Phase-3.4 hero visibility floor (forge_assemble) */
[data-design="a"] [data-mf-role="hero"] :is(h1,h2,p,.headline,.subtitle,.proof,[class*="headline"],[class*="subtitle"],[class*="proof"]),
[data-design="a"] [data-mf-role="cta"] { opacity: 1 !important; }
