/* ===========================================================================
   Big Rock Ranch · design-a body styles
   figma-canvas-counsel grammar (instrument-grade: hairline grid, mono matter-IDs,
   frame cards, snap/settle/breath motion) warmed to a high-desert ranch palette.
   ALL scoped to [data-design="a"]. Motion gate: transform / opacity / clip-path
   only. Every wrapper is windowed-centered (max-width + margin-inline:auto).
   The CTAs are styled BUTTONS (.fcc-key) — never bare anchors.
   Parallax: the handoff <figure data-bl-feature> is animated by the injected
   body-life.css/js via --bl-py (we only emit the mark; do not re-implement).
   =========================================================================== */

[data-design="a"]{
  /* ── High-desert token set (warm canvas, sage + sunset-rust accents) ─── */
  --fcc-canvas:        #F4EFE7;   /* warm bone — never pure white */
  --fcc-paper:         #FBF7F0;   /* raised surface */
  --fcc-ink:           #221C14;   /* warm near-black */
  --fcc-ink-2:         #4A4034;   /* secondary fg */
  --fcc-muted:         #897C6A;   /* tertiary fg / metadata */
  --fcc-border:        #E2D8C7;   /* hairline */
  --fcc-border-strong: #221C14;
  --fcc-accent:        #6A7B52;   /* sage / juniper green — the signature */
  --fcc-accent-deep:   #4C5A39;
  --fcc-accent-soft:   #EBEADB;   /* sage tint surface */
  --fcc-coral:         #C2622F;   /* sunset rust — second cursor + dusk warmth */
  --fcc-coral-soft:    #F3E2D2;

  --fcc-font-display:  'Inter', 'Söhne', -apple-system, system-ui, sans-serif;
  --fcc-font-body:     'Inter', 'Söhne', -apple-system, system-ui, sans-serif;
  --fcc-font-mono:     'JetBrains Mono', 'IBM Plex Mono', ui-monospace, Menlo, monospace;

  --fcc-r-frame: 10px;
  --fcc-r-pill: 6px;
  --fcc-maxw: 1280px;
  --fcc-pad: clamp(20px, 5vw, 48px);
  --fcc-rhythm: clamp(64px, 9vw, 112px);

  --fcc-dur-snap:    120ms;
  --fcc-dur-settle:  260ms;
  --fcc-ease-snap:   cubic-bezier(0.2, 0.9, 0.15, 1);
  --fcc-ease-settle: cubic-bezier(0.22, 1, 0.36, 1);

  /* drive the injected CTA button-floor's palette to match (belt-and-suspenders) */
  --bl-cta-bg: linear-gradient(135deg, #6A7B52, #4C5A39);
  --bl-cta-ink: #FBF7F0;

  color: var(--fcc-ink);
  font-family: var(--fcc-font-body);
  background: var(--fcc-canvas);
  -webkit-font-smoothing: antialiased;
}

[data-design="a"].dq-design{
  display: block;
  background: var(--fcc-canvas);
}

[data-design="a"].dq-design *,
[data-design="a"].dq-design *::before,
[data-design="a"].dq-design *::after{ box-sizing: border-box; }

[data-design="a"] .fcc-mono{
  font-family: var(--fcc-font-mono);
  font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--fcc-muted); font-variant-numeric: tabular-nums;
}

[data-design="a"] .fcc-section-head{
  font-family: var(--fcc-font-display);
  font-size: clamp(28px, 4.4vw, 44px); font-weight: 600;
  letter-spacing: -0.022em; line-height: 1.08; margin: 8px 0 0;
  color: var(--fcc-ink); max-width: 24ch;
}

