/* ==========================================================================
   Concierge Pilot — Shared POS Engine CSS
   Structural / layout styles. Colors, fonts, accents come from tenant skin.
   --------------------------------------------------------------------------
   Each tenant's index.html sets these CSS variables in :root, then this
   stylesheet renders the universal POS UI in their brand.
   ========================================================================== */

*{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Sensible defaults — every tenant overrides these */
  --bg:#0e0d0c;
  --bg-alt:#0e0d0c;
  --surface:#1c1a17;
  --surface-2:#25221d;
  --accent:#b8954c;
  --accent-deep:#8a6e34;
  --accent-glow:#e8a73a;
  --accent-soft:rgba(184,149,76,0.14);
  --ink:#e8dfd0;
  --ink-dim:#c7b9a8;
  --ink-faint:#8b8275;
  --rule:rgba(184,149,76,0.18);
  --watermark:rgba(184,149,76,0.06);
  --danger:#dc2626;
  --danger-deep:#7f1d1d;
  --success:#16a34a;
  /* Fonts — tenant supplies */
  --brand-body-font: 'Inter', sans-serif;
  --brand-heading-font: 'Cormorant Garamond', serif;
  --brand-mono-font: 'JetBrains Mono', monospace;
  --brand-heading-style: italic;
  --brand-heading-weight: 700;
  /* Engine maps legacy aliases to tenant accent so old rules still resolve */
  --green:var(--accent);
  --green-deep:var(--accent-deep);
  --green-soft:var(--accent-soft);
  --red:var(--accent);
  --red-deep:var(--accent-deep);
  --red-soft:var(--accent-soft);
  --yellow:var(--accent-glow);
  --yellow-deep:var(--accent-deep);
  --yellow-soft:var(--accent-soft);
  --text:var(--ink);
}

html,body{height:100%;background:var(--bg-alt);color:var(--text);font-family:var(--brand-body-font);overflow:hidden;user-select:none;-webkit-user-select:none;-webkit-font-smoothing:antialiased}
body{display:flex;flex-direction:column}
button{font-family:inherit;cursor:pointer;border:none}
h1,h2,h3,h4{font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-weight:var(--brand-heading-weight);color:var(--text);letter-spacing:0.02em}
.uppercase-eyebrow{letter-spacing:0.18em;text-transform:uppercase}

