/* ============================================================
   HORIZON — Design System (Editorial Warmth)
   Shared across landing, dashboard, order, onboard.
   ------------------------------------------------------------
   Direction: warm cream + deep ink + terracotta accent.
   Typography: Fraunces (display, high-contrast serif) + Space
   Grotesk (UI body) + JetBrains Mono (numeric / code).
   Motion: precise, never flashy. 180–280ms, cubic-bezier(.2,.9,.2,1).
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght,SOFT,WONK@0,9..144,300..900,0..100,0..1;1,9..144,300..900,0..100,0..1&family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
  /* Palette — warm earth, editorial */
  --cream-50: #FDFBF6;
  --cream-100: #F8F2E7;
  --cream-200: #EFE6D3;
  --cream-300: #E3D5B8;
  --line: #E8DFD1;
  --line-strong: #D6C8AE;

  --ink-900: #17130E;  /* deepest */
  --ink-800: #231C14;
  --ink-700: #332A1F;
  --ink-600: #5C4F3F;
  --ink-500: #7A6B58;
  --ink-400: #A29380;

  --terracotta-900: #6B2B15;
  --terracotta-700: #8F3D20;
  --terracotta-500: #C7633E;    /* primary accent */
  --terracotta-400: #DB825C;
  --terracotta-100: #F6D9C8;
  --terracotta-50:  #FBEBE0;

  --moss-700: #3B5540;
  --moss-500: #6D8A6F;

  --amber-500: #C89634;
  --ruby-500:  #A32E2E;

  /* Semantic — surfaces */
  --bg:        var(--cream-50);
  --surface:   #FFFFFF;
  --surface-2: var(--cream-100);
  --surface-elevated: #FFFFFF;            /* sticky bars, modals, popovers */

  /* Semantic — text (Linear/Vercel/Notion alignment with /app) */
  --text:        var(--ink-900);          /* primary */
  --text-soft:   var(--ink-700);          /* secondary, body-soft */
  --text-muted:  var(--ink-500);          /* tertiary, labels */
  --text-subtle: var(--ink-400);          /* placeholders, captions */
  --ink:         var(--text);             /* legacy alias */
  --ink-muted:   var(--text-muted);       /* legacy alias */

  /* Semantic — borders */
  --border:        var(--line);
  --border-strong: var(--line-strong);

  /* Semantic — inputs */
  --input-bg:    #FFFFFF;
  --placeholder: var(--ink-400);

  /* Semantic — buttons (CTA) */
  --btn-primary-bg:    var(--ink-900);
  --btn-primary-text:  #FFFFFF;
  --btn-primary-hover: var(--terracotta-500);

  /* Semantic — accent (immutable across modes, but tweak in dark for vibrance) */
  --accent:        var(--terracotta-500);
  --accent-soft:   var(--terracotta-50);
  --accent-strong: var(--terracotta-700);
  --accent-ink:    #FFFFFF;
  --accent-deep:   var(--terracotta-700);

  /* Feedback */
  --err-bg:   var(--terracotta-50);
  --err-text: var(--terracotta-900);

  /* Typography scale — editorial, generous leading */
  --font-display: 'Fraunces', ui-serif, Georgia, serif;
  --font-body:    'Space Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;

  --step--2: clamp(.72rem, .70rem + .10vw, .78rem);
  --step--1: clamp(.82rem, .80rem + .15vw, .90rem);
  --step-0:  clamp(.94rem, .92rem + .15vw, 1.02rem);
  --step-1:  clamp(1.08rem, 1.05rem + .25vw, 1.22rem);
  --step-2:  clamp(1.28rem, 1.20rem + .45vw, 1.55rem);
  --step-3:  clamp(1.60rem, 1.48rem + .80vw, 2.10rem);
  --step-4:  clamp(2.10rem, 1.80rem + 1.50vw, 3.10rem);
  --step-5:  clamp(2.80rem, 2.20rem + 3.00vw, 4.60rem);
  --step-6:  clamp(3.60rem, 2.60rem + 5.00vw, 6.80rem);

  /* Shape */
  --r-xs: 4px;
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 22px;
  --r-xl: 32px;
  --r-pill: 999px;

  /* Shadow — warm, multi-layer */
  --shadow-sm: 0 1px 0 rgba(23,19,14,.04), 0 1px 2px rgba(23,19,14,.06);
  --shadow-md: 0 1px 0 rgba(23,19,14,.04), 0 4px 12px -2px rgba(23,19,14,.08), 0 12px 32px -8px rgba(23,19,14,.10);
  --shadow-lg: 0 2px 0 rgba(23,19,14,.04), 0 18px 40px -12px rgba(23,19,14,.18), 0 40px 80px -20px rgba(23,19,14,.18);
  --shadow-xl: 0 32px 64px -16px rgba(23,19,14,.22);
  --shadow-accent: 0 14px 40px -14px rgba(199,99,62,.55);

  /* Motion */
  --ease: cubic-bezier(.2,.9,.2,1);
  --ease-spring: cubic-bezier(.2,1.1,.3,1);
  --t-fast: 160ms;
  --t: 240ms;
  --t-slow: 440ms;
  --t-reveal: 600ms;
  --t-parallax: 16ms;
  --ease-reveal: cubic-bezier(.15,.6,.25,1);
  --ease-cart-spring: cubic-bezier(.34,1.56,.64,1);
  --gradient-accent-animated: linear-gradient(120deg, var(--terracotta-500), var(--terracotta-600, var(--terracotta-700)), var(--terracotta-500));
  --mask-edge-fade: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  font-size: var(--step-0);
  line-height: 1.55;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* Typography primitives */
.h-display { font-family: var(--font-display); font-weight: 400; font-size: var(--step-6); line-height: .92; letter-spacing: -.035em; font-variation-settings: 'opsz' 144, 'SOFT' 50; }
.h-1 { font-family: var(--font-display); font-weight: 400; font-size: var(--step-5); line-height: 1.0; letter-spacing: -.028em; font-variation-settings: 'opsz' 100, 'SOFT' 30; }
.h-2 { font-family: var(--font-display); font-weight: 500; font-size: var(--step-4); line-height: 1.1; letter-spacing: -.022em; }
.h-3 { font-family: var(--font-display); font-weight: 500; font-size: var(--step-3); line-height: 1.18; letter-spacing: -.015em; }
.h-4 { font-family: var(--font-body); font-weight: 600; font-size: var(--step-2); line-height: 1.3; letter-spacing: -.01em; }
.h-eyebrow { font-family: var(--font-body); font-weight: 500; font-size: var(--step--1); letter-spacing: .14em; text-transform: uppercase; color: var(--terracotta-700); }
.mono { font-family: var(--font-mono); font-feature-settings: 'tnum' 1; }
em.italic-serif { font-family: var(--font-display); font-style: italic; font-weight: 400; font-variation-settings: 'SOFT' 100, 'WONK' 1; color: var(--terracotta-500); }
.subtle { color: var(--ink-muted); }
p.lead { font-size: var(--step-1); line-height: 1.55; color: var(--ink-600); max-width: 58ch; }

::selection { background: var(--terracotta-100); color: var(--ink); }

/* Primitive — link with precise underline animation */
a.link { color: var(--ink); text-decoration: none; background-image: linear-gradient(var(--accent),var(--accent)); background-repeat: no-repeat; background-size: 0 1.5px; background-position: 0 100%; transition: background-size var(--t) var(--ease), color var(--t) var(--ease); padding-bottom: 2px; }
a.link:hover { background-size: 100% 1.5px; color: var(--accent-deep); }