/* ── Element 1 · Header ──────────────────────────────────────────────── */
[data-design="a"] .fcc-header{
  position: sticky; top: 0; z-index: 40;
  background: color-mix(in oklab, var(--fcc-canvas) 90%, transparent);
  border-bottom: 1px solid var(--fcc-border);
  backdrop-filter: saturate(135%) blur(10px);
}
[data-design="a"] .fcc-header__grid{
  position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(to right, var(--fcc-border) 1px, transparent 1px),
    linear-gradient(to bottom, var(--fcc-border) 1px, transparent 1px);
  background-size: 32px 32px; opacity: 0.16;
  animation: fcc-grid-breath 32s ease-in-out infinite;
}
[data-design="a"] .fcc-header__bar{
  position: relative;
  display: flex; align-items: center; justify-content: space-between;
  height: 60px; max-width: var(--fcc-maxw); margin-inline: auto;
  padding-inline: var(--fcc-pad);
}
[data-design="a"] .fcc-logo{
  display: inline-flex; align-items: center; gap: 10px;
  color: var(--fcc-ink); text-decoration: none;
  font-family: var(--fcc-font-display); font-weight: 600;
  font-size: 16px; letter-spacing: -0.01em;
}
[data-design="a"] .fcc-logo__dot{
  width: 10px; height: 10px; border-radius: 9999px;
  background: var(--fcc-accent);
  box-shadow: 0 0 0 3px var(--fcc-accent-soft);
}
[data-design="a"] .fcc-burger{
  width: 44px; height: 44px; display: inline-flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 5px;
  background: transparent; border: 1px solid var(--fcc-border);
  border-radius: 8px; cursor: pointer;
  transition: border-color var(--fcc-dur-snap) var(--fcc-ease-snap),
              background-color var(--fcc-dur-snap) var(--fcc-ease-snap);
}
@media (hover:hover) and (pointer:fine){
  [data-design="a"] .fcc-burger:hover{ border-color: var(--fcc-ink); }
}
[data-design="a"] .fcc-burger:focus-visible{ outline: 2px solid var(--fcc-accent); outline-offset: 2px; }
[data-design="a"] .fcc-burger__line{ width: 18px; height: 1.5px; background: var(--fcc-ink); border-radius: 1px; }

[data-design="a"] .fcc-drawer{ position: fixed; inset: 0; pointer-events: none; z-index: 50; }
[data-design="a"] .fcc-drawer[data-open="true"]{ pointer-events: auto; }
[data-design="a"] .fcc-drawer__scrim{
  position: absolute; inset: 0;
  background: rgba(34,28,20,.34); backdrop-filter: blur(6px);
  opacity: 0; transition: opacity var(--fcc-dur-settle) var(--fcc-ease-settle);
}
[data-design="a"] .fcc-drawer[data-open="true"] .fcc-drawer__scrim{ opacity: 1; }
[data-design="a"] .fcc-drawer__panel{
  position: absolute; top: 0; right: 0; height: 100%; width: min(360px, 92vw);
  background: var(--fcc-paper); border-left: 1px solid var(--fcc-border);
  transform: translateX(100%);
  transition: transform var(--fcc-dur-settle) var(--fcc-ease-settle);
  display: flex; flex-direction: column;
}
[data-design="a"] .fcc-drawer[data-open="true"] .fcc-drawer__panel{ transform: translateX(0); }
[data-design="a"] .fcc-drawer__head{
  display: flex; justify-content: space-between; align-items: center;
  padding: 18px 24px; border-bottom: 1px solid var(--fcc-border);
}
[data-design="a"] .fcc-drawer__x{
  width: 32px; height: 32px; border: 1px solid var(--fcc-border);
  border-radius: 8px; background: transparent; color: var(--fcc-ink);
  font-size: 20px; line-height: 1; cursor: pointer;
}
[data-design="a"] .fcc-drawer__items{ display: flex; flex-direction: column; padding: 16px 12px; gap: 2px; }
[data-design="a"] .fcc-navlink{
  position: relative; padding: 13px 16px; min-height: 44px; display: flex; align-items: center;
  color: var(--fcc-ink); text-decoration: none; font-size: 16px; border-radius: 8px;
  transition: background-color var(--fcc-dur-snap) var(--fcc-ease-snap);
}
@media (hover:hover) and (pointer:fine){
  [data-design="a"] .fcc-navlink:hover{ background: var(--fcc-accent-soft); }
}
[data-design="a"] .fcc-key--drawer{ margin-top: 14px; }

