[data-design="b"] {
  /* -- Surface -- linen & menu stock -------------------------------- */
  --lin:     #F4EFE5;
  --lin-2:   #FCFAF3;
  --ardoise: #26221C;

  /* -- Ink -- warm charcoal, never pure black ------------------------ */
  --encre:   #211D17;
  --encre-2: #564F44;
  --cendre:  #8C8475;
  --sur-ardoise: #F1E9DA;

  /* -- Line -- drawn hairline ----------------------------------------*/
  --filet:      #E4DDCE;
  --filet-fort: #C8BBA2;

  /* -- Accent -- oxblood ---------------------------------------------*/
  --sang:       #6E1C2C;
  --sang-hover: #57111F;
  --sur-sang:   #F6F1E7;
  --design-b-primary: var(--sang);

  /* -- Ceremony -- antique gold (bounded to Element 5) ---------------*/
  --or:      #A9802F;
  --or-clair:#C9A24B;

  /* -- Semantic --------------------------------------------------------*/
  --success:  #496B4F;
  --critique: #9A2B1C;

  /* -- Typography --------------------------------------------------- */
  --font-display: "Didot", "GFS Didot", "Bodoni MT", "Bodoni 72", "Hoefler Text", Georgia, serif;
  --font-body:    "Neue Haas Grotesk Display", "Söhne", -apple-system, BlinkMacSystemFont,
                  "Helvetica Neue", "Segoe UI", system-ui, sans-serif;
  --font-mono:    "Söhne Mono", ui-monospace, "JetBrains Mono", monospace;

  --t-meta:    14px;
  --t-body:    16px;
  --t-lg:      18px;
  --t-title:   clamp(22px, 3.4vw, 30px);
  --t-head:    clamp(28px, 5vw, 46px);
  --t-display: clamp(40px, 8.5vw, 76px);
  --lh-body:   1.6;
  --lh-tight:  1.05;
  --track-label:   0.16em;
  --track-num:     0.1em;
  --track-display: 0.005em;

  --s-hair:  4px;
  --s-tight: 8px;
  --s-snug:  12px;
  --s-base:  16px;
  --s-room:  24px;
  --s-gap:   32px;
  --s-band:  48px;
  --s-wide:  64px;
  --s-sec:   96px;
  --s-sec-m: 56px;

  --menu-row-pad: 12px;
  --menu-item-gap: 2px;
  --menu-col-gap: var(--s-room);
  --menu-sec-gap: var(--s-wide);

  --r-edge: 2px;
  --r-soft: 8px;
  --r-pill: 999px;

  --dur-quick:  160ms;
  --dur-base:   260ms;
  --dur-settle: 480ms;
  --ease-plume:  cubic-bezier(0.22, 1, 0.36, 1);
  --ease-poser:  cubic-bezier(0.33, 1.02, 0.62, 1);
  --ease-veille: ease-in-out;
  --ease-lever:  cubic-bezier(0.34, 1.12, 0.64, 1);

  --elev-flat:   none;
  --elev-line:   0 1px 0 var(--filet-fort);
  --elev-card:   0 1px 0 0 var(--filet), 0 18px 40px -28px rgba(33, 29, 23, 0.40);
  --elev-raised: 0 28px 60px -24px rgba(33, 29, 23, 0.45);

  --focus-ring: 0 0 0 3px color-mix(in srgb, var(--sang) 38%, transparent);
}

@media (prefers-color-scheme: dark) {
  [data-design="b"] {
    --lin:     #1A1610;
    --lin-2:   #221D16;
    --ardoise: #14110C;
    --encre:   #F0E8D9;
    --encre-2: #BFB6A4;
    --cendre:  #8F8676;
    --sur-ardoise: #F0E8D9;
    --filet:      #332C22;
    --filet-fort: #564B3A;
    --sang:       #C75568;
    --sang-hover: #D9697B;
    --sur-sang:   #1A1610;
    --or:      #D2A64E;
    --or-clair:#EBC877;
    --success:  #6FA079;
    --critique: #D9624E;
  }
}

