/* =====================================================================
   Fuji Japanese Steakhouse — design-a (Cellar Book, remapped to "a")
   Tokens exposed on [data-design="a"]
   ===================================================================== */
[data-design="a"] {
  --design-a-primary: #6E2333;
  --clb-cellar: #241B1E;
  --clb-cellar-2: #2F2427;
  --clb-stone: #4A3E3D;
  --clb-page: #F4EDDC;
  --clb-feint: #DCD1B4;
  --clb-ink: #2B2320;
  --clb-chalk: #EFE6D2;
  --clb-muted: #7C7263;
  --clb-claret: #6E2333;
  --clb-candle: #D6A544;
  --clb-critical: #A03B2E;
  --clb-success: #4C6B4F;

  --clb-nip: 4px;
  --clb-taste: 8px;
  --clb-pour: 16px;
  --clb-glass: 24px;
  --clb-bottle: 32px;
  --clb-magnum: 48px;
  --clb-case: 64px;
  --clb-bin: 96px;

  --clb-sip: 150ms;
  --clb-draw: 320ms;
  --clb-decant: 560ms;
  --clb-twist-t: 620ms;
  --clb-give-t: 480ms;
  --clb-ease-velvet: cubic-bezier(0.25, 0.1, 0.25, 1);
  --clb-ease-twist: cubic-bezier(0.45, 0, 0.55, 1);
  --clb-ease-tension: cubic-bezier(0.6, 0, 0.9, 0.35);
  --clb-ease-give: cubic-bezier(0.2, 1.35, 0.4, 1);

  --clb-r-0: 0;
  --clb-r-card: 2px;
  --clb-r-punt: 999px;

  --clb-e-leaf: 0 1px 2px rgba(43,35,32,.18);
  --clb-e-bench: 0 6px 16px rgba(20,14,16,.35);
  --clb-e-well: inset 0 2px 6px rgba(0,0,0,.4);
  --clb-e-candle: 0 0 48px rgba(214,165,68,.18);
}

[data-design="a"].dq-design {
  font-family: "Crimson Text", Georgia, "Times New Roman", serif;
  color: var(--clb-ink);
  background: var(--clb-page);
  isolation: isolate;
}

/* ---------------------------------------------------------------------
   ELEMENT 1 — header
   --------------------------------------------------------------------- */
