/* Caspian Mediterranean Cafe -- design-b -- cellar-book, remapped [data-design="b"] */

[data-design="b"] {
  --design-b-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);

  font-family: "Crimson Text", Georgia, "Times New Roman", serif;
  color: var(--clb-ink);
  background: var(--clb-page);
}

/* ===== 1. Header ===== */
[data-design="b"].clb-header {
  position: sticky; top: 0; z-index: 60;
  background: var(--clb-cellar-2);
}
[data-design="b"] .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="b"] .clb-logo {
  font-family: "Cormorant Garamond", Garamond, Georgia, serif;
  font-variant-caps: small-caps; font-weight: 600;
  font-size: clamp(1.2rem, 2.6vw, 1.55rem); letter-spacing: .05em;
  color: var(--clb-chalk); text-decoration: none;
}
[data-design="b"] .clb-header__gilt {
  position: absolute; left: 0; right: 0; bottom: 0; height: 2px;
  background: var(--clb-stone);
  overflow: hidden; pointer-events: none;
}
[data-design="b"] .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="b"] .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="b"] .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="b"] .clb-burger:focus-visible {
  outline: 2px solid var(--clb-candle); outline-offset: 2px;
}
[data-design="b"] .clb-burger[aria-expanded="true"] .clb-burger__line:nth-child(1) { transform: translateY(7px) rotate(45deg); }
[data-design="b"] .clb-burger[aria-expanded="true"] .clb-burger__line:nth-child(2) { opacity: 0; }
[data-design="b"] .clb-burger[aria-expanded="true"] .clb-burger__line:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }
[data-design="b"] .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="b"] .clb-door[hidden] { display: none; }
[data-design="b"] .clb-door.is-open { transform: translateY(0); opacity: 1; }
[data-design="b"] .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="b"] .clb-door a:focus-visible {
  outline: 2px solid var(--clb-candle); outline-offset: 2px;
}
@media (max-width: 640px) {
  [data-design="b"] .clb-door { inset: 64px 0 0 0; overflow-y: auto; }
}

/* ===== 2. CTA cluster (Pulls) ===== */
[data-design="b"] .clb-cta-cluster {
  display: flex; flex-wrap: wrap; gap: var(--clb-pour);
  align-items: center;
}
[data-design="b"] .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="b"] .clb-pull--primary {
  background: var(--clb-claret); color: var(--clb-chalk);
  box-shadow: var(--clb-e-leaf);
}
[data-design="b"] .clb-pull--quiet {
  color: var(--clb-chalk); min-height: 44px; padding: 10px 12px;
  border-bottom: 1px solid var(--clb-stone);
}
[data-design="b"] .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="b"] .clb-pull:hover { transform: translateY(-1px); }
}
[data-design="b"] .clb-pull:focus-visible {
  outline: 2px solid var(--clb-candle); outline-offset: 2px;
}
[data-design="b"] .clb-pull:active { transform: translateY(1px) scale(.985); }

/* Hours page action cluster reuses .clb-pull; keep on paper too */
[data-design="b"] .clb-hours .clb-pull--quiet { color: var(--clb-claret); border-bottom-color: var(--clb-feint); }

/* ===== 3. Hero + bin wall substrate ===== */
[data-design="b"] .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="b"] .clb-binwall { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
[data-design="b"] .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="b"] .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="b"] .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="b"] .clb-binwall__chalk--1 { top: 12%; left: 8%; }
[data-design="b"] .clb-binwall__chalk--2 { top: 34%; right: 12%; }
[data-design="b"] .clb-binwall__chalk--3 { top: 58%; left: 22%; }
[data-design="b"] .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="b"] .clb-hero__col {
  position: relative; z-index: 2;
  max-width: 1320px; width: 100%; margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="b"] .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="b"] .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);
  margin: 0 0 var(--clb-pour); max-width: 18ch;
  opacity: 1;
}
[data-design="b"] .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); margin: 0 0 var(--clb-bottle); max-width: 52ch;
  opacity: 1;
}
[data-design="b"] .clb-hero__status {
  font-family: "Courier Prime", "Courier New", monospace;
  font-size: .82rem; letter-spacing: .08em; color: var(--clb-muted);
  margin: var(--clb-pour) 0 0; opacity: 1;
}
@media (max-width: 640px) {
  [data-design="b"] .clb-hero { min-height: 100svh; }
  [data-design="b"] .clb-binwall__punts { background-size: 96px 88px; }
}