[data-design="b"].dq-design { background: var(--lin); color: var(--encre); font-family: var(--font-body);
  isolation: isolate; }

/* === 1. Header ==================================================== */
[data-design="b"] .degustation-header { position: sticky; top: 0; z-index: 50;
  background: var(--lin); box-sizing: border-box; }
[data-design="b"] .dh-bar { display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-base); max-width: 1200px; margin-inline: auto; padding: var(--s-base) var(--s-room);
  box-sizing: border-box; }
[data-design="b"] .dh-logo { text-decoration: none; }
[data-design="b"] .dh-logo__mark { font-family: var(--font-display); font-weight: 600;
  font-size: clamp(22px, 4vw, 30px); letter-spacing: var(--track-display); color: var(--encre);
  display: inline-block; clip-path: inset(0 0 0 0); animation: db-tracer 760ms var(--ease-plume) both; }
[data-design="b"] .dh-burger { display: inline-flex; flex-direction: column; gap: 5px;
  width: 44px; height: 44px; align-items: center; justify-content: center; background: none; border: 0;
  cursor: pointer; border-radius: var(--r-edge); }
[data-design="b"] .dh-burger__l { width: 24px; height: 1.5px; background: var(--encre);
  transition: transform var(--dur-quick) var(--ease-plume), opacity var(--dur-quick); }
[data-design="b"] .dh-burger:focus-visible { outline: none; box-shadow: var(--focus-ring); }
[data-design="b"] .dh-burger[aria-expanded="true"] .dh-burger__l:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
[data-design="b"] .dh-burger[aria-expanded="true"] .dh-burger__l:nth-child(2) { opacity: 0; }
[data-design="b"] .dh-burger[aria-expanded="true"] .dh-burger__l:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
[data-design="b"] .dh-rule { position: relative; height: 1px; overflow: hidden;
  background: var(--sang); transform-origin: left; clip-path: inset(0 0 0 0);
  animation: db-tracer 900ms var(--ease-plume) both; }