/* ── Top bar ─────────────────────────────────────────────────────────── */
.pos-top{position:relative;display:flex;align-items:center;gap:5px;padding:10px 12px;background:var(--surface);border-bottom:1px solid var(--rule);flex:0 0 auto;flex-wrap:wrap}
.pos-top::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:2px;background:linear-gradient(90deg,transparent 0%,var(--accent) 20%,var(--accent-glow) 50%,var(--accent) 80%,transparent 100%);pointer-events:none}
.pos-brand{display:flex;align-items:center;gap:12px}
.pos-brand .nav-logo-text{font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-weight:var(--brand-heading-weight);font-size:1.55rem;color:var(--accent);letter-spacing:.02em;line-height:1}
.pos-brand .nav-logo-sub{font-family:var(--brand-mono-font);font-size:.62rem;color:var(--accent-glow);letter-spacing:.32em;line-height:1;margin-top:4px;text-transform:uppercase}
.pos-brand .brand-stack{display:flex;flex-direction:column}
.pos-brand h1{font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--ink-dim);font-family:var(--brand-body-font)}
.pos-brand .pill{font-size:10px;padding:3px 10px;border-radius:999px;background:var(--accent-glow);color:#1a1408;font-weight:700;letter-spacing:1px}
.pos-clock{font-family:var(--brand-mono-font);font-size:13px;color:var(--accent-glow);font-weight:600;letter-spacing:.12em}
.pos-nav-btn{background:var(--surface);border:1px solid var(--rule);color:var(--ink-dim);padding:7px 9px;border-radius:8px;font-size:10px;font-weight:600;letter-spacing:.5px;cursor:pointer;text-transform:uppercase;text-decoration:none;font-family:inherit;transition:all .15s;display:inline-flex;align-items:center;gap:5px}
.pos-nav-btn:hover{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}

/* Tenant brand mark slot (each tenant supplies their own SVG inside .brand-mark) */
.brand-mark{width:38px;height:38px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;background:var(--bg);border-radius:50%;border:1.5px solid var(--accent);box-shadow:0 2px 10px rgba(0,0,0,0.25);overflow:hidden}
.brand-mark svg,.brand-mark img{width:74%;height:74%}

/* ── Mode toggle (Cashier vs Waiter) ─────────────────────────────────── */
.mode-toggle{display:none !important}
.mode-toggle .mt-btn{background:transparent;border:0;color:var(--ink-dim);padding:7px 14px;border-radius:999px;font-size:10.5px;font-weight:700;letter-spacing:0.18em;cursor:pointer;text-transform:uppercase;font-family:inherit;transition:all .15s}
.mode-toggle .mt-btn.active{background:var(--accent);color:var(--bg);box-shadow:0 4px 14px -6px rgba(0,0,0,0.5)}
.mode-toggle .mt-btn:not(.active):hover{color:var(--accent)}

/* ── Waiter bar ──────────────────────────────────────────────────────── */
.waiter-bar{display:none;align-items:center;gap:10px;padding:10px 22px;background:var(--surface);border-bottom:1px solid var(--rule);flex-wrap:wrap}
body.mode-waiter .waiter-bar{display:flex}
.wb-field{display:flex;flex-direction:column;gap:3px}
.wb-field label{font-size:9px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--ink-faint)}
.wb-field select,.wb-field input{background:var(--surface);border:1.5px solid var(--rule);border-radius:8px;padding:8px 12px;font-size:13px;font-weight:600;color:var(--text);font-family:inherit;min-width:88px;transition:all .15s}
.wb-field select:focus,.wb-field input:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.wb-field select{cursor:pointer}
.wb-field.wb-server input{min-width:140px}
.wb-field.wb-guest input{min-width:80px;text-align:center}
.wb-badge{font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-size:.95rem;color:var(--accent);font-weight:400;letter-spacing:.18em;margin-left:auto;text-transform:uppercase}
/* Open-tables strip — your live tables, held on this station until they pay & leave */
.open-tables{flex:1 1 0;display:flex;align-items:center;gap:8px;overflow-x:auto;margin-left:16px;min-width:0;scrollbar-width:none}
.open-tables::-webkit-scrollbar{height:0}
.ot-label{flex:0 0 auto;font-size:9px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--ink-faint);font-family:var(--brand-body-font)}
.ot-chip{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-start;gap:1px;background:var(--surface);border:1px solid var(--rule);border-radius:10px;padding:6px 12px;cursor:pointer;font-family:var(--brand-body-font);transition:all .12s;-webkit-tap-highlight-color:transparent}
.ot-chip.active{border-color:var(--accent);background:var(--accent-soft)}
.ot-chip .ot-tbl{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);display:flex;align-items:center}
.ot-chip .ot-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent-glow);margin-right:5px}
.ot-chip .ot-unsent{background:#e0a000}
.ot-chip .ot-meta{font-size:9px;color:var(--ink-faint);letter-spacing:.04em;font-family:var(--brand-mono-font)}
/* Fire Seat button — waiter only, secondary outline under Fire Table */
.fire-seat-btn{display:none;width:100%;margin-top:8px;min-height:46px;padding:12px;border-radius:10px;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-family:var(--brand-body-font);background:transparent;color:var(--accent);border:1px solid var(--accent);cursor:pointer;-webkit-tap-highlight-color:transparent}
body.mode-waiter .fire-seat-btn{display:block}
.fire-seat-btn:disabled{opacity:.4;cursor:not-allowed}
/* SENT badge on a fired check item */
.item-sent{display:inline-block;font-family:var(--brand-body-font);font-size:8.5px;font-weight:700;letter-spacing:.12em;color:#34d27b;border:1px solid rgba(52,210,123,.5);border-radius:4px;padding:1px 5px;margin-left:6px;vertical-align:middle;text-transform:uppercase}
/* Allergy flags — red, prominent, on the check + summary + kitchen ticket */
.wb-allergy input{min-width:88px}
.item-allergy{display:inline-block;font-family:var(--brand-body-font);font-size:9px;font-weight:800;letter-spacing:.06em;color:#fff;background:#c44545;border-radius:4px;padding:1px 6px;margin-left:6px;vertical-align:middle;text-transform:uppercase}
.ts-allergy{display:inline-block;font-family:var(--brand-body-font);font-size:10px;font-weight:800;letter-spacing:.06em;color:#fff;background:#c44545;border-radius:5px;padding:2px 8px;margin-left:8px;vertical-align:middle;text-transform:uppercase}
.wb-seatname input{min-width:94px}
/* Summary button in the ticket-actions bar (waiter only) */
.summary-btn{display:none}
.ticket-actions .summary-btn{background:transparent !important;border:0 !important;border-radius:0 !important;box-shadow:none !important;margin:0 !important;padding:6px 18px !important;color:var(--ink) !important;font-family:var(--brand-body-font);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;align-items:center;justify-content:center;border-right:1px solid rgba(199,185,168,0.45) !important}
.ticket-actions .summary-btn:hover{color:var(--accent-glow) !important}
body.mode-waiter .ticket-actions .summary-btn{display:flex}
/* Full-screen Table Summary modal */
.ts-bd{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.72);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:20px}
.ts-bd.open{display:flex}
.ts-card{background:var(--surface);border:1px solid var(--rule);border-radius:16px;width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.55)}
.ts-head{display:flex;align-items:center;justify-content:space-between;padding:18px 24px 14px;border-bottom:1px solid var(--rule)}
.ts-head h3{font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-size:1.5rem;font-weight:var(--brand-heading-weight);color:var(--text);letter-spacing:.02em}
.ts-close{background:transparent;border:0;color:var(--ink-dim);font-size:18px;cursor:pointer;padding:4px 10px;-webkit-tap-highlight-color:transparent}
.ts-rush-btn{background:transparent;border:1px solid #ff3b30;color:#ff6b60;font-family:var(--brand-body-font);font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:7px 13px;border-radius:8px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.ts-rush-btn:hover{background:rgba(255,59,48,.12)}
.ts-body{flex:1;overflow-y:auto;padding:14px 22px}
.ts-seat{margin-bottom:16px}
.ts-seat-head{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--rule);padding-bottom:6px;margin-bottom:8px}
.ts-seat-head .ts-seat-name{font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-size:1.15rem;font-weight:var(--brand-heading-weight);color:var(--accent);letter-spacing:.02em}
.ts-seat-sub{font-family:var(--brand-mono-font);font-weight:700;color:var(--ink);font-size:.95rem}
.ts-line{display:flex;align-items:center;gap:10px;padding:5px 0;font-family:var(--brand-body-font);font-size:13px}
.ts-line .ts-q{font-family:var(--brand-mono-font);color:var(--ink-faint);min-width:28px}
.ts-line .ts-n{flex:1;color:var(--text)}
.ts-line .ts-p{font-family:var(--brand-mono-font);color:var(--accent);font-variant-numeric:tabular-nums}
.ts-pending{display:inline-block;font-size:8.5px;font-weight:700;letter-spacing:.12em;color:#e0a000;border:1px solid rgba(224,160,0,.5);border-radius:4px;padding:1px 5px;margin-left:6px;vertical-align:middle;text-transform:uppercase}
/* Live kitchen status pills in the summary */
.ks{display:inline-block;font-family:var(--brand-body-font);font-size:8.5px;font-weight:700;letter-spacing:.1em;border-radius:4px;padding:1px 6px;margin-left:6px;vertical-align:middle;text-transform:uppercase;white-space:nowrap}
.ks-pending{color:#8b8275;border:1px solid rgba(139,130,117,.5)}
.ks-fired{color:#e0a000;border:1px solid rgba(224,160,0,.5)}
.ks-cooking{color:#e8a73a;border:1px solid rgba(232,167,58,.6);background:rgba(232,167,58,.08)}
.ks-ready{color:#34d27b;border:1px solid rgba(52,210,123,.6);background:rgba(52,210,123,.10)}
.ts-foot{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-top:1px solid var(--rule);background:var(--bg-alt)}
.ts-foot span:first-child{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim)}
.ts-foot span:last-child{font-family:var(--brand-mono-font);font-size:1.3rem;font-weight:700;color:var(--accent)}
/* Checkout actions */
.co-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:16px 22px 22px;border-top:1px solid var(--rule)}
.co-btn{min-height:54px;padding:14px;border-radius:10px;font-family:var(--brand-body-font);font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;background:var(--surface);color:var(--ink);border:1px solid var(--rule);-webkit-tap-highlight-color:transparent}
.co-btn:hover{border-color:var(--accent)}
.co-btn.co-card{grid-column:auto;background:linear-gradient(180deg,var(--accent-glow) 0%,var(--accent) 100%);color:#1a1408;border:1px solid var(--accent)}
.co-btn[data-act="checkout-split"]{grid-column:1 / -1}
.co-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-family:var(--brand-body-font);font-size:14px;color:var(--ink-dim)}
.co-row .co-v{font-family:var(--brand-mono-font);color:var(--ink)}
.co-row.co-grand{margin-top:8px;padding-top:12px;border-top:1px solid var(--rule);font-size:18px;color:var(--text);font-weight:700}
.co-row.co-grand .co-v{color:var(--accent);font-size:20px;font-weight:700}
.seat-tag{display:inline-block;background:var(--accent);color:var(--bg);font-size:9px;font-weight:800;padding:2px 7px;border-radius:999px;margin-right:7px;letter-spacing:.16em;font-family:var(--brand-body-font);vertical-align:middle}

/* ── Tip calculator (waiter only) ────────────────────────────────────── */
.tip-block{display:none;margin:10px 0 6px}
body.mode-waiter .tip-block{display:block}
.tip-label{font-size:10px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--ink-faint);margin-bottom:6px}
.tip-row{display:flex;gap:5px}
.tip-btn{flex:1;background:var(--surface);border:1.5px solid var(--rule);color:var(--ink-dim);padding:9px 4px;border-radius:8px;font-size:11px;font-weight:700;letter-spacing:0.18em;cursor:pointer;font-family:inherit;transition:all .12s}
.tip-btn:hover{border-color:var(--accent);color:var(--accent)}
.tip-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent);box-shadow:0 4px 12px -4px rgba(0,0,0,0.45)}
.tip-custom-row{display:none;align-items:center;gap:8px;margin-top:7px}
.tip-custom-row.show{display:flex}
.tip-custom-row input{flex:1;background:var(--surface);border:1.5px solid var(--rule);color:var(--text);padding:9px 12px;border-radius:8px;font-family:var(--brand-mono-font);font-size:13px;font-weight:700;text-align:right}
.tip-custom-row input:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.tip-custom-apply{background:var(--accent);color:var(--bg);border:0;padding:9px 16px;border-radius:8px;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;font-family:inherit}
.tip-custom-apply:hover{background:var(--accent-deep)}

/* Split button */
.split-btn{display:none;background:var(--surface);border:1px solid var(--rule);color:var(--ink-dim);padding:5px 12px;border-radius:10px;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;font-family:inherit;transition:all .12s;margin-left:8px}
body.mode-waiter .split-btn{display:inline-block}
.split-btn:hover{border-color:var(--accent);color:var(--accent)}
.split-btn:disabled{opacity:.4;cursor:not-allowed}

/* ── Split-by-seat modal ─────────────────────────────────────────────── */
.split-card{background:var(--surface);border-radius:18px;width:100%;max-width:560px;max-height:92vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,0.45)}
.split-head{padding:20px 26px 14px;border-bottom:1px solid var(--rule)}
.split-head .mod-eyebrow{display:inline-block;font-size:.6rem;color:var(--accent);letter-spacing:.3em;text-transform:uppercase;font-weight:700;margin-bottom:6px}
.split-head h3{font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);color:var(--text);font-size:1.65rem;font-weight:var(--brand-heading-weight);letter-spacing:.04em}
.split-head .sub{color:var(--ink-faint);font-size:.86rem;margin-top:4px;line-height:1.4}
.split-body{flex:1;overflow-y:auto;padding:18px 26px}
.split-body::-webkit-scrollbar{width:6px}
.split-body::-webkit-scrollbar-thumb{background:var(--accent-soft);border-radius:100px}
.split-foot{padding:14px 26px 22px;border-top:1px solid var(--rule);background:var(--surface);display:flex;gap:10px}
.seat-card{background:var(--bg-alt);border:1.5px solid var(--rule);border-radius:14px;padding:14px 16px;margin-bottom:12px}
.seat-card .seat-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.seat-card .seat-name{font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-size:1.2rem;font-weight:var(--brand-heading-weight);color:var(--text);letter-spacing:.04em}
.seat-card .seat-total{font-family:var(--brand-mono-font);color:var(--accent);font-weight:700;font-size:1.05rem}
.seat-card .seat-items{margin:6px 0 10px}
.seat-card .seat-line{display:flex;justify-content:space-between;font-size:12.5px;color:var(--ink-dim);padding:3px 0;font-family:var(--brand-body-font)}
.seat-card .seat-line .v{font-family:var(--brand-mono-font)}
.seat-card .seat-meta{font-size:10px;color:var(--ink-faint);letter-spacing:.05em;text-transform:uppercase;border-top:1px solid var(--rule);padding-top:7px;display:flex;justify-content:space-between;font-weight:600}
.seat-card .seat-actions{display:flex;gap:6px;margin-top:10px}
.seat-card .seat-actions button{flex:1;padding:9px;border-radius:10px;font-weight:700;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--rule);background:var(--surface);color:var(--ink-dim);cursor:pointer;font-family:inherit;transition:all .15s}
.seat-card .seat-actions button:hover{border-color:var(--accent);color:var(--accent)}
.seat-card .seat-actions .pay-card{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.seat-card .seat-actions .pay-card:hover{background:var(--accent-deep);color:var(--bg)}
.split-empty{text-align:center;padding:30px 16px;background:var(--bg-alt);border:1.5px dashed var(--rule);border-radius:12px;color:var(--ink-dim);font-size:13px;line-height:1.55}

/* ── Main layout ─────────────────────────────────────────────────────── */
.pos-main{flex:1;display:grid;grid-template-columns:1fr 440px;gap:1px;background:var(--rule);overflow:hidden}
.menu-wrap{display:flex;flex-direction:column;background:var(--surface);overflow:hidden}
.menu-cats{display:flex;gap:6px;padding:12px 14px;background:var(--surface);border-bottom:1px solid var(--rule);overflow-x:auto;flex:0 0 auto;scrollbar-width:thin}
.menu-cats::-webkit-scrollbar{height:4px}
.menu-cats::-webkit-scrollbar-thumb{background:var(--accent-soft);border-radius:100px}
.cat-btn{background:var(--surface);border:1.5px solid var(--rule);color:var(--ink-dim);padding:9px 18px;border-radius:10px;font-size:11px;font-weight:700;cursor:pointer;white-space:nowrap;text-transform:uppercase;letter-spacing:0.18em;font-family:inherit;transition:all .15s}
.cat-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
.cat-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent);box-shadow:0 4px 14px -6px rgba(0,0,0,0.5)}

