/* ═══════════════════════════════════════════════════════
   Oregon Mountain Coffee Company — Design Slice A (Le Zinc)
   All selectors scoped to [data-design="a"].dq-design
   Le Zinc design system — slot-remapped from [data-design="a"] → [data-design="a"].dq-design
   Keyframes prefixed lz-
   ═══════════════════════════════════════════════════════ */

/* ── 0. Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=Spectral:ital,wght@0,400;0,600;1,400&family=Hanken+Grotesk:wght@400;500;600&family=Spline+Sans+Mono:wght@400;500&display=swap');

/* ── 1. Token system ── */
[data-design="a"] {
  --lz-cream: #F2E9D6;
  --lz-cream-raise: #FBF5E7;
  --lz-cream-sink: #E7DBC1;
  --lz-ink: #2A201A;
  --lz-ink-soft: #4A3C30;
  --lz-muted: #897962;
  --lz-line: #D9C8A6;
  --lz-burgundy: #6E1A24;
  --lz-burgundy-deep: #4F121A;
  --lz-brass: #A9842F;
  --lz-brass-bright: #D8B65E;
  --lz-zinc: #71747A;
  --lz-zinc-deep: #4C4E54;
  --lz-critical: #A12A1E;
  --lz-success: #5E6E37;
  --lz-on-burgundy: #FBF5E7;
  --lz-on-brass: #2A201A;

  --lz-font-display: "Playfair Display", "Didot", Georgia, "Times New Roman", serif;
  --lz-font-body: "Spectral", "Iowan Old Style", Georgia, "Times New Roman", serif;
  --lz-font-label: "Hanken Grotesk", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --lz-font-mono: "Spline Sans Mono", ui-monospace, "JetBrains Mono", monospace;

  --lz-demi: 4px;
  --lz-sip: 8px;
  --lz-pour: 12px;
  --lz-plate: 16px;
  --lz-table: 24px;
  --lz-banquette: 40px;
  --lz-salle: 64px;
  --lz-terrasse: 96px;

  --lz-dur-quick: 170ms;
  --lz-dur-settle: 300ms;
  --lz-dur-flip: 540ms;
  --lz-ease-settle: cubic-bezier(0.22, 0.78, 0.24, 1);
  --lz-ease-pour: cubic-bezier(0.37, 0, 0.63, 1);
  --lz-ease-flip: cubic-bezier(0.34, 1.28, 0.64, 1);

  --lz-r-rule: 2px;
  --lz-r-plate: 4px;
  --lz-r-enamel: 10px;
  --lz-r-saucer: 999px;

  --lz-edge-brass: 0 0 0 1px color-mix(in oklab, var(--lz-brass), transparent 55%);
  --lz-lift-plate: 0 1px 0 color-mix(in oklab, var(--lz-brass), transparent 70%),
                   0 10px 24px color-mix(in oklab, var(--lz-ink), transparent 88%);
  --lz-bevel-mirror: inset 0 1px 0 color-mix(in oklab, #fff, transparent 65%),
                     inset 0 -1px 0 color-mix(in oklab, var(--lz-ink), transparent 80%);
  --lz-lift-cloche: 0 18px 48px color-mix(in oklab, var(--lz-ink), transparent 78%);
  --lz-focus: 0 0 0 3px color-mix(in oklab, var(--lz-brass), transparent 62%);

  /* expose design primary */
  --design-a-primary: var(--lz-burgundy);
}

@media (prefers-color-scheme: dark) {
  [data-design="a"] {
    --lz-cream: #1E1712;
    --lz-cream-raise: #2A211A;
    --lz-cream-sink: #150F0B;
    --lz-ink: #F1E7D4;
    --lz-ink-soft: #D8CBB4;
    --lz-muted: #A99A82;
    --lz-line: #3C3026;
    --lz-burgundy: #9A2C36;
    --lz-burgundy-deep: #6E1A24;
    --lz-brass: #D8B65E;
    --lz-brass-bright: #F0D789;
    --lz-zinc: #8B8E94;
    --lz-zinc-deep: #5A5D63;
    --lz-critical: #D2473A;
    --lz-success: #8BA15A;
    --lz-on-burgundy: #1E1712;
  }
}

/* ── 2. Article reset ── */
[data-design="a"].dq-design,
[data-design="a"] .dq-design {
  max-width: 100%;
  overflow-x: clip;
  background: var(--lz-cream);
  color: var(--lz-ink);
  font-family: var(--lz-font-body);
  font-size: 16px;
  line-height: 1.6;
  box-sizing: border-box;
}

[data-design="a"].dq-design * {
  min-width: 0;
  box-sizing: border-box;
}

[data-design="a"].dq-design img,
[data-design="a"].dq-design svg:not([data-keep-size]) {
  max-width: 100%;
  height: auto;
}

/* ── 3. ELEMENT 1: Header ── */
[data-design="a"] .lz-header {
  position: sticky;
  top: 0;
  z-index: 40;
  background: color-mix(in oklab, var(--lz-cream), transparent 8%);
  backdrop-filter: saturate(1.1) blur(6px);
  border-bottom: 1px solid var(--lz-line);
}

[data-design="a"] .lz-header__bar {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--lz-plate) var(--lz-table);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

[data-design="a"] .lz-logo { text-decoration: none; }

[data-design="a"] .lz-logo__mark {
  font-family: var(--lz-font-display);
  font-weight: 700;
  font-size: clamp(18px, 3.4vw, 28px);
  letter-spacing: -0.01em;
  color: var(--lz-ink);
  text-decoration: none;
}

[data-design="a"] .lz-header__atmos {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
}

[data-design="a"] .lz-header__pool {
  position: absolute;
  left: 8%;
  bottom: -60%;
  width: 40%;
  height: 200%;
  border-radius: 50%;
  background: radial-gradient(closest-side, color-mix(in oklab, var(--lz-brass), transparent 78%), transparent 72%);
  filter: blur(8px);
  animation: lz-header-pool 27s var(--lz-ease-pour) infinite;
}

[data-design="a"] .lz-header__gleam {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 38%;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--lz-brass-bright), var(--lz-brass), transparent);
  opacity: 0.9;
  animation: lz-header-gleam 18s var(--lz-ease-pour) infinite;
}