/* Primitive — buttons */
.btn { display: inline-flex; align-items: center; gap: .55rem; padding: .85rem 1.35rem; font: 500 var(--step-0)/1 var(--font-body); color: var(--text); background: transparent; border: 1.5px solid var(--border-strong); border-radius: var(--r-pill); cursor: pointer; transition: transform var(--t-fast) var(--ease), background var(--t) var(--ease), border-color var(--t) var(--ease), box-shadow var(--t) var(--ease), color var(--t) var(--ease); text-decoration: none; user-select: none; letter-spacing: -.005em; }
.btn:hover { background: var(--btn-primary-bg); color: var(--btn-primary-text); border-color: var(--btn-primary-bg); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn:active { transform: translateY(0) scale(.98); }

.btn.primary { background: var(--btn-primary-bg); color: var(--btn-primary-text); border-color: var(--btn-primary-bg); }
.btn.primary:hover { background: var(--btn-primary-hover); color: #fff; border-color: var(--btn-primary-hover); box-shadow: var(--shadow-accent); }

.btn.accent { background: var(--accent); color: #fff; border-color: var(--accent); }
.btn.accent:hover { background: var(--accent-strong); border-color: var(--accent-strong); box-shadow: var(--shadow-accent); }

.btn.ghost { border-color: transparent; background: transparent; color: var(--text); }
.btn.ghost:hover { background: var(--surface-2); color: var(--text); border-color: transparent; }

.btn.small { padding: .55rem .95rem; font-size: var(--step--1); }
.btn.lg { padding: 1.05rem 1.75rem; font-size: var(--step-1); }

.btn .arrow { display: inline-block; transition: transform var(--t) var(--ease); }
.btn:hover .arrow { transform: translateX(4px); }

/* Inputs */
input[type="text"], input[type="email"], input[type="tel"], input[type="number"], input[type="password"], input[type="date"], input[type="time"], input[type="search"], input:not([type]), textarea, select {
  width: 100%;
  padding: .85rem 1rem;
  font: 400 var(--step-0)/1.4 var(--font-body);
  color: var(--ink);
  background: var(--surface);
  border: 1.5px solid var(--line);
  border-radius: var(--r-sm);
  transition: border-color var(--t) var(--ease), box-shadow var(--t) var(--ease), background var(--t) var(--ease);
  outline: none;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-soft);
  background: var(--input-bg);
}
textarea { resize: vertical; min-height: 5.5rem; font-family: inherit; }
label { display: block; margin-bottom: .4rem; font-size: var(--step--1); font-weight: 500; color: var(--ink-600); letter-spacing: -.005em; }

/* Cards */
.card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); padding: 1.6rem; transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease), border-color var(--t) var(--ease); }
.card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--line-strong); }

/* Divider grainy */
.rule { border: 0; border-top: 1px solid var(--line); margin: 3rem 0; }

/* Chip / badge */
.chip { display: inline-flex; align-items: center; gap: .4rem; padding: .35rem .7rem; background: var(--cream-100); border: 1px solid var(--line); border-radius: var(--r-pill); font-size: var(--step--1); font-weight: 500; color: var(--ink-600); letter-spacing: -.005em; }
.chip.accent { background: var(--terracotta-50); border-color: var(--terracotta-100); color: var(--terracotta-700); }
.chip.moss { background: color-mix(in oklab, var(--moss-500) 16%, var(--surface)); border-color: color-mix(in oklab, var(--moss-500) 35%, transparent); color: var(--moss-700); }

/* Menu item badges (bestseller / new / promo) — rendered on QR client cards AND dashboard menu table */
.item-badge { display: inline-flex; align-items: center; gap: .25rem; font-family: var(--font-mono); font-size: .66rem; font-weight: 600; letter-spacing: .06em; padding: .18rem .5rem; border-radius: var(--r-pill); text-transform: uppercase; border: 1px solid transparent; }
.item-badge--bestseller { background: var(--terracotta-50); color: var(--terracotta-700); border-color: var(--terracotta-100); }
.item-badge--new { background: color-mix(in oklab, var(--moss-500) 16%, var(--surface)); color: var(--moss-700); border-color: color-mix(in oklab, var(--moss-500) 35%, transparent); }
.item-badge--promo { background: color-mix(in oklab, var(--amber-500) 22%, var(--surface)); color: var(--amber-500); border-color: color-mix(in oklab, var(--amber-500) 45%, transparent); }

/* Reveal animations */
@keyframes h-rise { from { opacity: 0; transform: translateY(14px) } to { opacity: 1; transform: translateY(0) } }
@keyframes h-fade { from { opacity: 0 } to { opacity: 1 } }
.reveal { opacity: 0; transform: translateY(40px); transition: opacity var(--t-reveal) var(--ease-reveal) var(--stagger,0ms), transform var(--t-reveal) var(--ease-reveal) var(--stagger,0ms); }
.reveal.in { opacity: 1; transform: none; }
.reveal-x { opacity: 0; transform: translateX(-30px); transition: opacity var(--t-reveal) var(--ease-reveal) var(--stagger,0ms), transform var(--t-reveal) var(--ease-reveal) var(--stagger,0ms); }
.reveal-x.in { opacity: 1; transform: none; }
.reveal-scale { opacity: 0; transform: scale(.92); transition: opacity var(--t-reveal) var(--ease-reveal) var(--stagger,0ms), transform var(--t-reveal) var(--ease-reveal) var(--stagger,0ms); }
.reveal-scale.in { opacity: 1; transform: none; }

/* Accessibility — skip link hidden until focused (keyboard nav) */
.skip-link { position: absolute; top: -60px; left: 1rem; z-index: 9999; background: var(--ink-900); color: var(--cream-50); padding: .75rem 1rem; border-radius: var(--r-pill); font: 500 var(--step--1) var(--font-body); text-decoration: none; transition: top var(--t) var(--ease); }
.skip-link:focus { top: 1rem; outline: 2px solid var(--terracotta-500); outline-offset: 2px; }

/* Containers */
.container { max-width: 1240px; margin: 0 auto; padding: 0 clamp(1rem, 3vw, 2.4rem); }
.container-narrow { max-width: 820px; margin: 0 auto; padding: 0 clamp(1rem, 3vw, 2.4rem); }

/* Scrollbar (dashboard) */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: var(--cream-300); border-radius: 5px; border: 2px solid var(--bg); }
::-webkit-scrollbar-thumb:hover { background: var(--line-strong); }

/* Marquee-style numeric ticker (hero stats) */
.tick { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-weight: 500; }

/* Accessible focus ring */
:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--terracotta-100); border-radius: 6px; }

/* Utility */
.stack-1 > * + * { margin-top: .6rem; }
.stack-2 > * + * { margin-top: 1.2rem; }
.stack-3 > * + * { margin-top: 2rem; }
.cluster { display: flex; flex-wrap: wrap; gap: .8rem; align-items: center; }
.grid-2 { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.4rem; }
.grid-3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.4rem; }