/* ── Menu region with tenant watermark ───────────────────────────────── */
.menu-region{flex:1;position:relative;overflow:hidden;background:var(--bg-alt)}
.menu-watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-weight:var(--brand-heading-weight);font-size:14vw;color:var(--watermark);pointer-events:none;line-height:1;letter-spacing:0.02em;user-select:none;z-index:0;white-space:nowrap}
.menu-grid{position:relative;z-index:1;height:100%;padding:16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;overflow-y:auto;align-content:start;grid-auto-rows:max-content}
.menu-grid::-webkit-scrollbar{width:8px}
.menu-grid::-webkit-scrollbar-thumb{background:var(--accent-soft);border-radius:100px}
.menu-tile{position:relative;background:var(--surface);border:1px solid var(--rule);border-radius:14px;padding:0;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;overflow:hidden}
.menu-tile:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(0,0,0,0.45)}
.menu-tile:active{transform:scale(.98)}
.tile-img{height:130px;background:var(--bg-alt) center/cover no-repeat;flex-shrink:0}
.tile-img.placeholder{display:flex;align-items:center;justify-content:center;font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);color:var(--accent-soft);font-size:2rem;font-weight:var(--brand-heading-weight)}
.tile-body{padding:11px 14px 14px;display:flex;flex-direction:column;gap:4px;flex:0 0 auto}
.tile-name{font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-size:1.15rem;font-weight:var(--brand-heading-weight);color:var(--text);line-height:1.15;letter-spacing:.02em;overflow-wrap:break-word}
.tile-desc{font-size:11px;color:var(--ink-faint);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-family:var(--brand-body-font)}
.tile-price{font-family:var(--brand-mono-font);font-size:14px;font-weight:700;color:var(--accent);margin-top:auto;padding-top:6px;letter-spacing:-.02em}
.tile-flag{position:absolute;top:8px;right:8px;background:var(--accent-glow);color:var(--bg);font-size:9px;font-weight:800;padding:3px 8px;border-radius:999px;letter-spacing:.18em;text-transform:uppercase;box-shadow:0 4px 10px rgba(0,0,0,0.25)}
.tile-flag.spicy{background:var(--accent-deep);color:var(--accent-glow);box-shadow:0 4px 10px rgba(0,0,0,0.3)}
/* 86 / out-of-stock — greyed, unorderable, red 86 badge (synced live across devices) */
.menu-tile.is-86{opacity:.45;filter:grayscale(.65)}
.menu-tile.is-86:hover{transform:none;box-shadow:none;border-color:var(--rule)}
.tile-86-badge{position:absolute;top:8px;left:8px;background:#c44545;color:#fff;font-size:10px;font-weight:800;letter-spacing:.14em;padding:3px 9px;border-radius:6px;z-index:3;box-shadow:0 4px 10px rgba(0,0,0,0.35)}

/* ── Check panel ─────────────────────────────────────────────────────── */
.check-wrap{background:var(--surface);display:flex;flex-direction:column;overflow:hidden}
.check-head{padding:18px 22px;border-bottom:1px solid var(--rule);display:flex;justify-content:space-between;align-items:center;background:var(--surface)}
.check-head h2{font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-size:1.55rem;font-weight:var(--brand-heading-weight);color:var(--text);letter-spacing:.02em}
.check-count{background:var(--accent-soft);padding:4px 12px;border-radius:999px;font-family:var(--brand-mono-font);font-size:11px;color:var(--accent);font-weight:700;letter-spacing:.05em}
.check-body{flex:1;min-height:0;overflow-y:auto;padding:8px 14px;background:var(--bg-alt)}
.check-body::-webkit-scrollbar{width:6px}
.check-body::-webkit-scrollbar-thumb{background:var(--accent-soft);border-radius:100px}
.check-empty{text-align:center;color:var(--ink-faint);padding:80px 20px;font-size:11px;text-transform:uppercase;letter-spacing:2px;font-weight:600;font-family:var(--brand-body-font)}
.check-empty .ck-emp-mark{font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-size:3.5rem;color:var(--accent-soft);margin-bottom:10px;font-weight:var(--brand-heading-weight);letter-spacing:.02em;text-transform:none}

.check-item{display:grid;grid-template-columns:auto 1fr auto auto;gap:16px;align-items:center;padding:14px 8px;border-bottom:1px solid var(--rule)}
.qty-ctrl{display:flex;background:var(--surface);border:1px solid var(--rule);border-radius:10px;overflow:hidden;margin-right:6px}
.qty-btn{background:transparent;border:none;color:var(--accent);padding:9px 12px;font-size:18px;font-weight:800;cursor:pointer;font-family:inherit;min-width:36px;line-height:1}
.qty-btn:hover{background:var(--accent-soft)}
.qty-val{min-width:30px;text-align:center;font-family:var(--brand-mono-font);font-weight:700;color:var(--ink);padding:9px 2px;font-size:14px;background:var(--surface)}
.check-item .name{font-size:13px;font-weight:600;color:var(--text);line-height:1.3;font-family:var(--brand-body-font)}
.check-item .line-total{font-family:var(--brand-mono-font);font-weight:700;color:var(--accent);font-size:14px;min-width:80px;text-align:right;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.check-item .remove{background:transparent;border:none;color:var(--ink-faint);cursor:pointer;font-size:20px;padding:6px 10px;border-radius:8px;line-height:1}
.check-item .remove:hover{color:var(--danger);background:rgba(239,68,68,0.10)}

.check-totals{padding:16px 22px;border-top:1px solid var(--rule);background:var(--surface)}
.total-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:13px;color:var(--ink-dim)}
.total-row .val{font-family:var(--brand-mono-font);font-weight:600;font-variant-numeric:tabular-nums}
.total-row.grand{margin-top:12px;padding-top:12px;border-top:1px solid var(--rule);font-size:18px;color:var(--text);font-weight:700;font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);letter-spacing:.04em}
.total-row.grand .val{color:var(--accent);font-size:22px;font-family:var(--brand-mono-font);font-weight:700}