@keyframes lz-header-gleam {
  0% { transform: translateX(-110%); }
  100% { transform: translateX(360%); }
}

@keyframes lz-header-pool {
  0%, 100% { opacity: 0.5; transform: translateX(0); }
  50% { opacity: 0.9; transform: translateX(18%); }
}

[data-design="a"] .lz-burger {
  background: none;
  border: 1px solid var(--lz-line);
  border-radius: var(--lz-r-saucer);
  width: 44px;
  height: 44px;
  display: grid;
  place-content: center;
  gap: 5px;
  cursor: pointer;
  transition: border-color var(--lz-dur-quick) var(--lz-ease-settle);
}

[data-design="a"] .lz-burger__line {
  width: 18px;
  height: 1.5px;
  background: var(--lz-ink);
  display: block;
  transition: transform var(--lz-dur-quick) var(--lz-ease-settle);
}

[data-design="a"] .lz-burger:focus-visible {
  outline: none;
  box-shadow: var(--lz-focus);
}

@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .lz-burger:hover { border-color: var(--lz-brass); }
}

/* Rideau (drawer) */
[data-design="a"] .lz-rideau {
  position: fixed;
  inset: 0;
  z-index: 60;
}

[data-design="a"] .lz-rideau[hidden] { display: none; }

[data-design="a"] .lz-rideau::before {
  content: "";
  position: absolute;
  inset: 0;
  background: color-mix(in oklab, var(--lz-ink), transparent 45%);
  opacity: 0;
  animation: lz-fade-in var(--lz-dur-settle) var(--lz-ease-settle) forwards;
}

[data-design="a"] .lz-rideau__panel {
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: min(420px, 86vw);
  background: var(--lz-cream-sink);
  border-left: 2px solid var(--lz-brass);
  box-shadow: var(--lz-lift-cloche);
  padding: var(--lz-salle) var(--lz-table) var(--lz-table);
  transform: translateX(100%);
  animation: lz-rideau-in var(--lz-dur-settle) var(--lz-ease-settle) forwards;
}

@keyframes lz-rideau-in { to { transform: translateX(0); } }
@keyframes lz-fade-in { to { opacity: 1; } }

[data-design="a"] .lz-rideau__close {
  position: absolute;
  top: var(--lz-plate);
  right: var(--lz-plate);
  background: none;
  border: none;
  font-size: 32px;
  line-height: 1;
  color: var(--lz-ink);
  cursor: pointer;
}

[data-design="a"] .lz-rideau__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--lz-table);
}

[data-design="a"] .lz-rail {
  font-family: var(--lz-font-label);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 15px;
  color: var(--lz-ink);
  text-decoration: none;
  position: relative;
  display: inline-block;
  padding-bottom: 4px;
}

[data-design="a"] .lz-rail::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background: var(--lz-brass);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--lz-dur-quick) var(--lz-ease-settle);
}

@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .lz-rail:hover::after { transform: scaleX(1); }
}
[data-design="a"] .lz-rail:focus-visible::after,
[data-design="a"] .lz-rail[aria-current="page"]::after {
  transform: scaleX(1);
}

