/* ===========================================================================
   Crystal Creek Cabin — design-a (Cloudbank Journal grammar, scoped [data-design="a"])
   BODY ONLY. Hero is injected by the assembler. No funnel.
   Motion gate: transform / opacity / clip-path only.
   =========================================================================== */

[data-design="a"].dq-design {
  /* ---- Cloudbank Journal tokens (forest-dusk register) ---- */
  --stock: #EFEAE0;
  --stock-deep: #E2DAC9;
  --ink: #1A1C20;
  --ink-soft: #3D4248;
  --muted: #7B7C77;
  --rule: #3A3D40;
  --moss: #3B5230;
  --moss-bright: #4d6a3e;
  --silt: #7E5A36;
  --horizon: #C4683A;
  --seal: #3B5230;

  --font-display: "Cardo", "Garamond Premier", "EB Garamond", Georgia, serif;
  --font-body: "Cardo", "Garamond Premier", "EB Garamond", Georgia, serif;
  --font-caption: "Söhne Mono", "IBM Plex Mono", "JetBrains Mono", ui-monospace, monospace;

  --text-cap: 12px;
  --text-foot: 14px;
  --text-body: 18px;
  --text-pull: 22px;
  --text-plate: 32px;

  --space-em: 8px;
  --space-stop: 16px;
  --space-frame: 24px;
  --space-passe: 40px;
  --space-spread: 72px;
  --space-folio: 120px;

  --ease-sky: cubic-bezier(.45,.05,.55,.95);
  --ease-shutter: cubic-bezier(.16,1,.3,1);
  --ease-plate: cubic-bezier(.22,.61,.36,1);

  --maxw: 1280px;

  /* body-life CTA-floor token hooks (harmless; our CTAs carry classes) */
  --bl-cta-bg: linear-gradient(135deg,#4d6a3e,#2c3a1f);
  --bl-cta-ink: #f3ecdc;

  display: block;
  background: var(--stock);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: var(--text-body);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}

/* ---- shared windowed-center column ---- */
[data-design="a"] .cc-story__wrap,
[data-design="a"] .cc-facts__wrap,
[data-design="a"] .cc-stays__wrap,
[data-design="a"] .cc-gallery__wrap,
[data-design="a"] .cc-nearby__wrap,
[data-design="a"] .cc-host__wrap,
[data-design="a"] .cc-closing__wrap,
[data-design="a"] .cc-header__bar {
  box-sizing: border-box;
  width: 100%;
  max-width: var(--maxw);
  margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
}

[data-design="a"] .cc-anchor { display:block; height:0; }

[data-design="a"] .cc-eyebrow {
  margin: 0 0 var(--space-stop);
  font-family: var(--font-caption);
  font-size: var(--text-cap);
  letter-spacing: .16em;
  text-transform: lowercase;
  color: var(--muted);
}

/* =========================================================================
   1. HEADER — the weather band
   ========================================================================= */
[data-design="a"] .cc-header {
  position: relative;
  z-index: 5;
  width: 100%;
  background: var(--stock);
  border-bottom: 1px solid var(--rule);
  overflow: hidden;
}
[data-design="a"] .cc-weatherwash {
  position: absolute; inset: 0;
  background: linear-gradient(100deg, #2B3A4A 0%, var(--horizon) 48%, #2B3A4A 100%);
  background-size: 280% 100%;
  opacity: .16;
  mix-blend-mode: multiply;
  animation: cc-weather-drift 30s var(--ease-sky) infinite;
}
[data-design="a"] .cc-horizon {
  position: absolute; left:0; right:0; bottom:0; height:1px;
  background: var(--horizon); opacity:.5;
}
[data-design="a"] .cc-header__bar {
  position: relative; z-index: 2;
  display: flex; align-items: center; justify-content: space-between;
  padding-block: var(--space-stop);
}
[data-design="a"] .cc-logo { text-decoration:none; }
[data-design="a"] .cc-logo__mark {
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(20px, 3.4vw, 28px);
  color: var(--ink); letter-spacing:.01em;
}
[data-design="a"] .cc-burger {
  appearance:none; background:none; border:1px solid var(--rule); border-radius:0;
  padding:9px 10px; min-width:44px; min-height:44px; cursor:pointer;
  display:inline-flex; flex-direction:column; gap:4px; align-items:center; justify-content:center;
}
[data-design="a"] .cc-burger__rule {
  display:block; width:20px; height:1px; background:var(--ink);
  transition: transform .32s var(--ease-shutter), opacity .2s;
}
[data-design="a"] .cc-burger[aria-expanded="true"] .cc-burger__rule:nth-child(1){ transform: translateY(5px) rotate(45deg); }
[data-design="a"] .cc-burger[aria-expanded="true"] .cc-burger__rule:nth-child(2){ opacity:0; }
[data-design="a"] .cc-burger[aria-expanded="true"] .cc-burger__rule:nth-child(3){ transform: translateY(-5px) rotate(-45deg); }

[data-design="a"] .cc-drawer {
  position: fixed; inset:0; z-index:60;
  display:flex; justify-content:flex-end; pointer-events:none; opacity:0;
  background: color-mix(in oklab, var(--ink) 40%, transparent);
  transition: opacity .32s var(--ease-sky);
}
[data-design="a"] .cc-drawer[data-open="true"]{ pointer-events:auto; opacity:1; }
[data-design="a"] .cc-drawer__sheet {
  position:relative; box-sizing:border-box;
  width:min(380px,86vw); height:100%;
  background:var(--stock); border-left:1px solid var(--rule);
  padding: var(--space-spread) var(--space-frame) var(--space-frame);
  display:flex; flex-direction:column; gap:var(--space-frame);
  transform: translateX(18px);
  transition: transform .32s var(--ease-plate);
}
[data-design="a"] .cc-drawer[data-open="true"] .cc-drawer__sheet{ transform: translateX(0); }
[data-design="a"] .cc-drawer__close {
  position:absolute; top:var(--space-frame); right:var(--space-frame);
  background:none; border:none; cursor:pointer;
  font-family:var(--font-caption); font-size:var(--text-cap);
  letter-spacing:.14em; text-transform:lowercase; color:var(--muted);
}
[data-design="a"] .cc-nav { display:flex; flex-direction:column; gap:var(--space-stop); }
[data-design="a"] .cc-nav a {
  width:max-content; padding-bottom:4px;
  font-family:var(--font-display); font-style:italic; font-size:var(--text-pull);
  color:var(--ink); text-decoration:none;
  background-image: linear-gradient(var(--moss), var(--moss));
  background-size:0% 2px; background-position:0 100%; background-repeat:no-repeat;
  transition: background-size .32s var(--ease-plate);
}
[data-design="a"] .cc-drawer__mark {
  margin-top:auto; font-family:var(--font-caption); font-size:var(--text-cap);
  letter-spacing:.12em; text-transform:lowercase; color:var(--silt);
}

/* =========================================================================
   CTA — the Plate button (styled, classed; never a bare link)
   ========================================================================= */
[data-design="a"] .cc-cta {
  position: relative; isolation: isolate;
  display: inline-flex; align-items: center; gap: .6em;
  box-sizing: border-box; min-height: 52px;
  padding: 15px 30px;
  border: 1px solid var(--ink); border-radius: 0;
  background: var(--stock);
  color: var(--ink);
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(16px, 2vw, 19px); letter-spacing:.01em;
  text-decoration: none;
  transition: transform .2s var(--ease-plate),
              background-color .18s var(--ease-shutter),
              color .18s var(--ease-shutter),
              box-shadow .2s var(--ease-plate);
}
[data-design="a"] .cc-cta__ext { font-style: normal; color: var(--moss); transition: transform .26s var(--ease-plate); }
@media (hover:hover) and (pointer:fine) {
  [data-design="a"] .cc-cta:hover {
    transform: translateY(-2px);
    background: var(--ink); color: var(--stock);
    box-shadow: 0 10px 26px rgba(8,12,20,.22);
  }
  [data-design="a"] .cc-cta:hover .cc-cta__ext { transform: translate(3px,-3px); color: var(--stock); }
}
[data-design="a"] .cc-cta:focus-visible { outline: 3px solid var(--moss); outline-offset: 3px; }
[data-design="a"] .cc-cta:active { transform: translateY(0); }

/* primary closing + panel CTA = filled moss "Plate" */
[data-design="a"] .cc-cta--closing,
[data-design="a"] .cc-cta--panel,
[data-design="a"] .cc-cta--drawer {
  background: linear-gradient(135deg, var(--moss-bright), #2c3a1f);
  color: #f3ecdc; border-color: transparent;
  box-shadow: 0 6px 22px rgba(8,12,20,.20);
  animation: cc-cta-breath 4.6s ease-in-out infinite;
}
@media (hover:hover) and (pointer:fine) {
  [data-design="a"] .cc-cta--closing:hover,
  [data-design="a"] .cc-cta--panel:hover,
  [data-design="a"] .cc-cta--drawer:hover {
    background: linear-gradient(135deg, #57754a, #344726);
    color:#fff; box-shadow: 0 12px 30px rgba(61,74,42,.40);
  }
  [data-design="a"] .cc-cta--closing:hover .cc-cta__ext,
  [data-design="a"] .cc-cta--panel:hover .cc-cta__ext,
  [data-design="a"] .cc-cta--drawer:hover .cc-cta__ext { color:#fff; }
}
[data-design="a"] .cc-cta--closing .cc-cta__ext,
[data-design="a"] .cc-cta--panel .cc-cta__ext,
[data-design="a"] .cc-cta--drawer .cc-cta__ext { color:#dfe7cf; }
[data-design="a"] .cc-cta--drawer { width:max-content; }

@keyframes cc-cta-breath {
  0%,100% { box-shadow: 0 6px 22px rgba(8,12,20,.20); }
  50%     { box-shadow: 0 9px 30px rgba(61,74,42,.42); }
}

/* =========================================================================
   2. PLACE STORY + feature parallax photo
   ========================================================================= */
[data-design="a"] .cc-story { padding-top: var(--space-folio); }
[data-design="a"] .cc-story__title {
  margin: .1em 0 var(--space-passe);
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  font-size: clamp(30px, 5vw, 46px); line-height: 1.12; color: var(--ink);
  max-width: 24ch; text-wrap: balance;
}
[data-design="a"] .cc-story__body {
  columns: 2; column-gap: var(--space-passe);
}
[data-design="a"] .cc-story__body p {
  margin: 0 0 var(--space-stop); break-inside: avoid;
  color: var(--ink-soft); text-wrap: pretty;
}
/* the handoff feature image — body-life adds data-bl-parallax-frame + drives --bl-py */
[data-design="a"] .cc-feature {
  margin: var(--space-folio) auto 0;
  width: 100%; max-width: var(--maxw);
  padding-inline: clamp(20px, 5vw, 48px); box-sizing: border-box;
}
[data-design="a"] .cc-feature img {
  display: block; width: 100%; aspect-ratio: 16/9;
  object-fit: cover; border-radius: 2px;
  box-shadow: 0 0 0 1px var(--rule), 0 0 0 8px var(--stock);
}
[data-design="a"] .cc-feature__cap {
  margin: var(--space-stop) 0 0;
  font-family: var(--font-caption); font-size: var(--text-foot);
  letter-spacing: .04em; color: var(--muted);
}

/* =========================================================================
   3. KEY FACTS
   ========================================================================= */
[data-design="a"] .cc-facts { padding-block: var(--space-spread); }
[data-design="a"] .cc-facts__grid {
  margin: 0; display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-frame);
}
[data-design="a"] .cc-fact {
  padding-top: var(--space-stop);
  border-top: 1px solid var(--rule);
}
[data-design="a"] .cc-fact dt {
  margin: 0 0 var(--space-em); font-family: var(--font-caption);
  font-size: var(--text-cap); letter-spacing: .14em; text-transform: lowercase;
  color: var(--moss);
}
[data-design="a"] .cc-fact dd {
  margin: 0; font-size: var(--text-body); line-height: 1.5; color: var(--ink-soft);
}

/* =========================================================================
   4. STAYS SELECTOR (INT-1)
   ========================================================================= */
[data-design="a"] .cc-stays {
  padding-block: var(--space-folio);
  background: var(--stock-deep);
  border-block: 1px solid var(--rule);
}
[data-design="a"] .cc-stays__title {
  margin: .1em 0 var(--space-spread);
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  font-size: var(--text-plate); color: var(--ink); text-wrap: balance;
}
[data-design="a"] .cc-stays__tabs {
  display: flex; flex-wrap: wrap; gap: var(--space-stop);
  margin-bottom: var(--space-spread);
  border-bottom: 1px solid var(--rule);
}
[data-design="a"] .cc-tab {
  appearance: none; background: none; border: none; cursor: pointer;
  padding: 0 0 var(--space-stop); margin-bottom: -1px;
  min-height: 44px;
  font-family: var(--font-display); font-style: italic; font-size: var(--text-pull);
  color: var(--muted);
  position: relative;
  transition: color .26s var(--ease-plate);
}
[data-design="a"] .cc-tab::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px;
  background: var(--moss);
  transform: scaleX(0); transform-origin: left center;
  transition: transform .3s var(--ease-plate);
}
[data-design="a"] .cc-tab[aria-selected="true"] { color: var(--ink); }
[data-design="a"] .cc-tab[aria-selected="true"]::after { transform: scaleX(1); }
@media (hover:hover) and (pointer:fine) {
  [data-design="a"] .cc-tab:hover { color: var(--ink); }
}
[data-design="a"] .cc-tab:focus-visible { outline: 2px solid var(--moss); outline-offset: 4px; }

[data-design="a"] .cc-panel {
  display: grid; grid-template-columns: 1.15fr 1fr; gap: var(--space-passe);
  align-items: center;
}
[data-design="a"] .cc-panel[hidden] { display: none; }
[data-design="a"] .cc-panel {
  opacity: 1;
  animation: cc-panel-in .42s var(--ease-plate) both;
}
[data-design="a"] .cc-panel__photo { margin: 0; overflow: hidden; border-radius: 2px;
  box-shadow: 0 0 0 1px var(--rule), 0 0 0 8px var(--stock); }
[data-design="a"] .cc-panel__photo img {
  display: block; width: 100%; aspect-ratio: 4/3; object-fit: cover;
  transform: scale(1.02); transition: transform .9s var(--ease-plate);
}
@media (hover:hover) and (pointer:fine) {
  [data-design="a"] .cc-panel__photo:hover img { transform: scale(1.06); }
}
[data-design="a"] .cc-panel__datum {
  margin: 0 0 var(--space-stop); font-family: var(--font-caption);
  font-size: var(--text-cap); letter-spacing: .1em; text-transform: lowercase; color: var(--muted);
}
[data-design="a"] .cc-panel__name {
  margin: 0 0 var(--space-stop); font-family: var(--font-display); font-style: italic;
  font-weight: 400; font-size: var(--text-plate); color: var(--ink);
}
[data-design="a"] .cc-panel__note {
  margin: 0 0 var(--space-passe); max-width: 52ch; color: var(--ink-soft); text-wrap: pretty;
}

@keyframes cc-panel-in {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* =========================================================================
   POINTER (Element 6) — place-rooted wayfinder (a leaf drifting toward gallery)
   Not a button. Motion: transform/opacity only, slow cycle.
   ========================================================================= */
[data-design="a"] .cc-pointer {
  display: flex; flex-direction: column; align-items: center; gap: var(--space-stop);
  width: max-content; margin: 0 auto;
  padding: var(--space-spread) 24px;
  text-decoration: none;
}
[data-design="a"] .cc-pointer__label {
  font-family: var(--font-caption); font-size: var(--text-cap);
  letter-spacing: .2em; text-transform: lowercase; color: var(--muted);
  transition: color .3s var(--ease-plate);
}
[data-design="a"] .cc-pointer__stem {
  position: relative; display: block; width: 1px; height: 56px;
  background: linear-gradient(var(--rule), transparent);
}
[data-design="a"] .cc-pointer__leaf {
  position: absolute; left: -3px; top: 0;
  width: 7px; height: 7px; border-radius: 0 50% 50% 50%;
  background: var(--moss);
  transform: translateY(0) rotate(45deg); opacity: .9;
  animation: cc-leaf-fall 5.2s var(--ease-sky) infinite;
}
@media (hover:hover) and (pointer:fine) {
  [data-design="a"] .cc-pointer:hover .cc-pointer__label { color: var(--ink); }
}
[data-design="a"] .cc-pointer:focus-visible { outline: 2px solid var(--moss); outline-offset: 6px; }
@keyframes cc-leaf-fall {
  0%   { transform: translateY(0) rotate(45deg);   opacity: 0; }
  18%  { opacity: .95; }
  100% { transform: translateY(50px) rotate(135deg); opacity: 0; }
}

/* =========================================================================
   5. GALLERY
   ========================================================================= */
[data-design="a"] .cc-gallery { padding-block: var(--space-folio); }
[data-design="a"] .cc-gallery__title {
  margin: .1em 0 var(--space-spread);
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  font-size: var(--text-plate); color: var(--ink);
}
[data-design="a"] .cc-gallery__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-frame);
}
[data-design="a"] .cc-plate { margin: 0; overflow: hidden; border-radius: 2px;
  box-shadow: 0 0 0 1px var(--rule); }
[data-design="a"] .cc-plate img {
  display: block; width: 100%; aspect-ratio: 4/3; object-fit: cover;
  transform: scale(1.01); transition: transform .9s var(--ease-plate);
}
@media (hover:hover) and (pointer:fine) {
  [data-design="a"] .cc-plate:hover img { transform: scale(1.07); }
}

/* =========================================================================
   6. NEARBY
   ========================================================================= */
[data-design="a"] .cc-nearby { padding-block: var(--space-folio); background: var(--stock-deep); border-block: 1px solid var(--rule); }
[data-design="a"] .cc-nearby__title {
  margin: .1em 0 var(--space-spread); font-family: var(--font-display);
  font-style: italic; font-weight: 400; font-size: var(--text-plate); color: var(--ink); text-wrap: balance;
}
[data-design="a"] .cc-nearby__list { list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap: var(--space-passe) var(--space-frame); }
[data-design="a"] .cc-nearby__list li {
  display: flex; flex-direction: column; gap: var(--space-em);
  padding-top: var(--space-stop); border-top: 1px solid var(--rule);
}
[data-design="a"] .cc-nearby__name { font-family: var(--font-display); font-style: italic; font-size: var(--text-pull); color: var(--ink); }
[data-design="a"] .cc-nearby__desc { font-size: var(--text-foot); line-height: 1.55; color: var(--ink-soft); }

/* =========================================================================
   7. HOST
   ========================================================================= */
[data-design="a"] .cc-host { padding-block: var(--space-folio); }
[data-design="a"] .cc-host__title {
  margin: .1em 0 var(--space-frame); font-family: var(--font-display);
  font-style: italic; font-weight: 400; font-size: var(--text-plate); color: var(--ink);
}
[data-design="a"] .cc-host__note { margin: 0; max-width: 64ch; font-size: var(--text-pull); line-height: 1.5; color: var(--ink-soft); text-wrap: pretty; }

/* =========================================================================
   8. CLOSING
   ========================================================================= */
[data-design="a"] .cc-closing { padding-block: var(--space-folio); background: var(--ink); }
[data-design="a"] .cc-closing__wrap { text-align: center; }
[data-design="a"] .cc-closing__title {
  margin: 0 0 var(--space-stop); font-family: var(--font-display); font-style: italic;
  font-weight: 400; font-size: clamp(30px, 5vw, 46px); line-height: 1.15; color: var(--stock); text-wrap: balance;
}
[data-design="a"] .cc-closing__note {
  margin: 0 0 var(--space-passe); font-family: var(--font-caption);
  font-size: var(--text-cap); letter-spacing: .12em; text-transform: lowercase; color: #b9b3a3;
}
[data-design="a"] .cc-closing .cc-cta { font-size: clamp(17px, 2.2vw, 20px); }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 880px) {
  [data-design="a"] .cc-panel { grid-template-columns: 1fr; gap: var(--space-frame); }
  [data-design="a"] .cc-gallery__grid { grid-template-columns: repeat(2, 1fr); }
  [data-design="a"] .cc-story__body { columns: 1; }
}
@media (max-width: 560px) {
  [data-design="a"] .cc-story { padding-top: var(--space-spread); }
  [data-design="a"] .cc-gallery__grid { grid-template-columns: 1fr; }
  [data-design="a"] .cc-feature img { aspect-ratio: 4/3; }
  [data-design="a"] .cc-drawer__sheet { width: 100vw; border-left: none; }
  [data-design="a"] .cc-cta { width: 100%; justify-content: center; }
  [data-design="a"] .cc-cta--drawer { width: 100%; }
}
@media (max-width: 390px) {
  [data-design="a"] .cc-logo__mark { font-size: 18px; }
}

/* =========================================================================
   REDUCED MOTION
   ========================================================================= */
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .cc-weatherwash { animation: none; background-position: 40% 50%; }
  [data-design="a"] .cc-cta,
  [data-design="a"] .cc-cta--closing,
  [data-design="a"] .cc-cta--panel,
  [data-design="a"] .cc-cta--drawer,
  [data-design="a"] .cc-cta__ext,
  [data-design="a"] .cc-burger__rule,
  [data-design="a"] .cc-drawer,
  [data-design="a"] .cc-drawer__sheet,
  [data-design="a"] .cc-tab,
  [data-design="a"] .cc-tab::after,
  [data-design="a"] .cc-panel__photo img,
  [data-design="a"] .cc-plate img,
  [data-design="a"] .cc-nav a { transition: none; animation: none; }
  [data-design="a"] .cc-panel { animation: none; }
  [data-design="a"] .cc-pointer__leaf { animation: none; opacity: .9; }
  [data-design="a"] .cc-pointer__label { transition: none; }
}

/* =========================================================================
   MOBILE NO-OVERFLOW 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; }