.send-btn{margin-top:14px;width:100%;padding:16px;font-size:13px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;background:linear-gradient(180deg,var(--accent-glow) 0%,var(--accent) 100%);color:var(--bg);border:1px solid var(--accent);border-radius:10px;cursor:pointer;transition:all .2s;box-shadow:inset 0 1px 0 rgba(255,255,255,0.18),0 8px 24px rgba(0,0,0,0.25);font-family:var(--brand-body-font)}
.send-btn:hover{filter:brightness(1.08);transform:translateY(-1px)}
.send-btn:disabled{background:var(--rule);color:var(--ink-faint);cursor:not-allowed;box-shadow:none;transform:none;filter:none}
/* PAY NOW — secondary action (charge without firing). Distinct from the gold SEND button. */
.pay-now-btn{margin-top:8px;background:transparent;color:var(--accent-glow);box-shadow:none}
.pay-now-btn:hover{background:rgba(184,149,76,.12);filter:none}
.pay-now-btn:disabled{background:transparent;border-color:var(--rule)}
.mode-waiter .pay-now-btn{display:none}  /* waiter pays via the check-out flow on the SEND button */
/* Counter 3-mode selector + open-tickets list */
.cmode-bar{display:flex;gap:0;margin:0 0 10px;border:1px solid var(--rule);border-radius:9px;overflow:hidden}
.cmode-bar .cmode-btn{flex:1;padding:9px 6px;background:transparent;border:none;color:var(--ink-dim);font-family:inherit;font-size:.7rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;cursor:pointer;white-space:nowrap}
.cmode-bar .cmode-btn.active{background:rgba(184,149,76,.16);color:var(--accent-glow)}
.mode-waiter .cmode-bar{display:none}
.open-tix{display:flex;flex-direction:column;gap:8px;padding:4px 14px 8px}
.open-tix .ot-row{padding:11px 13px;border:1px solid var(--rule);border-radius:9px;background:rgba(255,255,255,.03);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:10px}
.open-tix .ot-row:hover{border-color:var(--accent);background:rgba(184,149,76,.08)}
.open-tix .ot-tbl{font-weight:700;color:var(--ink)}
.open-tix .ot-meta{font-size:.72rem;color:var(--ink-dim);margin-top:2px}
.open-tix .ot-amt{font-family:'JetBrains Mono',monospace;color:var(--accent-glow);font-weight:700;white-space:nowrap}
.open-tix .ot-empty{padding:24px;text-align:center;color:var(--ink-faint);font-size:.85rem}
.clear-btn{margin-top:8px;width:100%;padding:10px;font-size:10px;letter-spacing:2px;text-transform:uppercase;background:transparent;color:var(--ink-dim);border:1px solid var(--rule);border-radius:10px;cursor:pointer;font-weight:600}
.clear-btn:hover{border-color:var(--danger);color:var(--danger)}
/* Secondary actions — equal square grid (Redeem Gift · Attach Customer · Text Receipt · Clear Check) */
.sec-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
.sec-actions > button{position:static !important;inset:auto !important;bottom:auto !important;right:auto !important;top:auto !important;left:auto !important;width:100%;margin:0 !important;min-height:48px;padding:13px 10px;border-radius:10px;font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-family:var(--brand-body-font);background:var(--surface);color:var(--ink-dim);border:1px solid var(--rule);box-shadow:none;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;gap:6px;text-align:center}
.sec-actions > button:hover{border-color:var(--accent);color:var(--accent)}
.sec-actions > .gc-redeem-btn{order:1}
.sec-actions > #posCustomerBtn{order:2}
.sec-actions > #posTextReceiptBtn{order:3}
.sec-actions > .clear-btn{order:4}
/* One scrollable check card — items + totals + payment scroll together as a single column.
   Flick up to see the full itemized list, flick down to reach the payment. The header
   (TICKET · MODS · count) stays pinned; everything below scrolls in one motion. */