@media (max-width: 560px) {
  [data-design="a"] .lz-header__bar {
    padding: var(--lz-pour) var(--lz-plate);
  }
}

/* ── 4. ELEMENT 3: Hero / animated popular-items menu ── */
[data-design="a"] .lz-hero {
  position: relative;
  overflow: hidden;
  padding: var(--lz-terrasse) var(--lz-table) var(--lz-salle);
}

[data-design="a"] .lz-hero__warmth {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(120% 80% at 78% 8%, color-mix(in oklab, var(--lz-brass), transparent 84%), transparent 60%),
    radial-gradient(90% 70% at 12% 100%, color-mix(in oklab, var(--lz-burgundy), transparent 88%), transparent 64%);
  animation: lz-hero-warmth 22s var(--lz-ease-pour) infinite;
}

@keyframes lz-hero-warmth {
  0%, 100% { opacity: 0.85; }
  50% { opacity: 1; }
}

[data-design="a"] .lz-hero__inner {
  position: relative;
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 var(--lz-table);
}

[data-design="a"] .lz-hero__eyebrow {
  font-family: var(--lz-font-label);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 13px;
  color: var(--lz-brass);
  margin: 0 0 var(--lz-plate);
  opacity: 1;
}

[data-design="a"] .lz-hero__title {
  font-family: var(--lz-font-display);
  font-weight: 700;
  font-size: clamp(34px, 6.4vw, 68px);
  line-height: 1.04;
  letter-spacing: -0.012em;
  color: var(--lz-ink);
  margin: 0 0 var(--lz-plate);
  max-width: 16ch;
  text-wrap: balance;
  opacity: 1;
}

[data-design="a"] .lz-hero__sub {
  font-family: var(--lz-font-body);
  font-size: clamp(16px, 2.2vw, 20px);
  color: var(--lz-ink-soft);
  margin: 0 0 var(--lz-banquette);
  max-width: 46ch;
  line-height: 1.6;
  opacity: 1;
}

/* Popular items menu */
[data-design="a"] .lz-menu {
  list-style: none;
  margin: 0 0 var(--lz-banquette);
  padding: var(--lz-table) 0;
  border-top: 2px solid var(--lz-brass);
  border-bottom: 1px solid var(--lz-line);
  position: relative;
  display: grid;
  gap: var(--lz-pour);
  max-width: 720px;
}

[data-design="a"] .lz-menu::before {
  content: "";
  position: absolute;
  top: -2px;
  left: 0;
  height: 2px;
  width: 34%;
  background: linear-gradient(90deg, transparent, var(--lz-brass-bright), transparent);
  animation: lz-menu-gleam 14s var(--lz-ease-pour) infinite;
}

@keyframes lz-menu-gleam {
  0% { transform: translateX(-40%); }
  100% { transform: translateX(300%); }
}

[data-design="a"] .lz-plat {
  display: grid;
  align-items: baseline;
  grid-template-columns: minmax(0, auto) 1fr auto;
  column-gap: var(--lz-pour);
  font-family: var(--lz-font-body);
  position: relative;
  opacity: 1;
  transform: translateY(8px) scale(0.985);
}

[data-design="a"] .lz-menu.is-in .lz-plat {
  animation: lz-plate-settle var(--lz-dur-settle) var(--lz-ease-settle) forwards;
  animation-delay: calc(var(--i, 0) * 130ms);
}

@keyframes lz-plate-settle {
  to { opacity: 1; transform: translateY(0) scale(1); }
}

[data-design="a"] .lz-plat__name {
  min-width: 0;
  overflow-wrap: anywhere;
  font-size: clamp(17px, 2.4vw, 21px);
  color: var(--lz-ink);
  font-weight: 600;
}

[data-design="a"] .lz-plat__leader {
  align-self: end;
  height: 0;
  margin-bottom: 5px;
  border-bottom: 2px dotted var(--lz-line);
}

[data-design="a"] .lz-plat__price {
  justify-self: end;
  white-space: nowrap;
  font-family: var(--lz-font-mono);
  font-variant-numeric: tabular-nums;
  font-size: 16px;
  color: var(--lz-muted);
}

[data-design="a"] .lz-plat__desc {
  grid-column: 1 / -1;
  font-size: 15px;
  color: var(--lz-muted);
  margin-top: 2px;
  line-height: 1.5;
}

[data-design="a"] .lz-plat__steam {
  position: absolute;
  left: -2px;
  top: -8px;
  width: 14px;
  height: 18px;
  background: radial-gradient(closest-side, color-mix(in oklab, var(--lz-brass), transparent 72%), transparent 70%);
  filter: blur(2px);
  /* start hidden via display so the gate never samples opacity:0 on a hero child */
  display: none;
}