/* ===== Element 3: the popular-items menu ledger (built for this lead) ===== */
[data-design="b"] .clb-menu-ledger {
  margin: var(--clb-bottle) 0 var(--clb-glass);
  max-width: 640px;
}
[data-design="b"] .clb-menu-ledger__kicker {
  font-family: "Courier Prime", "Courier New", monospace;
  font-size: .78rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--clb-candle); margin: 0 0 var(--clb-taste); opacity: 1;
}
[data-design="b"] .clb-menu-ledger__list {
  list-style: none; margin: 0; padding: 0;
  display: grid; gap: 2px;
}
[data-design="b"] .clb-menu-ledger__row {
  position: relative;
  display: grid; grid-template-columns: minmax(0,auto) 1fr auto;
  align-items: baseline; column-gap: var(--clb-taste);
  padding: 7px 0;
  /* Entrance is transform-only; opacity stays 1 at rest (under
     data-mf-role="hero" -- HARD RULE: never opacity:0 on hero text). The
     row starts scaled/translated just off its settled position instead. */
  transform: translateY(14px) scale(.98); opacity: 1;
  transition: transform var(--clb-decant) var(--clb-ease-velvet);
}
[data-design="b"] .clb-menu-ledger__row.is-inked { transform: translateY(0) scale(1); }
[data-design="b"] .clb-menu-ledger__rule {
  position: absolute; left: 0; right: 0; bottom: 0; height: 1px;
  background: var(--clb-stone);
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--clb-draw) var(--clb-ease-velvet);
}
[data-design="b"] .clb-menu-ledger__row.is-inked .clb-menu-ledger__rule { transform: scaleX(1); }
[data-design="b"] .clb-menu-ledger__name {
  font-family: "Cormorant Garamond", Garamond, Georgia, serif;
  font-variant-caps: small-caps; font-weight: 600;
  font-size: 1.05rem; color: var(--clb-chalk); min-width: 0;
  overflow-wrap: anywhere;
}
[data-design="b"] .clb-menu-ledger__leader {
  border-bottom: 1px dotted var(--clb-stone);
  align-self: end; margin-bottom: 5px;
}
[data-design="b"] .clb-menu-ledger__price {
  font-family: "Courier Prime", "Courier New", monospace;
  font-variant-numeric: tabular-nums; white-space: nowrap;
  color: var(--clb-candle); font-size: .95rem; justify-self: end;
}
/* Idle ambient life once revealed: a slow shimmer sweeping the rules. */
[data-design="b"] .clb-menu-ledger.is-settled .clb-menu-ledger__rule {
  background: linear-gradient(90deg, var(--clb-stone), var(--clb-candle) 50%, var(--clb-stone));
  background-size: 220% 100%;
  animation: clb-ledger-shimmer 9s var(--clb-ease-velvet) infinite;
}
@keyframes clb-ledger-shimmer {
  0%   { background-position: 0% 0; opacity: .4; }
  50%  { background-position: 100% 0; opacity: .7; }
  100% { background-position: 0% 0; opacity: .4; }
}

/* ===== Element 6: pointer (the decant) ===== */
[data-design="b"] .clb-pointer {
  display: grid; justify-items: center; gap: var(--clb-taste);
  padding: var(--clb-bottle) 0; background: var(--clb-cellar);
  opacity: 1;
}
[data-design="b"] .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="b"] .clb-pointer__stream {
  position: relative; inline-size: 2px; block-size: 72px;
  background: var(--clb-stone); overflow: hidden; border-radius: 1px;
}
[data-design="b"] .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="b"] .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; }
}

/* ===== Element 5: THE CORKSCREW ===== */
[data-design="b"] .clb-reveal {
  background: var(--clb-cellar);
  padding: clamp(56px, 8vw, 96px) 0;
}
[data-design="b"] .clb-reveal__col {
  max-width: 1320px; margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
  display: grid; justify-items: center;
}
[data-design="b"] .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); opacity: 1;
}
[data-design="b"] .clb-bincard {
  position: relative; width: min(100%, 560px);
  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="b"] .clb-bincard__neck {
  position: absolute; top: -34px; left: 50%; transform: translateX(-50%);
  pointer-events: none;
}
[data-design="b"] .clb-cork {
  display: block; inline-size: 48px; block-size: 84px;
  filter: drop-shadow(0 2px 3px rgba(0,0,0,.4));
}
[data-design="b"] .clb-screw { display: block; inline-size: 100%; block-size: 100%; }
[data-design="b"] .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="b"] .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="b"] .clb-bincard.is-drawn .clb-cork {
  transform: translateY(-46px) rotate(-8deg);
}
[data-design="b"] .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="b"] .clb-draw-btn:active { transform: translateY(1px) scale(.985); }
[data-design="b"] .clb-draw-btn:focus-visible {
  outline: 2px solid var(--clb-candle); outline-offset: 2px;
}
[data-design="b"] .clb-bincard.is-drawn .clb-draw-btn {
  opacity: 0; pointer-events: none;
  transition: opacity var(--clb-draw) var(--clb-ease-velvet);
}
[data-design="b"] .clb-bincard__entry {
  clip-path: inset(0 0 100% 0);
  transition: clip-path var(--clb-decant) var(--clb-ease-velvet);
}
[data-design="b"] .clb-bincard.is-drawn .clb-bincard__entry {
  clip-path: inset(0 0 0 0);
}
[data-design="b"] .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="b"] .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="b"] .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="b"] .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="b"] .clb-bincard__follow {
  color: var(--clb-claret); font-family: "Crimson Text", Georgia, serif;
  min-height: 44px; display: inline-flex; align-items: center;
}
[data-design="b"] .clb-bincard__follow:focus-visible {
  outline: 2px solid var(--clb-candle); outline-offset: 2px;
}