.check-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}
.check-scroll::-webkit-scrollbar{width:6px}
.check-scroll::-webkit-scrollbar-thumb{background:var(--accent-soft);border-radius:100px}
.check-scroll .check-body{flex:none;min-height:0;overflow:visible}
.check-scroll .check-totals{flex:none}
/* Blank background behind the menu — no decorative watermark word */
.menu-watermark{display:none !important}
/* Workspace selector living in the POS header (replaces the old top shell bar).
   Styled to match the header nav buttons — dark, thin border, no loud amber pill. */
.role-sel{-webkit-appearance:none;appearance:none;background:var(--surface);color:var(--ink-dim);border:1px solid var(--rule);border-radius:8px;padding:8px 34px 8px 14px;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;font-family:inherit;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23b8954c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 12px center;transition:all .15s}
.role-sel:hover{border-color:var(--accent);color:var(--accent)}
.role-sel:focus{outline:none;border-color:var(--accent)}
.role-sel option{background:var(--surface);color:var(--ink);text-transform:none;letter-spacing:normal}
/* Ticket action bar — borderless segments divided by thin pipes (MODS | SPLIT BY SEAT | count).
   Count is the number centered above the uppercase word, same font family as the buttons. */
.ticket-actions{display:flex;align-items:stretch}
.ticket-actions .mods-btn,
.ticket-actions .split-btn{
  background:transparent !important;border:0 !important;border-radius:0 !important;box-shadow:none !important;
  margin:0 !important;padding:6px 18px !important;
  color:var(--ink) !important;font-family:var(--brand-body-font);font-size:12px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;cursor:pointer;
  align-items:center;justify-content:center;
  border-right:1px solid rgba(199,185,168,0.45) !important;
}
/* Keep MODS / Split-by-Seat waiter-only — only make them flex when actually shown,
   so we don't override their display:none in cashier mode. */