[data-design="b"] .dh-rule__sheen { position: absolute; inset: 0; transform: translateX(-40%);
  background: linear-gradient(90deg, transparent 42%, color-mix(in srgb,#fff 75%,transparent) 50%, transparent 58%);
  animation: db-fremir 18s linear infinite; }
[data-design="b"] .dh-drawer { position: fixed; inset: 0; z-index: 60; }
[data-design="b"] .dh-drawer[hidden] { display: none; }
[data-design="b"] .dh-drawer__scrim { position: absolute; inset: 0;
  background: color-mix(in srgb, var(--encre) 60%, transparent); opacity: 0; transition: opacity var(--dur-base); }
[data-design="b"] .dh-drawer.is-open .dh-drawer__scrim { opacity: 1; }
[data-design="b"] .dh-drawer__panel { position: absolute; inset: 0; background: var(--lin-2);
  border-top: 2px solid var(--sang); padding: clamp(56px, 12vh, 96px) var(--s-room) var(--s-room);
  display: flex; flex-direction: column; gap: var(--s-base); box-sizing: border-box;
  transform: scale(0.985); opacity: 0;
  transition: transform var(--dur-base) var(--ease-plume), opacity var(--dur-base); overflow-y: auto; }
[data-design="b"] .dh-drawer.is-open .dh-drawer__panel { transform: scale(1); opacity: 1; }
[data-design="b"] .dh-entree { font-family: var(--font-display); font-weight: 600;
  font-size: var(--t-title); color: var(--encre); text-decoration: none; width: max-content;
  position: relative; padding: var(--s-tight) 0; }
[data-design="b"] .dh-entree::after { content: ""; position: absolute; left: 0; bottom: 2px;
  height: 1.5px; width: 100%; background: var(--sang); clip-path: inset(0 100% 0 0);
  transition: clip-path var(--dur-base) var(--ease-plume); }
[data-design="b"] .dh-entree:focus-visible { outline: none; }
[data-design="b"] .dh-entree:focus-visible::after { clip-path: inset(0 0 0 0); }
[data-design="b"] .dh-drawer__actions { margin-top: var(--s-room); }
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .dh-entree:hover::after { clip-path: inset(0 0 0 0); }
}
@keyframes db-tracer { from { clip-path: inset(0 100% 0 0); opacity: 0.3; }
  to { clip-path: inset(0 0 0 0); opacity: 1; } }
@keyframes db-fremir { 0% { transform: translateX(-40%); } 100% { transform: translateX(280%); } }
@media (max-width: 560px) { [data-design="b"] .dh-bar { padding: var(--s-snug) var(--s-base); } }
@media (max-width: 380px) { [data-design="b"] .dh-logo__mark { font-size: 21px; } }

/* === Chips / Jetons (shared action components) ===================== */
[data-design="b"] .dq-chip { position: relative; display: inline-flex; align-items: center;
  gap: var(--s-tight); padding: 12px var(--s-room); min-height: 44px; border-radius: var(--r-edge);
  font-family: var(--font-body); font-weight: 600; font-size: var(--t-body);
  letter-spacing: 0.02em; text-decoration: none; box-sizing: border-box;
  transition: transform var(--dur-quick) var(--ease-plume), box-shadow var(--dur-quick) var(--ease-plume),
    background-color var(--dur-quick); }
[data-design="b"] .dq-chip--primary { background: var(--sang); color: var(--sur-sang); box-shadow: var(--elev-card); }
[data-design="b"] .dq-chip--secondary { background: var(--lin-2); color: var(--encre);
  border: 1px solid var(--filet-fort); }
[data-design="b"] .dq-chip--ghost { background: transparent; color: var(--encre);
  border: 1px solid var(--encre); }
[data-design="b"] .dq-chip:focus-visible { outline: none; box-shadow: var(--focus-ring); }
[data-design="b"] .dq-chip:active { transform: translateY(1px); }
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .dq-chip--primary:hover { transform: translateY(-1px); background: var(--sang-hover);
    box-shadow: var(--elev-raised); }
  [data-design="b"] .dq-chip--secondary:hover,
  [data-design="b"] .dq-chip--ghost:hover { transform: translateY(-1px); border-color: var(--sang); color: var(--sang); }
}
[data-design="b"] .dq-jeton { display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; min-height: 32px; border-radius: var(--r-pill);
  font-family: var(--font-body); text-transform: uppercase; letter-spacing: var(--track-label);
  font-size: var(--t-meta); box-sizing: border-box; }
[data-design="b"] .dq-jeton--info { color: var(--encre-2); border: 1px solid var(--filet-fort); background: var(--lin-2); }

/* === 3. Hero -- coursed carte ======================================= */
[data-design="b"] .da-hero { max-width: 1100px; margin-inline: auto;
  padding: var(--s-wide) var(--s-room) var(--s-sec-m); text-align: center; box-sizing: border-box;
  position: relative; isolation: isolate; }
[data-design="b"] .da-hero__kicker { font-family: var(--font-body); text-transform: uppercase;
  letter-spacing: var(--track-label); font-size: var(--t-meta); color: var(--cendre); margin: 0 0 var(--s-base); }
[data-design="b"] .da-hero__head { font-family: var(--font-display); font-weight: 600; color: var(--encre);
  font-size: var(--t-display); line-height: var(--lh-tight); letter-spacing: var(--track-display);
  margin: 0 0 var(--s-snug); text-wrap: balance; opacity: 1; position: relative; z-index: 2; }
[data-design="b"] .da-hero__sub { font-family: var(--font-body); color: var(--encre-2);
  font-size: var(--t-lg); line-height: var(--lh-body); max-width: 54ch; margin: 0 auto var(--s-band);
  opacity: 1; position: relative; z-index: 2; }