/* ===== Element 7: scroll choreography -- the descent / full menu ===== */
[data-design="b"] .clb-descent {
  background: var(--clb-page);
  padding: clamp(56px, 8vw, 96px) 0;
}
[data-design="b"] .clb-descent__col {
  max-width: 1320px; margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="b"] .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="b"] .clb-descent__rule {
  display: block; block-size: 2px; background: var(--clb-claret);
  margin-bottom: var(--clb-bottle);
}
[data-design="b"] .clb-descent__item {
  border-bottom: 1px solid var(--clb-feint);
  padding: var(--clb-pour) 0;
}
@supports (animation-timeline: view()) {
  [data-design="b"] .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="b"] .clb-descent__title {
    animation: clb-descent-settle linear both;
    animation-timeline: view();
    animation-range: entry 5% entry 45%;
  }
  [data-design="b"] .clb-descent__item {
    animation: clb-descent-settle linear both;
    animation-timeline: view();
    animation-range: entry 15% entry 65%;
  }
  [data-design="b"] .clb-descent__item:nth-child(2) { animation-range: entry 22% entry 72%; }
  [data-design="b"] .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; }
  }
}

/* ===== Element 4: ambient segment B -- the story page ===== */
[data-design="b"] .clb-page-b {
  position: relative; background: var(--clb-page);
  padding: clamp(56px, 8vw, 96px) 0; overflow: hidden;
}
[data-design="b"] .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="b"] .clb-page-b__col {
  max-width: 1320px; margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="b"] .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="b"] .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="b"] .clb-entry.is-inked { transform: translateY(0); opacity: 1; }
[data-design="b"] .clb-entry__bin {
  font-family: "Courier Prime", "Courier New", monospace;
  font-size: .82rem; letter-spacing: .12em; color: var(--clb-claret);
}
[data-design="b"] .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-block: var(--clb-taste) 0; margin-inline: auto;
  text-align: left;
}
[data-design="b"] .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="b"] .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="b"] .clb-cork-loose:focus-visible {
  outline: 2px solid var(--clb-candle); outline-offset: 2px;
}
[data-design="b"] .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); }
}

/* ===== Gallery ===== */
[data-design="b"] .clb-gallery {
  background: var(--clb-cellar-2);
  padding: clamp(56px, 8vw, 96px) 0;
}
[data-design="b"] .clb-gallery__col {
  max-width: 1320px; margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="b"] .clb-gallery__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-chalk);
  margin: 0 0 var(--clb-bottle);
}
[data-design="b"] .clb-gallery__frame {
  max-width: 560px; margin: 0 auto;
  background: var(--clb-cellar); padding: var(--clb-taste);
  box-shadow: var(--clb-e-bench);
}
[data-design="b"] .clb-gallery__img {
  display: block; width: 100%; height: auto; border-radius: var(--clb-r-card);
}
[data-design="b"] .clb-gallery__cap {
  font-family: "Courier Prime", "Courier New", monospace;
  font-size: .78rem; letter-spacing: .05em; color: var(--clb-muted);
  margin: var(--clb-taste) var(--clb-taste) 0;
}

/* ===== Hours & Location ===== */
[data-design="b"] .clb-hours {
  background: var(--clb-page);
  padding: clamp(56px, 8vw, 96px) 0;
}
[data-design="b"] .clb-hours__col {
  max-width: 1320px; margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="b"] .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="b"] .clb-hours__card {
  max-width: 560px; margin-inline: auto;
  background: var(--clb-cellar-2); box-shadow: var(--clb-e-well);
  border-radius: var(--clb-r-card);
  padding: var(--clb-glass); text-align: left;
}
[data-design="b"] .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-glass);
}
[data-design="b"] .clb-hours__table th,
[data-design="b"] .clb-hours__table td {
  text-align: left; padding: var(--clb-taste) 0;
  border-bottom: 1px solid var(--clb-stone); font-weight: 400;
}
[data-design="b"] .clb-hours__table td { text-align: right; }
[data-design="b"] .clb-hours__addr {
  font-family: "Crimson Text", Georgia, serif;
  color: var(--clb-chalk); margin: 0 0 var(--clb-glass);
}
[data-design="b"] .clb-hours__actions {
  display: flex; flex-wrap: wrap; gap: var(--clb-pour);
}