[data-design="a"].clb-header {
  position: sticky; top: 0; z-index: 60;
  background: var(--clb-cellar-2);
}
[data-design="a"] .clb-header__band {
  max-width: 1320px; margin-inline: auto;
  padding: 14px clamp(20px, 5vw, 48px);
  display: flex; align-items: center; justify-content: space-between;
  min-height: 64px;
}
[data-design="a"] .clb-logo {
  font-family: "Cormorant Garamond", Garamond, Georgia, serif;
  font-variant-caps: small-caps; font-weight: 600;
  font-size: clamp(1.1rem, 2.6vw, 1.55rem); letter-spacing: .05em;
  color: var(--clb-chalk); text-decoration: none;
}
[data-design="a"] .clb-header__gilt {
  position: absolute; left: 0; right: 0; bottom: 0; height: 2px;
  background: var(--clb-stone);
  overflow: hidden; pointer-events: none;
}
[data-design="a"] .clb-header__sheen {
  position: absolute; inset: 0 auto 0 0; width: 180px;
  background: linear-gradient(90deg, transparent,
              rgba(214,165,68,.85) 50%, transparent);
  animation: clb-gilt-sheen 26s linear infinite;
}
@keyframes clb-gilt-sheen {
  0%   { transform: translateX(-200px); opacity: 0; }
  6%   { opacity: 1; }
  94%  { opacity: 1; }
  100% { transform: translateX(calc(100vw + 200px)); opacity: 0; }
}
[data-design="a"] .clb-burger {
  display: grid; gap: 5px; padding: 12px; min-width: 44px; min-height: 44px;
  background: none; border: 0; cursor: pointer; place-content: center;
}
[data-design="a"] .clb-burger__line {
  width: 22px; height: 2px; background: var(--clb-chalk);
  transition: transform var(--clb-sip) var(--clb-ease-velvet),
              opacity var(--clb-sip) var(--clb-ease-velvet);
}
[data-design="a"] .clb-burger:focus-visible {
  outline: 2px solid var(--clb-candle); outline-offset: 2px;
}
[data-design="a"] .clb-burger[aria-expanded="true"] .clb-burger__line:nth-child(1) { transform: translateY(7px) rotate(45deg); }
[data-design="a"] .clb-burger[aria-expanded="true"] .clb-burger__line:nth-child(2) { opacity: 0; }
[data-design="a"] .clb-burger[aria-expanded="true"] .clb-burger__line:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }
[data-design="a"] .clb-door {
  position: fixed; inset: 64px 0 auto 0; z-index: 59;
  background: var(--clb-cellar-2);
  box-shadow: var(--clb-e-bench);
  display: grid; gap: 4px; padding: 24px clamp(20px, 5vw, 48px) 32px;
  transform: translateY(-10px); opacity: 0;
  transition: transform var(--clb-decant) var(--clb-ease-velvet),
              opacity var(--clb-decant) var(--clb-ease-velvet);
}
[data-design="a"] .clb-door.is-open { transform: translateY(0); opacity: 1; }
[data-design="a"] .clb-door[hidden] { display: none; }
[data-design="a"] .clb-door a {
  font-family: "Cormorant Garamond", Garamond, Georgia, serif;
  font-variant-caps: small-caps; font-size: 1.15rem; letter-spacing: .04em;
  color: var(--clb-chalk); text-decoration: none;
  padding: 12px 0; min-height: 44px; display: flex; align-items: center;
  border-bottom: 1px solid var(--clb-stone);
}
[data-design="a"] .clb-door a:focus-visible {
  outline: 2px solid var(--clb-candle); outline-offset: 2px;
}
[data-design="a"] .clb-door__tel { color: var(--clb-candle); }
@media (max-width: 640px) {
  [data-design="a"] .clb-door { inset: 64px 0 0 0; overflow-y: auto; }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .clb-header__sheen { animation: none; opacity: .5; transform: translateX(35vw); }
  [data-design="a"] .clb-door { transition: none; }
}

/* ---------------------------------------------------------------------
   ELEMENT 3 — hero (bin wall + composer-built animated menu)
   --------------------------------------------------------------------- */