/* ── The CTA button (.fcc-key) — STYLED, never a bare anchor ─────────── */
[data-design="a"] .fcc-key{
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 26px; min-height: 48px; border-radius: 10px;
  background: linear-gradient(135deg, var(--fcc-accent), var(--fcc-accent-deep));
  color: #FBF7F0; text-decoration: none;
  font-family: var(--fcc-font-display); font-weight: 600;
  font-size: clamp(15px, 1.6vw, 17px); letter-spacing: 0.005em; line-height: 1.1;
  border: 1px solid color-mix(in oklab, var(--fcc-accent-deep) 70%, var(--fcc-ink) 30%);
  box-shadow: 0 6px 22px rgba(34,28,20,.18);
  animation: fcc-cta-breath 4600ms ease-in-out infinite;
  transition: transform var(--fcc-dur-snap) var(--fcc-ease-snap),
              box-shadow var(--fcc-dur-snap) var(--fcc-ease-snap),
              filter var(--fcc-dur-snap) var(--fcc-ease-snap);
}
[data-design="a"] .fcc-key__ext{ display: inline-flex; transition: transform var(--fcc-dur-snap) var(--fcc-ease-snap); }
@media (hover:hover) and (pointer:fine){
  [data-design="a"] .fcc-key:hover{ transform: translateY(-2px); filter: brightness(1.05); box-shadow: 0 10px 30px rgba(76,90,57,.36); }
  [data-design="a"] .fcc-key:hover .fcc-key__ext{ transform: translate(2px, -2px); }
}
[data-design="a"] .fcc-key:active{ transform: translateY(0); }
[data-design="a"] .fcc-key:focus-visible{ outline: 3px solid var(--fcc-accent); outline-offset: 3px; }
[data-design="a"] .fcc-key--lg{ padding: 18px 36px; font-size: clamp(16px, 2vw, 19px); }

@keyframes fcc-cta-breath{
  0%,100%{ box-shadow: 0 6px 22px rgba(34,28,20,.18); }
  50%    { box-shadow: 0 9px 30px rgba(106,123,82,.40); }
}

/* ── 2 · Place story ─────────────────────────────────────────────────── */
[data-design="a"] .fcc-story{
  max-width: var(--fcc-maxw); margin-inline: auto; padding-inline: var(--fcc-pad);
  padding-block: var(--fcc-rhythm);
  display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(28px, 5vw, 64px);
  align-items: center;
}
[data-design="a"] .fcc-story__strip{ display: block; margin-bottom: 16px; color: var(--fcc-accent-deep); }
[data-design="a"] .fcc-story__head{
  font-family: var(--fcc-font-display);
  font-size: clamp(30px, 4.8vw, 52px); font-weight: 600;
  letter-spacing: -0.024em; line-height: 1.06; margin: 0 0 22px;
  max-width: 18ch;
}
[data-design="a"] .fcc-story__body{
  font-size: clamp(16px, 1.4vw, 18px); line-height: 1.62; color: var(--fcc-ink-2);
  margin: 0 0 16px; max-width: 64ch;
}
[data-design="a"] .fcc-story__feature{
  margin: 0; border-radius: var(--fcc-r-frame); overflow: hidden;
  border: 1px solid var(--fcc-border); background: var(--fcc-paper);
  box-shadow: 0 1px 2px rgba(34,28,20,.05), 0 24px 56px -20px rgba(34,28,20,.22);
}
[data-design="a"] .fcc-story__feature img{
  display: block; width: 100%; aspect-ratio: 4 / 3; object-fit: cover;
}
[data-design="a"] .fcc-story__cap{
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 12px 16px; border-top: 1px solid var(--fcc-border);
  font-size: 13px; color: var(--fcc-muted);
}