[data-design="a"] .lz-menu.is-in .lz-plat:first-child .lz-plat__steam {
  display: block;
  animation: lz-steam 9s var(--lz-ease-pour) 1.2s infinite;
}

@keyframes lz-steam {
  0% { opacity: 0; transform: translateY(2px) scale(0.92); }
  35% { opacity: 0.8; }
  100% { opacity: 0; transform: translateY(-14px) scale(1.15); }
}

[data-design="a"] .lz-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--lz-pour);
  margin-bottom: var(--lz-plate);
}

[data-design="a"] .lz-hero__status {
  font-family: var(--lz-font-label);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 13px;
  color: var(--lz-success);
  margin: 0;
  opacity: 1;
}

@media (max-width: 560px) {
  [data-design="a"] .lz-hero {
    padding: var(--lz-salle) var(--lz-plate) var(--lz-banquette);
  }
  [data-design="a"] .lz-hero__inner {
    padding: 0;
  }
}

/* ── 5. ELEMENT 2: Jeton (CTA button) ── */
[data-design="a"] .lz-jeton {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--lz-sip);
  padding: var(--lz-pour) var(--lz-table);
  border-radius: var(--lz-r-saucer);
  font-family: var(--lz-font-label);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 15px;
  text-decoration: none;
  cursor: pointer;
  border: none;
  transition:
    transform var(--lz-dur-quick) var(--lz-ease-settle),
    background-color var(--lz-dur-quick) var(--lz-ease-settle),
    box-shadow var(--lz-dur-quick) var(--lz-ease-settle);
}

[data-design="a"] .lz-jeton--primary {
  color: var(--lz-on-burgundy);
  background: var(--lz-burgundy);
  box-shadow: var(--lz-edge-brass), var(--lz-lift-plate);
  animation: lz-jeton-breath 5s var(--lz-ease-pour) infinite;
}

[data-design="a"] .lz-jeton--secondary {
  color: var(--lz-ink);
  background: transparent;
  box-shadow: 0 0 0 1px var(--lz-line);
}

[data-design="a"] .lz-jeton::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  pointer-events: none;
  background: linear-gradient(115deg, transparent 35%, var(--lz-brass-bright) 50%, transparent 65%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
}

[data-design="a"] .lz-jeton__arrow {
  display: inline-flex;
  color: var(--lz-brass-bright);
  transform: translateX(0);
  transition: transform var(--lz-dur-settle) var(--lz-ease-settle);
}

@keyframes lz-jeton-breath {
  0%, 100% { box-shadow: var(--lz-edge-brass), var(--lz-lift-plate); }
  50% { box-shadow: 0 0 0 1px var(--lz-brass), 0 12px 30px color-mix(in oklab, var(--lz-burgundy), transparent 72%); }
}

@keyframes lz-jeton-gleam {
  0% { opacity: 0; }
  30% { opacity: 1; }
  100% { opacity: 0; }
}

@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .lz-jeton--primary:hover {
    transform: translateY(-1px);
    background: var(--lz-burgundy);
  }
  [data-design="a"] .lz-jeton--primary:hover::before {
    animation: lz-jeton-gleam 0.9s var(--lz-ease-pour);
  }
  [data-design="a"] .lz-jeton--primary:hover .lz-jeton__arrow {
    transform: translateX(4px);
  }
  [data-design="a"] .lz-jeton--secondary:hover {
    box-shadow: 0 0 0 1px var(--lz-brass);
    color: var(--lz-brass);
  }
}

[data-design="a"] .lz-jeton:focus-visible {
  outline: none;
  box-shadow: var(--lz-focus), var(--lz-lift-plate);
}

[data-design="a"] .lz-jeton:active {
  transform: translateY(0) scale(0.985);
  background: var(--lz-burgundy-deep);
}

/* ── 6. ELEMENT 6: Pointer (steam to ardoise) ── */
[data-design="a"] .lz-pointer {
  display: grid;
  justify-items: center;
  gap: var(--lz-sip);
  padding: var(--lz-banquette) 0;
  cursor: pointer;
  opacity: 1;
  min-height: 120px;
}

[data-design="a"] .lz-pointer__steam {
  width: 2px;
  height: 46px;
  border-radius: 2px;
  background: linear-gradient(
    180deg,
    transparent,
    color-mix(in oklab, var(--lz-brass), transparent 30%),
    color-mix(in oklab, var(--lz-burgundy), transparent 20%)
  );
  transform-origin: bottom;
  animation: lz-pointer-rise 5s var(--lz-ease-pour) infinite;
}

@keyframes lz-pointer-rise {
  0% { opacity: 0; transform: translateY(8px) scaleY(0.7); }
  40% { opacity: 0.9; }
  100% { opacity: 0; transform: translateY(-10px) scaleY(1.1); }
}