[data-design="b"] .da-carte { position: relative; background: var(--lin-2);
  border: 1px solid var(--filet-fort); border-radius: var(--r-edge); box-shadow: var(--elev-card);
  padding: var(--s-gap) clamp(var(--s-room), 5vw, var(--s-band)); max-width: 640px; margin-inline: auto;
  box-sizing: border-box; overflow: hidden; }
[data-design="b"] .da-carte__glow { position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background: radial-gradient(80% 120% at 50% 8%, color-mix(in srgb, var(--or-clair) 26%, transparent), transparent 60%);
  opacity: 0.5; animation: db-bougie 6s var(--ease-veille) infinite; }
[data-design="b"] .da-carte__rule { display: block; height: 1px; background: var(--sang);
  clip-path: inset(0 100% 0 0); position: relative; z-index: 1; }
[data-design="b"] .da-carte.is-in .da-carte__rule { animation: db-tracer 700ms var(--ease-plume) both; }
[data-design="b"] .da-carte__rule--bot { margin-top: var(--s-snug); animation-delay: 280ms; }
[data-design="b"] .da-carte__list { list-style: none; counter-reset: course; margin: var(--s-room) 0; padding: 0;
  text-align: left; position: relative; z-index: 1; }
[data-design="b"] .da-course { counter-increment: course; display: grid;
  grid-template-columns: auto minmax(0,1fr) auto; align-items: baseline; column-gap: var(--s-base);
  padding: var(--menu-row-pad) 0; border-bottom: 1px solid var(--filet); opacity: 1; transform: translateY(10px); }
[data-design="b"] .da-carte.is-in .da-course { animation: db-dresser 540ms var(--ease-poser) both;
  animation-delay: calc(var(--i) * 150ms + 200ms); }
[data-design="b"] .da-course:last-child { border-bottom: 0; }
[data-design="b"] .da-course__num { font-family: var(--font-body); font-size: var(--t-meta);
  letter-spacing: var(--track-num); color: var(--sang); font-variant-numeric: tabular-nums; padding-top: 3px; }
[data-design="b"] .da-course__num::before { content: counter(course, upper-roman); }
[data-design="b"] .da-course__name { font-family: var(--font-display); font-weight: 600;
  font-size: var(--t-lg); color: var(--encre); min-width: 0; overflow-wrap: anywhere; display: block; }
[data-design="b"] .da-course__desc { font-family: var(--font-body); font-size: var(--t-meta);
  color: var(--cendre); line-height: 1.45; display: block; margin-top: 2px; }
[data-design="b"] .da-course__price { font-family: var(--font-body); font-weight: 600;
  color: var(--encre-2); font-variant-numeric: tabular-nums; white-space: nowrap; justify-self: end; }
[data-design="b"] .da-hero__actions { display: flex; flex-wrap: wrap; gap: var(--s-snug);
  justify-content: center; align-items: center; margin-top: var(--s-band); position: relative; z-index: 2; }
@keyframes db-dresser { from { opacity: 0.001; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
@keyframes db-bougie { 0%,100% { opacity: 0.18; filter: brightness(1); }
  50% { opacity: 0.34; filter: brightness(1.12) saturate(1.06); } }
@media (max-width: 380px) { [data-design="b"] .da-course__name { font-size: var(--t-body); } }

/* === 6. Pointer ===================================================== */
[data-design="b"] .dp-pointer { display: flex; flex-direction: column; align-items: center;
  gap: var(--s-tight); padding: var(--s-band) 0; cursor: pointer; opacity: 1; min-height: 8px; }
[data-design="b"] .dp-pointer__label { font-family: var(--font-body); text-transform: uppercase;
  letter-spacing: var(--track-label); font-size: var(--t-meta); color: var(--cendre); }
[data-design="b"] .dp-pointer__line { width: 1px; height: 48px; background: var(--sang);
  transform-origin: top; clip-path: inset(0 0 0 0); animation: db-draw-down 1400ms var(--ease-plume) both; }
[data-design="b"] .dp-pointer__chev { display: block; }
[data-design="b"] .dp-pointer__ember { width: 10px; height: 10px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--or-clair) 80%, transparent), transparent 70%);
  opacity: 0.5; animation: db-bougie-ember 5s var(--ease-veille) infinite; }