/* ── 3 · Facts (frame cards) ─────────────────────────────────────────── */
[data-design="a"] .fcc-facts{
  max-width: var(--fcc-maxw); margin-inline: auto; padding-inline: var(--fcc-pad);
  padding-block: var(--fcc-rhythm);
}
[data-design="a"] .fcc-facts__head{ margin-bottom: 32px; }
[data-design="a"] .fcc-facts__grid{
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
}
[data-design="a"] .fcc-frame{
  background: var(--fcc-paper); border: 1px solid var(--fcc-border);
  border-radius: var(--fcc-r-frame); padding: 20px;
  display: flex; flex-direction: column; gap: 12px;
  transition: border-color var(--fcc-dur-snap) var(--fcc-ease-snap),
              transform var(--fcc-dur-snap) var(--fcc-ease-snap);
}
@media (hover:hover) and (pointer:fine){
  [data-design="a"] .fcc-frame:hover{ border-color: var(--fcc-ink); transform: translateY(-2px); }
}
[data-design="a"] .fcc-frame__title{
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 10px; border-bottom: 1px dashed var(--fcc-border);
}
[data-design="a"] .fcc-frame__live{
  width: 8px; height: 8px; border-radius: 9999px; background: var(--fcc-accent);
  animation: fcc-live-pulse 2600ms ease-in-out infinite;
}
[data-design="a"] .fcc-frame__v{
  font-family: var(--fcc-font-display); font-weight: 600;
  font-size: clamp(17px, 1.5vw, 20px); letter-spacing: -0.012em; color: var(--fcc-ink);
}
[data-design="a"] .fcc-frame__body{ margin: 0; font-size: 14.5px; line-height: 1.55; color: var(--fcc-ink-2); }

@keyframes fcc-live-pulse{
  0%,100%{ box-shadow: 0 0 0 0 color-mix(in oklab, var(--fcc-accent) 55%, transparent); }
  50%    { box-shadow: 0 0 0 6px color-mix(in oklab, var(--fcc-accent) 0%, transparent); }
}

/* ── 4 · Stays selector (INT-1) ──────────────────────────────────────── */
[data-design="a"] .fcc-stays{
  max-width: var(--fcc-maxw); margin-inline: auto; padding-inline: var(--fcc-pad);
  padding-block: var(--fcc-rhythm);
}
[data-design="a"] .fcc-stays__head{ margin-bottom: 28px; }
[data-design="a"] .fcc-stays__lede{
  margin: 14px 0 0; color: var(--fcc-ink-2); font-size: clamp(16px, 1.4vw, 18px);
  line-height: 1.55; max-width: 56ch;
}
[data-design="a"] .fcc-stays__widget{
  background: var(--fcc-paper); border: 1px solid var(--fcc-border);
  border-radius: var(--fcc-r-frame); overflow: hidden;
}
[data-design="a"] .fcc-stays__tabs{
  display: flex; gap: 0; border-bottom: 1px solid var(--fcc-border);
  background: color-mix(in oklab, var(--fcc-canvas) 55%, transparent);
}
[data-design="a"] .fcc-stays__tab{
  flex: 1 1 0; min-width: 0; min-height: 56px;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px; flex-wrap: wrap;
  padding: 14px 20px; cursor: pointer;
  background: transparent; border: 0; border-bottom: 2px solid transparent;
  color: var(--fcc-muted); font-family: var(--fcc-font-display);
  font-weight: 600; font-size: clamp(14px, 1.4vw, 16px); letter-spacing: -0.005em;
  transition: color var(--fcc-dur-snap) var(--fcc-ease-snap),
              background-color var(--fcc-dur-snap) var(--fcc-ease-snap),
              border-color var(--fcc-dur-snap) var(--fcc-ease-snap);
}
[data-design="a"] .fcc-stays__tab .fcc-mono{ color: inherit; opacity: .7; }
@media (hover:hover) and (pointer:fine){
  [data-design="a"] .fcc-stays__tab:hover{ color: var(--fcc-ink); background: var(--fcc-accent-soft); }
}
[data-design="a"] .fcc-stays__tab[aria-selected="true"]{
  color: var(--fcc-ink); background: var(--fcc-paper);
  border-bottom-color: var(--fcc-accent);
}
[data-design="a"] .fcc-stays__tab:focus-visible{ outline: 2px solid var(--fcc-accent); outline-offset: -3px; }
[data-design="a"] .fcc-stays__stage{
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 0;
}
[data-design="a"] .fcc-stays__stage:focus-visible{ outline: 2px solid var(--fcc-accent); outline-offset: -3px; }
[data-design="a"] .fcc-stays__frame{ position: relative; overflow: hidden; min-height: 320px; }
[data-design="a"] .fcc-stays__photo{
  position: absolute; inset: 0; width: 100%; height: 100% !important; object-fit: cover;
  animation: fcc-stay-in 360ms var(--fcc-ease-settle) both;
}
[data-design="a"] .fcc-stays__detail{
  padding: clamp(24px, 3vw, 40px); display: flex; flex-direction: column; gap: 14px;
  justify-content: center;
}
[data-design="a"] .fcc-stays__strip{ color: var(--fcc-accent-deep); }
[data-design="a"] .fcc-stays__name{
  margin: 0; font-family: var(--fcc-font-display); font-weight: 600;
  font-size: clamp(22px, 2.6vw, 30px); letter-spacing: -0.02em; line-height: 1.1;
  color: var(--fcc-ink);
}
[data-design="a"] .fcc-stays__desc{ margin: 0; font-size: clamp(15px, 1.3vw, 17px); line-height: 1.6; color: var(--fcc-ink-2); max-width: 56ch; }
[data-design="a"] .fcc-stays__detail [data-stay-name],
[data-design="a"] .fcc-stays__detail [data-stay-desc],
[data-design="a"] .fcc-stays__detail [data-stay-strip]{
  animation: fcc-stay-in 360ms var(--fcc-ease-settle) both;
}
[data-design="a"] .fcc-stays__book{ align-self: flex-start; margin-top: 4px; }