[data-design="a"] .clb-hero {
  position: relative; overflow: hidden; isolation: isolate;
  background: var(--clb-cellar);
  min-height: 72vh; display: flex; align-items: flex-end;
  padding: var(--clb-bin) 0 var(--clb-case);
}
[data-design="a"] .clb-binwall { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
[data-design="a"] .clb-binwall__punts {
  position: absolute; inset: 0;
  background:
    radial-gradient(circle 34px at 40px 44px, #3A2C30 62%, #2A2023 66%, transparent 70%),
    radial-gradient(circle 12px at 40px 44px, #1D1517 70%, transparent 74%);
  background-size: 128px 112px;
  opacity: .9;
}
[data-design="a"] .clb-binwall__joints {
  position: absolute; inset: 0;
  background:
    linear-gradient(to bottom, transparent 110px, var(--clb-stone) 111px, transparent 112px),
    linear-gradient(to right, transparent 254px, var(--clb-stone) 255px, transparent 256px);
  background-size: 100% 112px, 256px 100%;
  opacity: .5;
}
[data-design="a"] .clb-binwall__chalk {
  position: absolute;
  font-family: "Courier Prime", "Courier New", monospace;
  font-size: .8rem; letter-spacing: .12em; color: var(--clb-chalk); opacity: .38;
}
[data-design="a"] .clb-binwall__chalk--1 { top: 12%; left: 8%; }
[data-design="a"] .clb-binwall__chalk--2 { top: 34%; right: 12%; }
[data-design="a"] .clb-binwall__chalk--3 { top: 58%; left: 22%; }
[data-design="a"] .clb-candlepool {
  position: absolute; top: -20%; left: -10%;
  inline-size: 90vmin; aspect-ratio: 1; border-radius: var(--clb-r-punt);
  background: radial-gradient(circle,
    rgba(214,165,68,.34) 0%, rgba(214,165,68,.14) 38%, transparent 68%);
  animation: clb-candle-drift 22s var(--clb-ease-velvet) infinite alternate;
  will-change: transform;
}
@keyframes clb-candle-drift {
  0%   { transform: translate(0, 0) scale(1); opacity: .85; }
  45%  { transform: translate(38vw, 12vh) scale(1.12); opacity: 1; }
  100% { transform: translate(62vw, 4vh) scale(.94); opacity: .8; }
}
[data-design="a"] .clb-hero__col {
  position: relative; z-index: 2;
  max-width: 1320px; width: 100%; margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="a"] .clb-hero__kicker {
  font-family: "Courier Prime", "Courier New", monospace;
  font-size: .85rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--clb-candle); margin: 0 0 var(--clb-taste); opacity: 1;
}
[data-design="a"] .clb-hero__title {
  font-family: "Cormorant Garamond", Garamond, Georgia, serif;
  font-weight: 600; font-size: clamp(2.1rem, 6.5vw, 4.05rem);
  line-height: 1.12; color: var(--clb-chalk); opacity: 1;
  margin: 0 0 var(--clb-pour); max-width: 18ch;
}
[data-design="a"] .clb-hero__sub {
  font-family: "Crimson Text", Georgia, serif; font-style: italic;
  font-size: clamp(1.05rem, 2.2vw, 1.3rem); line-height: 1.5;
  color: var(--clb-muted); opacity: 1; margin: 0 0 var(--clb-bottle); max-width: 52ch;
}
@media (max-width: 640px) {
  [data-design="a"] .clb-hero { min-height: 100svh; }
  [data-design="a"] .clb-binwall__punts { background-size: 96px 88px; }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .clb-candlepool {
    animation: none; transform: translate(30vw, 8vh);
  }
}

/* The composer-built animated popular-items menu — native to cellar-book
   tokens/type/motion. Reveals in sequence, THEN settles into an ongoing
   ambient idle (a slow claret rule shimmer) per trade.md Element 3. */
[data-design="a"] .clb-menu-ledger {
  position: relative; z-index: 2;
  margin: 0 auto var(--clb-bottle);
  max-width: 46ch;
}
[data-design="a"] .clb-menu-ledger__flag {
  font-family: "Courier Prime", "Courier New", monospace;
  font-size: .72rem; letter-spacing: .08em; text-transform: uppercase;
  color: var(--clb-muted); opacity: 1; margin: 0 0 var(--clb-taste);
}
[data-design="a"] .clb-menu-ledger__list {
  list-style: none; margin: 0; padding: 0;
  display: grid; gap: var(--clb-taste);
}
[data-design="a"] .clb-menu-ledger__row {
  display: flex; align-items: baseline; gap: var(--clb-taste);
  padding-bottom: var(--clb-nip);
  border-bottom: 1px solid var(--clb-stone);
  color: var(--clb-chalk); opacity: 1;
  font-family: "Cormorant Garamond", Garamond, Georgia, serif;
  font-size: 1.05rem;
  transform: translateY(10px); opacity: 0;
  animation: clb-menu-reveal var(--clb-decant) var(--clb-ease-velvet) forwards;
}
[data-design="a"] .clb-menu-ledger__row:nth-child(1) { animation-delay: .05s; }
[data-design="a"] .clb-menu-ledger__row:nth-child(2) { animation-delay: .25s; }
[data-design="a"] .clb-menu-ledger__row:nth-child(3) { animation-delay: .45s; }
[data-design="a"] .clb-menu-ledger__row:nth-child(4) { animation-delay: .65s; }
@keyframes clb-menu-reveal {
  from { transform: translateY(10px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
[data-design="a"] .clb-menu-ledger__name { flex: 0 0 auto; }
[data-design="a"] .clb-menu-ledger__leader {
  flex: 1 1 auto; align-self: center;
  height: 1px; background: var(--clb-stone);
  position: relative; overflow: hidden;
}
/* Ongoing idle ambience after reveal — a slow claret shimmer along the
   leader rule, transform/opacity only, tasteful, no flashing under 4s. */
[data-design="a"] .clb-menu-ledger__leader::after {
  content: ""; position: absolute; inset: 0 auto 0 0; width: 40%;
  background: linear-gradient(90deg, transparent, var(--clb-candle) 50%, transparent);
  animation: clb-leader-shimmer 9s var(--clb-ease-velvet) infinite;
  animation-delay: 1.4s;
}
@keyframes clb-leader-shimmer {
  0%   { transform: translateX(-120%); opacity: 0; }
  10%  { opacity: .6; }
  50%  { opacity: .6; }
  60%  { transform: translateX(260%); opacity: 0; }
  100% { transform: translateX(260%); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .clb-menu-ledger__row {
    animation: none; transform: none; opacity: 1;
  }
  [data-design="a"] .clb-menu-ledger__leader::after { animation: none; opacity: 0; }
}

/* ---------------------------------------------------------------------
   ELEMENT 2 — action cluster (the Pulls)
   --------------------------------------------------------------------- */
[data-design="a"] .clb-cta-cluster {
  position: relative; z-index: 2;
  display: flex; flex-wrap: wrap; gap: var(--clb-pour);
  align-items: center;
}
[data-design="a"] .clb-pull {
  position: relative; display: inline-flex; align-items: center; justify-content: center;
  min-height: 56px; padding: 14px 28px;
  font-family: "Cormorant Garamond", Garamond, Georgia, serif;
  font-variant-caps: small-caps; font-weight: 600; letter-spacing: .06em;
  font-size: 1.1rem; text-decoration: none;
  border-radius: var(--clb-r-card);
  transition: transform var(--clb-sip) var(--clb-ease-velvet);
}
[data-design="a"] .clb-pull--primary {
  background: var(--clb-claret); color: var(--clb-chalk);
  box-shadow: var(--clb-e-leaf);
}
[data-design="a"] .clb-pull--quiet {
  color: var(--clb-chalk); min-height: 44px; padding: 10px 12px;
  border-bottom: 1px solid var(--clb-stone);
}
[data-design="a"] .clb-pull__wick {
  position: absolute; left: 12px; right: 12px; bottom: 6px; height: 2px;
  background: var(--clb-candle); transform-origin: center;
  animation: clb-wick-breath 5s var(--clb-ease-velvet) infinite;
}
@keyframes clb-wick-breath {
  0%, 100% { transform: scaleX(.55); opacity: .55; }
  50%      { transform: scaleX(1);   opacity: 1; }
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .clb-pull:hover { transform: translateY(-1px); }
}
[data-design="a"] .clb-pull:focus-visible {
  outline: 2px solid var(--clb-candle); outline-offset: 2px;
}
[data-design="a"] .clb-pull:active { transform: translateY(1px) scale(.985); }
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .clb-pull__wick { animation: none; transform: scaleX(1); opacity: .8; }
  [data-design="a"] .clb-pull { transition: none; }
}

/* ---------------------------------------------------------------------
   ELEMENT 6 — pointer (the decant)
   --------------------------------------------------------------------- */
[data-design="a"] .clb-pointer {
  display: grid; justify-items: center; gap: var(--clb-taste);
  padding: var(--clb-bottle) 0; background: var(--clb-cellar);
  opacity: 1;
}
[data-design="a"] .clb-pointer__label {
  font-family: "Cormorant Garamond", Garamond, Georgia, serif;
  font-variant-caps: small-caps; letter-spacing: .1em;
  font-size: .95rem; color: var(--clb-muted);
}
[data-design="a"] .clb-pointer__stream {
  position: relative; inline-size: 2px; block-size: 72px;
  background: var(--clb-stone); overflow: hidden; border-radius: 1px;
}
[data-design="a"] .clb-pointer__fill {
  position: absolute; inset: 0;
  background: var(--clb-claret);
  transform: scaleY(0); transform-origin: top;
  animation: clb-decant-fill 5.5s var(--clb-ease-velvet) infinite;
}
[data-design="a"] .clb-pointer__drop {
  position: absolute; top: 0; left: 50%;
  inline-size: 6px; block-size: 6px; margin-left: -3px;
  border-radius: var(--clb-r-punt); background: var(--clb-claret);
  animation: clb-decant-drop 5.5s var(--clb-ease-velvet) infinite;
}
@keyframes clb-decant-fill {
  0%       { transform: scaleY(0); opacity: 1; }
  55%      { transform: scaleY(1); opacity: 1; }
  82%      { transform: scaleY(1); opacity: .35; }
  100%     { transform: scaleY(1); opacity: 0; }
}
@keyframes clb-decant-drop {
  0%   { transform: translateY(-8px); opacity: 0; }
  12%  { opacity: 1; }
  55%  { transform: translateY(70px); opacity: 1; }
  70%, 100% { transform: translateY(70px); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .clb-pointer__fill { animation: none; transform: scaleY(1); opacity: .8; }
  [data-design="a"] .clb-pointer__drop { animation: none; opacity: 0; }
}

/* ---------------------------------------------------------------------
   ELEMENT 5 — THE CORKSCREW (the interactive centerpiece, INT-1)
   --------------------------------------------------------------------- */
[data-design="a"] .clb-reveal {
  background: var(--clb-cellar);
  padding: clamp(56px, 8vw, 96px) 0;
}
[data-design="a"] .clb-reveal__col {
  max-width: 1320px; margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
  display: grid; justify-items: center;
}
[data-design="a"] .clb-reveal__kicker {
  font-family: "Courier Prime", "Courier New", monospace;
  font-size: .85rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--clb-candle); margin: 0 0 var(--clb-glass);
}
[data-design="a"] .clb-bincard {
  position: relative; width: min(100%, 560px);
  margin-inline: auto;
  background: var(--clb-page); border-radius: var(--clb-r-card);
  box-shadow: var(--clb-e-bench);
  padding: var(--clb-magnum) var(--clb-glass) var(--clb-glass);
  text-align: left;
}
[data-design="a"] .clb-bincard__neck {
  position: absolute; top: -34px; left: 50%; transform: translateX(-50%);
  pointer-events: none;
}
[data-design="a"] .clb-cork {
  display: block; inline-size: 48px; block-size: 84px;
  filter: drop-shadow(0 2px 3px rgba(0,0,0,.4));
}
[data-design="a"] .clb-screw { display: block; inline-size: 100%; block-size: 100%; }
[data-design="a"] .clb-bincard.is-twisting .clb-screw {
  animation: clb-twist var(--clb-twist-t) var(--clb-ease-twist) forwards;
}
@keyframes clb-twist {
  0%   { transform: rotate(0turn) translateY(0); }
  100% { transform: rotate(2turn) translateY(10px); }
}
[data-design="a"] .clb-bincard.is-giving .clb-cork {
  animation: clb-give var(--clb-give-t) var(--clb-ease-tension) forwards;
}
@keyframes clb-give {
  0%   { transform: translateY(0) rotate(0); }
  55%  { transform: translateY(-8px) rotate(0); }
  80%  { transform: translateY(-52px) rotate(-6deg); }
  100% { transform: translateY(-46px) rotate(-8deg); }
}
[data-design="a"] .clb-bincard.is-drawn .clb-cork {
  transform: translateY(-46px) rotate(-8deg);
}
[data-design="a"] .clb-draw-btn {
  display: block; margin: 0 auto var(--clb-glass);
  min-height: 56px; min-width: 44px; padding: 14px 28px;
  background: var(--clb-claret); color: var(--clb-chalk);
  font-family: "Cormorant Garamond", Garamond, Georgia, serif;
  font-variant-caps: small-caps; font-weight: 600; font-size: 1.08rem;
  letter-spacing: .06em; border: 0; border-radius: var(--clb-r-card);
  cursor: pointer;
  transition: transform var(--clb-sip) var(--clb-ease-velvet);
}
[data-design="a"] .clb-draw-btn:active { transform: translateY(1px) scale(.985); }
[data-design="a"] .clb-draw-btn:focus-visible {
  outline: 2px solid var(--clb-candle); outline-offset: 2px;
}
[data-design="a"] .clb-bincard.is-drawn .clb-draw-btn {
  opacity: 0; pointer-events: none;
  transition: opacity var(--clb-draw) var(--clb-ease-velvet);
}
[data-design="a"] .clb-bincard__entry {
  clip-path: inset(0 0 100% 0);
  transition: clip-path var(--clb-decant) var(--clb-ease-velvet);
}
[data-design="a"] .clb-bincard.is-drawn .clb-bincard__entry {
  clip-path: inset(0 0 0 0);
}
[data-design="a"] .clb-bincard__title {
  font-family: "Cormorant Garamond", Garamond, Georgia, serif;
  font-weight: 600; font-size: clamp(1.35rem, 3vw, 1.8rem);
  color: var(--clb-ink); margin: 0 0 var(--clb-taste);
  border-top: 1px solid var(--clb-feint); padding-top: var(--clb-pour);
}
[data-design="a"] .clb-bincard__note {
  font-family: "Crimson Text", Georgia, serif; font-style: italic;
  font-size: 1.05rem; line-height: 1.65; color: var(--clb-ink);
  margin: 0 0 var(--clb-pour); max-width: 60ch;
}
[data-design="a"] .clb-bincard__foot {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: var(--clb-pour); border-top: 1px dotted var(--clb-feint);
  padding-top: var(--clb-pour);
}
[data-design="a"] .clb-bincard__price {
  font-family: "Courier Prime", "Courier New", monospace;
  font-variant-numeric: tabular-nums; white-space: nowrap;
  color: var(--clb-claret); font-size: 1.1rem;
}
[data-design="a"] .clb-bincard__follow {
  color: var(--clb-claret); font-family: "Crimson Text", Georgia, serif;
  min-height: 44px; display: inline-flex; align-items: center;
}
[data-design="a"] .clb-bincard__follow:focus-visible {
  outline: 2px solid var(--clb-candle); outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .clb-bincard.is-twisting .clb-screw,
  [data-design="a"] .clb-bincard.is-giving .clb-cork { animation: none; }
  [data-design="a"] .clb-bincard__entry { transition: none; }
  [data-design="a"] .clb-bincard.is-drawn .clb-cork { transform: translateY(-46px) rotate(-8deg); }
}

/* ---------------------------------------------------------------------
   ELEMENT 7 — scroll choreography (the descent / full menu)
   --------------------------------------------------------------------- */
[data-design="a"] .clb-descent {
  background: var(--clb-page);
  padding: clamp(56px, 8vw, 96px) 0;
}
[data-design="a"] .clb-descent__col {
  max-width: 1320px; margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="a"] .clb-descent__title {
  font-family: "Cormorant Garamond", Garamond, Georgia, serif;
  font-variant-caps: small-caps; font-weight: 600;
  font-size: clamp(1.55rem, 3.4vw, 2.1rem); color: var(--clb-ink);
  margin: 0 0 var(--clb-pour);
}
[data-design="a"] .clb-descent__rule {
  display: block; block-size: 2px; background: var(--clb-claret);
  margin-bottom: var(--clb-bottle);
  transform: scaleX(1); transform-origin: left;
}
[data-design="a"] .clb-descent__item {
  border-bottom: 1px solid var(--clb-feint);
  padding: var(--clb-pour) 0;
}
@supports (animation-timeline: view()) {
  [data-design="a"] .clb-descent__rule {
    transform-origin: left;
    animation: clb-descent-rule linear both;
    animation-timeline: view();
    animation-range: entry 10% entry 55%;
  }
  @keyframes clb-descent-rule {
    from { transform: scaleX(0); }
    to   { transform: scaleX(1); }
  }
  [data-design="a"] .clb-descent__title {
    animation: clb-descent-settle linear both;
    animation-timeline: view();
    animation-range: entry 5% entry 45%;
  }
  [data-design="a"] .clb-descent__item {
    animation: clb-descent-settle linear both;
    animation-timeline: view();
    animation-range: entry 15% entry 65%;
  }
  [data-design="a"] .clb-descent__item:nth-child(2) { animation-range: entry 22% entry 72%; }
  [data-design="a"] .clb-descent__item:nth-child(3) { animation-range: entry 29% entry 79%; }
  @keyframes clb-descent-settle {
    from { transform: translateY(26px); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
  }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .clb-descent__rule,
  [data-design="a"] .clb-descent__title,
  [data-design="a"] .clb-descent__item {
    animation: none; transform: none; opacity: 1;
  }
}
[data-design="a"] .clb-entry__bin {
  font-family: "Courier Prime", "Courier New", monospace;
  font-size: .82rem; letter-spacing: .12em; color: var(--clb-claret);
}
[data-design="a"] .clb-entry__note {
  font-family: "Crimson Text", Georgia, serif;
  font-size: 1.06rem; line-height: 1.65; color: var(--clb-ink);
  max-width: 65ch; margin: var(--clb-taste) 0 0;
}
/* The reading column itself: capped to the prose measure per design.md's
   "single 65ch reading column" pattern, self-centered so it never reads
   as a stranded box against the wider padded section at ultrawide
   viewports (1440 stranded-wrapper sweep). */
[data-design="a"] .clb-page-b__entries {
  max-width: 65ch;
  margin-inline: auto;
}
/* The full-menu descent rows reuse .clb-entry__note as a full-width row
   description (not a narrow reading column) -- uncap the measure there so
   it fills the 1320px row instead of stranding left with a wide right gap. */
[data-design="a"] .clb-descent__item .clb-entry__note {
  max-width: none;
}

/* ---------------------------------------------------------------------
   ELEMENT 4 — ambient segment B (gallery / about / loose cork TAC-3)
   --------------------------------------------------------------------- */
[data-design="a"] .clb-page-b {
  position: relative; background: var(--clb-page);
  padding: clamp(56px, 8vw, 96px) 0; overflow: hidden;
}
[data-design="a"] .clb-ribbon {
  position: absolute; top: -8px; right: clamp(24px, 8vw, 120px);
  inline-size: 22px; block-size: 120px;
  background: var(--clb-claret);
  clip-path: polygon(0 0, 100% 0, 100% 100%, 50% 86%, 0 100%);
  transform-origin: top center;
  animation: clb-ribbon-sway 14s ease-in-out infinite;
  box-shadow: var(--clb-e-leaf);
}
@keyframes clb-ribbon-sway {
  0%, 100% { transform: rotate(-2.5deg); }
  50%      { transform: rotate(2.5deg); }
}
[data-design="a"] .clb-page-b__col {
  max-width: 1320px; margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="a"] .clb-page-b__title {
  font-family: "Cormorant Garamond", Garamond, Georgia, serif;
  font-variant-caps: small-caps; font-weight: 600;
  font-size: clamp(1.55rem, 3.4vw, 2.1rem); color: var(--clb-ink);
  margin: 0 0 var(--clb-bottle);
}
[data-design="a"] .clb-entry {
  border-bottom: 1px solid var(--clb-feint);
  padding: var(--clb-pour) 0;
  transform: translateY(16px); opacity: 0;
  transition: transform var(--clb-decant) var(--clb-ease-velvet),
              opacity var(--clb-decant) var(--clb-ease-velvet);
}
[data-design="a"] .clb-entry.is-inked { transform: translateY(0); opacity: 1; }
[data-design="a"] .clb-cork-loose {
  display: block; margin-top: var(--clb-glass);
  inline-size: 44px; block-size: 44px;
  border: 0; cursor: pointer; padding: 10px; background: none;
}
[data-design="a"] .clb-cork-loose::before {
  content: ""; display: block; inline-size: 24px; block-size: 15px;
  border-radius: var(--clb-r-punt);
  background: linear-gradient(#C9A876, #A9885B);
  box-shadow: var(--clb-e-leaf);
}
[data-design="a"] .clb-cork-loose:focus-visible {
  outline: 2px solid var(--clb-candle); outline-offset: 2px;
}
[data-design="a"] .clb-cork-loose.is-rocked::before {
  animation: clb-cork-rock 640ms var(--clb-ease-give);
}
@keyframes clb-cork-rock {
  0%   { transform: rotate(0); }
  30%  { transform: rotate(-24deg) translateX(-2px); }
  60%  { transform: rotate(14deg) translateX(2px); }
  100% { transform: rotate(0); }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .clb-ribbon { animation: none; transform: rotate(0); }
  [data-design="a"] .clb-entry { transform: none; opacity: 1; transition: none; }
  [data-design="a"] .clb-cork-loose.is-rocked::before { animation: none; }
}

/* ---------------------------------------------------------------------
   Hours & Location
   --------------------------------------------------------------------- */
[data-design="a"] .clb-hours {
  background: var(--clb-page);
  padding: clamp(56px, 8vw, 96px) 0;
}
[data-design="a"] .clb-hours__col {
  max-width: 1320px; margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="a"] .clb-hours__title {
  font-family: "Cormorant Garamond", Garamond, Georgia, serif;
  font-variant-caps: small-caps; font-weight: 600;
  font-size: clamp(1.55rem, 3.4vw, 2.1rem); color: var(--clb-ink);
  margin: 0 0 var(--clb-bottle);
}
[data-design="a"] .clb-hours__card {
  background: var(--clb-cellar-2);
  box-shadow: var(--clb-e-well);
  border-radius: var(--clb-r-card);
  padding: var(--clb-glass);
  max-width: 480px;
  margin-inline: auto;
}
[data-design="a"] .clb-hours__table {
  width: 100%; border-collapse: collapse;
  font-family: "Courier Prime", "Courier New", monospace;
  font-variant-numeric: tabular-nums;
  color: var(--clb-chalk); margin-bottom: var(--clb-pour);
}
[data-design="a"] .clb-hours__table td {
  padding: var(--clb-taste) 0;
  border-bottom: 1px solid var(--clb-stone);
}
[data-design="a"] .clb-hours__table td:last-child { text-align: right; }
[data-design="a"] .clb-hours__address {
  font-family: "Crimson Text", Georgia, serif;
  color: var(--clb-chalk); margin: 0 0 var(--clb-glass);
}
[data-design="a"] .clb-hours__actions {
  display: flex; flex-wrap: wrap; gap: var(--clb-pour);
}

/* ---------------------------------------------------------------------
   Footer
   --------------------------------------------------------------------- */
[data-design="a"] .clb-footer {
  background: var(--clb-cellar);
  padding: var(--clb-case) 0 var(--clb-glass);
}
[data-design="a"] .clb-footer__col {
  max-width: 1320px; margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--clb-glass);
}
[data-design="a"] .clb-footer__heading {
  font-family: "Cormorant Garamond", Garamond, Georgia, serif;
  font-variant-caps: small-caps; font-weight: 600;
  font-size: 1.05rem; color: var(--clb-candle); margin: 0 0 var(--clb-pour);
}
[data-design="a"] .clb-footer__table {
  font-family: "Courier Prime", "Courier New", monospace;
  font-variant-numeric: tabular-nums; color: var(--clb-chalk);
  border-collapse: collapse;
}
[data-design="a"] .clb-footer__table td { padding: var(--clb-nip) var(--clb-taste) var(--clb-nip) 0; }
[data-design="a"] .clb-footer__addr {
  font-family: "Crimson Text", Georgia, serif; color: var(--clb-chalk);
  margin: 0 0 var(--clb-taste); line-height: 1.5;
}
[data-design="a"] .clb-footer__link {
  display: block; color: var(--clb-chalk); text-decoration: none;
  min-height: 32px; padding: 4px 0; border-bottom: 1px solid transparent;
}
[data-design="a"] .clb-footer__link:hover { color: var(--clb-candle); }
[data-design="a"] .clb-footer__link:focus-visible {
  outline: 2px solid var(--clb-candle); outline-offset: 2px;
}
[data-design="a"] .clb-footer__rule {
  max-width: 1320px; margin: var(--clb-case) auto var(--clb-glass);
  padding-inline: clamp(20px, 5vw, 48px);
  height: 1px; background: var(--clb-stone);
  position: relative;
}
[data-design="a"] .clb-footer__dot {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: 6px; height: 6px; border-radius: var(--clb-r-punt);
  background: var(--clb-candle); box-shadow: var(--clb-e-candle);
}
[data-design="a"] .clb-footer__copy {
  text-align: center; font-family: "Courier Prime", "Courier New", monospace;
  font-size: .8rem; color: var(--clb-muted); margin: 0;
}
@media (max-width: 640px) {
  [data-design="a"] .clb-footer__col { grid-template-columns: 1fr; }
}

/* =====================================================================
   MOBILE SAFETY SWEEP (mandatory, bottom-of-file, article-scoped only)
   ===================================================================== */
[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,
[data-design="a"].dq-design svg:not([data-keep-size]) { 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; }