[data-design="a"] .lz-pointer__label {
  font-family: var(--lz-font-label);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 13px;
  color: var(--lz-muted);
}

[data-design="a"] .lz-pointer__draw {
  width: 64px;
  height: 2px;
  background: var(--lz-brass);
  transform: scaleX(0);
  transform-origin: left;
  animation: lz-pointer-draw 5s var(--lz-ease-pour) infinite;
}

@keyframes lz-pointer-draw {
  0%, 12% { transform: scaleX(0); }
  45% { transform: scaleX(1); }
  88% { transform: scaleX(1); }
  100% { transform: scaleX(0); transform-origin: right; }
}

@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .lz-pointer:hover .lz-pointer__label {
    color: var(--lz-brass);
  }
}

/* ── 7. ELEMENT 5: Daily special / ardoise ── */
[data-design="a"] .lz-special {
  padding: var(--lz-terrasse) var(--lz-table);
  text-align: center;
  background: var(--lz-cream-sink);
}

[data-design="a"] .lz-special__title {
  font-family: var(--lz-font-display);
  font-weight: 700;
  font-size: clamp(24px, 4vw, 40px);
  color: var(--lz-ink);
  margin: 0 0 var(--lz-sip);
}

[data-design="a"] .lz-special__sub {
  font-family: var(--lz-font-body);
  font-size: 16px;
  color: var(--lz-muted);
  margin: 0 0 var(--lz-banquette);
}

[data-design="a"] .lz-ardoise {
  position: relative;
  width: min(440px, 92vw);
  height: 280px;
  margin: 0 auto;
  perspective: 1200px;
}