@keyframes fcc-stay-in{
  from{ opacity: 0; transform: translateY(8px); }
  to  { opacity: 1; transform: none; }
}

/* ── Pointer (Element 6) ─────────────────────────────────────────────── */
[data-design="a"] .fcc-pointer{
  max-width: var(--fcc-maxw); margin-inline: auto; padding-inline: var(--fcc-pad);
  padding-block: clamp(20px, 3vw, 36px);
  display: flex; justify-content: center;
}
[data-design="a"] .fcc-pointer__link{
  display: inline-flex; flex-direction: column; align-items: center; gap: 12px;
  text-decoration: none; color: var(--fcc-muted); padding: 8px 16px;
}
[data-design="a"] .fcc-pointer__sun{
  width: 34px; height: 34px; border-radius: 9999px;
  background: radial-gradient(circle at 50% 42%, var(--fcc-coral), color-mix(in oklab, var(--fcc-coral) 30%, transparent) 72%);
  animation: fcc-sun-set 9s ease-in-out infinite;
}
[data-design="a"] .fcc-pointer__rule{
  width: 1px; height: 30px; background: linear-gradient(var(--fcc-border), transparent);
  transform-origin: top; animation: fcc-rule-creep 9s ease-in-out infinite;
}
[data-design="a"] .fcc-pointer__label{ letter-spacing: 0.16em; }

@keyframes fcc-sun-set{
  0%,100%{ transform: translateY(-3px); opacity: .85; }
  50%    { transform: translateY(3px); opacity: 1; }
}
@keyframes fcc-rule-creep{
  0%,100%{ transform: scaleY(.7); opacity: .6; }
  50%    { transform: scaleY(1); opacity: 1; }
}

/* ── 5 · Gallery ─────────────────────────────────────────────────────── */
[data-design="a"] .fcc-gallery{
  max-width: var(--fcc-maxw); margin-inline: auto; padding-inline: var(--fcc-pad);
  padding-block: var(--fcc-rhythm);
}
[data-design="a"] .fcc-gallery__head{ margin-bottom: 32px; }
[data-design="a"] .fcc-gallery__grid{
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px;
}
[data-design="a"] .fcc-gallery__cell{
  margin: 0; grid-column: span 2; border-radius: var(--fcc-r-frame); overflow: hidden;
  border: 1px solid var(--fcc-border); background: var(--fcc-paper);
}
[data-design="a"] .fcc-gallery__cell--wide{ grid-column: span 3; }
[data-design="a"] .fcc-gallery__cell img{
  display: block; width: 100%; height: 100%; aspect-ratio: 3 / 2; object-fit: cover;
  transition: transform 240ms var(--fcc-ease-settle);
}
@media (hover:hover) and (pointer:fine){
  [data-design="a"] .fcc-gallery__cell:hover img{ transform: scale(1.04); }
}