/* Motion utilities — opt-in classes for scroll-driven, parallax, cart, drop-zone, tab fade */
.parallax-layer { will-change: transform; transform: translate3d(var(--px,0), var(--py,0), 0); transition: transform var(--t-parallax) linear; }
.gradient-animated { background: var(--gradient-accent-animated); background-size: 200% 100%; animation: gradient-shift 4s ease-in-out infinite; }
@keyframes gradient-shift { 0%,100% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } }
.mask-edges { -webkit-mask-image: var(--mask-edge-fade); mask-image: var(--mask-edge-fade); }
.cart-spring-in { animation: cart-spring var(--t-slow) var(--ease-cart-spring); }
@keyframes cart-spring { from { transform: translateY(100%); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.bounce-add { animation: bounce-add 280ms var(--ease-spring); }
@keyframes bounce-add { 0%,100% { transform: scale(1); } 35% { transform: scale(1.15); } 70% { transform: scale(.96); } }
.pulse-waiter { animation: pulse-waiter 2.2s ease-in-out infinite; }
@keyframes pulse-waiter { 0%,100% { box-shadow: 0 0 0 0 color-mix(in oklab, var(--terracotta-500) 40%, transparent); } 50% { box-shadow: 0 0 0 12px transparent; } }
.plan--glow:hover, .plan-card--glow-hover:hover { background: var(--gradient-accent-animated); background-size: 200% 100%; animation: gradient-shift 4s ease-in-out infinite; color: var(--accent-ink); }
.drop-zone--active { border-color: var(--terracotta-500) !important; box-shadow: 0 0 0 4px color-mix(in oklab, var(--terracotta-500) 18%, transparent); transform: scale(1.01); }
.upgrade--shimmer:hover { background: var(--gradient-accent-animated); background-size: 200% 100%; animation: gradient-shift 5s ease-in-out infinite; color: #fff; }
/* Force readable text inside the upgrade card whenever the terracotta gradient
   shows (hover + the always-on demo panel on the right). Without this, the
   default ink-600/cream-300 text is dark-on-terracotta and very low contrast. */
.upgrade--shimmer:hover .lead,
.upgrade--shimmer:hover .stack-1,
.upgrade--shimmer:hover .subtle,
.upgrade--shimmer:hover p,
.upgrade--shimmer:hover .h-eyebrow { color: rgba(255,255,255,.95) !important; }
.upgrade--shimmer:hover .btn.ghost { color: #fff; border-color: rgba(255,255,255,.4); }
.upgrade--shimmer:hover .btn.ghost:hover { background: rgba(255,255,255,.1); }
.tab-content--fade { animation: tab-fade 200ms var(--ease); }
@keyframes tab-fade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.stepper-dot--progress { transition: all var(--t-slow) var(--ease-reveal); }

/* Hero intro — play on mount */
.hero-intro { opacity: 0; transform: translateY(32px); animation: hero-rise 900ms var(--ease-reveal) forwards; animation-delay: var(--hero-delay, 0ms); }
@keyframes hero-rise { to { opacity: 1; transform: none; } }

/* Floating ambient orbs — slow drift background */
.float-orbs { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 0; }
.float-orb { position: absolute; border-radius: 50%; filter: blur(60px); opacity: .55; will-change: transform; animation: orb-drift var(--orb-dur, 18s) ease-in-out infinite; }
.float-orb.a { top: -80px; left: -60px; width: 340px; height: 340px; background: radial-gradient(circle, var(--terracotta-400), transparent 70%); --orb-dur: 22s; }
.float-orb.b { bottom: -80px; right: -80px; width: 420px; height: 420px; background: radial-gradient(circle, var(--moss-500), transparent 65%); --orb-dur: 28s; animation-delay: -8s; opacity: .35; }
.float-orb.c { top: 40%; left: 40%; width: 280px; height: 280px; background: radial-gradient(circle, var(--terracotta-100), transparent 70%); --orb-dur: 19s; animation-delay: -4s; opacity: .45; }
@keyframes orb-drift {
  0%,100% { transform: translate3d(0,0,0) scale(1); }
  25% { transform: translate3d(60px,-40px,0) scale(1.08); }
  50% { transform: translate3d(-30px,50px,0) scale(.96); }
  75% { transform: translate3d(40px,20px,0) scale(1.04); }
}

/* Scroll progress bar — terracotta at top */
.scroll-progress { position: fixed; top: 0; left: 0; right: 0; height: 3px; background: transparent; z-index: 9999; pointer-events: none; }
.scroll-progress::after { content: ''; display: block; height: 100%; width: calc(var(--scroll-progress, 0) * 100%); background: linear-gradient(90deg, var(--terracotta-500), var(--terracotta-400), var(--terracotta-700)); background-size: 200% 100%; animation: gradient-shift 3s ease-in-out infinite; transition: width 80ms linear; }

/* Magnetic button — CSS part (JS sets --mag-x, --mag-y) */
.btn-magnetic { transform: translate3d(var(--mag-x, 0px), var(--mag-y, 0px), 0); transition: transform 320ms var(--ease-spring); }

/* Button shimmer — primary CTA glow pass */
.btn-shimmer { position: relative; overflow: hidden; }
.btn-shimmer::after { content: ''; position: absolute; inset: 0; background: linear-gradient(110deg, transparent 30%, color-mix(in oklab, var(--terracotta-400) 50%, transparent) 50%, transparent 70%); transform: translateX(-120%); transition: transform 800ms var(--ease); pointer-events: none; }
.btn-shimmer:hover::after { transform: translateX(120%); }

/* Lift on hover — generic utility (stronger than current .step:hover) */
.lift-strong { transition: transform var(--t) var(--ease-spring), box-shadow var(--t) var(--ease); }
.lift-strong:hover { transform: translateY(-6px) scale(1.01); box-shadow: var(--shadow-lg); }

@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; animation: none !important; }
  .reveal, .reveal.in { opacity: 1 !important; transform: none !important; transition: none !important; }
  .parallax-layer { transform: none !important; }
  .gradient-animated, .plan--glow:hover, .plan-card--glow-hover:hover, .upgrade--shimmer:hover { animation: none !important; background-size: 100% 100% !important; }
  .cart-spring-in, .bounce-add, .pulse-waiter, .tab-content--fade { animation: none !important; }
  .hero-intro { opacity: 1 !important; transform: none !important; animation: none !important; }
  .float-orb { animation: none !important; opacity: .3 !important; }
  .scroll-progress::after { animation: none !important; }
  .btn-magnetic { transform: none !important; }
  .reveal-x, .reveal-x.in, .reveal-scale, .reveal-scale.in { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* Menu item badges — TOP 10 / Nouveau / Promo (shared across dashboard + QR order) */
.menu-badge { position: absolute; top: 10px; right: 10px; padding: 4px 9px; border-radius: var(--r-pill); font-family: var(--font-body); font-size: 10px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; z-index: 2; pointer-events: none; white-space: nowrap; box-shadow: 0 2px 6px rgba(23,19,14,.15); line-height: 1.2; }
.menu-badge--bestseller { background: var(--terracotta-500); color: var(--cream-50); }
.menu-badge--new { background: var(--moss-500); color: var(--cream-50); }
.menu-badge--promo { background: var(--amber-500); color: var(--ink-900); animation: menu-badge-pulse 2.4s ease-in-out infinite; }
.menu-badge--scarcity { background: var(--ruby-500); color: var(--cream-50); animation: menu-badge-pulse 1.6s ease-in-out infinite; font-weight: 700; }
@keyframes menu-badge-pulse {
  0%, 100% { transform: scale(1); box-shadow: 0 2px 6px rgba(23,19,14,.15); }
  50% { transform: scale(1.06); box-shadow: 0 4px 12px color-mix(in oklab, var(--amber-500) 50%, transparent); }
}
@media (prefers-reduced-motion: reduce) {
  .menu-badge--promo, .menu-badge--scarcity { animation: none !important; }
}

/* Recipe picker (dashboard Menu ↔ Stock linkage) */
.recipe-list { display: flex; flex-direction: column; gap: .25rem; max-height: 240px; overflow-y: auto; border: 1px solid var(--line); border-radius: var(--r-sm); padding: .5rem; background: var(--cream-50); }
.recipe-row { display: grid; grid-template-columns: 22px 1fr 130px 90px; gap: .6rem; align-items: center; padding: .4rem .3rem; border-radius: var(--r-xs); transition: background var(--t-fast) var(--ease); }
.recipe-row:hover { background: var(--cream-100); }
.recipe-row input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--terracotta-500); cursor: pointer; }
.recipe-row .r-name { font-family: var(--font-body); font-size: var(--step--1); color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.recipe-row .r-qty { display: flex; align-items: center; gap: .3rem; }
.recipe-row .r-qty input { width: 100%; padding: .3rem .5rem; border: 1px solid var(--line); border-radius: var(--r-xs); font-family: var(--font-mono); font-size: var(--step--1); text-align: right; }
.recipe-row .r-qty input:disabled { background: var(--cream-100); color: var(--ink-400); cursor: not-allowed; }
.recipe-row .r-qty .r-unit { font-family: var(--font-mono); font-size: var(--step--2); color: var(--ink-500); }
.recipe-row .r-stock { font-size: var(--step--2); color: var(--ink-500); font-family: var(--font-mono); text-align: right; white-space: nowrap; }
.recipe-row .r-stock.low { color: var(--ruby-500); font-weight: 600; }
.recipe-empty { padding: 1rem; background: var(--cream-100); border-radius: var(--r-sm); text-align: center; font-size: var(--step--1); color: var(--ink-600); }
.recipe-empty a { color: var(--terracotta-500); text-decoration: underline; cursor: pointer; }

/* ============================================================
   Phase 1 v2 — Skeleton kit + Toast + Dark mode
   Shared foundation layer across landing, dashboard, order,
   onboard, success. Pure tokens — no hardcoded hex below :root.
   ============================================================ */

/* --- Missing shadow token (lift used by toasts + floating UI) --- */
:root {
  --shadow-lift: 0 8px 24px rgba(23,19,14,.14);
}

/* ---------- Skeleton kit (Phase 1 v2) ---------- */
.skeleton-text,
.skeleton-card,
.skeleton-avatar,
.skeleton-btn {
  background: linear-gradient(90deg, var(--cream-100) 0%, var(--cream-200) 50%, var(--cream-100) 100%);
  background-size: 200% 100%;
  animation: shimmer-v2 1.6s ease-in-out infinite;
  display: block;
}
.skeleton-text { height: 1em; width: 60%; border-radius: var(--r-sm); }
.skeleton-text.short { width: 40%; }
.skeleton-text.long  { width: 80%; }
.skeleton-card   { height: 120px; width: 100%; border-radius: var(--r-md); }
.skeleton-avatar { width: 36px; height: 36px; border-radius: 50%; }
.skeleton-btn    { height: 44px; width: 120px; border-radius: var(--r-pill); }

@keyframes shimmer-v2 {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}

@media (prefers-reduced-motion: reduce) {
  .skeleton-text,
  .skeleton-card,
  .skeleton-avatar,
  .skeleton-btn {
    animation: none !important;
    background: var(--cream-100) !important;
  }
}

/* ---------- Toast stack (Phase 1 v2) ---------- */
.toast-stack {
  position: fixed;
  bottom: calc(env(safe-area-inset-bottom, 0px) + 1rem);
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  pointer-events: none;
}
.toast-stack .toast {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .75rem 1.1rem;
  border-radius: var(--r-pill);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: .95rem;
  line-height: 1.3;
  box-shadow: var(--shadow-lift);
  min-width: 220px;
  max-width: min(92vw, 420px);
  pointer-events: auto;
  animation: toast-in 240ms var(--ease-spring) both;
  cursor: pointer;
}
.toast-stack .toast-success { background: var(--moss-500); color: var(--cream-50); }
.toast-stack .toast-info    { background: var(--ink-800); color: var(--cream-50); }
.toast-stack .toast-error   { background: var(--ruby-500); color: var(--cream-50); }
.toast-stack .toast.toast-leaving { animation: toast-out 180ms ease both; }

@keyframes toast-in {
  from { opacity: 0; transform: translateY(12px) scale(.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes toast-out {
  to { opacity: 0; transform: translateY(8px) scale(.96); }
}

@media (prefers-reduced-motion: reduce) {
  .toast-stack .toast,
  .toast-stack .toast.toast-leaving {
    animation: opacity 180ms ease both !important;
    transform: none !important;
  }
}

/* ---------- Dark mode tokens (Phase 1 v2) ----------
   Opt-in model:
   - <body data-theme="dark">  → always dark
   - <body data-theme="light"> → always light (explicit force)
   - <body data-theme="auto">  → follows prefers-color-scheme
   Scope for now: order.html + success.html (other pages stay light).
*/
[data-theme="dark"],
[data-theme="auto"] {
  /* These are shared by both dark and auto, but auto only activates the full
     dark palette below through prefers-color-scheme. */
}

/* Dark token palette — values are LITERAL (no self-referencing var() chains).
   Cream-* tokens flip to dark surfaces; ink-* tokens flip to bright text.
   Both halves are independent — a renderer using `background: var(--cream-100)`
   gets a dark card, and `color: var(--ink-900)` gets bright text on it. */
[data-theme="dark"] {
  /* Scale tokens — flip palette */
  --bg:          #17130E;
  --surface:     #211c16;
  --surface-2:   #2a241c;
  --surface-elevated: #1c1814;
  --ink:         rgba(253, 251, 246, .94);
  --ink-muted:   rgba(253, 251, 246, .64);
  --line:        rgba(255, 255, 255, .08);
  --line-strong: rgba(255, 255, 255, .14);
  --cream-50:    #1a1712;
  --cream-100:   #211c16;
  --cream-200:   #2a241c;
  --cream-300:   #342d22;
  --ink-400:     rgba(253, 251, 246, .48);
  --ink-500:     rgba(253, 251, 246, .64);
  --ink-600:     rgba(253, 251, 246, .78);
  --ink-700:     rgba(253, 251, 246, .88);
  --ink-800:     rgba(253, 251, 246, .94);
  --ink-900:     rgba(253, 251, 246, 1);
  --terracotta-50:  #2a1913;
  --terracotta-100: #3a221a;

  /* Semantic tokens — explicit dark values (not via var() chains) */
  --text:        rgba(253, 251, 246, .94);
  --text-soft:   rgba(253, 251, 246, .78);
  --text-muted:  rgba(253, 251, 246, .60);
  --text-subtle: rgba(253, 251, 246, .42);

  --border:        rgba(255, 255, 255, .08);
  --border-strong: rgba(255, 255, 255, .16);

  --input-bg:    #1a1712;
  --placeholder: rgba(253, 251, 246, .35);

  --btn-primary-bg:    #f3eee5;            /* CTA flips clair sur foncé */
  --btn-primary-text:  #181513;
  --btn-primary-hover: #d97849;            /* terracotta vif pour le hover */

  --accent:        #d97849;                /* terracotta légèrement plus chaud */
  --accent-soft:   #2e1a13;
  --accent-strong: #f5a17b;

  --err-bg:   #3a1d10;
  --err-text: #ffb89a;

  --shadow-sm: 0 2px 6px rgba(0, 0, 0, .35);
  --shadow-md: 0 8px 24px -6px rgba(0, 0, 0, .50);
  --shadow-lg: 0 24px 48px -12px rgba(0, 0, 0, .65);
  --shadow-xl: 0 32px 64px -16px rgba(0, 0, 0, .75);
  --shadow-lift:   0 8px 24px rgba(0, 0, 0, .55);
  --shadow-accent: 0 14px 40px -14px rgba(217, 120, 73, .55);
}

/* Pin minimal hard-coded surfaces in dark : skip-link + backdrops + pairing-add. */
[data-theme="dark"] .skip-link { background: var(--accent); color: #fff; }
[data-theme="dark"] .cmd-backdrop,
[data-theme="dark"] .recents-backdrop { background: #000 !important; opacity: .55 !important; }
[data-theme="dark"] .pairing-add { background: var(--accent); color: #fff; }
[data-theme="dark"] .plan-card .btn[disabled] { background: rgba(255,255,255,.08) !important; color: rgba(253,251,246,.7) !important; border-color: rgba(255,255,255,.18) !important; }

/* Safety-net : inline-style hardcoded hex (legacy renderers, third-party HTML).
   Sources should use semantic tokens — this is a fallback. */
[data-theme="dark"] [style*="background:#fff"],
[data-theme="dark"] [style*="background: #fff"],
[data-theme="dark"] [style*="background-color:#fff"],
[data-theme="dark"] [style*="background-color: #fff"] { background-color: var(--surface) !important; color: var(--text); }
[data-theme="dark"] [style*="color:#000"],
[data-theme="dark"] [style*="color: #000"] { color: var(--text) !important; }
[data-theme="dark"] [style*="background:#fef3c7"],
[data-theme="dark"] [style*="background: #fef3c7"],
[data-theme="dark"] [style*="background:#FEF3C7"],
[data-theme="dark"] [style*="background:#fef9e7"] { background-color: var(--surface-2) !important; color: var(--text); }

@media (prefers-color-scheme: dark) {
  [data-theme="auto"] {
    /* Scale tokens — flip palette */
    --bg:          #17130E;
    --surface:     #211c16;
    --surface-2:   #2a241c;
    --surface-elevated: #1c1814;
    --ink:         rgba(253, 251, 246, .94);
    --ink-muted:   rgba(253, 251, 246, .64);
    --line:        rgba(255, 255, 255, .08);
    --line-strong: rgba(255, 255, 255, .14);
    --cream-50:    #1a1712;
    --cream-100:   #211c16;
    --cream-200:   #2a241c;
    --cream-300:   #342d22;
    --ink-400:     rgba(253, 251, 246, .48);
    --ink-500:     rgba(253, 251, 246, .64);
    --ink-600:     rgba(253, 251, 246, .78);
    --ink-700:     rgba(253, 251, 246, .88);
    --ink-800:     rgba(253, 251, 246, .94);
    --ink-900:     rgba(253, 251, 246, 1);
    --terracotta-50:  #2a1913;
    --terracotta-100: #3a221a;

    /* Semantic tokens — explicit dark values */
    --text:        rgba(253, 251, 246, .94);
    --text-soft:   rgba(253, 251, 246, .78);
    --text-muted:  rgba(253, 251, 246, .60);
    --text-subtle: rgba(253, 251, 246, .42);
    --border:        rgba(255, 255, 255, .08);
    --border-strong: rgba(255, 255, 255, .16);
    --input-bg:    #1a1712;
    --placeholder: rgba(253, 251, 246, .35);
    --btn-primary-bg:    #f3eee5;
    --btn-primary-text:  #181513;
    --btn-primary-hover: #d97849;
    --accent:        #d97849;
    --accent-soft:   #2e1a13;
    --accent-strong: #f5a17b;
    --err-bg:   #3a1d10;
    --err-text: #ffb89a;
    --shadow-sm: 0 2px 6px rgba(0, 0, 0, .35);
    --shadow-md: 0 8px 24px -6px rgba(0, 0, 0, .50);
    --shadow-lg: 0 24px 48px -12px rgba(0, 0, 0, .65);
    --shadow-xl: 0 32px 64px -16px rgba(0, 0, 0, .75);
    --shadow-lift:   0 8px 24px rgba(0, 0, 0, .55);
    --shadow-accent: 0 14px 40px -14px rgba(217, 120, 73, .55);
  }
  [data-theme="auto"] .skip-link { background: var(--accent); color: #fff; }
  [data-theme="auto"] .cmd-backdrop,
  [data-theme="auto"] .recents-backdrop { background: #000 !important; opacity: .55 !important; }
  [data-theme="auto"] .pairing-add { background: var(--accent); color: #fff; }
  [data-theme="auto"] .plan-card .btn[disabled] { background: rgba(255,255,255,.08) !important; color: rgba(253,251,246,.7) !important; border-color: rgba(255,255,255,.18) !important; }
  [data-theme="auto"] [style*="background:#fff"],
  [data-theme="auto"] [style*="background: #fff"],
  [data-theme="auto"] [style*="background-color:#fff"],
  [data-theme="auto"] [style*="background-color: #fff"] { background-color: var(--surface) !important; color: var(--text); }
  [data-theme="auto"] [style*="color:#000"],
  [data-theme="auto"] [style*="color: #000"] { color: var(--text) !important; }
  [data-theme="auto"] [style*="background:#fef3c7"],
  [data-theme="auto"] [style*="background: #fef3c7"],
  [data-theme="auto"] [style*="background:#FEF3C7"],
  [data-theme="auto"] [style*="background:#fef9e7"] { background-color: var(--surface-2) !important; color: var(--text); }
}

/* ============================================================
   Command Palette + Skeletons (v22)
   ⌘K launcher + J/R/N/? shortcuts + list-row skeletons + recents.
   Tokens only — no hardcoded colors, no new radii.
   ============================================================ */

/* ---------- Row-level skeletons (list placeholders before async fetch) ---------- */
.skeleton {
  display: block;
  background: var(--cream-100);
  border-radius: var(--r-sm);
  animation: skeleton-pulse 1.2s var(--ease) infinite;
}
.skeleton-row {
  height: 44px;
  width: 100%;
  margin-bottom: .5rem;
  background: linear-gradient(90deg, var(--cream-100) 0%, var(--cream-200) 50%, var(--cream-100) 100%);
  background-size: 200% 100%;
  border-radius: var(--r-sm);
  animation: skeleton-shimmer 1.2s var(--ease) infinite;
}
.skeleton-pulse {
  animation: skeleton-pulse 1.2s var(--ease) infinite;
}
.skeleton-stack {
  padding: 1rem 0;
}
.skeleton-stack .skeleton-row:nth-child(even) { opacity: .88; }

@keyframes skeleton-pulse {
  0%, 100% { opacity: .45; }
  50%      { opacity: .80; }
}
@keyframes skeleton-shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}
@media (prefers-reduced-motion: reduce) {
  .skeleton, .skeleton-row, .skeleton-pulse {
    animation: none !important;
    background: var(--cream-100) !important;
  }
}

/* ---------- Command Palette (⌘K) ---------- */
.command-palette {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding: 12vh 1rem 1rem;
}
.command-palette.is-open { display: flex; }

.command-palette__backdrop {
  position: absolute;
  inset: 0;
  background: var(--ink-900);
  opacity: .2;
  animation: cmd-backdrop-in var(--t) var(--ease);
}

.command-palette__modal {
  position: relative;
  width: 100%;
  max-width: 640px;
  background: var(--cream-50);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  max-height: 70vh;
  animation: cmd-modal-in 180ms var(--ease-spring);
}

@keyframes cmd-backdrop-in { from { opacity: 0; } to { opacity: .2; } }
@keyframes cmd-modal-in {
  from { opacity: 0; transform: translateY(-8px) scale(.96); }
  to   { opacity: 1; transform: translateY(0)     scale(1);   }
}
@media (prefers-reduced-motion: reduce) {
  .command-palette__backdrop,
  .command-palette__modal { animation: none; }
}

.command-palette__input-wrap {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--line);
  background: var(--cream-50);
}
.command-palette__input-wrap::before {
  content: '⌕';
  font-family: var(--font-display);
  font-variation-settings: 'opsz' 144;
  color: var(--ink-500);
  font-size: 1.35rem;
  line-height: 1;
}
.command-palette__input {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-family: var(--font-body);
  font-size: var(--step-1);
  color: var(--ink-900);
  padding: 0;
}
.command-palette__input::placeholder {
  color: var(--ink-400);
  font-family: var(--font-display);
  font-style: italic;
  font-variation-settings: 'SOFT' 100;
}
.command-palette__hint {
  font-family: var(--font-mono);
  font-size: var(--step--2);
  color: var(--ink-500);
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
}

.command-palette__results {
  flex: 1;
  overflow-y: auto;
  padding: .5rem 0;
}

.command-palette__group {
  padding: .25rem 0 .5rem;
}
.command-palette__group + .command-palette__group { border-top: 1px solid var(--line); }

.command-palette__group-label {
  font-family: var(--font-mono);
  font-size: var(--step--2);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-500);
  padding: .6rem 1.25rem .35rem;
}

.command-palette__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .7rem 1.25rem;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease);
  border-left: 3px solid transparent;
}
.command-palette__item:hover,
.command-palette__item--active {
  background: var(--terracotta-50);
  border-left-color: var(--terracotta-500);
}
.command-palette__item-main {
  display: flex;
  flex-direction: column;
  gap: .15rem;
  min-width: 0;
  flex: 1;
}
.command-palette__item-label {
  font-family: var(--font-body);
  font-size: var(--step-0);
  color: var(--ink-900);
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.command-palette__item-meta {
  font-family: var(--font-mono);
  font-size: var(--step--2);
  color: var(--ink-500);
}
.command-palette__item mark {
  background: transparent;
  color: var(--terracotta-700);
  font-weight: 600;
}
.command-palette__item-tag {
  font-family: var(--font-mono);
  font-size: var(--step--2);
  color: var(--ink-400);
  text-transform: uppercase;
  letter-spacing: .08em;
  white-space: nowrap;
}

.command-palette__empty {
  padding: 2rem 1.25rem;
  text-align: center;
  font-family: var(--font-display);
  font-style: italic;
  font-variation-settings: 'SOFT' 100;
  color: var(--ink-500);
}

/* Highlight flash when arriving on a row through palette / shortcut */
.cmd-highlight-row {
  border-left: 3px solid var(--terracotta-500) !important;
  background: var(--terracotta-50) !important;
  transition: background 300ms var(--ease), border-color 300ms var(--ease);
  animation: cmd-highlight-fade 2s var(--ease) forwards;
}
@keyframes cmd-highlight-fade {
  0%   { background: var(--terracotta-50); }
  70%  { background: var(--terracotta-50); }
  100% { background: transparent; }
}
@media (prefers-reduced-motion: reduce) {
  .cmd-highlight-row { animation: none; }
}

/* ---------- Shortcuts help overlay (?) ---------- */
.shortcuts-help {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.shortcuts-help.is-open { display: flex; }

.shortcuts-help__backdrop {
  position: absolute;
  inset: 0;
  background: var(--ink-900);
  opacity: .3;
}
.shortcuts-help__modal {
  position: relative;
  width: 100%;
  max-width: 480px;
  background: var(--cream-50);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg);
  padding: 1.75rem 1.75rem 1.5rem;
  animation: cmd-modal-in 180ms var(--ease-spring);
}
.shortcuts-help__title {
  font-family: var(--font-display);
  font-variation-settings: 'opsz' 144, 'SOFT' 40;
  font-weight: 400;
  font-size: var(--step-2);
  color: var(--ink-900);
  margin: 0 0 1rem;
}
.shortcuts-help__list {
  display: flex;
  flex-direction: column;
  gap: .65rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
.shortcuts-help__list li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .35rem 0;
  border-bottom: 1px dashed var(--line);
  font-size: var(--step-0);
  color: var(--ink-700);
}
.shortcuts-help__list li:last-child { border-bottom: none; }
.shortcuts-help kbd {
  font-family: var(--font-mono);
  font-size: var(--step--1);
  background: var(--cream-100);
  border: 1px solid var(--line-strong);
  border-bottom-width: 2px;
  border-radius: var(--r-xs);
  padding: .15rem .5rem;
  color: var(--ink-900);
  min-width: 24px;
  display: inline-block;
  text-align: center;
}
.shortcuts-help__close {
  font-family: var(--font-mono);
  font-size: var(--step--2);
  color: var(--ink-500);
  text-align: center;
  margin-top: 1rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}

/* ---------- Recents widget (today's viewed customers / dishes / resas) ---------- */
.recents-widget {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .5rem;
  padding: .8rem 1.25rem;
  background: var(--cream-100);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.recents-widget__label {
  font-family: var(--font-mono);
  font-size: var(--step--2);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-500);
  margin-right: .3rem;
}
.recents-widget__chip {
  font-family: var(--font-body);
  font-size: var(--step--1);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-pill);
  padding: .3rem .75rem;
  cursor: pointer;
  color: var(--ink-700);
  transition: transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.recents-widget__chip:hover {
  transform: translateY(-1px);
  border-color: var(--terracotta-500);
  box-shadow: var(--shadow-sm);
  color: var(--ink-900);
}
.recents-widget__chip-meta {
  font-family: var(--font-mono);
  font-size: var(--step--2);
  color: var(--ink-500);
  margin-left: .4rem;
}

/* ============================================================
   QR order UX (#7 last-order, #8 diet filters, #9 pairings,
   #10 kitchen countdown). All tokens — no hex.
   ============================================================ */

/* #7 — "Reprendre ma dernière commande" card, above categories */
.last-order-card {
  margin: .9rem 1.1rem .3rem;
  padding: .95rem 1rem;
  background: var(--cream-100);
  border: 1px solid var(--terracotta-500);
  border-radius: var(--r-md);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: .9rem;
  align-items: center;
  box-shadow: var(--shadow-sm);
  transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.last-order-card:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); }
.last-order-card h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--step-0);
  letter-spacing: -.01em;
  line-height: 1.2;
  margin: 0 0 .15rem;
  font-variation-settings: 'opsz' 100, 'SOFT' 30;
}
.last-order-card h3 em {
  font-style: italic;
  color: var(--terracotta-500);
  font-variation-settings: 'SOFT' 100, 'WONK' 1;
  font-weight: 400;
}
.last-order-card .lo-meta {
  font-family: var(--font-mono);
  font-size: var(--step--2);
  color: var(--ink-500);
  letter-spacing: .02em;
  line-height: 1.35;
}
.last-order-card .lo-meta strong { color: var(--ink-700); font-weight: 500; }
.last-order-card .lo-cta {
  background: var(--terracotta-500);
  color: var(--cream-50);
  border: none;
  padding: .55rem 1rem;
  border-radius: var(--r-pill);
  font: 500 var(--step--1) var(--font-body);
  cursor: pointer;
  transition: background var(--t) var(--ease), transform var(--t) var(--ease), box-shadow var(--t) var(--ease);
  white-space: nowrap;
}
.last-order-card .lo-cta:hover { background: var(--terracotta-700); transform: translateY(-1px); box-shadow: var(--shadow-accent); }
.last-order-card .lo-cta:active { transform: translateY(0) scale(.98); }
@media (prefers-reduced-motion: reduce) {
  .last-order-card, .last-order-card:hover, .last-order-card .lo-cta { transition: none; transform: none; }
}

/* #8 — Diet filter chips, sticky under header */
.diet-filters {
  position: sticky;
  top: 66px;
  z-index: 19;
  background: var(--cream-50);
  padding: .55rem 1.1rem .45rem;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: .45rem;
  overflow-x: auto;
  scrollbar-width: none;
}
.diet-filters::-webkit-scrollbar { display: none; }
.diet-filters + .categories { top: 115px; }
.diet-chip {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .38rem .85rem;
  border: 1px solid var(--line);
  background: var(--cream-100);
  color: var(--ink-700);
  border-radius: var(--r-pill);
  font: 500 var(--step--1) var(--font-body);
  letter-spacing: -.005em;
  cursor: pointer;
  transition: background var(--t) var(--ease), color var(--t) var(--ease), border-color var(--t) var(--ease), transform var(--t) var(--ease);
}
.diet-chip:hover { background: var(--cream-200); }
.diet-chip[aria-pressed="true"] {
  background: var(--terracotta-500);
  color: var(--cream-50);
  border-color: var(--terracotta-500);
  box-shadow: var(--shadow-accent);
}
.diet-chip[aria-pressed="true"]:hover { background: var(--terracotta-700); border-color: var(--terracotta-700); }
@media (prefers-reduced-motion: reduce) {
  .diet-chip { transition: none; }
}

/* #8 — Dimmed items when they don't match the active diet filters */
.menu-item--dimmed { opacity: .42; transition: opacity var(--t) var(--ease); }
.menu-item--dimmed .item-img::after {
  content: "⚠";
  position: absolute;
  top: 6px;
  left: 6px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--ruby-500);
  color: var(--cream-50);
  display: grid;
  place-items: center;
  font-size: 12px;
  font-weight: 600;
  font-family: var(--font-body);
  box-shadow: var(--shadow-sm);
  z-index: 3;
}
.diet-warning {
  margin: 0 0 1rem;
  padding: .7rem .9rem;
  background: var(--terracotta-50);
  border: 1px solid var(--terracotta-100);
  border-radius: var(--r-sm);
  font: 500 var(--step--1) var(--font-body);
  color: var(--terracotta-700);
  line-height: 1.4;
  display: flex;
  gap: .5rem;
  align-items: flex-start;
}
.diet-warning::before {
  content: "⚠";
  font-size: 1.1rem;
  line-height: 1.2;
  flex-shrink: 0;
}

/* #9 — "Souvent commandés avec" inside the item-detail sheet */
.pairings-section { margin: 1.4rem 0 1rem; }
.pairings-title {
  font-family: var(--font-display);
  font-size: var(--step-0);
  font-weight: 500;
  letter-spacing: -.01em;
  margin: 0 0 .6rem;
  font-variation-settings: 'opsz' 100, 'SOFT' 30;
}
.pairings-title em {
  font-style: italic;
  color: var(--terracotta-500);
  font-variation-settings: 'SOFT' 100, 'WONK' 1;
}
.pairings-list { display: flex; flex-direction: column; gap: .55rem; }
.pairing-row {
  display: grid;
  grid-template-columns: 64px 1fr auto;
  gap: .8rem;
  padding: .55rem;
  background: var(--cream-50);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  align-items: center;
  transition: border-color var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.pairing-row:hover { border-color: var(--line-strong); box-shadow: var(--shadow-sm); }
.pairing-img {
  width: 64px;
  height: 64px;
  border-radius: var(--r-sm);
  background: var(--cream-200) center/cover;
  position: relative;
  overflow: hidden;
}
.pairing-img.placeholder::before {
  content: attr(data-initial);
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-size: 1.8rem;
  color: var(--ink-400);
  font-style: italic;
  font-variation-settings: 'opsz' 100, 'SOFT' 80;
}
.pairing-info { min-width: 0; }
.pairing-info h5 {
  font-family: var(--font-display);
  font-size: var(--step-0);
  font-weight: 500;
  letter-spacing: -.01em;
  line-height: 1.2;
  margin: 0 0 .15rem;
}
.pairing-info .price {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: var(--step--1);
  color: var(--ink-700);
}
.pairing-add {
  background: var(--ink-900);
  color: var(--cream-50);
  border: none;
  width: 36px; height: 36px;
  border-radius: 50%;
  font: 400 22px/1 var(--font-body);
  cursor: pointer;
  display: grid; place-items: center;
  transition: background var(--t) var(--ease), transform var(--t) var(--ease);
}
.pairing-add:hover { background: var(--terracotta-500); transform: scale(1.08); }
.pairing-add:active { transform: scale(.95); }
.pairing-add.added { background: var(--moss-700); pointer-events: none; }
.pairing-add.added::before { content: "✓"; font-size: 16px; }
.pairing-add.added > * { display: none; }
@media (prefers-reduced-motion: reduce) {
  .pairing-row, .pairing-add { transition: none; }
  .pairing-add:hover { transform: none; }
}

/* Item detail sheet — reuses .sheet styles, this is just the body layout */
.item-detail-head {
  display: grid;
  grid-template-columns: 112px 1fr;
  gap: 1rem;
  margin-bottom: 1rem;
  align-items: flex-start;
}
.item-detail-img {
  width: 112px; height: 112px;
  border-radius: var(--r-md);
  background: var(--cream-200) center/cover;
  position: relative;
  overflow: hidden;
}
.item-detail-img.placeholder::before {
  content: attr(data-initial);
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-size: 3rem;
  color: var(--ink-400);
  font-style: italic;
  font-variation-settings: 'opsz' 100, 'SOFT' 80;
}
.item-detail-info h3 {
  font-family: var(--font-display);
  font-size: var(--step-2);
  font-weight: 500;
  letter-spacing: -.015em;
  line-height: 1.15;
  margin: 0 0 .35rem;
  font-variation-settings: 'opsz' 100, 'SOFT' 30;
}
.item-detail-info .price {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: var(--step-1);
  color: var(--ink-900);
}
.item-detail-desc {
  font-size: var(--step--1);
  color: var(--ink-600);
  line-height: 1.5;
  margin: 0 0 .6rem;
}
.item-detail-allergens {
  font-family: var(--font-mono);
  font-size: var(--step--2);
  color: var(--ink-500);
  letter-spacing: .02em;
  margin: 0 0 .6rem;
  line-height: 1.4;
}

/* #10 — Kitchen countdown banner, under header */
.kitchen-banner {
  position: sticky;
  top: 66px;
  z-index: 18;
  margin: 0;
  padding: .65rem 1.1rem .7rem;
  background: var(--cream-100);
  border-bottom: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.kitchen-banner .kb-row {
  display: flex;
  align-items: center;
  gap: .6rem;
  justify-content: space-between;
}
.kitchen-banner .kb-label {
  font-family: var(--font-display);
  font-size: var(--step-0);
  font-weight: 500;
  letter-spacing: -.01em;
  color: var(--ink-900);
  font-variation-settings: 'opsz' 100, 'SOFT' 30;
}
.kitchen-banner .kb-label em {
  font-style: italic;
  color: var(--terracotta-500);
  font-variation-settings: 'SOFT' 100, 'WONK' 1;
  font-weight: 400;
}
.kitchen-banner .kb-eta {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: var(--step-0);
  color: var(--moss-700);
  letter-spacing: .02em;
}
.kitchen-banner.is-ready {
  background: var(--terracotta-50);
  border-bottom-color: var(--terracotta-100);
}
.kitchen-banner.is-ready .kb-label,
.kitchen-banner.is-ready .kb-eta { color: var(--terracotta-700); }
.kitchen-bar {
  height: 4px;
  background: var(--cream-300);
  border-radius: var(--r-pill);
  overflow: hidden;
  position: relative;
}
.kitchen-bar-fill {
  position: absolute;
  inset: 0;
  width: 0%;
  background: linear-gradient(90deg, var(--moss-500), var(--moss-700));
  border-radius: var(--r-pill);
  transition: width var(--t-slow) var(--ease);
}
.kitchen-banner.is-ready .kitchen-bar-fill {
  background: linear-gradient(90deg, var(--terracotta-400), var(--terracotta-500));
  width: 100% !important;
}
/* When the banner is shown, categories need to slide further down to avoid overlap */
.kitchen-banner ~ .diet-filters,
.kitchen-banner + .diet-filters { top: calc(66px + 58px); }
.kitchen-banner ~ .diet-filters + .categories { top: calc(66px + 58px + 49px); }
.kitchen-banner ~ .categories { top: calc(66px + 58px); }
@media (prefers-reduced-motion: reduce) {
  .kitchen-bar-fill { transition: none; }
}


/* ============================================================
   Progression card — Duolingo-style addictive overview header
   Used by src/client/renderers/progression-card.js
   ============================================================ */
.hz-prog-card {
  background: linear-gradient(180deg, var(--cream-50), var(--cream-100));
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 1.5rem 1.6rem;
  box-shadow: var(--shadow-md);
  position: relative;
  overflow: hidden;
}
.hz-prog-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; height: 4px;
  background: var(--tier-bg, linear-gradient(90deg,#cd7f32,#fde68a));
}
.hz-prog-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1rem;
}
.hz-prog-tier-ribbon {
  padding: .35rem .8rem;
  border-radius: var(--r-pill);
  color: #fff;
  text-shadow: 0 1px 2px rgba(0,0,0,.2);
  box-shadow: 0 2px 6px rgba(0,0,0,.15);
}
.hz-prog-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .8rem;
  margin-bottom: 1rem;
}
.hz-prog-stat {
  display: flex;
  align-items: center;
  gap: .7rem;
  padding: .6rem .8rem;
  background: var(--cream-100);
  border: 1px solid var(--line);
  border-radius: 12px;
}
.hz-prog-current {
  display: flex;
  align-items: center;
  gap: .8rem;
  padding: .8rem 1rem;
  background: var(--cream-200);
  border-radius: 12px;
  margin-bottom: 1rem;
}
.hz-prog-next { margin-bottom: 1rem; }
.hz-prog-bar {
  height: 14px;
  background: var(--cream-200);
  border-radius: var(--r-pill);
  overflow: hidden;
  border: 1px solid var(--line);
  position: relative;
}
.hz-prog-bar-fill {
  height: 100%;
  background: var(--tier-bg, linear-gradient(90deg,#cd7f32,#fde68a));
  border-radius: var(--r-pill);
  transition: width 800ms cubic-bezier(.4,0,.2,1);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.3);
  position: relative;
}
.hz-prog-bar-fill::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.4), transparent);
  animation: hz-prog-shine 2.5s ease-in-out infinite;
}
@keyframes hz-prog-shine {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}
.hz-prog-stops {
  display: flex;
  justify-content: space-between;
  gap: .3rem;
  margin: 1rem 0 .5rem;
  padding: .4rem 0;
}
.hz-prog-stop {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--cream-200);
  border: 2px solid var(--line);
  display: grid;
  place-items: center;
  font-size: 1rem;
  filter: grayscale(.85) opacity(.45);
  transition: all 300ms var(--ease);
  cursor: help;
  position: relative;
}
.hz-prog-stop--unlocked {
  filter: none;
  background: var(--cream-50);
  border-color: var(--terracotta-500);
  box-shadow: 0 0 0 2px rgba(202,82,49,.15);
}
.hz-prog-stop--current {
  transform: scale(1.18);
  border-color: var(--tier-color);
  box-shadow: 0 0 0 4px rgba(212,160,23,.25), 0 4px 12px rgba(0,0,0,.15);
  animation: hz-prog-pulse 2s ease-in-out infinite;
}
@keyframes hz-prog-pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(212,160,23,.25), 0 4px 12px rgba(0,0,0,.15); }
  50%      { box-shadow: 0 0 0 8px rgba(212,160,23,.05), 0 4px 16px rgba(0,0,0,.2); }
}
.hz-prog-challenge {
  margin-top: 1rem;
  padding: .9rem 1.1rem;
  background: var(--cream-50);
  border: 1px dashed var(--line-strong);
  border-radius: 12px;
}
.hz-prog-challenge-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: .35rem;
}

