[data-design="a"] {
  /* ── 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 (the design-a primary + THE one focal color) */
  --design-a-primary: #6E1C2C;
  --sang:       #6E1C2C;
  --sang-hover: #57111F;
  --sur-sang:   #F6F1E7;

  /* ── Ceremony — antique gold (BOUNDED to Element 5's cloche reveal) */
  --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="a"] {
    --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="a"].dq-design { background: var(--lin); color: var(--encre); font-family: var(--font-body);
  isolation: isolate; }

/* ── 1. Header ─────────────────────────────────────────────────────── */
[data-design="a"] .degustation-header { position: sticky; top: 0; z-index: 50;
  background: var(--lin); box-sizing: border-box; }
[data-design="a"] .dh-bar { display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-base); max-width: 1200px; margin: 0 auto; padding: var(--s-base) var(--s-room);
  box-sizing: border-box; }
[data-design="a"] .dh-logo { text-decoration: none; }
[data-design="a"] .dh-logo__mark { font-family: var(--font-display); font-weight: 600;
  font-size: clamp(20px, 3.6vw, 28px); letter-spacing: var(--track-display); color: var(--encre);
  display: inline-block; clip-path: inset(0 0 0 0); animation: a-tracer 760ms var(--ease-plume) both; }
[data-design="a"] .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="a"] .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="a"] .dh-burger:focus-visible { outline: none; box-shadow: var(--focus-ring); }
[data-design="a"] .dh-burger[aria-expanded="true"] .dh-burger__l:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
[data-design="a"] .dh-burger[aria-expanded="true"] .dh-burger__l:nth-child(2) { opacity: 0; }
[data-design="a"] .dh-burger[aria-expanded="true"] .dh-burger__l:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
[data-design="a"] .dh-rule { position: relative; height: 1px; overflow: hidden;
  background: var(--sang); transform-origin: left; clip-path: inset(0 0 0 0);
  animation: a-tracer 900ms var(--ease-plume) both; }
[data-design="a"] .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: a-fremir 18s linear infinite; }
[data-design="a"] .dh-drawer { position: fixed; inset: 0; z-index: 60; }
[data-design="a"] .dh-drawer[hidden] { display: none; }
[data-design="a"] .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="a"] .dh-drawer.is-open .dh-drawer__scrim { opacity: 1; }
[data-design="a"] .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; overflow-y: auto;
  transition: transform var(--dur-base) var(--ease-plume), opacity var(--dur-base); }
[data-design="a"] .dh-drawer.is-open .dh-drawer__panel { transform: scale(1); opacity: 1; }
[data-design="a"] .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="a"] .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="a"] .dh-entree:focus-visible { outline: none; }
[data-design="a"] .dh-entree:focus-visible::after { clip-path: inset(0 0 0 0); }
[data-design="a"] .dh-drawer__actions { margin-top: var(--s-base); }
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .dh-entree:hover::after { clip-path: inset(0 0 0 0); }
}
@keyframes a-tracer { from { clip-path: inset(0 100% 0 0); opacity: 0.3; }
  to { clip-path: inset(0 0 0 0); opacity: 1; } }
@keyframes a-fremir { 0% { transform: translateX(-40%); } 100% { transform: translateX(280%); } }
@media (max-width: 560px) { [data-design="a"] .dh-bar { padding: var(--s-snug) var(--s-base); } }
@media (max-width: 380px) { [data-design="a"] .dh-logo__mark { font-size: 19px; } }

/* ── Bouton (shared chip / CTA grammar) ──────────────────────────────── */
[data-design="a"] .da-chip { position: relative; display: inline-flex; align-items: center;
  gap: var(--s-tight); padding: 10px var(--s-room); border-radius: var(--r-edge);
  background: var(--lin-2); border: 1px solid var(--filet-fort); color: var(--encre);
  font-family: var(--font-body); font-weight: 600; font-size: var(--t-meta);
  letter-spacing: 0.02em; text-decoration: none; box-sizing: border-box; min-height: 44px;
  transition: transform var(--dur-quick) var(--ease-plume), box-shadow var(--dur-quick) var(--ease-plume),
    background-color var(--dur-quick), border-color var(--dur-quick); }