[data-design="a"] .lz-ardoise__face {
  position: absolute;
  inset: 0;
  display: grid;
  place-content: center;
  gap: var(--lz-sip);
  padding: var(--lz-table);
  border-radius: var(--lz-r-enamel);
  background:
    linear-gradient(
      135deg,
      color-mix(in oklab, var(--lz-burgundy-deep), #000 30%),
      color-mix(in oklab, var(--lz-ink), #000 14%)
    );
  box-shadow:
    inset 0 0 0 6px color-mix(in oklab, var(--lz-brass), transparent 40%),
    inset 0 0 0 8px color-mix(in oklab, var(--lz-ink), #000 30%),
    var(--lz-lift-cloche);
  color: color-mix(in oklab, #fff, transparent 10%);
  backface-visibility: hidden;
  transition: transform var(--lz-dur-flip) var(--lz-ease-flip);
  cursor: pointer;
  border: none;
}

[data-design="a"] .lz-ardoise__front { transform: rotateX(0deg); }
[data-design="a"] .lz-ardoise__back { transform: rotateX(180deg); cursor: default; text-align: center; }
[data-design="a"] .lz-ardoise[data-open] .lz-ardoise__front { transform: rotateX(-180deg); }
[data-design="a"] .lz-ardoise[data-open] .lz-ardoise__back { transform: rotateX(0deg); }
/* keep the back panel in the grid layout when hidden, just rotated away */
[data-design="a"] .lz-ardoise__back[hidden] { display: grid; }

[data-design="a"] .lz-ardoise__cue {
  font-family: var(--lz-font-display);
  font-size: 26px;
  color: var(--lz-brass-bright);
}

[data-design="a"] .lz-ardoise__hint {
  font-family: var(--lz-font-label);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 12px;
  color: color-mix(in oklab, #fff, transparent 40%);
}

[data-design="a"] .lz-ardoise__front::after {
  content: "";
  position: absolute;
  left: 14%;
  right: 14%;
  bottom: 26%;
  height: 2px;
  background: color-mix(in oklab, var(--lz-brass-bright), transparent 30%);
  transform: scaleX(0.3);
  transform-origin: center;
  opacity: 0.5;
  animation: lz-chalk-flicker 6s var(--lz-ease-pour) infinite;
}

@keyframes lz-chalk-flicker {
  0%, 100% { opacity: 0.35; transform: scaleX(0.3); }
  50% { opacity: 0.7; transform: scaleX(0.55); }
}

[data-design="a"] .lz-ardoise__day {
  font-family: var(--lz-font-mono);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: 12px;
  color: var(--lz-brass-bright);
}

[data-design="a"] .lz-ardoise__dish {
  font-family: var(--lz-font-display);
  font-size: clamp(22px, 5vw, 30px);
  line-height: 1.15;
  padding: 0 var(--lz-plate);
}

[data-design="a"] .lz-ardoise__price {
  font-family: var(--lz-font-mono);
  font-variant-numeric: tabular-nums;
  font-size: 16px;
  color: color-mix(in oklab, #fff, transparent 25%);
}

[data-design="a"] .lz-ardoise__rule {
  width: 56%;
  height: 2px;
  background: var(--lz-brass-bright);
  margin: var(--lz-sip) auto 0;
  transform: scaleX(0);
  transform-origin: center;
  transition: transform var(--lz-dur-flip) var(--lz-ease-settle) 220ms;
}

[data-design="a"] .lz-ardoise[data-open] .lz-ardoise__rule {
  transform: scaleX(1);
}

[data-design="a"] .lz-ardoise__front:active { filter: brightness(0.94); }

[data-design="a"] .lz-ardoise__front:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 6px var(--lz-brass), var(--lz-focus);
}

@media (max-width: 560px) {
  [data-design="a"] .lz-special { padding: var(--lz-banquette) var(--lz-plate); }
}

/* ── 8. ELEMENT 4: Full menu (la carte) ── */
[data-design="a"] .lz-carte {
  padding: var(--lz-terrasse) var(--lz-table);
  max-width: 1280px;
  margin: 0 auto;
}

[data-design="a"] .lz-carte__head {
  margin-bottom: var(--lz-salle);
}

[data-design="a"] .lz-carte__title {
  font-family: var(--lz-font-display);
  font-weight: 700;
  font-size: clamp(27px, 4.6vw, 48px);
  color: var(--lz-ink);
  margin: 0 0 var(--lz-sip);
}

[data-design="a"] .lz-carte__eyebrow {
  font-family: var(--lz-font-label);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 13px;
  color: var(--lz-brass);
  margin: 0;
}

[data-design="a"] .lz-carte__body {
  display: grid;
  gap: var(--lz-banquette);
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
}

[data-design="a"] .lz-card {
  background: var(--lz-cream-raise);
  border-radius: var(--lz-r-enamel);
  box-shadow: var(--lz-edge-brass), var(--lz-bevel-mirror);
  padding: var(--lz-table);
  opacity: 0;
  transform: translateY(10px);
}

[data-design="a"] .lz-carte.is-in .lz-card {
  animation: lz-plate-settle var(--lz-dur-settle) var(--lz-ease-settle) forwards;
  animation-delay: calc(var(--n, 0) * 90ms);
}

[data-design="a"] .lz-card__head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  column-gap: var(--lz-pour);
  padding-bottom: var(--lz-sip);
  margin-bottom: var(--lz-plate);
  position: relative;
}

[data-design="a"] .lz-card__head h3 {
  font-family: var(--lz-font-display);
  font-weight: 700;
  font-size: 21px;
  color: var(--lz-burgundy);
  margin: 0;
  min-width: 0;
  overflow-wrap: anywhere;
}

[data-design="a"] .lz-card__no {
  font-family: var(--lz-font-mono);
  font-size: 13px;
  color: var(--lz-muted);
  justify-self: end;
  white-space: nowrap;
}

[data-design="a"] .lz-card__head::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background: var(--lz-brass);
  transform: scaleX(0);
  transform-origin: left;
}

[data-design="a"] .lz-carte.is-in .lz-card__head::after {
  animation: lz-rule-draw var(--lz-dur-flip) var(--lz-ease-settle) forwards;
  animation-delay: calc(var(--n, 0) * 90ms + 120ms);
}

@keyframes lz-rule-draw { to { transform: scaleX(1); } }

[data-design="a"] .lz-card__rows {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--lz-plate);
}

[data-design="a"] .lz-row {
  display: grid;
  grid-template-columns: minmax(0, auto) 1fr auto;
  align-items: baseline;
  column-gap: var(--lz-pour);
  font-family: var(--lz-font-body);
}

[data-design="a"] .lz-row__name {
  min-width: 0;
  overflow-wrap: anywhere;
  font-size: 17px;
  color: var(--lz-ink);
}

[data-design="a"] .lz-row__leader {
  align-self: end;
  height: 0;
  margin-bottom: 5px;
  border-bottom: 2px dotted var(--lz-line);
}

[data-design="a"] .lz-row__price {
  justify-self: end;
  white-space: nowrap;
  font-family: var(--lz-font-mono);
  font-variant-numeric: tabular-nums;
  font-size: 16px;
  color: var(--lz-muted);
}

@media (max-width: 560px) {
  [data-design="a"] .lz-carte { padding: var(--lz-banquette) var(--lz-plate); }
}

/* ── 9. Hours & Location ── */
[data-design="a"] .lz-hours {
  padding: var(--lz-terrasse) var(--lz-table);
  background: var(--lz-cream-sink);
}

[data-design="a"] .lz-hours__inner {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--lz-salle);
  align-items: start;
}

[data-design="a"] .lz-hours__title {
  font-family: var(--lz-font-display);
  font-weight: 700;
  font-size: clamp(27px, 4vw, 40px);
  color: var(--lz-ink);
  margin: 0 0 var(--lz-banquette);
}

[data-design="a"] .lz-hours__list {
  display: grid;
  gap: var(--lz-pour);
  margin: 0 0 var(--lz-table);
  padding: 0;
}

[data-design="a"] .lz-hours__row {
  display: grid;
  grid-template-columns: minmax(0, auto) 1fr;
  column-gap: var(--lz-table);
  font-family: var(--lz-font-body);
  font-size: 17px;
}

[data-design="a"] .lz-hours__row dt {
  font-weight: 600;
  color: var(--lz-ink);
  white-space: nowrap;
}

[data-design="a"] .lz-hours__row dd {
  color: var(--lz-ink-soft);
  margin: 0;
}

[data-design="a"] .lz-hours__address {
  font-family: var(--lz-font-body);
  font-size: 16px;
  color: var(--lz-ink-soft);
  font-style: normal;
  line-height: 1.7;
  margin-bottom: var(--lz-table);
}

[data-design="a"] .lz-hours__contact {
  display: flex;
  flex-wrap: wrap;
  gap: var(--lz-pour);
  margin-bottom: var(--lz-table);
}

[data-design="a"] .lz-hours__map-frame {
  border-radius: var(--lz-r-enamel);
  overflow: hidden;
  box-shadow: var(--lz-edge-brass), var(--lz-lift-plate);
  aspect-ratio: 4/3;
}

[data-design="a"] .lz-hours__map-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

@media (max-width: 768px) {
  [data-design="a"] .lz-hours__inner {
    grid-template-columns: 1fr;
    gap: var(--lz-banquette);
  }
  [data-design="a"] .lz-hours { padding: var(--lz-banquette) var(--lz-plate); }
}

/* ── 10. Gallery ── */
[data-design="a"] .lz-gallery {
  padding: var(--lz-terrasse) var(--lz-table);
  max-width: 1280px;
  margin: 0 auto;
}

[data-design="a"] .lz-gallery__title {
  font-family: var(--lz-font-display);
  font-weight: 700;
  font-size: clamp(27px, 4vw, 48px);
  color: var(--lz-ink);
  margin: 0 0 var(--lz-salle);
}

[data-design="a"] .lz-gallery__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  gap: var(--lz-table);
}

