/* Shared QR-menu styles. Theme via :root vars set per restaurant shell. */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
body{background:var(--bg);color:var(--fg);font-family:'Syne',system-ui,sans-serif;padding-bottom:80px}
.topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--surface);border-bottom:1px solid var(--border)}
.brand{font-family:'Bebas Neue',Impact,sans-serif;font-size:1.6rem;letter-spacing:1px;color:var(--accent);flex:0 0 auto}
.tablepill{flex:1;text-align:center;font-size:.85rem;color:var(--muted)}
.langs{display:flex;gap:4px}
.lng{background:transparent;border:1px solid var(--border);color:var(--muted);border-radius:6px;padding:5px 8px;font-size:.7rem;font-weight:700}
.lng.on{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.warn{margin:10px 14px;padding:10px;background:#3a2a00;border:1px solid var(--accent);border-radius:8px;font-size:.85rem}
.tabs{display:flex;gap:8px;overflow-x:auto;padding:12px 14px;position:sticky;top:57px;background:var(--bg);z-index:4}
.tab{flex:0 0 auto;background:var(--surface);border:1px solid var(--border);color:var(--fg);border-radius:20px;padding:8px 16px;font-size:.85rem;white-space:nowrap}
.tab.on{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:700}
.grid{display:grid;grid-template-columns:1fr;gap:12px;padding:6px 14px}
@media(min-width:600px){.grid{grid-template-columns:1fr 1fr}}
.card{display:flex;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.thumb{flex:0 0 96px;width:96px;height:96px;background-size:cover;background-position:center}
.thumb.noimg{display:flex;align-items:center;justify-content:center;font-size:2rem;background:var(--card)}
.cbody{flex:1;padding:10px 10px 10px 0;display:flex;flex-direction:column;gap:4px}
.cname{font-weight:700;font-size:.98rem}
.cdesc{font-size:.78rem;color:var(--muted);line-height:1.3}
.crow{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:6px}
.price{color:var(--accent);font-weight:700}
.b{font-size:.62rem;padding:1px 5px;border-radius:4px;margin-left:4px;font-weight:700}
.b.vg{background:#1f5e3a;color:#bff0d0}.b.hot{background:#5e1f1f;color:#ffd0d0}
.addbtn{background:var(--accent);color:var(--bg);border:0;border-radius:8px;padding:7px 14px;font-weight:700}
.qty{display:flex;align-items:center;gap:10px}
.qty button{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--fg);font-size:1.1rem}
.qty b{min-width:18px;text-align:center}
.cartbar{position:fixed;left:14px;right:14px;bottom:14px;z-index:6;display:flex;justify-content:space-between;background:var(--accent);color:var(--bg);border:0;border-radius:12px;padding:16px;font-weight:700;font-size:1rem;box-shadow:0 6px 20px rgba(0,0,0,.4)}
.cartbar.hide,.hide{display:none}
.overlay{position:fixed;inset:0;z-index:10;background:rgba(0,0,0,.6);display:flex;align-items:flex-end}
.sheet{width:100%;max-height:92vh;overflow-y:auto;background:var(--surface);border-radius:18px 18px 0 0;padding:20px 16px 30px;position:relative}
.sheet h2{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;color:var(--accent);margin-bottom:12px}
.sheet h3{font-size:.9rem;margin:16px 0 8px}
.x{position:absolute;top:14px;right:14px;background:var(--card);border:0;color:var(--fg);width:34px;height:34px;border-radius:50%;font-size:1rem}
.line{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:.9rem}
.line small{color:var(--muted)}
.muted{color:var(--muted)}
.drinks{margin:12px 0;padding:10px;background:#10324d;border:1px solid var(--blue,#3a7ab5);border-radius:8px;font-size:.82rem}
textarea,.contact{width:100%;background:var(--card);border:1px solid var(--border);color:var(--fg);border-radius:8px;padding:10px;font-family:inherit;font-size:.9rem;margin-top:6px}
textarea{min-height:54px;resize:vertical}
.opts{display:flex;flex-wrap:wrap;gap:8px}
.opt{flex:1;min-width:45%;background:var(--card);border:1px solid var(--border);color:var(--fg);border-radius:8px;padding:11px;font-size:.85rem}
.opt.on{border-color:var(--accent);background:var(--accent);color:var(--bg);font-weight:700}
.bigtotal{margin:16px 0 10px;font-size:1.2rem;font-weight:700;text-align:right}
.send{width:100%;background:var(--accent);color:var(--bg);border:0;border-radius:12px;padding:16px;font-size:1.05rem;font-weight:700}
.send:disabled{opacity:.4}