[data-design="a"] .da-chip:focus-visible { outline: none; box-shadow: var(--focus-ring); }
[data-design="a"] .da-chip--primary { background: var(--sang); color: var(--sur-sang); border-color: var(--sang);
  font-size: var(--t-body); padding: 14px var(--s-room); box-shadow: var(--elev-card); }
[data-design="a"] .da-chip--footer { background: transparent; border-color: var(--filet); color: var(--sur-ardoise); }
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .da-chip:hover { transform: translateY(-1px); border-color: var(--sang); }
  [data-design="a"] .da-chip--primary:hover { background: var(--sang-hover); box-shadow: var(--elev-raised); }
  [data-design="a"] .da-chip--footer:hover { border-color: var(--sur-ardoise); }
}
[data-design="a"] .da-chip:active { transform: translateY(1px); }

/* ── 3. Hero — the carte (real menu categories) ──────────────────────── */
[data-design="a"] .da-hero { max-width: 1100px; margin: 0 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="a"] .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);
  position: relative; z-index: 2; opacity: 1; }
[data-design="a"] .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; position: relative; z-index: 2; opacity: 1; }
[data-design="a"] .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);
  position: relative; z-index: 2; opacity: 1; }
[data-design="a"] .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: 0 auto;
  box-sizing: border-box; overflow: hidden; z-index: 2; }
[data-design="a"] .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: a-bougie 6s var(--ease-veille) infinite; }
[data-design="a"] .da-carte__rule { display: block; height: 1px; background: var(--sang);
  clip-path: inset(0 100% 0 0); position: relative; z-index: 1; }
[data-design="a"] .da-carte.is-in .da-carte__rule { animation: a-tracer 700ms var(--ease-plume) both; }
[data-design="a"] .da-carte__rule--bot { margin-top: var(--s-snug); animation-delay: 280ms; }
[data-design="a"] .da-carte__note { font-family: var(--font-body); text-transform: uppercase;
  letter-spacing: var(--track-label); font-size: 12px; color: var(--cendre); text-align: center;
  margin: var(--s-tight) 0 0; position: relative; z-index: 1; }
[data-design="a"] .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="a"] .da-course { counter-increment: course; display: grid;
  grid-template-columns: auto minmax(0,1fr); align-items: baseline; column-gap: var(--s-base);
  padding: var(--menu-row-pad) 0; border-bottom: 1px solid var(--filet); opacity: 0; transform: translateY(10px); }
[data-design="a"] .da-carte.is-in .da-course { animation: a-dresser 540ms var(--ease-poser) both;
  animation-delay: calc(var(--i) * 150ms + 200ms); }
[data-design="a"] .da-course:last-child { border-bottom: 0; }
[data-design="a"] .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="a"] .da-course__num::before { content: counter(course, upper-roman); }
[data-design="a"] .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="a"] .da-hero__actions { display: flex; flex-wrap: wrap; gap: var(--s-snug);
  justify-content: center; margin-top: var(--s-band); position: relative; z-index: 2; }
@keyframes a-dresser { to { opacity: 1; transform: translateY(0); } }
@media (max-width: 380px) { [data-design="a"] .da-course__name { font-size: var(--t-body); } }

/* ── 6. Pointer ───────────────────────────────────────────────────────── */
[data-design="a"] .dp-pointer { display: flex; flex-direction: column; align-items: center;
  gap: var(--s-tight); padding: var(--s-band) 0; cursor: pointer; opacity: 1; }
[data-design="a"] .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="a"] .dp-pointer__line { width: 1px; height: 48px; background: var(--sang);
  transform-origin: top; clip-path: inset(0 0 0 0); animation: a-draw-down 1400ms var(--ease-plume) both; }
[data-design="a"] .dp-pointer__chev { display: block; }
[data-design="a"] .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: a-bougie 5s var(--ease-veille) infinite; }
@keyframes a-draw-down { from { clip-path: inset(0 0 100% 0); opacity: 0.3; }
  to { clip-path: inset(0 0 0 0); opacity: 1; } }