body.mode-waiter .ticket-actions .mods-btn,
body.mode-waiter .ticket-actions .split-btn{display:flex}
.ticket-actions .mods-btn:hover,
.ticket-actions .split-btn:hover{color:var(--accent-glow) !important;background:transparent !important}
.ticket-actions .mods-btn:disabled,
.ticket-actions .split-btn:disabled{opacity:.5}
.ticket-actions .check-count{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:transparent !important;border:0 !important;border-radius:0 !important;
  padding:2px 18px !important;
}
.ticket-actions .check-count .cc-num{
  font-family:var(--brand-body-font);font-size:12px;font-weight:700;color:var(--ink);line-height:1.2;
}
.ticket-actions .check-count .cc-lbl{
  font-family:var(--brand-body-font);font-size:12px;font-weight:700;color:var(--ink);
  letter-spacing:.12em;text-transform:uppercase;line-height:1.2;
}
/* Touch devices: remove the gray tap flash and stop a tapped button from staying
   stuck in its :hover look until you tap elsewhere (iOS keeps :hover after a tap). */
*{-webkit-tap-highlight-color:transparent}
@media (hover:none){
  .menu-tile:hover{border-color:var(--rule) !important;transform:none !important;box-shadow:none !important}
  .cat-btn:hover{border-color:var(--rule) !important;color:var(--ink-dim) !important;background:var(--surface) !important}
  .tip-btn:hover{border-color:var(--rule) !important;color:var(--ink-dim) !important}
  .pos-nav-btn:hover{background:var(--surface) !important;color:var(--ink-dim) !important;border-color:var(--rule) !important}
  .send-btn:hover{filter:none !important;transform:none !important}
  .clear-btn:hover{border-color:var(--rule) !important;color:var(--ink-dim) !important}
  .sec-actions>button:hover{border-color:var(--rule) !important;color:var(--ink-dim) !important}
  .ticket-actions .mods-btn:hover,.ticket-actions .split-btn:hover{color:var(--ink) !important}
  .mod-pill:hover{border-color:var(--rule) !important;color:var(--ink-dim) !important}
}