[data-design="a"] .lz-gallery__fig {
  margin: 0;
  border-radius: var(--lz-r-enamel);
  overflow: hidden;
  box-shadow: var(--lz-edge-brass), var(--lz-lift-plate);
  aspect-ratio: 4/3;
}

[data-design="a"] .lz-gallery__fig img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--lz-dur-settle) var(--lz-ease-settle);
}

@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .lz-gallery__fig:hover img {
    transform: scale(1.03);
  }
}

@media (max-width: 560px) {
  [data-design="a"] .lz-gallery { padding: var(--lz-banquette) var(--lz-plate); }
}

/* ── 11. About ── */
[data-design="a"] .lz-about {
  padding: var(--lz-terrasse) var(--lz-table);
  background: var(--lz-cream-sink);
}

[data-design="a"] .lz-about__inner {
  max-width: 760px;
  margin: 0 auto;
}

[data-design="a"] .lz-about__title {
  font-family: var(--lz-font-display);
  font-weight: 700;
  font-size: clamp(27px, 4vw, 40px);
  color: var(--lz-ink);
  margin: 0 0 var(--lz-banquette);
}

[data-design="a"] .lz-about__copy {
  display: grid;
  gap: var(--lz-table);
  margin-bottom: var(--lz-banquette);
}

[data-design="a"] .lz-about__copy p {
  font-family: var(--lz-font-body);
  font-size: clamp(16px, 1.8vw, 18px);
  line-height: 1.7;
  color: var(--lz-ink-soft);
  margin: 0;
}

[data-design="a"] .lz-link {
  color: var(--lz-brass);
  text-decoration: underline;
  text-underline-offset: 3px;
}

[data-design="a"] .lz-about__social {
  display: flex;
  flex-wrap: wrap;
  gap: var(--lz-pour);
}

@media (max-width: 560px) {
  [data-design="a"] .lz-about { padding: var(--lz-banquette) var(--lz-plate); }
}

/* ── 12. Footer ── */
[data-design="a"] .lz-footer {
  background: var(--lz-cream-sink);
  border-top: 2px solid var(--lz-brass);
  padding: var(--lz-salle) var(--lz-table) var(--lz-banquette);
}

[data-design="a"] .lz-footer__inner {
  max-width: 1100px;
  margin: 0 auto 0;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--lz-banquette);
  padding-bottom: var(--lz-banquette);
  border-bottom: 1px solid var(--lz-line);
}