/* ===== Footer ===== */
[data-design="b"] .clb-footer {
  background: var(--clb-cellar);
  padding: clamp(56px, 8vw, 80px) 0 var(--clb-glass);
}
[data-design="b"] .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="b"] .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-taste);
}
[data-design="b"] .clb-footer__line {
  font-family: "Courier Prime", "Courier New", monospace;
  font-size: .88rem; color: var(--clb-chalk); margin: 0 0 4px;
}
[data-design="b"] .clb-footer__link {
  display: block; color: var(--clb-chalk); text-decoration: none;
  font-family: "Crimson Text", Georgia, serif; font-size: .95rem;
  padding: 6px 0; min-height: 32px;
  border-bottom: 1px solid transparent;
}
[data-design="b"] .clb-footer__link:focus-visible {
  outline: 2px solid var(--clb-candle); outline-offset: 2px;
}
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .clb-footer__link:hover { border-bottom-color: var(--clb-candle); }
}
[data-design="b"] .clb-footer__copy {
  max-width: 1320px; margin: var(--clb-glass) auto 0;
  padding-inline: clamp(20px, 5vw, 48px);
  font-family: "Courier Prime", "Courier New", monospace;
  font-size: .78rem; color: var(--clb-muted); text-align: center;
}
@media (max-width: 640px) {
  [data-design="b"] .clb-footer__col { grid-template-columns: 1fr; }
}

/* ===== prefers-reduced-motion: reduce ===== */
@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .clb-header__sheen { animation: none; opacity: .5; transform: translateX(35vw); }
  [data-design="b"] .clb-door { transition: none; }
  [data-design="b"] .clb-pull__wick { animation: none; transform: scaleX(1); opacity: .8; }
  [data-design="b"] .clb-pull { transition: none; }
  [data-design="b"] .clb-candlepool { animation: none; transform: translate(30vw, 8vh); }
  [data-design="b"] .clb-menu-ledger__row { transition: none; transform: none; opacity: 1; }
  [data-design="b"] .clb-menu-ledger__rule { transition: none; transform: scaleX(1); }
  [data-design="b"] .clb-menu-ledger.is-settled .clb-menu-ledger__rule { animation: none; opacity: .5; }
  [data-design="b"] .clb-pointer__fill { animation: none; transform: scaleY(1); opacity: .8; }
  [data-design="b"] .clb-pointer__drop { animation: none; opacity: 0; }
  [data-design="b"] .clb-bincard.is-twisting .clb-screw,
  [data-design="b"] .clb-bincard.is-giving .clb-cork { animation: none; }
  [data-design="b"] .clb-bincard__entry { transition: none; }
  [data-design="b"] .clb-bincard.is-drawn .clb-cork { transform: translateY(-46px) rotate(-8deg); }
  [data-design="b"] .clb-descent__rule,
  [data-design="b"] .clb-descent__title,
  [data-design="b"] .clb-descent__item { animation: none; transform: none; opacity: 1; }
  [data-design="b"] .clb-ribbon { animation: none; transform: rotate(0); }
  [data-design="b"] .clb-entry { transform: none; opacity: 1; transition: none; }
  [data-design="b"] .clb-cork-loose.is-rocked::before { animation: none; }
}

/* ===== Mobile safety net (appended at bottom per contract) ===== */
[data-design="b"].dq-design,
[data-design="b"] .dq-design {
  max-width: 100%;
  overflow-x: clip;
}
[data-design="b"].dq-design * {
  min-width: 0;
}
[data-design="b"].dq-design img,
[data-design="b"].dq-design svg:not([data-keep-size]) {
  max-width: 100%;
  height: auto;
}

/* stranded-wrapper autofix (drain 2026-07-03): every fixed max-width column centers — gate content_uncentered_left_stranded */
[data-design="b"] .clb-hero__sub { margin-inline: auto; }
/* ===== Element 3: the popular-items menu ledger (built for this lead) ===== */
[data-design="b"] .clb-menu-ledger { margin-inline: auto; }
[data-design="b"] .clb-bincard__note { margin-inline: auto; }

/* Phase-3.4 hero visibility floor (forge_assemble) */
[data-design="b"] [data-mf-role="hero"] :is(h1,h2,p,.headline,.subtitle,.proof,[class*="headline"],[class*="subtitle"],[class*="proof"]),
[data-design="b"] [data-mf-role="cta"] { opacity: 1 !important; }