/* ── Modifier picker modal ───────────────────────────────────────────── */
.mod-bd{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.mod-bd.open{display:flex}
.mod-card{background:var(--surface);border-radius:18px;width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,0.45)}
.mod-sticky-top{padding:22px 28px 16px;border-bottom:1px solid var(--rule);flex:0 0 auto;background:var(--surface);position:sticky;top:0;z-index:3}
.mod-eyebrow{display:inline-block;font-size:.6rem;color:var(--accent);letter-spacing:.3em;text-transform:uppercase;font-weight:700;margin-bottom:6px}
.mod-card h3{font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);color:var(--text);font-size:1.95rem;margin-bottom:4px;letter-spacing:.02em;font-weight:var(--brand-heading-weight);line-height:1.05}
.mod-card h3 em{font-style:inherit;color:var(--accent);font-weight:inherit}
.mod-card .sub{color:var(--ink-faint);font-size:.86rem;margin-bottom:0;line-height:1.4;font-family:var(--brand-body-font)}
.mod-scroll{flex:1;overflow-y:auto;padding:18px 28px 16px}
.mod-scroll::-webkit-scrollbar{width:6px}
.mod-scroll::-webkit-scrollbar-thumb{background:var(--accent-soft);border-radius:100px}
.mod-sticky-bottom{padding:14px 28px 22px;border-top:1px solid var(--rule);background:var(--surface);flex:0 0 auto;display:flex;gap:12px}
.mod-card .group-label{font-family:var(--brand-body-font);font-size:.66rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin:18px 0 10px;display:flex;justify-content:space-between;align-items:center}
.mod-card .group-label:first-child{margin-top:0}
.mod-card .group-label .req{font-size:.62rem;color:var(--ink-faint);font-weight:500;letter-spacing:.05em;text-transform:none}
.pill-row{display:flex;gap:8px;flex-wrap:wrap}
.mod-pill{padding:11px 18px;border:1.5px solid var(--rule);border-radius:10px;font-weight:600;font-size:.84rem;background:var(--surface);cursor:pointer;color:var(--ink-dim);font-family:inherit;transition:all .12s;letter-spacing:.01em}
.mod-pill:hover{border-color:var(--accent);color:var(--accent)}
.mod-pill.selected{background:var(--accent);color:var(--bg);border-color:var(--accent);box-shadow:0 6px 16px -6px rgba(0,0,0,0.4)}
.mod-pill.spice-mild.selected{background:#16a34a;border-color:#16a34a;color:#fff}
.mod-pill.spice-medium.selected{background:#e0a000;border-color:#e0a000;color:#1a0f0a}
.mod-pill.spice-hot.selected{background:#ea580c;border-color:#ea580c;color:#fff}
.mod-pill.spice-extra.selected{background:#dc2626;border-color:#dc2626;color:#fff}
.mod-pill .pill-price{font-family:var(--brand-mono-font);margin-left:6px;opacity:.85;font-size:.76rem}
.mod-row{display:flex;justify-content:space-between;align-items:center;padding:11px 16px;background:var(--surface);border:1.5px solid var(--rule);border-radius:12px;margin-bottom:6px;cursor:pointer;transition:all .12s;gap:10px}
.mod-row:hover{border-color:var(--accent)}
.mod-row.selected{background:var(--accent-soft);border-color:var(--accent)}
.mod-row .opt-name{font-size:.94rem;font-weight:500;color:var(--text);flex:1}
.mod-row .opt-price{font-family:var(--brand-mono-font);font-weight:700;color:var(--accent);font-size:.86rem;font-variant-numeric:tabular-nums}
.mod-row .check{width:18px;height:18px;border-radius:50%;border:2px solid var(--rule);flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--bg);font-size:11px;font-weight:800;background:var(--surface)}
.mod-row.selected .check{background:var(--accent);border-color:var(--accent)}
.mod-textarea{width:100%;padding:12px 14px;border:1.5px solid var(--rule);border-radius:10px;font-family:var(--brand-body-font);font-size:.92rem;color:var(--text);resize:vertical;min-height:64px;line-height:1.5;background:var(--surface)}
.mod-textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.mod-cancel{flex:0 0 auto;padding:14px 24px;border-radius:10px;font-weight:600;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;background:transparent;color:var(--ink-dim);border:1px solid var(--rule);cursor:pointer;font-family:inherit}
.mod-cancel:hover{border-color:var(--ink);color:var(--ink)}
.mod-confirm{flex:1;padding:14px;border-radius:10px;font-weight:700;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;background:linear-gradient(180deg,var(--accent-glow) 0%,var(--accent) 100%);color:var(--bg);border:0;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;justify-content:center;gap:10px;box-shadow:inset 0 1px 0 rgba(255,255,255,0.18),0 8px 20px -8px rgba(0,0,0,0.45)}
.mod-confirm:hover{filter:brightness(1.08)}
.mod-confirm:disabled{background:var(--rule);color:var(--ink-faint);cursor:not-allowed;box-shadow:none;filter:none}
.mod-confirm .price{font-family:var(--brand-mono-font);font-weight:800}

/* ── Toast ───────────────────────────────────────────────────────────── */
.pos-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--accent);color:var(--bg);padding:14px 26px;border-radius:999px;font-weight:600;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;box-shadow:0 12px 30px -10px rgba(0,0,0,.45);display:none;z-index:150;font-family:var(--brand-body-font)}
.pos-toast.show{display:block;animation:toastIn .25s}
.pos-toast.err{background:var(--danger-deep);color:#fff}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%,0)}}

/* ── Receipt preview ─────────────────────────────────────────────────── */
.rcpt-bd{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:120;padding:20px}
.rcpt-bd.open{display:flex}
.rcpt-card{background:var(--surface);border-radius:16px;width:100%;max-width:440px;max-height:92vh;display:flex;flex-direction:column;overflow:hidden}
.rcpt-head{padding:16px 22px;border-bottom:1px solid var(--rule);display:flex;justify-content:space-between;align-items:center}
.rcpt-head h3{font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-size:1.4rem;font-weight:var(--brand-heading-weight);color:var(--text);letter-spacing:.04em}
.rcpt-scroll{flex:1;overflow-y:auto;padding:18px;background:var(--bg-alt)}
.rcpt-foot{padding:14px 22px;border-top:1px solid var(--rule);display:flex;gap:10px}
.rcpt-foot button{flex:1;padding:13px;border-radius:10px;font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;border:0;cursor:pointer;font-family:inherit}
.rcpt-foot .print{background:linear-gradient(180deg,var(--accent-glow) 0%,var(--accent) 100%);color:var(--bg)}
.rcpt-foot .print:hover{filter:brightness(1.08)}
.rcpt-foot .done{background:transparent;color:var(--ink-dim);border:1px solid var(--rule)}
.rcpt-foot .done:hover{border-color:var(--ink-dim);color:var(--ink)}

#receipt{background:#fff;margin:0 auto;width:72mm;min-height:auto;padding:8mm 4mm;font-family:var(--brand-mono-font),ui-monospace,Menlo,monospace;font-size:11px;color:#111;line-height:1.35}
#receipt .r-brand{font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-size:22px;text-align:center;letter-spacing:.06em;margin-bottom:2px;font-weight:var(--brand-heading-weight)}
#receipt .r-sub{text-align:center;font-size:9px;letter-spacing:.5px;color:#333;margin-bottom:8px}
#receipt .r-sep{text-align:center;font-size:10px;letter-spacing:.5px;margin:6px 0;color:#111}
#receipt .r-row{display:flex;justify-content:space-between;gap:6px;font-size:11px}
#receipt .r-row .r-name{flex:1}
#receipt .r-row .r-val{font-weight:700;white-space:nowrap}
#receipt .r-meta{font-size:10px;margin-bottom:2px}
#receipt .r-item{margin:4px 0}
#receipt .r-item .r-notes{font-size:10px;color:#555;margin-left:12px}
#receipt .r-total{font-weight:900;font-size:14px}
#receipt .r-footer{text-align:center;margin-top:10px;font-size:10px;color:#333}
#receipt .r-big{font-size:14px;font-weight:900;letter-spacing:1px}

@media print{
  @page{size:72mm auto;margin:0}
  body{background:#fff!important;overflow:visible!important;height:auto!important}
  body *{visibility:hidden!important}
  #receipt,#receipt *{visibility:visible!important}
  #receipt{position:absolute;left:0;top:0;width:72mm;padding:4mm 3mm;margin:0;border:0;box-shadow:none}
  .rcpt-bd,.rcpt-card,.rcpt-head,.rcpt-foot,.rcpt-scroll{background:transparent!important;border:0!important;padding:0!important;box-shadow:none!important;max-height:none!important;overflow:visible!important}
}

@media(max-width:1100px){.pos-main{grid-template-columns:1fr 380px}.menu-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}}
@media(max-width:860px){
  html,body{overflow:auto;height:auto}
  body{display:block}
  .pos-main{display:block}
  .menu-wrap,.check-wrap{overflow:visible}
  .menu-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .pos-top{flex-wrap:wrap;gap:8px;padding:10px 14px}
  .pos-clock{margin-left:0;order:99;font-size:11px}
  .mode-toggle{order:50}
  .waiter-bar{padding:10px 14px;gap:8px}
  .wb-field select,.wb-field input{min-width:0;width:100%}
  .wb-field{flex:1 1 calc(50% - 8px);min-width:120px}
}
@media(max-width:560px){.wb-field{flex:1 1 100%}.wb-badge{display:none}}

/* Live fired-item status badge: SENT (brass) → POURING/COOKING (amber, pulsing) → READY (green) */
.item-sent{color:#c9a24a;border-color:rgba(201,162,74,.5)}
.item-sent.cooking{color:#e8a73a;border-color:rgba(232,167,58,.65);animation:sentPulse 1.6s ease-in-out infinite}
.item-sent.ready{color:#34d27b;border-color:rgba(52,210,123,.65)}
/* READY badge is a tappable button for the waiter (pick up + complete); keep the badge look */
button.item-sent{background:rgba(52,210,123,.08);cursor:pointer;font-family:var(--brand-body-font)}
button.item-sent.ready:hover{background:rgba(52,210,123,.2)}
.item-sent.picked{color:var(--ink-dim,#9a958a);border-color:rgba(255,255,255,.18);background:transparent}
/* Dine-in / Takeout toggle above the fire button */
.otype-toggle{display:flex;gap:6px;margin:10px 0 8px}
.otype-toggle .ot-btn{flex:1;padding:9px 8px;border:1px solid var(--rule,rgba(184,149,76,.3));background:transparent;color:var(--ink-dim,#9a958a);border-radius:8px;font-family:inherit;font-size:.78rem;font-weight:700;letter-spacing:.04em;cursor:pointer;transition:all .15s}
.otype-toggle .ot-btn.active{background:rgba(184,149,76,.16);color:var(--accent-glow,#e8a73a);border-color:var(--accent,#b8954c)}
@keyframes sentPulse{0%,100%{opacity:1}50%{opacity:.5}}

/* Waiter → station message/change */
.ci-change{background:none;border:none;color:#e8a73a;font-size:15px;cursor:pointer;padding:2px 5px;line-height:1}
.ci-change:hover{transform:scale(1.15)}
.change-modal{position:fixed;inset:0;z-index:99999;background:rgba(10,8,6,.85);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}
.cm-panel{background:var(--surface,#1c1a17);border:1px solid var(--rule,rgba(184,149,76,.35));border-radius:16px;width:100%;max-width:460px;padding:20px}
.cm-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:14px}
.cm-head h3{margin:0;font-family:var(--brand-heading-font,'Cormorant Garamond',serif);font-style:italic;font-size:1.4rem;color:var(--ink,#e8dfd0);text-transform:capitalize}
.cm-head span{font-size:.78rem;color:var(--ink-dim,#c7b9a8)}
.cm-x{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);color:#fff;width:34px;height:34px;border-radius:9px;font-size:1.2rem;cursor:pointer;flex:none}
.cm-presets{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.cm-preset{background:rgba(255,255,255,.06);border:1px solid var(--rule,rgba(184,149,76,.3));color:var(--ink,#e8dfd0);border-radius:9px;padding:8px 12px;font-size:.8rem;cursor:pointer}
.cm-preset:hover{background:rgba(232,167,58,.18);color:#e8a73a}
.cm-text{width:100%;background:rgba(0,0,0,.3);border:1px solid var(--rule,rgba(184,149,76,.3));border-radius:10px;color:var(--ink,#e8dfd0);padding:10px;font-family:inherit;font-size:.95rem;resize:vertical;box-sizing:border-box}
.cm-actions{display:flex;gap:10px;margin-top:14px}
.cm-cancel-item{flex:1;background:rgba(204,79,72,.15);border:1px solid rgba(204,79,72,.5);color:#ff6b63;border-radius:11px;padding:13px;font-weight:700;font-size:.82rem;cursor:pointer}
.cm-send{flex:1.4;background:linear-gradient(180deg,#e8a73a,#b8954c);border:none;color:#1a1408;border-radius:11px;padding:13px;font-weight:800;font-size:.9rem;letter-spacing:.04em;cursor:pointer}
