:root{
  --bg:#f6f8ff;
  --card:#ffffff;
  --txt:#0f172a;
  --muted:#64748b;
  --pri:#2563eb;
  --pri2:#1d4ed8;
  --border:rgba(15,23,42,.10);
  --shadow:0 10px 30px rgba(2,6,23,.10);
  --shadow2:0 10px 22px rgba(2,6,23,.08);

  --ok:#16a34a;
  --warn:#f59e0b;
  --danger:#dc2626;
}

*{box-sizing:border-box;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial;}
body{
  margin:0;
  background:radial-gradient(1200px 600px at 20% 0%, #eef2ff 0%, var(--bg) 55%, #f8fafc 100%);
  color:var(--txt);
}

/* Layout base */
.wrap{max-width:1100px;margin:0 auto;padding:14px;}
.muted{color:var(--muted);} .small{font-size:.85rem;}
.mini{font-size:.9rem;}

.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px;
  padding:14px;
  box-shadow:var(--shadow);
}

.top{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;}
.actions{display:flex;gap:10px;flex-wrap:wrap;}

/* Botões */
.btn{
  background:var(--pri);
  border:0;
  color:#fff;
  padding:10px 12px;
  border-radius:14px;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  cursor:pointer;
  font-weight:800;
}
.btn:hover{background:var(--pri2);}
.btn.ghost{
  background:transparent;
  border:1px solid var(--border);
  color:var(--txt);
}
.btn.ghost:hover{background:rgba(37,99,235,.08);border-color:rgba(37,99,235,.25);}

/* Form */
.input{
  width:100%;
  padding:11px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--txt);
  outline:none;
  margin:6px 0 10px;
}
.input:focus{border-color:rgba(37,99,235,.45);box-shadow:0 0 0 4px rgba(37,99,235,.12);}

/* Grid */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
.tables-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));}
@media (min-width: 1200px){
  .tables-grid{grid-template-columns:repeat(5,1fr);}
}

@media(min-width:720px){.grid{grid-template-columns:repeat(5,1fr);} }

/* Notifications (toast + sound unlock banner) */
.toast{position:fixed;left:12px;right:12px;bottom:12px;z-index:50;display:flex;align-items:center;gap:10px;justify-content:space-between;padding:12px 12px;background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:0 18px 40px rgba(0,0,0,.18)}
.toast.hidden{display:none}
.toast #toastText{font-size:14px;line-height:1.2}

.sound-banner{position:fixed;left:12px;right:12px;top:12px;z-index:60;display:flex;align-items:center;gap:10px;justify-content:space-between;padding:10px 12px;background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:0 12px 30px rgba(0,0,0,.14)}
.sound-banner.hidden{display:none}