@keyframes db-draw-down { from { clip-path: inset(0 0 100% 0); opacity: 0.3; }
  to { clip-path: inset(0 0 0 0); opacity: 1; } }
@keyframes db-bougie-ember { 0%,100% { opacity: 0.35; } 50% { opacity: 0.75; } }

/* === 5. Cloche reveal ================================================ */
[data-design="b"] .di-reveal { background: var(--ardoise); padding: var(--s-sec) var(--s-room);
  text-align: center; box-sizing: border-box; }
[data-design="b"] .di-reveal__kicker { font-family: var(--font-display); font-style: italic;
  font-size: var(--t-title); color: var(--or); margin: 0 0 var(--s-tight); }
[data-design="b"] .di-reveal__title { font-family: var(--font-display); font-weight: 600; color: var(--sur-ardoise);
  font-size: var(--t-head); margin: 0 0 var(--s-gap); }
[data-design="b"] .di-cloche { display: inline-flex; flex-direction: column; align-items: center; gap: var(--s-base); }
[data-design="b"] .di-cloche__btn { position: relative; width: min(300px, 84vw); height: 230px;
  background: none; border: 0; padding: 0; cursor: pointer; border-radius: var(--r-soft); }
[data-design="b"] .di-cloche__btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }
[data-design="b"] .di-plate { position: absolute; left: 50%; bottom: 12px; transform: translateX(-50%);
  width: 84%; min-height: 150px; background: var(--lin-2); border-radius: var(--r-soft);
  box-shadow: var(--elev-raised); display: flex; align-items: center; justify-content: center;
  padding: var(--s-room); box-sizing: border-box; }
[data-design="b"] .di-plate__rim { position: absolute; inset: 8px; border-radius: calc(var(--r-soft) - 2px);
  border: 2px solid var(--or); pointer-events: none; }
[data-design="b"] .di-plate__content { position: relative; display: flex; flex-direction: column;
  align-items: center; gap: var(--s-tight); opacity: 1; transform: translateY(6px);
  transition: opacity var(--dur-base) var(--ease-plume) 120ms, transform var(--dur-base) var(--ease-plume) 120ms; }
[data-design="b"] .di-cloche.is-open .di-plate__content { opacity: 1; transform: translateY(0); }
[data-design="b"] .di-plate__day { font-family: var(--font-body); text-transform: uppercase;
  letter-spacing: var(--track-label); font-size: var(--t-meta); color: var(--sang); }
[data-design="b"] .di-plate__special { font-family: var(--font-display); font-weight: 600;
  font-size: var(--t-title); color: var(--encre); line-height: 1.2; max-width: 30ch; }
[data-design="b"] .di-plate__price { font-family: var(--font-body); font-weight: 600; color: var(--encre-2);
  font-variant-numeric: tabular-nums; }
[data-design="b"] .di-plate__link { font-family: var(--font-body); font-size: var(--t-meta);
  text-transform: uppercase; letter-spacing: var(--track-label); color: var(--sang); text-decoration: none;
  border-bottom: 1px solid currentColor; padding-bottom: 1px; margin-top: var(--s-tight); }
[data-design="b"] .di-plate__link:focus-visible { outline: none; box-shadow: var(--focus-ring); border-radius: 1px; }
[data-design="b"] .di-dome { position: absolute; left: 50%; bottom: 70px; transform: translateX(-50%);
  max-width: 70%; height: auto; filter: drop-shadow(0 10px 14px rgba(0,0,0,0.4));
  transition: transform var(--dur-settle) var(--ease-lever), opacity var(--dur-settle) var(--ease-lever); }