/* ── 5. Cloche reveal (Signature Style) ──────────────────────────────── */
[data-design="a"] .di-reveal { background: var(--ardoise); padding: var(--s-sec) var(--s-room);
  text-align: center; box-sizing: border-box; }
[data-design="a"] .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="a"] .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="a"] .di-cloche { display: inline-flex; flex-direction: column; align-items: center; gap: var(--s-base); }
[data-design="a"] .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="a"] .di-cloche__btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }
[data-design="a"] .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="a"] .di-plate__rim { position: absolute; inset: 8px; border-radius: calc(var(--r-soft) - 2px);
  border: 2px solid var(--or); pointer-events: none; }
[data-design="a"] .di-plate__content { position: relative; display: flex; flex-direction: column;
  align-items: center; gap: var(--s-tight); opacity: 0; transform: translateY(6px);
  transition: opacity var(--dur-base) var(--ease-plume) 120ms, transform var(--dur-base) var(--ease-plume) 120ms; }
[data-design="a"] .di-cloche.is-open .di-plate__content { opacity: 1; transform: translateY(0); }
[data-design="a"] .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="a"] .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="a"] .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="a"] .di-plate__link:focus-visible { outline: none; box-shadow: var(--focus-ring); border-radius: 1px; }
[data-design="a"] .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="a"] .di-cloche.is-open .di-dome { transform: translateX(-50%) translateY(-86px) scale(1.04); opacity: 0; }
[data-design="a"] .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="a"] .di-cloche.is-open .di-vapor { animation: a-vapor 1100ms var(--ease-veille) 1; }
[data-design="a"] .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="a"] .di-cloche.is-open .di-reveal__hint { opacity: 0; transition: opacity var(--dur-base); }
@keyframes a-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="a"] .di-plate__special { font-size: var(--t-lg); } }

/* ── 4. Full menu categories (mid-page) ──────────────────────────────── */
[data-design="a"] .db-menu { max-width: 1100px; margin: 0 auto; padding: var(--s-sec) var(--s-room);
  box-sizing: border-box; }
[data-design="a"] .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="a"] .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-base); }
[data-design="a"] .db-menu__intro { font-family: var(--font-body); color: var(--encre-2); font-size: var(--t-body);
  line-height: var(--lh-body); max-width: 62ch; margin: 0 auto var(--s-band); text-align: center; }
[data-design="a"] .db-menu__cols { display: grid; grid-template-columns: 1fr; gap: var(--menu-sec-gap); }
[data-design="a"] .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-tight); }
[data-design="a"] .db-sec__rule { position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: var(--sang); clip-path: inset(0 100% 0 0); }
[data-design="a"] .db-menu.is-in .db-sec__rule { animation: a-tracer 760ms var(--ease-plume) both; }
[data-design="a"] .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="a"] .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="a"] .db-sec__note { font-family: var(--font-body); color: var(--encre-2); font-size: var(--t-body);
  line-height: var(--lh-body); margin: 0; }
[data-design="a"] .db-menu__cta { text-align: center; margin-top: var(--s-sec-m); }
@media (min-width: 1024px) { [data-design="a"] .db-menu__cols { grid-template-columns: 1fr 1fr;
  column-gap: var(--s-sec); } }

/* ── Gallery ──────────────────────────────────────────────────────────── */
[data-design="a"] .dg-gallery { max-width: 1100px; margin: 0 auto; padding: var(--s-sec-m) var(--s-room) var(--s-sec);
  box-sizing: border-box; }
[data-design="a"] .dg-gallery__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="a"] .dg-gallery__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="a"] .dg-gallery__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--s-room); }
[data-design="a"] .dg-tile { margin: 0; background: var(--lin-2); border: 1px solid var(--filet-fort);
  border-radius: var(--r-edge); overflow: hidden; box-shadow: var(--elev-card);
  transition: transform var(--dur-base) var(--ease-plume); }
[data-design="a"] .dg-tile img { display: block; width: 100%; height: auto; }
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .dg-tile:hover { transform: translateY(-2px); }
}