/* Badges */
.pill{
  padding:7px 12px;
  border-radius:999px;
  border:1px solid var(--border);
  font-size:.82rem;
  font-weight:900;
  color:var(--muted);
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:rgba(15,23,42,.03);
}
.pill.ok{color:var(--ok);background:rgba(22,163,74,.10);border-color:rgba(22,163,74,.22);}
.pill.busy{color:#9a3412;background:rgba(245,158,11,.14);border-color:rgba(245,158,11,.28);}
.pill.danger{color:#b91c1c;background:rgba(220,38,38,.12);border-color:rgba(220,38,38,.26);}

/* Linhas */
.itemline{display:flex;justify-content:space-between;gap:10px;padding:12px 0;border-bottom:1px solid rgba(15,23,42,.08);}
.kbd{border:1px solid var(--border);padding:5px 10px;border-radius:999px;background:rgba(2,6,23,.03);font-size:.85rem;color:var(--muted);}
hr{border:0;border-top:1px solid rgba(15,23,42,.08);margin:14px 0;}

/* ===== Garçom: lista de mesas ===== */
#tables.grid{grid-template-columns:repeat(2,minmax(0,1fr));}
@media(min-width:720px){#tables.grid{grid-template-columns:repeat(3,minmax(0,1fr));}}
@media(min-width:980px){#tables.grid{grid-template-columns:repeat(5,minmax(0,1fr));}}

.tablecard{
  border:1px solid var(--border);
  border-radius:20px;
  padding:16px 14px;
  /* tamanho fixo para alinhar todos os cards */
  height:178px;
  min-height:178px;
  cursor:pointer;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  box-shadow:var(--shadow2);
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease, filter .12s ease;
  position:relative;
  overflow:hidden;
}
.tablecard:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(2,6,23,.10);border-color:rgba(37,99,235,.22);}
.tablecard strong{font-size:1.06rem;font-weight:950;letter-spacing:-.2px;}
.tablecard .muted{display:flex;align-items:center;gap:10px;margin-top:8px;flex-wrap:wrap;}

.tablecard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:rgba(15,23,42,.12);}
.tablecard .dot{width:10px;height:10px;border-radius:999px;background:rgba(15,23,42,.18);box-shadow:0 0 0 4px rgba(2,6,23,.03);}

.tablecard.free{background:linear-gradient(180deg,#d1fae5 0%, #bbf7d0 60%, #86efac 100%);} 
.tablecard.free::before{background:rgba(22,163,74,.70);} 
.tablecard.free .dot{background:rgba(22,163,74,.90);box-shadow:0 0 0 4px rgba(22,163,74,.14);} 

.tablecard.occupied{background:linear-gradient(180deg,#fff7ed 0%, #ffedd5 50%, #fdba74 100%);} 
.tablecard.occupied::before{background:rgba(249,115,22,.88);} 
.tablecard.occupied .dot{background:rgba(249,115,22,.95);box-shadow:0 0 0 4px rgba(249,115,22,.18);} 

.tablecard.unavailable{background:linear-gradient(180deg,#fef2f2 0%, #fee2e2 100%);cursor:not-allowed;filter:saturate(.95);} 
.tablecard.unavailable::before{background:rgba(220,38,38,.85);} 
.tablecard.unavailable .dot{background:rgba(220,38,38,.92);box-shadow:0 0 0 4px rgba(220,38,38,.16);} 

.tablecard .meta{width:100%;margin-top:10px;font-size:.85rem;font-weight:800;max-height:54px;overflow:hidden;}
.tablecard .meta .line{display:flex;justify-content:space-between;gap:14px;}

/* Destaque quando existir item PRONTO para retirada */
.badge-ready{
  position:absolute;
  top:10px;
  right:10px;
  font-size:.82rem;
  font-weight:950;
  letter-spacing:-.1px;
  padding:7px 12px;
  border-radius:999px;
  color:#064e3b;
  background:linear-gradient(180deg, rgba(34,197,94,.28), rgba(34,197,94,.16));
  border:1px solid rgba(34,197,94,.42);
  box-shadow:0 12px 26px rgba(2,6,23,.12);
  display:inline-flex;
  align-items:center;
  gap:6px;
}

@keyframes pulseBadge{
  0%{transform:scale(1); box-shadow:0 12px 26px rgba(2,6,23,.12)}
  50%{transform:scale(1.03); box-shadow:0 18px 34px rgba(34,197,94,.22)}
  100%{transform:scale(1); box-shadow:0 12px 26px rgba(2,6,23,.12)}
}
.tablecard.ready .badge-ready{animation:pulseBadge 1.1s infinite;}


@keyframes blinkReady{
  0%{filter:brightness(1); transform:translateY(0); box-shadow:0 0 0 0 rgba(34,197,94,.34);}
  45%{filter:brightness(1.06); transform:translateY(-1px); box-shadow:0 0 0 12px rgba(34,197,94,0);}
  100%{filter:brightness(1); transform:translateY(0); box-shadow:0 0 0 0 rgba(34,197,94,0);}
}
.tablecard.ready{animation:blinkReady 1.2s infinite;}

/* ===== Garçom: tela da mesa ===== */
.two{display:grid;grid-template-columns:1fr;gap:14px;}
@media(min-width:720px){
  .two{grid-template-columns:1.35fr .65fr;align-items:start;}
  .two > .card:last-child{position:sticky;top:14px;}
}

.tabs{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0 12px;}
.tab{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.12);
  background:rgba(2,6,23,.03);
  cursor:pointer;
  font-weight:900;
}
.tab:hover{background:rgba(37,99,235,.08);border-color:rgba(37,99,235,.22);}
.tab.active{background:rgba(37,99,235,.10);border-color:rgba(37,99,235,.30);color:var(--pri);}

.prod{
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius:18px;
  padding:14px;
  box-shadow:var(--shadow2);
  cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
  min-height:98px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.prod:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(2,6,23,.10);border-color:rgba(37,99,235,.22);}
.prod strong{display:block;font-size:1rem;font-weight:950;line-height:1.15;}
.price{color:var(--txt);font-weight:900;margin-top:6px;}

/* Busca no topo (mesa) */
#q.input{max-width:320px;margin:0;}

#prods.grid{grid-template-columns:repeat(2,minmax(0,1fr));}
@media(min-width:720px){#prods.grid{grid-template-columns:repeat(3,minmax(0,1fr));}}
@media(min-width:1100px){#prods.grid{grid-template-columns:repeat(4,minmax(0,1fr));}}

.footerbar{background:linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(246,248,255,.75) 45%, rgba(246,248,255,.95) 100%);padding-top:10px;border-radius:16px;}
.footerbar .btn{box-shadow:0 10px 22px rgba(37,99,235,.18);}

/* ===== Admin ===== */
.kpi{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
@media(min-width:720px){.kpi{grid-template-columns:repeat(4,1fr);}}
.kpibox{padding:12px;border-radius:16px;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow2);}
.kpibox .v{font-size:1.25rem;font-weight:950;margin-top:6px;}

.menu-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:12px;}
@media(min-width:720px){.menu-grid{grid-template-columns:1fr 1fr;}}
.menucard{padding:14px;border-radius:18px;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow2);cursor:pointer;transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;}
.menucard:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(2,6,23,.10);border-color:rgba(37,99,235,.22);}
.menucard h3{margin:0 0 4px;font-size:1.05rem;}
.menucard .desc{color:var(--muted);font-size:.9rem;}

.row{display:grid;grid-template-columns:1fr;gap:10px;}
@media(min-width:720px){.row{grid-template-columns:1fr 1fr;}}

/* Impressão */
@media print{
  body{background:#fff;}
  .wrap{max-width:none;padding:0;}
  .btn,.actions,header,.top{display:none !important;}
  .card{box-shadow:none;border:0;padding:0;}
}

/* ===== Kanban (Bar/Cozinha) ===== */
.board{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:start}
@media (max-width:900px){.board{grid-template-columns:1fr;}}
.kcol{background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:0 8px 24px rgba(16,24,40,.06);overflow:hidden;min-height:240px}
.kcol .khead{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#ffffff, #fbfcff)}
.kcol .khead strong{font-size:14px}
.kcol .khead .count{font-size:12px;color:var(--muted);background:#f3f6ff;border:1px solid var(--border);padding:2px 8px;border-radius:999px}
.kbody{padding:10px;display:flex;flex-direction:column;gap:10px;min-height:160px}
.kdrop{outline:2px dashed rgba(47,123,255,.25);outline-offset:-6px;background:rgba(47,123,255,.04)}
.kcard{border:1px solid var(--border);border-radius:16px;background:#fff;box-shadow:0 6px 18px rgba(16,24,40,.06);padding:12px;cursor:grab}
.kcard:active{cursor:grabbing}
.kcard .kmeta{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.kcard .kmeta .title{font-weight:700}
.kcard .kmeta .sub{color:var(--muted);font-size:12px;margin-top:2px}
.kcard .kline{display:flex;align-items:center;gap:10px;margin-top:10px}
.kcard .kline .name{flex:1}
.kcard .kline .tag{font-size:12px;color:var(--muted);background:#f7f8fb;border:1px solid var(--border);padding:2px 8px;border-radius:999px}
.kcard .kactions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.kcard .kactions .btn{padding:8px 10px}
.khint{color:var(--muted);font-size:12px;padding:10px 12px}


/* Close table preview */
.kpirow{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}
.kpi{border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:10px;background:#fff}
.kval{font-weight:800}

.link{color:#2f7bff;text-decoration:underline}
.table th.r,.table td.r{text-align:right}