/* ── 6 · Nearby ──────────────────────────────────────────────────────── */
[data-design="a"] .fcc-nearby{
  max-width: var(--fcc-maxw); margin-inline: auto; padding-inline: var(--fcc-pad);
  padding-block: var(--fcc-rhythm);
}
[data-design="a"] .fcc-nearby__head{ margin-bottom: 28px; }
[data-design="a"] .fcc-nearby__list{ list-style: none; margin: 0; padding: 0; display: grid; gap: 0; }
[data-design="a"] .fcc-nearby__item{
  display: grid; grid-template-columns: 130px 1fr; gap: 8px 24px;
  align-items: baseline; padding: 22px 4px;
  border-top: 1px solid var(--fcc-border);
}
[data-design="a"] .fcc-nearby__item:last-child{ border-bottom: 1px solid var(--fcc-border); }
[data-design="a"] .fcc-nearby__no{ color: var(--fcc-accent-deep); }
[data-design="a"] .fcc-nearby__name{
  font-family: var(--fcc-font-display); font-weight: 600;
  font-size: clamp(18px, 1.8vw, 23px); letter-spacing: -0.014em; color: var(--fcc-ink);
}
[data-design="a"] .fcc-nearby__note{ grid-column: 2; color: var(--fcc-ink-2); font-size: 15.5px; line-height: 1.55; max-width: 60ch; }