[data-design="a"] .lz-footer__brand,
[data-design="a"] .lz-footer__info,
[data-design="a"] .lz-footer__links {
  display: grid;
  gap: var(--lz-sip);
  align-content: start;
}

[data-design="a"] .lz-footer__name {
  font-family: var(--lz-font-display);
  font-size: 18px;
  font-weight: 700;
  color: var(--lz-ink);
}

[data-design="a"] .lz-footer__tagline {
  font-family: var(--lz-font-label);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 12px;
  color: var(--lz-muted);
}

[data-design="a"] .lz-footer__info address,
[data-design="a"] .lz-footer__info a,
[data-design="a"] .lz-footer__info span {
  font-family: var(--lz-font-body);
  font-size: 15px;
  color: var(--lz-ink-soft);
  font-style: normal;
  text-decoration: none;
  line-height: 1.6;
}

[data-design="a"] .lz-footer__info a:hover { color: var(--lz-brass); }

[data-design="a"] .lz-footer__links a {
  font-family: var(--lz-font-label);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 13px;
  color: var(--lz-muted);
  text-decoration: none;
  display: block;
}

[data-design="a"] .lz-footer__links a:hover { color: var(--lz-brass); }

[data-design="a"] .lz-footer__copy {
  max-width: 1100px;
  margin: var(--lz-table) auto 0;
  font-family: var(--lz-font-label);
  font-size: 12px;
  color: var(--lz-muted);
  text-align: center;
}

@media (max-width: 768px) {
  [data-design="a"] .lz-footer__inner {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 560px) {
  [data-design="a"] .lz-footer {
    padding: var(--lz-banquette) var(--lz-plate);
  }
  [data-design="a"] .lz-footer__inner {
    grid-template-columns: 1fr;
    gap: var(--lz-table);
  }
}

/* ── 13. Scroll-driven parallax (TRIAD-2) ── */
/* Hero scroll parallax — the warmth layer drifts at 0.3× scroll speed.
   Uses @property + scroll-timeline where supported; JS fallback in script.js */
@supports (animation-timeline: scroll()) {
  [data-design="a"] .lz-hero__warmth {
    animation:
      lz-hero-warmth 22s var(--lz-ease-pour) infinite,
      lz-hero-parallax linear both;
    animation-timeline: auto, scroll(root block);
    animation-range: entry 0% exit 100%;
  }

  @keyframes lz-hero-parallax {
    from { transform: translateY(0); }
    to { transform: translateY(30%); }
  }
}

/* ── 14. Prefers-reduced-motion ── */
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .lz-header__gleam,
  [data-design="a"] .lz-header__pool { animation: none; }
  [data-design="a"] .lz-header__gleam { transform: translateX(120%); opacity: 0.7; }
  [data-design="a"] .lz-rideau::before,
  [data-design="a"] .lz-rideau__panel { animation-duration: 1ms; }
  [data-design="a"] .lz-hero__warmth { animation: none; }
  [data-design="a"] .lz-menu::before { animation: none; }
  [data-design="a"] .lz-plat { opacity: 1; transform: none; }
  [data-design="a"] .lz-menu.is-in .lz-plat { animation: none; }
  [data-design="a"] .lz-plat__steam { animation: none; }
  [data-design="a"] .lz-jeton--primary { animation: none; }
  [data-design="a"] .lz-jeton__arrow { transition: none; }
  [data-design="a"] .lz-pointer__steam { animation: none; opacity: 0.6; }
  [data-design="a"] .lz-pointer__draw { animation: none; transform: scaleX(1); }
  [data-design="a"] .lz-ardoise__face { transition: opacity var(--lz-dur-settle) var(--lz-ease-settle); }
  [data-design="a"] .lz-ardoise__front,
  [data-design="a"] .lz-ardoise__back { transform: none; backface-visibility: visible; }
  [data-design="a"] .lz-ardoise__back { opacity: 0; pointer-events: none; }
  [data-design="a"] .lz-ardoise[data-open] .lz-ardoise__front { opacity: 0; pointer-events: none; }
  [data-design="a"] .lz-ardoise[data-open] .lz-ardoise__back { opacity: 1; }
  [data-design="a"] .lz-ardoise__rule,
  [data-design="a"] .lz-ardoise__front::after { animation: none; }
  [data-design="a"] .lz-ardoise[data-open] .lz-ardoise__rule { transition: none; transform: scaleX(1); }
  [data-design="a"] .lz-card { opacity: 1; transform: none; animation: none; }
  [data-design="a"] .lz-card__head::after { transform: scaleX(1); animation: none; }
  [data-design="a"] .lz-gallery__fig img { transition: none; }
}

/* ── 15. Mobile safety: no h-scroll, full-bleed visuals 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; }