/* ── About ────────────────────────────────────────────────────────────── */
[data-design="a"] .da-about { max-width: 62ch; margin: 0 auto; padding: var(--s-sec-m) var(--s-room);
  box-sizing: border-box; }
[data-design="a"] .da-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="a"] .da-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="a"] .da-about__body { font-family: var(--font-body); color: var(--encre-2); font-size: var(--t-body);
  line-height: var(--lh-body); margin: 0; }

/* ── Catering funnel ──────────────────────────────────────────────────── */
[data-design="a"] .dk-catering { background: var(--lin-2); padding: var(--s-sec) var(--s-room);
  box-sizing: border-box; border-top: 1px solid var(--filet); border-bottom: 1px solid var(--filet); }
[data-design="a"] .dk-catering__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="a"] .dk-catering__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="a"] .dk-catering__intro { font-family: var(--font-body); color: var(--encre-2); font-size: var(--t-body);
  text-align: center; margin: 0 0 var(--s-band); }
[data-design="a"] .dk-form { max-width: 640px; margin: 0 auto; background: var(--lin);
  border: 1px solid var(--filet-fort); border-radius: var(--r-edge); box-shadow: var(--elev-card);
  padding: var(--s-gap); box-sizing: border-box; }
[data-design="a"] .dk-steps { list-style: none; margin: 0; padding: 0; }
[data-design="a"] .dk-step { display: none; }
[data-design="a"] .dk-step.is-active { display: block; opacity: 1; transform: none; animation: a-dresser 420ms var(--ease-poser) both; }
[data-design="a"] .dk-step__q { font-family: var(--font-display); font-weight: 600; font-size: var(--t-title);
  color: var(--encre); margin: 0 0 var(--s-room); }
[data-design="a"] .dk-step__note { font-family: var(--font-body); color: var(--encre-2); font-size: var(--t-body);
  margin: 0 0 var(--s-room); }
[data-design="a"] .dk-options { display: flex; flex-wrap: wrap; gap: var(--s-snug); }
[data-design="a"] .dk-opt { min-height: 44px; padding: 12px var(--s-room); border-radius: var(--r-edge);
  background: var(--lin-2); border: 1px solid var(--filet-fort); color: var(--encre);
  font-family: var(--font-body); font-weight: 600; font-size: var(--t-meta); cursor: pointer;
  transition: transform var(--dur-quick) var(--ease-plume), border-color var(--dur-quick), background-color var(--dur-quick); }
[data-design="a"] .dk-opt:focus-visible { outline: none; box-shadow: var(--focus-ring); }
[data-design="a"] .dk-opt.is-selected { background: var(--sang); border-color: var(--sang); color: var(--sur-sang); }
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .dk-opt:hover { transform: translateY(-1px); border-color: var(--sang); }
}
[data-design="a"] .dk-fields { display: flex; flex-direction: column; gap: var(--s-base); margin-bottom: var(--s-room); }
[data-design="a"] .dk-field { display: flex; flex-direction: column; gap: var(--s-hair);
  font-family: var(--font-body); font-size: var(--t-meta); text-transform: uppercase;
  letter-spacing: var(--track-label); color: var(--cendre); }
[data-design="a"] .dk-field input,
[data-design="a"] .dk-field textarea { font-family: var(--font-body); font-size: var(--t-body);
  color: var(--encre); background: var(--lin-2); border: 0; border-bottom: 1px solid var(--filet-fort);
  padding: var(--s-tight) var(--s-hair); text-transform: none; letter-spacing: normal; box-sizing: border-box;
  transition: border-color var(--dur-quick); min-height: 44px; }
[data-design="a"] .dk-field textarea { min-height: 72px; resize: vertical; }
[data-design="a"] .dk-field input:focus,
[data-design="a"] .dk-field textarea:focus { outline: none; border-color: var(--sang); }
[data-design="a"] .dk-next { min-height: 44px; padding: 12px var(--s-room); border-radius: var(--r-edge);
  background: var(--sang); color: var(--sur-sang); border: 0; font-family: var(--font-body); font-weight: 600;
  font-size: var(--t-body); cursor: pointer; transition: transform var(--dur-quick) var(--ease-plume), background-color var(--dur-quick); }