/* ── 7 · Host ────────────────────────────────────────────────────────── */
[data-design="a"] .fcc-host{
  max-width: var(--fcc-maxw); margin-inline: auto; padding-inline: var(--fcc-pad);
  padding-block: var(--fcc-rhythm);
  display: grid; grid-template-columns: 1.4fr 1fr; gap: clamp(28px, 5vw, 64px); align-items: center;
}
[data-design="a"] .fcc-host__name{
  font-family: var(--fcc-font-display); font-weight: 600;
  font-size: clamp(26px, 3.4vw, 40px); letter-spacing: -0.022em; line-height: 1.1;
  margin: 8px 0 18px; color: var(--fcc-ink); max-width: 18ch;
}
[data-design="a"] .fcc-host__body{ font-size: clamp(16px, 1.4vw, 18px); line-height: 1.62; color: var(--fcc-ink-2); margin: 0; max-width: 60ch; }
[data-design="a"] .fcc-host__panel{
  position: relative; min-height: 220px; border-radius: var(--fcc-r-frame);
  border: 1px solid var(--fcc-border); background: var(--fcc-paper);
  background-image:
    linear-gradient(to right, var(--fcc-border) 1px, transparent 1px),
    linear-gradient(to bottom, var(--fcc-border) 1px, transparent 1px);
  background-size: 26px 26px; overflow: hidden;
}
[data-design="a"] .fcc-host__panel .fcc-cursor{
  position: absolute; display: inline-flex; align-items: flex-end; gap: 4px;
  will-change: transform;
}
[data-design="a"] .fcc-cursor em{ font-style: normal; font-size: 10px; padding: 2px 6px; border-radius: 4px; color: #fff; }
[data-design="a"] .fcc-cursor--blue{ left: 18%; top: 28%; animation: fcc-drift-a 26s cubic-bezier(0.45,0.05,0.55,0.95) infinite; }
[data-design="a"] .fcc-cursor--blue em{ background: var(--fcc-accent); }
[data-design="a"] .fcc-cursor--coral{ left: 62%; top: 54%; animation: fcc-drift-b 33s cubic-bezier(0.45,0.05,0.55,0.95) infinite; }
[data-design="a"] .fcc-cursor--coral em{ background: var(--fcc-coral); }
[data-design="a"] .fcc-host__panel-note{
  position: absolute; left: 18px; bottom: 16px; color: var(--fcc-muted);
}
@keyframes fcc-drift-a{
  0%{ transform: translate(0,0); } 25%{ transform: translate(40px,46px); }
  55%{ transform: translate(120px,10px); } 80%{ transform: translate(60px,60px); }
  100%{ transform: translate(0,0); }
}
@keyframes fcc-drift-b{
  0%{ transform: translate(0,0); } 30%{ transform: translate(-70px,-30px); }
  60%{ transform: translate(-110px,20px); } 85%{ transform: translate(-30px,-44px); }
  100%{ transform: translate(0,0); }
}

/* ── 8 · Closing ─────────────────────────────────────────────────────── */
[data-design="a"] .fcc-closing{
  max-width: var(--fcc-maxw); margin-inline: auto; padding-inline: var(--fcc-pad);
  padding-block: var(--fcc-rhythm);
}
[data-design="a"] .fcc-closing__inner{
  background: linear-gradient(150deg, var(--fcc-accent-soft), color-mix(in oklab, var(--fcc-coral-soft) 60%, var(--fcc-paper)));
  border: 1px solid var(--fcc-border); border-radius: var(--fcc-r-frame);
  padding: clamp(36px, 6vw, 72px); text-align: left;
  display: flex; flex-direction: column; align-items: flex-start; gap: 16px;
}
[data-design="a"] .fcc-closing__head{
  margin: 6px 0 0; font-family: var(--fcc-font-display); font-weight: 600;
  font-size: clamp(28px, 4.4vw, 48px); letter-spacing: -0.024em; line-height: 1.06;
  color: var(--fcc-ink); max-width: 20ch;
}
[data-design="a"] .fcc-closing__sub{ margin: 0; font-size: clamp(16px, 1.5vw, 19px); line-height: 1.55; color: var(--fcc-ink-2); max-width: 56ch; }
[data-design="a"] .fcc-closing .fcc-key{ margin-top: 8px; }

/* ── grid breath (header) ────────────────────────────────────────────── */
@keyframes fcc-grid-breath{ 0%,100%{ opacity: 0.14; } 50%{ opacity: 0.30; } }

/* ── Responsive ──────────────────────────────────────────────────────── */
@media (max-width: 960px){
  [data-design="a"] .fcc-story,
  [data-design="a"] .fcc-host{ grid-template-columns: 1fr; }
  [data-design="a"] .fcc-host__panel{ order: -1; min-height: 180px; }
  [data-design="a"] .fcc-facts__grid{ grid-template-columns: 1fr 1fr; }
  [data-design="a"] .fcc-stays__stage{ grid-template-columns: 1fr; }
  [data-design="a"] .fcc-stays__frame{ min-height: 260px; aspect-ratio: 16 / 10; }
  [data-design="a"] .fcc-gallery__cell,
  [data-design="a"] .fcc-gallery__cell--wide{ grid-column: span 3; }
}
@media (max-width: 560px){
  [data-design="a"] .fcc-facts__grid{ grid-template-columns: 1fr; }
  [data-design="a"] .fcc-gallery__grid{ grid-template-columns: 1fr 1fr; }
  [data-design="a"] .fcc-gallery__cell,
  [data-design="a"] .fcc-gallery__cell--wide{ grid-column: span 1; }
  [data-design="a"] .fcc-nearby__item{ grid-template-columns: 1fr; }
  [data-design="a"] .fcc-nearby__note{ grid-column: 1; }
  [data-design="a"] .fcc-stays__tab{ flex-direction: column; gap: 4px; }
  [data-design="a"] .fcc-header__grid{ background-size: 24px 24px; }
}

/* ── Reduced motion: hold the artifacts, never remove ────────────────── */
@media (prefers-reduced-motion: reduce){
  [data-design="a"] .fcc-header__grid,
  [data-design="a"] .fcc-frame__live,
  [data-design="a"] .fcc-key,
  [data-design="a"] .fcc-pointer__sun,
  [data-design="a"] .fcc-pointer__rule,
  [data-design="a"] .fcc-cursor--blue,
  [data-design="a"] .fcc-cursor--coral,
  [data-design="a"] .fcc-stays__photo,
  [data-design="a"] .fcc-stays__detail [data-stay-name],
  [data-design="a"] .fcc-stays__detail [data-stay-desc],
  [data-design="a"] .fcc-stays__detail [data-stay-strip]{ animation: none; }
  [data-design="a"] .fcc-key__ext,
  [data-design="a"] .fcc-gallery__cell img{ transition: none; }
}

/* ── Mobile no-h-scroll floor (mandatory tail) ───────────────────────── */
[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; }

/* 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; }
