/* =========================================================
   TapEato — Customer menu demo styles
   ========================================================= */
:root{
  --bg:#0B0B0F; --surface:#121420; --surface-2:#171a29;
  --border:rgba(255,255,255,.08); --border-2:rgba(255,255,255,.14);
  --purple:#7C3AED; --purple-2:#9d5bf6; --blue:#2563EB;
  --grad:linear-gradient(135deg,#7C3AED,#2563EB);
  --ink:#F4F5FB; --ink-soft:rgba(244,245,251,.72); --ink-mute:rgba(244,245,251,.46);
  --veg:#16a34a; --non:#dc2626; --gold:#f5c451;
  --display:"Space Grotesk",system-ui,sans-serif;
  --body:"Plus Jakarta Sans",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --app-w:440px;
}
*{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }
body{
  font-family:var(--body); background:#06070b; color:var(--ink); line-height:1.5;
  -webkit-font-smoothing:antialiased; min-height:100vh;
}
body::before{ content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(900px 500px at 80% -10%,rgba(124,58,237,.18),transparent 60%),
             radial-gradient(800px 500px at 0% 0%,rgba(37,99,235,.14),transparent 55%); }
img{ max-width:100%; display:block; }
button{ font-family:inherit; cursor:pointer; border:0; background:none; color:inherit; }
::selection{ background:rgba(124,58,237,.45); }

/* App shell — phone-width column centered on desktop */
.menu-app{
  position:relative; z-index:1; width:100%; max-width:var(--app-w); margin:0 auto;
  min-height:100vh; background:var(--bg);
  box-shadow:0 0 0 1px var(--border), 0 40px 120px -40px rgba(0,0,0,.9);
}
@media (min-width:520px){ .menu-app{ margin-top:0; min-height:100vh; } }

/* ---------- Cover + restaurant header ---------- */
.cover{ position:relative; height:188px; overflow:hidden;
  background:
    radial-gradient(120% 120% at 70% 10%, rgba(124,58,237,.5), transparent 55%),
    linear-gradient(160deg,#3a1f0e,#1a1208 70%);
}
.cover::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(11,11,15,.05),rgba(11,11,15,.95));
  /* subtle texture */
}
.cover .cov-stripe{ position:absolute; inset:0; opacity:.5;
  background:repeating-linear-gradient(115deg, rgba(255,255,255,.05) 0 2px, transparent 2px 26px); }