[data-design="a"] .dk-next:focus-visible { outline: none; box-shadow: var(--focus-ring); }
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .dk-next:hover { transform: translateY(-1px); background: var(--sang-hover); }
}
[data-design="a"] .dk-progress { text-align: center; margin: var(--s-room) 0 0; font-family: var(--font-body);
  text-transform: uppercase; letter-spacing: var(--track-label); font-size: 12px; color: var(--cendre); }
[data-design="a"] .dk-catering__alt { text-align: center; margin: var(--s-band) 0 0; font-family: var(--font-body);
  color: var(--encre-2); font-size: var(--t-body); display: flex; flex-wrap: wrap; gap: var(--s-snug);
  align-items: center; justify-content: center; }

/* ── Footer ───────────────────────────────────────────────────────────── */
[data-design="a"] .dz-footer { background: var(--ardoise); color: var(--sur-ardoise);
  padding: var(--s-sec-m) var(--s-room); box-sizing: border-box; text-align: center;
  border-top: 1px solid var(--sang); position: relative; }
[data-design="a"] .dz-footer__brand { font-family: var(--font-display); font-weight: 600;
  font-size: var(--t-head); margin: 0 0 var(--s-room); color: var(--sur-ardoise); }
[data-design="a"] .dz-footer__grid { display: flex; flex-wrap: wrap; justify-content: center;
  gap: var(--s-room); margin: 0 0 var(--s-band); }
[data-design="a"] .dz-footer__line { margin: 0; font-family: var(--font-body); font-size: var(--t-body); }
[data-design="a"] .dz-footer__copy { margin: 0; font-family: var(--font-body); font-size: var(--t-meta);
  color: var(--cendre); }

/* ── Ambient / candle breath primitives ──────────────────────────────── */
@keyframes a-bougie { 0%,100% { opacity: 0.18; filter: brightness(1); }
  50% { opacity: 0.34; filter: brightness(1.12) saturate(1.06); } }

/* ── Reduced motion (all signature elements) ─────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .dh-logo__mark,
  [data-design="a"] .dh-rule { animation: none; clip-path: inset(0 0 0 0); }
  [data-design="a"] .dh-rule__sheen { animation: none; opacity: 0; }
  [data-design="a"] .dh-drawer__panel,
  [data-design="a"] .dh-drawer__scrim { transition: none; }
  [data-design="a"] .da-carte__glow { animation: none; opacity: 0.5; }
  [data-design="a"] .da-carte__rule { clip-path: inset(0 0 0 0); }
  [data-design="a"] .da-carte.is-in .da-carte__rule,
  [data-design="a"] .da-carte.is-in .da-course { animation: none; }
  [data-design="a"] .da-course { opacity: 1; transform: none; }
  [data-design="a"] .dp-pointer__line { animation: none; clip-path: inset(0 0 0 0); }
  [data-design="a"] .dp-pointer__ember { animation: none; opacity: 0.5; }
  [data-design="a"] .di-dome { transition: opacity var(--dur-base); }
  [data-design="a"] .di-cloche.is-open .di-dome { transform: translateX(-50%); opacity: 0; }
  [data-design="a"] .di-plate__content { transition: opacity var(--dur-base); transform: none; }
  [data-design="a"] .di-cloche.is-open .di-plate__content { transform: none; }
  [data-design="a"] .di-cloche.is-open .di-vapor { animation: none; opacity: 0; }
  [data-design="a"] .db-sec__rule { clip-path: inset(0 0 0 0); }
  [data-design="a"] .db-menu.is-in .db-sec__rule,
  [data-design="a"] .db-menu.is-in .db-row { animation: none; }
  [data-design="a"] .dg-tile,
  [data-design="a"] .da-chip,
  [data-design="a"] .dk-opt,
  [data-design="a"] .dk-next { transition: none; }
  [data-design="a"] .dk-step.is-active { animation: none; }
}

/* ── Mobile safety (appended at bottom per contract) ─────────────────── */
[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; }