[data-design="b"] .di-cloche.is-open .di-dome { transform: translateX(-50%) translateY(-86px) scale(1.04); opacity: 0; }
[data-design="b"] .di-vapor { position: absolute; left: 50%; bottom: 150px; width: 8px; height: 30px;
  border-radius: 50%; transform: translateX(-50%); opacity: 0;
  background: radial-gradient(circle, color-mix(in srgb,#fff 75%,transparent), transparent 70%); }
[data-design="b"] .di-cloche.is-open .di-vapor { animation: db-vapor 1100ms var(--ease-veille) 1; }
[data-design="b"] .di-reveal__hint { font-family: var(--font-body); font-size: var(--t-meta);
  color: color-mix(in srgb, var(--sur-ardoise) 70%, transparent); margin: 0; }
[data-design="b"] .di-cloche.is-open .di-reveal__hint { opacity: 0; transition: opacity var(--dur-base); }
[data-design="b"] .di-reveal__note { font-family: var(--font-body); font-size: var(--t-meta);
  color: color-mix(in srgb, var(--sur-ardoise) 55%, transparent); margin: var(--s-room) auto 0; max-width: 46ch; }
@keyframes db-vapor { 0% { opacity: 0; transform: translateX(-50%) translateY(0) scaleX(1); }
  40% { opacity: 0.6; } 100% { opacity: 0; transform: translateX(-50%) translateY(-30px) scaleX(1.5); } }
@media (max-width: 380px) { [data-design="b"] .di-plate__special { font-size: var(--t-lg); } }

/* === 4. Full menu ==================================================== */
[data-design="b"] .db-menu { max-width: 1100px; margin-inline: auto; padding: var(--s-sec) var(--s-room);
  box-sizing: border-box; }
[data-design="b"] .db-menu__kicker { font-family: var(--font-body); text-transform: uppercase;
  letter-spacing: var(--track-label); font-size: var(--t-meta); color: var(--cendre); text-align: center; margin: 0 0 var(--s-tight); }
[data-design="b"] .db-menu__title { font-family: var(--font-display); font-weight: 600; color: var(--encre);
  font-size: var(--t-head); text-align: center; margin: 0 0 var(--s-tight); }
[data-design="b"] .db-menu__note { font-family: var(--font-body); font-size: var(--t-meta); color: var(--cendre);
  text-align: center; max-width: 54ch; margin: 0 auto var(--s-band); }
[data-design="b"] .db-menu__cols { display: grid; grid-template-columns: 1fr; gap: var(--menu-sec-gap); }
[data-design="b"] .db-sec__head { position: relative; display: grid; grid-template-columns: 1fr auto;
  align-items: baseline; column-gap: var(--s-base); padding-top: var(--s-snug); margin-bottom: var(--s-base); }
[data-design="b"] .db-sec__rule { position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: var(--sang); clip-path: inset(0 0 0 0); }
[data-design="b"] .db-sec__head h3 { font-family: var(--font-display); font-weight: 600; font-size: var(--t-title);
  color: var(--encre); margin: 0; min-width: 0; overflow-wrap: anywhere; }
[data-design="b"] .db-sec__no { font-family: var(--font-body); text-transform: uppercase;
  letter-spacing: var(--track-label); font-size: var(--t-meta); color: var(--cendre); justify-self: end; white-space: nowrap; }
[data-design="b"] .db-rows { list-style: none; margin: 0; padding: 0; }
[data-design="b"] .db-row { display: grid; grid-template-columns: minmax(0,auto) 1fr auto; align-items: baseline;
  column-gap: var(--menu-col-gap); padding: var(--menu-row-pad) 0; opacity: 1; }
[data-design="b"] .db-row__name { font-family: var(--font-body); font-weight: 600; font-size: var(--t-lg);
  color: var(--encre); min-width: 0; overflow-wrap: anywhere; }
[data-design="b"] .db-row__lead { align-self: flex-end; transform: translateY(-5px);
  border-bottom: 1px dotted var(--filet-fort); }
[data-design="b"] .db-row__price { font-family: var(--font-body); font-weight: 600; color: var(--encre-2);
  font-variant-numeric: tabular-nums; white-space: nowrap; justify-self: end; }
@media (min-width: 1024px) { [data-design="b"] .db-menu__cols { grid-template-columns: 1fr 1fr;
  column-gap: var(--s-sec); } }
@media (max-width: 380px) { [data-design="b"] .db-row__name { font-size: var(--t-body); } }

/* === Bands / cartons / about / footer (trade sections) ============== */
[data-design="b"] .dq-band { max-width: 1100px; margin-inline: auto; padding: var(--s-sec-m) var(--s-room);
  box-sizing: border-box; }
[data-design="b"] .dq-band--flat { padding-top: 0; }
[data-design="b"] .dq-band--dark { max-width: none; background: var(--ardoise); margin-inline: 0;
  padding: var(--s-sec-m) var(--s-room); }
[data-design="b"] .dq-band__kicker { font-family: var(--font-body); text-transform: uppercase;
  letter-spacing: var(--track-label); font-size: var(--t-meta); color: var(--cendre); text-align: center; margin: 0 0 var(--s-tight); }
[data-design="b"] .dq-band__title { font-family: var(--font-display); font-weight: 600; color: var(--encre);
  font-size: var(--t-head); text-align: center; margin: 0 0 var(--s-band); }
[data-design="b"] .dq-band__title--light { color: var(--sur-ardoise); }
[data-design="b"] .dq-2up { display: grid; grid-template-columns: 1fr; gap: var(--s-room); max-width: 900px; margin-inline: auto; }
@media (min-width: 768px) { [data-design="b"] .dq-2up { grid-template-columns: 1fr 1fr; } }
[data-design="b"] .dq-carton { background: var(--lin-2); border: 1px solid var(--filet-fort);
  border-radius: var(--r-edge); box-shadow: var(--elev-card); padding: var(--s-room); box-sizing: border-box;
  transition: transform var(--dur-quick) var(--ease-plume); }
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .dq-carton:hover { transform: translateY(-1px); }
}
[data-design="b"] .dq-carton__title { font-family: var(--font-display); font-weight: 600; font-size: var(--t-title);
  color: var(--encre); margin: 0 0 var(--s-base); }
[data-design="b"] .dq-carton__body { font-family: var(--font-body); font-size: var(--t-body); color: var(--encre-2);
  line-height: var(--lh-body); margin: 0 0 var(--s-base); }
[data-design="b"] .dq-hours { margin: 0; }
[data-design="b"] .dq-hours__row { display: grid; grid-template-columns: minmax(0,auto) 1fr; column-gap: var(--s-base);
  padding: var(--s-tight) 0; border-bottom: 1px solid var(--filet); font-size: var(--t-body); }
[data-design="b"] .dq-hours__row:last-child { border-bottom: 0; }
[data-design="b"] .dq-hours__row dt { font-weight: 600; color: var(--encre); }
[data-design="b"] .dq-hours__row dd { margin: 0; color: var(--encre-2); text-align: right;
  font-variant-numeric: tabular-nums; }
[data-design="b"] .dq-rules { margin: 0; padding-left: 1.1em; color: var(--encre-2); font-size: var(--t-body);
  line-height: var(--lh-body); }
[data-design="b"] .dq-rules li { margin-bottom: var(--s-tight); }
[data-design="b"] .dq-rules li:last-child { margin-bottom: 0; }

[data-design="b"] .dq-about { max-width: 900px; margin-inline: auto; padding: var(--s-sec-m) var(--s-room);
  box-sizing: border-box; }
[data-design="b"] .dq-about__kicker { font-family: var(--font-body); text-transform: uppercase;
  letter-spacing: var(--track-label); font-size: var(--t-meta); color: var(--cendre); margin: 0 0 var(--s-tight); }
[data-design="b"] .dq-about__title { font-family: var(--font-display); font-weight: 600; color: var(--encre);
  font-size: var(--t-head); margin: 0 0 var(--s-base); }
[data-design="b"] .dq-about__body { font-family: var(--font-body); font-size: var(--t-lg); color: var(--encre-2);
  line-height: var(--lh-body); max-width: 65ch; text-align: left; margin: 0; }

[data-design="b"] .dq-contact-links { display: flex; flex-wrap: wrap; gap: var(--s-snug); justify-content: center;
  max-width: 900px; margin-inline: auto; }

[data-design="b"] .dq-footer { background: var(--ardoise); border-top: 2px solid var(--sang);
  box-sizing: border-box; padding: var(--s-sec-m) var(--s-room) var(--s-room); }
[data-design="b"] .dq-footer__inner { max-width: 1100px; margin-inline: auto; display: grid;
  grid-template-columns: 1fr; gap: var(--s-room); }
@media (min-width: 768px) { [data-design="b"] .dq-footer__inner { grid-template-columns: 1.4fr 1fr 1fr; } }
[data-design="b"] .dq-footer__col { display: flex; flex-direction: column; gap: var(--s-tight); }
[data-design="b"] .dq-footer__brand { font-family: var(--font-display); font-weight: 600; font-size: var(--t-title);
  color: var(--sur-ardoise); margin: 0; }
[data-design="b"] .dq-footer__addr { font-family: var(--font-body); font-size: var(--t-body);
  color: color-mix(in srgb, var(--sur-ardoise) 75%, transparent); margin: 0; }
[data-design="b"] .dq-footer__link { font-family: var(--font-body); font-size: var(--t-body);
  color: color-mix(in srgb, var(--sur-ardoise) 85%, transparent); text-decoration: none;
  border-bottom: 1px solid transparent; width: max-content; padding-bottom: 1px; min-height: 24px; }
[data-design="b"] .dq-footer__link:focus-visible { outline: none; box-shadow: var(--focus-ring); border-radius: 1px; }
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .dq-footer__link:hover { border-bottom-color: currentColor; }
}
[data-design="b"] .dq-footer__copy { max-width: 1100px; margin: var(--s-band) auto 0; font-family: var(--font-body);
  font-size: var(--t-meta); color: color-mix(in srgb, var(--sur-ardoise) 55%, transparent); text-align: center; }

@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .dh-logo__mark,
  [data-design="b"] .dh-rule,
  [data-design="b"] .da-carte__rule,
  [data-design="b"] .dp-pointer__line { animation: none; clip-path: inset(0 0 0 0); }
  [data-design="b"] .dh-rule__sheen { animation: none; opacity: 0; }
  [data-design="b"] .dh-drawer__panel,
  [data-design="b"] .dh-drawer__scrim { transition: none; }
  [data-design="b"] .da-carte__glow { animation: none; opacity: 0.5; }
  [data-design="b"] .da-carte.is-in .da-course { animation: none; }
  [data-design="b"] .da-course { opacity: 1; transform: none; }
  [data-design="b"] .dp-pointer__ember { animation: none; opacity: 0.5; }
  [data-design="b"] .di-dome { transition: opacity var(--dur-base); }
  [data-design="b"] .di-cloche.is-open .di-dome { transform: translateX(-50%); opacity: 0; }
  [data-design="b"] .di-plate__content { transition: opacity var(--dur-base); transform: none; }
  [data-design="b"] .di-cloche.is-open .di-plate__content { transform: none; }
  [data-design="b"] .di-cloche.is-open .di-vapor { animation: none; opacity: 0; }
  [data-design="b"] .dq-chip,
  [data-design="b"] .dq-carton { transition: none; }
}

/* === Mobile / viewport / motion-gate hardening (bottom-appended) ==== */
[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"] .di-plate__special { margin-inline: auto; }
[data-design="b"] .dq-about__body { 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; }