/* Confetti burst — fired once on milestone unlock */
.hz-confetti-burst {
  position: absolute;
  inset: 0;
  pointer-events: none;
  display: grid;
  place-items: center;
  z-index: 5;
}
.hz-confetti-burst span {
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 2px;
  animation: hz-confetti-fly 1.4s cubic-bezier(.2,.7,.4,1) forwards;
}
@keyframes hz-confetti-fly {
  0%   { transform: translate(0,0) scale(.6) rotate(0deg);    opacity: 1; }
  60%  { opacity: 1; }
  100% { transform: translate(var(--dx), var(--dy)) scale(1) rotate(720deg); opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  .hz-prog-bar-fill::after,
  .hz-prog-stop--current,
  .hz-confetti-burst span { animation: none; }
}

/* Call-waiter pulse — when /order's bell triggers an SSE 'call_waiter' event,
   the matching ticket card on /service flashes terracotta for a few seconds. */
.call-waiter-pulse {
  animation: hz-call-waiter-pulse 4s var(--ease) 1;
}
@keyframes hz-call-waiter-pulse {
  0%      { box-shadow: 0 0 0 0 rgba(202,82,49,.6); border-color: var(--terracotta-500); }
  10%     { box-shadow: 0 0 0 8px rgba(202,82,49,.25); border-color: var(--terracotta-500); }
  60%     { box-shadow: 0 0 0 16px rgba(202,82,49,0); border-color: var(--terracotta-500); }
  100%    { box-shadow: 0 0 0 0 rgba(202,82,49,0); border-color: var(--line); }
}
@media (prefers-reduced-motion: reduce) {
  .call-waiter-pulse { animation: none; outline: 2px solid var(--terracotta-500); outline-offset: 2px; }
}

/* ============================================================
   Floor canvas — theme-aware bg + grid (was hardcoded inline `#fff`).
   Light: warm cream with sage-tinted grid; Dark: deep coffee with
   barely-there warm-grey grid.
   ============================================================ */
.floor-canvas-wrap {
  background: var(--cream-50);
  border-top: 1px solid var(--line);
}
.floor-canvas {
  background-color: #fbf8f0;
  background-image:
    linear-gradient(rgba(122,154,134,.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(122,154,134,.10) 1px, transparent 1px);
  background-size: 40px 40px;
}
[data-theme="dark"] .floor-canvas-wrap { background: var(--surface); border-top-color: var(--border); }
[data-theme="dark"] .floor-canvas {
  background-color: var(--surface);
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
}
@media (prefers-color-scheme: dark) {
  [data-theme="auto"] .floor-canvas-wrap { background: var(--surface); border-top-color: var(--border); }
  [data-theme="auto"] .floor-canvas {
    background-color: #1c1812;
    background-image:
      linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  }
}

/* Floor tables in dark mode — soften the new warm palette to dark earth tones
   so tables don't burn against the dark canvas. Keep status hints (border) bright. */
[data-theme="dark"] [style*="#f5efe2"] { background-color: #2a241c !important; color: rgba(253,251,246,.9) !important; }
[data-theme="dark"] [style*="#f3e7d2"] { background-color: #2e251a !important; color: rgba(253,251,246,.9) !important; }
[data-theme="dark"] [style*="#efd9d4"] { background-color: #2e2220 !important; color: rgba(253,251,246,.9) !important; }
[data-theme="dark"] [style*="color:#5b4f3d"] { color: rgba(253,251,246,.94) !important; }
[data-theme="dark"] [style*="color:#6b5530"] { color: rgba(253,251,246,.94) !important; }
[data-theme="dark"] [style*="color:#7b3e34"] { color: rgba(253,251,246,.94) !important; }
@media (prefers-color-scheme: dark) {
  [data-theme="auto"] [style*="#f5efe2"] { background-color: #2a241c !important; color: rgba(253,251,246,.9) !important; }
  [data-theme="auto"] [style*="#f3e7d2"] { background-color: #2e251a !important; color: rgba(253,251,246,.9) !important; }
  [data-theme="auto"] [style*="#efd9d4"] { background-color: #2e2220 !important; color: rgba(253,251,246,.9) !important; }
  [data-theme="auto"] [style*="color:#5b4f3d"] { color: rgba(253,251,246,.94) !important; }
  [data-theme="auto"] [style*="color:#6b5530"] { color: rgba(253,251,246,.94) !important; }
  [data-theme="auto"] [style*="color:#7b3e34"] { color: rgba(253,251,246,.94) !important; }
}

/* ============================================================
   MOBILE RESPONSIVE — Universal patterns (375px reference)
   --------------------------------------------------------------
   Last-mile fixes applied across pages so every public surface is
   usable on iPhone SE (375 × 667) without horizontal scroll.
   These rules layer on top of page-specific media queries; they are
   defensive (last in cascade) and respect the design tokens.
   ============================================================ */

/* iOS — prevent auto-zoom on input focus by ensuring 16px font-size.
   iOS Safari zooms in when an input < 16px gets focused; this is jarring
   on form pages (onboard, login, giftcard). 16px = no zoom. */
@media (max-width: 768px) {
  input, select, textarea {
    font-size: max(16px, var(--step-0)) !important;
  }
  /* Restore tighter sizes for in-table editable cells (dashboard) — the table
     itself is overflow-x:auto on mobile so we don't trigger zoom there. */
  table td input, table td select { font-size: var(--step--1) !important; }
}

/* Universal touch target floor — anything tappable should be ≥ 44px tall.
   Buttons, .btn, .chip role=button, anchors with .btn class. */
@media (max-width: 768px) {
  .btn, button:not(.theme-toggle):not(.mobile-view-btn):not(.close):not(.add-more) {
    min-height: 44px;
  }
  .btn.small, button.small { min-height: 38px; }
}

/* Buttons that need to break to 100% on tiny screens (cluster of CTAs) */
@media (max-width: 480px) {
  .cta-row .btn,
  .step-foot .btn:not(.ghost) {
    width: 100%;
    justify-content: center;
  }
}

/* Container padding floor on small screens — keep edge gutter consistent */
@media (max-width: 480px) {
  .container, .container-narrow { padding: 0 1rem; }
}

/* Tables : universal "scrollable wrapper" hint via gradient mask edges,
   so users see content fades = scrollable. Applied to ANY table that ends
   up wider than its parent (dashboard-side tables). */
@media (max-width: 768px) {
  .panel > table,
  .panel > div > table {
    min-width: 100%;
  }
  /* When wrapper has overflow-x:auto + the table overflows, the right
     edge gets a soft fade to hint there's more. Using mask not pseudo
     because mask doesn't break in-flow scroll. */
  .panel > div[style*="overflow-x"]:not(:has(canvas)),
  .panel-scroll {
    -webkit-mask-image: linear-gradient(90deg, #000 calc(100% - 24px), transparent);
    mask-image: linear-gradient(90deg, #000 calc(100% - 24px), transparent);
  }
}

/* Modal sheet — on phones, slide up from bottom (matches QR sheet pattern)
   so the user keeps muscle memory across the suite. */
@media (max-width: 600px) {
  .modal-backdrop { padding: 0; align-items: flex-end; }
  .modal {
    border-radius: var(--r-lg) var(--r-lg) 0 0;
    max-height: 92vh;
    width: 100%;
    max-width: 100%;
    animation: modal-sheet-up var(--t-slow) var(--ease-spring);
  }
  /* Grab handle to invite swipe-to-dismiss recognition */
  .modal::before {
    content: '';
    display: block;
    width: 40px;
    height: 4px;
    background: var(--cream-300);
    border-radius: var(--r-pill);
    margin: .6rem auto 0;
  }
  .modal-head { padding: 1rem 1.4rem; }
  .modal-head h3 { font-size: var(--step-1); }
  .modal-body { padding: 1.2rem 1.4rem; }
  .modal-foot {
    padding: 1rem 1.4rem;
    /* Stick the action row to the bottom for thumb reach */
    position: sticky; bottom: 0; background: var(--cream-50);
    border-top: 1px solid var(--line);
  }
  .modal-foot .btn { flex: 1; justify-content: center; }
}
@keyframes modal-sheet-up {
  from { transform: translateY(100%); opacity: .6; }
  to { transform: translateY(0); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .modal { animation: none !important; }
}

/* Toasts — bottom positioned on mobile so they don't conflict with sticky
   headers. Slide up instead of in from right. */
@media (max-width: 600px) {
  #toasts {
    top: auto !important; right: 0 !important; left: 0 !important;
    bottom: 1rem !important;
    align-items: center !important;
    padding: 0 1rem;
  }
  .toast { max-width: 100%; width: 100%; }
}

/* Skip link — make sure it's tappable when revealed on mobile */
@media (max-width: 600px) {
  .skip-link:focus { left: .5rem; right: .5rem; text-align: center; }
}