.cover .cov-label{ position:absolute; left:16px; bottom:54px; font-family:var(--mono); font-size:10px; letter-spacing:.18em; color:rgba(255,255,255,.45); text-transform:uppercase; }
.cover .back{ position:absolute; top:14px; left:14px; z-index:3; width:38px; height:38px; border-radius:50%; background:rgba(8,9,13,.55); backdrop-filter:blur(8px); display:grid; place-items:center; border:1px solid var(--border-2); }
.cover .back svg{ width:19px; height:19px; stroke:#fff; fill:none; stroke-width:2; }
.cover .cov-actions{ position:absolute; top:14px; right:14px; z-index:3; display:flex; gap:9px; }
.cov-actions button{ width:38px; height:38px; border-radius:50%; background:rgba(8,9,13,.55); backdrop-filter:blur(8px); display:grid; place-items:center; border:1px solid var(--border-2); }
.cov-actions svg{ width:18px; height:18px; stroke:#fff; fill:none; stroke-width:2; }
.cov-table{ position:absolute; right:14px; bottom:54px; z-index:3; font-size:11px; font-weight:600; color:#fff; background:rgba(124,58,237,.85); padding:6px 12px; border-radius:999px; box-shadow:0 6px 18px -6px rgba(124,58,237,.8); }

.r-head{ position:relative; z-index:2; margin-top:-30px; padding:0 18px 18px; }
.r-card{ background:var(--surface); border:1px solid var(--border); border-radius:18px; padding:16px 16px 14px; box-shadow:0 16px 40px -20px rgba(0,0,0,.8); }
.r-top{ display:flex; align-items:flex-start; gap:13px; }
.r-logo{ width:50px; height:50px; border-radius:14px; background:var(--grad); display:grid; place-items:center; font-family:var(--display); font-weight:700; font-size:22px; color:#fff; flex:none; box-shadow:0 0 30px -8px rgba(124,58,237,.7); }
.r-top h1{ font-family:var(--display); font-size:21px; font-weight:600; letter-spacing:-.01em; }
#rMeta{ font-size:12.5px; color:var(--ink-soft); margin-top:3px; }
.r-rating{ color:var(--gold); font-weight:600; }
.r-foot{ display:flex; align-items:center; gap:14px; margin-top:13px; padding-top:13px; border-top:1px solid var(--border); font-size:12px; color:var(--ink-mute); }
.r-foot .open{ color:#34d399; font-weight:600; display:flex; align-items:center; gap:6px; }
.r-foot .open::before{ content:""; width:7px; height:7px; border-radius:50%; background:#34d399; box-shadow:0 0 8px #34d399; }
.r-foot .sep{ width:1px; height:12px; background:var(--border-2); }
.r-powered{ margin-left:auto; font-size:10.5px; color:var(--ink-mute); display:flex; align-items:center; gap:5px; }
.r-powered b{ color:var(--purple-2); font-family:var(--display); }

/* ---------- Sticky bar (name + search + chips) ---------- */
.m-sticky{ position:sticky; top:0; z-index:20; background:rgba(11,11,15,.86); backdrop-filter:blur(16px) saturate(140%); border-bottom:1px solid var(--border); }
.m-bar{ display:flex; align-items:center; gap:10px; padding:11px 16px 9px; }
.m-bar #rNameBar{ font-family:var(--display); font-weight:600; font-size:15px; opacity:0; transform:translateY(4px); transition:.25s; }
.m-sticky.solid #rNameBar{ opacity:1; transform:none; }
.veg-toggle{ margin-left:auto; display:flex; align-items:center; gap:8px; font-size:12px; color:var(--ink-soft); }
.veg-toggle .sw{ width:38px; height:22px; border-radius:999px; background:rgba(255,255,255,.12); position:relative; transition:.25s; border:1px solid var(--border-2); }
.veg-toggle .sw::after{ content:""; position:absolute; top:2px; left:2px; width:16px; height:16px; border-radius:50%; background:#fff; transition:.25s; }
.veg-toggle.on .sw{ background:var(--veg); border-color:transparent; }
.veg-toggle.on .sw::after{ transform:translateX(16px); }
.chips{ display:flex; gap:8px; overflow-x:auto; padding:4px 16px 12px; scrollbar-width:none; }
.chips::-webkit-scrollbar{ display:none; }
.chip{ white-space:nowrap; font-size:13px; font-weight:500; color:var(--ink-soft); padding:8px 15px; border-radius:999px; border:1px solid var(--border); background:rgba(255,255,255,.03); transition:.2s; }
.chip.active{ background:var(--grad); color:#fff; border-color:transparent; box-shadow:0 6px 16px -8px rgba(124,58,237,.8); }

/* ---------- Menu sections ---------- */
#list{ padding:6px 16px 130px; }
.msec{ padding-top:22px; scroll-margin-top:120px; }
.msec-head{ display:flex; align-items:center; gap:10px; margin-bottom:6px; }
.msec-ic{ width:30px; height:30px; border-radius:9px; background:rgba(124,58,237,.14); border:1px solid var(--border-2); display:grid; place-items:center; color:var(--purple-2); }
.msec-ic svg{ width:17px; height:17px; }
.msec-head h2{ font-family:var(--display); font-size:18px; font-weight:600; }
.msec-count{ font-size:12px; color:var(--ink-mute); background:rgba(255,255,255,.05); padding:2px 9px; border-radius:999px; }

.dish{ display:flex; gap:14px; padding:18px 0; border-bottom:1px solid var(--border); align-items:flex-start; }
.dish:last-child{ border-bottom:0; }
.dish-info{ flex:1; min-width:0; }
.dish-row1{ display:flex; align-items:center; gap:9px; margin-bottom:7px; min-height:16px; }
.veg-mark{ width:15px; height:15px; border-radius:3px; border:1.5px solid var(--veg); display:grid; place-items:center; flex:none; }
.veg-mark.non{ border-color:var(--non); }
.veg-mark i{ width:7px; height:7px; border-radius:50%; background:var(--veg); }
.veg-mark.non i{ background:var(--non); border-radius:0; clip-path:polygon(50% 0,100% 100%,0 100%); }
.dish-tag{ font-size:10.5px; font-weight:600; letter-spacing:.02em; color:var(--gold); text-transform:uppercase; }
.dish-tag.spicy{ color:#fb7185; }
.dish h3{ font-family:var(--display); font-size:16.5px; font-weight:500; }
.dish-price{ font-size:15px; font-weight:700; margin-top:5px; }
.dish-price small{ font-size:12px; font-weight:500; color:var(--ink-mute); }
.dish-rating{ font-size:11.5px; color:var(--gold); font-weight:600; margin-top:5px; }
.dish-rating span{ color:var(--ink-mute); font-weight:400; }
.dish-desc{ font-size:12.5px; color:var(--ink-mute); margin-top:7px; line-height:1.5; max-width:42ch; }

.dish-media{ width:122px; flex:none; display:flex; flex-direction:column; align-items:center; }
.dish-img{ width:122px; height:104px; border-radius:16px; position:relative; overflow:hidden; border:1px solid var(--border-2);
  background:
    linear-gradient(150deg, hsl(var(--h) 55% 32%), hsl(calc(var(--h) + 18) 48% 20%));
}
.dish-img::after{ content:""; position:absolute; inset:0; background:repeating-linear-gradient(125deg, rgba(255,255,255,.07) 0 2px, transparent 2px 13px); }
.dish-img span{ position:absolute; left:0; right:0; bottom:8px; text-align:center; font-family:var(--mono); font-size:8.5px; letter-spacing:.14em; color:rgba(255,255,255,.62); z-index:1; }
.dish-cta{ margin-top:-19px; z-index:2; }
.add-btn{ background:var(--surface-2); color:var(--purple-2); font-weight:700; font-size:13px; letter-spacing:.04em; padding:9px 22px; border-radius:11px; border:1px solid var(--purple); box-shadow:0 8px 20px -8px rgba(0,0,0,.7); display:flex; align-items:center; gap:6px; transition:.18s; }
.add-btn span{ font-size:15px; line-height:0; }
.add-btn:hover{ background:var(--purple); color:#fff; }
.add-btn:active{ transform:scale(.94); }
.stepper{ display:flex; align-items:center; background:var(--purple); border-radius:11px; box-shadow:0 8px 20px -8px rgba(124,58,237,.8); overflow:hidden; }
.stepper button{ width:34px; height:36px; color:#fff; font-size:18px; font-weight:600; display:grid; place-items:center; }
.stepper button:active{ background:rgba(0,0,0,.2); }
.stepper .qn{ min-width:24px; text-align:center; color:#fff; font-weight:700; font-size:14px; }
.stepper.sm button{ width:28px; height:30px; font-size:16px; }
.stepper.sm{ box-shadow:none; }

/* veg-only filter hides non-veg */
body.veg-only .dish[data-veg="0"]{ display:none; }

/* ---------- Bottom cart bar ---------- */
.cart-bar{ position:fixed; left:50%; bottom:16px; transform:translate(-50%,150%); z-index:30;
  width:min(var(--app-w), calc(100% - 28px)); max-width:412px;
  background:var(--grad); border-radius:16px; padding:13px 18px; display:flex; align-items:center; gap:14px;
  box-shadow:0 20px 50px -16px rgba(124,58,237,.9); transition:transform .4s cubic-bezier(.2,.8,.25,1); cursor:pointer; }
.cart-bar.show{ transform:translate(-50%,0); }
.cart-bar.bump{ animation:cbPop .35s ease; }
@keyframes cbPop{ 0%{ transform:translate(-50%,0) scale(1);} 40%{ transform:translate(-50%,-3px) scale(1.015);} 100%{ transform:translate(-50%,0) scale(1);} }
.cb-left{ display:flex; flex-direction:column; line-height:1.25; }
.cb-qty{ font-size:11.5px; color:rgba(255,255,255,.85); }
.cb-total{ font-size:16px; font-weight:700; color:#fff; }
.cb-total small{ font-size:11.5px; font-weight:500; opacity:.8; }
.cb-cta{ margin-left:auto; display:flex; align-items:center; gap:8px; font-weight:700; font-size:14px; color:#fff; }
.cb-cta svg{ width:17px; height:17px; stroke:#fff; fill:none; stroke-width:2.2; }

/* ---------- Sheet ---------- */
.overlay{ position:fixed; inset:0; z-index:40; background:rgba(4,5,8,.6); backdrop-filter:blur(3px); opacity:0; pointer-events:none; transition:.3s; }
.overlay.show{ opacity:1; pointer-events:auto; }
.sheet{ position:fixed; left:50%; bottom:0; transform:translate(-50%,100%); z-index:41;
  width:100%; max-width:var(--app-w); background:var(--surface); border-radius:24px 24px 0 0;
  border:1px solid var(--border-2); border-bottom:0; transition:transform .42s cubic-bezier(.2,.8,.25,1);
  max-height:86vh; display:flex; flex-direction:column; }
.sheet.open{ transform:translate(-50%,0); }
.sheet-grip{ width:42px; height:4px; border-radius:99px; background:var(--border-2); margin:11px auto 4px; }
.sheet-head{ display:flex; align-items:center; justify-content:space-between; padding:8px 20px 14px; border-bottom:1px solid var(--border); }
.sheet-head h3{ font-family:var(--display); font-size:18px; font-weight:600; }
.sheet-head button{ width:32px; height:32px; border-radius:50%; background:rgba(255,255,255,.05); display:grid; place-items:center; }
.sheet-head svg{ width:17px; height:17px; stroke:var(--ink-soft); stroke-width:2.2; fill:none; }
.sheet-scroll{ overflow-y:auto; padding:6px 20px; }
.si{ display:flex; align-items:center; gap:11px; padding:13px 0; border-bottom:1px solid var(--border); }
.si-info{ flex:1; min-width:0; }
.si-info b{ font-size:14px; font-weight:600; font-family:var(--display); display:block; }
.si-info span{ font-size:11.5px; color:var(--ink-mute); }
.si-amt{ font-size:14px; font-weight:700; min-width:54px; text-align:right; }
.summary{ padding:16px 20px; border-top:1px solid var(--border); }
.sum-row{ display:flex; justify-content:space-between; font-size:13.5px; color:var(--ink-soft); margin-bottom:9px; }
.sum-row small{ color:var(--ink-mute); font-weight:500; }
.sum-row.total{ font-size:17px; font-weight:700; color:var(--ink); padding-top:11px; border-top:1px dashed var(--border-2); margin-top:4px; }
.sum-row.total small{ font-size:13px; }
.place-order{ width:100%; background:var(--grad); color:#fff; font-weight:700; font-size:15.5px; padding:15px; border-radius:14px; margin-top:6px; display:flex; align-items:center; justify-content:center; gap:9px; box-shadow:0 14px 34px -12px rgba(124,58,237,.9); }
.place-order:active{ transform:scale(.99); }
.place-order svg{ width:18px; height:18px; stroke:#fff; fill:none; stroke-width:2.2; }
.safe{ font-size:11px; color:var(--ink-mute); text-align:center; margin-top:11px; padding-bottom:6px; }

/* Order success */
.order-ok{ position:fixed; inset:0; z-index:50; display:none; place-items:center; background:rgba(6,7,11,.86); backdrop-filter:blur(8px); }
.order-ok.show{ display:grid; }
.order-ok .box{ text-align:center; padding:30px; }
.order-ok .check{ width:84px; height:84px; border-radius:50%; background:var(--grad); display:grid; place-items:center; margin:0 auto 20px; animation:okPop .5s cubic-bezier(.2,1.4,.4,1); box-shadow:0 0 50px -8px rgba(124,58,237,.8); }
.order-ok .check svg{ width:42px; height:42px; stroke:#fff; stroke-width:3; fill:none; }
@keyframes okPop{ 0%{ transform:scale(0); } 100%{ transform:scale(1); } }
.order-ok h3{ font-family:var(--display); font-size:24px; margin-bottom:8px; }
.order-ok p{ color:var(--ink-soft); font-size:14px; }

/* Entrance */
.rise{ opacity:0; transform:translateY(14px); transition:opacity .5s cubic-bezier(.2,.7,.3,1), transform .5s cubic-bezier(.2,.7,.3,1); }
.rise.show{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .rise{ opacity:1; transform:none; } }
