/* ================================================================
   RAW COMANDA DIGITAL — Design System v4.0
   Profissional · Limpo · Restaurante/Bar
   ================================================================ */

/* ── Tokens ─────────────────────────────────────────────────────── */
:root {
  --brand:        #2563eb;
  --brand-d:      #1d4ed8;
  --brand-glow:   rgba(37,99,235,.14);
  --green:        #16a34a;
  --green-d:      #15803d;
  --green-glow:   rgba(22,163,74,.18);
  --amber:        #d97706;
  --red:          #dc2626;
  --cyan:         #0891b2;
  --online:       #059669;
  --online-glow:  rgba(5,150,105,.20);

  /* surfaces */
  --bg:           #f8fafc;
  --bg2:          #f1f5f9;
  --surface:      #ffffff;
  --surface2:     #f8fafc;
  --border:       #e2e8f0;
  --border2:      #cbd5e1;
  --text:         #0f172a;
  --text2:        #475569;
  --text3:        #94a3b8;

  --topbar-bg:    #ffffff;
  --nav-bg:       #ffffff;
  --input-bg:     #f8fafc;

  --shadow-xs:    0 1px 2px rgba(0,0,0,.06);
  --shadow-sm:    0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.05);
  --shadow:       0 4px 16px rgba(0,0,0,.08);
  --shadow-lg:    0 10px 40px rgba(0,0,0,.12);
  --shadow-xl:    0 20px 60px rgba(0,0,0,.16);

  --r-sm: 8px; --r: 14px; --r-lg: 20px; --r-xl: 28px;
  --font:   'Inter', system-ui, sans-serif;
  --mono:   'JetBrains Mono', 'Fira Code', monospace;
  --t: .16s cubic-bezier(.4,0,.2,1);
}

[data-theme="dark"] {
  --bg:        #090e1a;
  --bg2:       #0f172a;
  --surface:   #131f35;
  --surface2:  #0f172a;
  --border:    #1e293b;
  --border2:   #2d3f55;
  --text:      #f1f5f9;
  --text2:     #94a3b8;
  --text3:     #475569;
  --topbar-bg: #0a0f1e;
  --nav-bg:    #0a0f1e;
  --input-bg:  #0f172a;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.4);
  --shadow:    0 4px 16px rgba(0,0,0,.4);
  --shadow-lg: 0 10px 40px rgba(0,0,0,.55);
}

/* ── Reset ───────────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { height:100%; -webkit-text-size-adjust:100%; }
body { font-family:var(--font); background:var(--bg); color:var(--text); line-height:1.5; min-height:100%; -webkit-font-smoothing:antialiased; }
a { color:var(--brand); text-decoration:none; }
button { font-family:inherit; cursor:pointer; border:none; }
input,select,textarea { font-family:inherit; }
img { max-width:100%; display:block; }
::-webkit-scrollbar { width:4px; height:4px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border2); border-radius:99px; }

/* ── Shell ───────────────────────────────────────────────────────── */
.app { display:flex; flex-direction:column; height:100dvh; overflow:hidden; }
.app.hidden { display:none; }
.hidden { display:none !important; }

/* ── Topbar ──────────────────────────────────────────────────────── */
.topbar {
  display:flex; align-items:center; justify-content:space-between;
  padding:0 18px; height:56px; background:var(--topbar-bg);
  border-bottom:1px solid var(--border); box-shadow:var(--shadow-xs);
  flex-shrink:0; z-index:100; gap:12px;
}
.brand { display:flex; align-items:center; gap:10px; font-weight:800; font-size:.9rem; color:var(--text); white-space:nowrap; }
.mark {
  display:inline-flex; align-items:center; justify-content:center;
  width:32px; height:32px; background:var(--brand);
  color:#fff; font-weight:900; font-size:.72rem; border-radius:9px;
  letter-spacing:.5px; flex-shrink:0;
}
.actions { display:flex; align-items:center; gap:7px; }
.role-pill {
  background:var(--bg2); border:1px solid var(--border); color:var(--text2);
  font-size:.68rem; font-weight:700; padding:3px 9px; border-radius:99px;
  letter-spacing:.5px; text-transform:uppercase;
}
.icon-btn {
  display:inline-flex; align-items:center; justify-content:center;
  width:34px; height:34px; border-radius:9px; border:1px solid var(--border);
  background:var(--surface); color:var(--text2); font-size:.95rem; transition:var(--t);
}
.icon-btn:hover { background:var(--bg2); border-color:var(--border2); color:var(--text); }
.ic-sun { display:none; }
[data-theme="dark"] .ic-moon { display:none; }
[data-theme="dark"] .ic-sun  { display:block; }

/* ── View ────────────────────────────────────────────────────────── */
.view { flex:1; overflow-y:auto; padding:18px; scroll-behavior:smooth; max-width:1360px; margin:0 auto; width:100%; box-sizing:border-box; }

/* ── Bottom Nav ──────────────────────────────────────────────────── */
.bottom-nav {
  display:flex; background:var(--nav-bg); border-top:1px solid var(--border);
  box-shadow:0 -2px 12px rgba(0,0,0,.06); flex-shrink:0;
  padding:0 4px env(safe-area-inset-bottom,6px); z-index:100;
}
.nav-item {
  flex:1; display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:2px; padding:7px 4px; border:none; background:none;
  color:var(--text3); font-size:.6rem; font-weight:700; letter-spacing:.5px;
  text-transform:uppercase; border-radius:8px; transition:var(--t); cursor:pointer;
}
.nav-item .nav-icon { font-size:1.3rem; line-height:1; }
.nav-item.active { color:var(--brand); }
.nav-item.active .nav-icon { background:var(--brand-glow); border-radius:8px; padding:3px 10px; }
.nav-item:hover:not(.active) { color:var(--text2); }

/* ── Login ───────────────────────────────────────────────────────── */
.login-screen {
  min-height:100dvh; display:flex; align-items:center; justify-content:center;
  padding:24px; background:var(--bg);
}
.login-card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r-xl);
  padding:34px 28px; width:100%; max-width:400px; box-shadow:var(--shadow-xl);
  display:flex; flex-direction:column; gap:15px;
}
.login-card h1 { font-size:1.35rem; font-weight:800; }
.slogan { color:var(--text2); font-size:.85rem; margin-top:-8px; }
.admin-only-note {
  background:rgba(99,102,241,.07); border:1px solid rgba(99,102,241,.18);
  border-radius:var(--r-sm); padding:10px 13px; font-size:.79rem; color:var(--text2); line-height:1.5;
}
.role-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(76px,1fr)); gap:8px; }
.role-card {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:5px; padding:13px 8px; border:2px solid var(--border); background:var(--surface2);
  border-radius:var(--r); font-size:.7rem; font-weight:700; color:var(--text2);
  transition:var(--t); cursor:pointer; letter-spacing:.4px; text-transform:uppercase;
}
.role-card .role-icon { font-size:1.35rem; }
.role-card.active { border-color:var(--brand); background:rgba(99,102,241,.1); color:var(--brand); box-shadow:0 0 0 3px var(--brand-glow); }
.role-card:hover:not(.active) { border-color:var(--border2); background:var(--bg2); }

/* ── Inputs ──────────────────────────────────────────────────────── */
.field { display:flex; flex-direction:column; gap:5px; }
.field label { font-size:.78rem; font-weight:600; color:var(--text2); }
.input {
  width:100%; padding:9px 13px; background:var(--input-bg); border:1.5px solid var(--border);
  border-radius:var(--r-sm); color:var(--text); font-size:.88rem; transition:var(--t); outline:none;
}
.input:focus { border-color:var(--brand); box-shadow:0 0 0 3px var(--brand-glow); }
.input::placeholder { color:var(--text3); }
select.input { cursor:pointer; }
textarea.input { resize:vertical; min-height:72px; }

/* ── Buttons ─────────────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  padding:9px 17px; border-radius:var(--r-sm); border:none; font-size:.85rem;
  font-weight:700; transition:var(--t); cursor:pointer; white-space:nowrap;
  letter-spacing:.25px; line-height:1;
}
.btn.block { width:100%; }
.btn.lg { padding:12px 22px; font-size:.92rem; border-radius:var(--r); }
.btn.sm { padding:6px 12px; font-size:.76rem; }
.btn.xs { padding:3px 9px; font-size:.7rem; border-radius:6px; }

.btn.primary { background:var(--brand); color:#fff; }
.btn.primary:hover { background:var(--brand-d); }
.btn.primary:active { background:var(--brand-d); }

.btn.success { background:var(--green); color:#fff; }
.btn.success:hover { background:var(--green-d); }

.btn.danger { background:var(--red); color:#fff; }
.btn.danger:hover { background:#dc2626; }

.btn.ghost { background:var(--bg2); border:1.5px solid var(--border); color:var(--text2); }
.btn.ghost:hover { border-color:var(--border2); color:var(--text); }

.btn.outline { background:transparent; border:1.5px solid var(--brand); color:var(--brand); }
.btn.outline:hover { background:var(--brand-glow); }

.btn.amber-btn { background:var(--amber); color:#fff; }
.btn:disabled { opacity:.45; cursor:not-allowed; transform:none !important; }

/* ── Cards ───────────────────────────────────────────────────────── */
.card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r);
  padding:16px; box-shadow:var(--shadow-sm); transition:var(--t);
}
.card-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:13px; gap:10px; }
.card-title { font-size:.92rem; font-weight:700; }

/* ── Badges ──────────────────────────────────────────────────────── */
.badge {
  display:inline-flex; align-items:center; gap:3px; padding:2px 8px;
  border-radius:99px; font-size:.68rem; font-weight:700; letter-spacing:.4px; text-transform:uppercase;
}
.badge.green  { background:rgba(34,197,94,.14);  color:#15803d; }
.badge.amber  { background:rgba(245,158,11,.14);  color:#b45309; }
.badge.red    { background:rgba(239,68,68,.14);   color:#b91c1c; }
.badge.blue   { background:rgba(59,130,246,.14);  color:#1d4ed8; }
.badge.purple { background:rgba(99,102,241,.14);  color:#6366f1; }
.badge.gray   { background:var(--bg2);            color:var(--text2); }
.badge.cyan   { background:rgba(6,182,212,.14);   color:#0e7490; }

/* ONLINE badge */
.badge.online {
  background:var(--online);
  color:#fff;
}

/* ── Mesas ───────────────────────────────────────────────────────── */
.mesas-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:10px; }
.mesa-card {
  background:var(--surface); border:2px solid var(--border); border-radius:var(--r);
  padding:16px 12px 12px; display:flex; flex-direction:column; align-items:center;
  gap:7px; cursor:pointer; transition:var(--t); text-align:center;
  box-shadow:var(--shadow-sm); position:relative; overflow:hidden;
}
.mesa-card:hover { transform:translateY(-2px); box-shadow:var(--shadow); }
.mesa-card.livre { border-color:var(--green); }
.mesa-card.livre::before { content:''; position:absolute; inset:0; background:rgba(34,197,94,.04); }
.mesa-card.ocupada { border-color:var(--amber); }
.mesa-card.ocupada::before { content:''; position:absolute; inset:0; background:rgba(245,158,11,.04); }
.mesa-card.fechamento_pendente { border-color:var(--cyan); }
.mesa-card.conta_encerrada { border-color:var(--text3); opacity:.55; }
.mesa-card.offline { opacity:.45; cursor:not-allowed; }
.mesa-icon { font-size:1.9rem; }
.mesa-nome { font-size:.78rem; font-weight:700; }
.mesa-total { font-family:var(--mono); font-size:.76rem; font-weight:700; color:var(--green); }
.mesa-dot {
  width:8px; height:8px; border-radius:50%;
  position:absolute; top:9px; right:9px;
}
.mesa-card.livre .mesa-dot { background:var(--green); box-shadow:0 0 6px var(--green); }
.mesa-card.ocupada .mesa-dot { background:var(--amber); }
.mesa-card.fechamento_pendente .mesa-dot { background:var(--cyan); }

/* ── Produtos ────────────────────────────────────────────────────── */
.produto-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(155px,1fr)); gap:9px; }
.produto-card {
  background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r);
  padding:13px; cursor:pointer; transition:var(--t); display:flex; flex-direction:column; gap:4px;
}
.produto-card:hover { border-color:var(--brand); transform:translateY(-1px); box-shadow:var(--shadow); }
.produto-card .pnome { font-size:.83rem; font-weight:700; }
.produto-card .pdesc { font-size:.7rem; color:var(--text2); line-height:1.4; }
.produto-card .pprice { font-family:var(--mono); font-size:.88rem; font-weight:800; color:var(--green); margin-top:5px; }
.produto-card.indisponivel { opacity:.4; cursor:not-allowed; }

/* Itens comanda */
.item-list { display:flex; flex-direction:column; gap:5px; }
.item-row {
  display:flex; align-items:center; gap:9px; padding:9px 13px;
  background:var(--bg2); border-radius:var(--r-sm); font-size:.83rem;
}
.item-nome { flex:1; font-weight:600; }
.item-qtd { font-family:var(--mono); font-size:.76rem; color:var(--text2); }
.item-valor { font-family:var(--mono); font-weight:700; }
.item-dot { width:7px; height:7px; border-radius:50%; display:inline-block; margin-right:3px; }
.status-recebido  .item-dot { background:var(--amber); }
.status-preparo   .item-dot { background:var(--cyan); }
.status-pronto    .item-dot { background:var(--green); }
.status-entregue  .item-dot { background:var(--text3); }
.status-cancelado .item-dot { background:var(--red); }

/* Totais */
.totais {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r);
  padding:14px; display:flex; flex-direction:column; gap:7px; margin-top:10px;
}
.total-row { display:flex; justify-content:space-between; font-size:.85rem; color:var(--text2); }
.total-row.final { font-size:1rem; font-weight:800; color:var(--text); border-top:1px solid var(--border); padding-top:7px; }
.total-row .val { font-family:var(--mono); }

/* ── Cozinha Kanban ──────────────────────────────────────────────── */
.kanban { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; height:100%; }
.kanban-col { background:var(--bg2); border-radius:var(--r); border:1px solid var(--border); display:flex; flex-direction:column; overflow:hidden; }
.kanban-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:11px 13px; font-size:.76rem; font-weight:800; text-transform:uppercase;
  letter-spacing:.6px; border-bottom:2px solid;
}
.kanban-head.recebido { border-color:var(--amber); color:var(--amber); background:rgba(245,158,11,.07); }
.kanban-head.preparo  { border-color:var(--cyan);  color:var(--cyan);  background:rgba(6,182,212,.07); }
.kanban-head.pronto   { border-color:var(--green); color:var(--green); background:rgba(34,197,94,.07); }
.kanban-body { flex:1; overflow-y:auto; padding:8px; display:flex; flex-direction:column; gap:7px; }

/* Pedido card + online variant */
.pedido-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-sm); padding:11px; transition:var(--t);
}
.pedido-card:hover { box-shadow:var(--shadow); }
.pedido-card.online-order {
  border-color:var(--online) !important;
  box-shadow:0 0 0 1.5px var(--online),0 4px 14px var(--online-glow) !important;
}
.online-food-badge {
  display:inline-flex; align-items:center; gap:3px;
  background:linear-gradient(135deg,#10b981,#059669);
  color:#fff; font-size:.6rem; font-weight:800; padding:2px 7px;
  border-radius:99px; letter-spacing:.3px; text-transform:uppercase;
  box-shadow:0 0 8px var(--online-glow),0 0 18px rgba(16,185,129,.2);
  animation:online-pulse 2s ease-in-out infinite;
}
.pedido-mesa { font-size:.7rem; font-weight:700; color:var(--text2); text-transform:uppercase; letter-spacing:.4px; }
.pedido-nome { font-size:.88rem; font-weight:700; margin:2px 0; }
.pedido-obs  { font-size:.74rem; color:var(--text2); font-style:italic; }
.pedido-time { font-size:.68rem; color:var(--text3); font-family:var(--mono); }
.pedido-actions { display:flex; gap:5px; margin-top:7px; }

/* ── Tabs ────────────────────────────────────────────────────────── */
.tabs {
  display:flex; gap:3px; background:var(--bg2); border-radius:var(--r-sm);
  padding:3px; margin-bottom:14px; border:1px solid var(--border);
}
.tab-btn {
  flex:1; padding:8px; border-radius:7px; border:none; background:none;
  font-size:.76rem; font-weight:700; color:var(--text2); cursor:pointer; transition:var(--t);
}
.tab-btn.active { background:var(--surface); color:var(--text); box-shadow:var(--shadow-sm); }

/* ── Stat cards ──────────────────────────────────────────────────── */
.stats-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:10px; margin-bottom:14px; }
.stat-card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r);
  padding:13px; display:flex; flex-direction:column; gap:4px;
}
.stat-label { font-size:.68rem; font-weight:700; color:var(--text2); text-transform:uppercase; letter-spacing:.5px; }
.stat-value { font-size:1.25rem; font-weight:800; font-family:var(--mono); color:var(--text); }
.stat-value.g { color:var(--green); }
.stat-value.a { color:var(--amber); }
.stat-value.r { color:var(--red); }
.stat-value.b { color:var(--brand); }
.stat-value.o { color:var(--online); }

/* ── Modals ──────────────────────────────────────────────────────── */
.overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.52); backdrop-filter:blur(5px);
  display:none; align-items:flex-end; justify-content:center; z-index:1000; padding:12px;
}
@media(min-width:600px) { .overlay { align-items:center; } }
.overlay.active { display:flex; }
.modal {
  background:var(--surface); border-radius:var(--r-xl) var(--r-xl) var(--r) var(--r);
  padding:22px; width:100%; max-width:460px; max-height:90dvh; overflow-y:auto;
  display:flex; flex-direction:column; gap:13px;
  box-shadow:var(--shadow-xl); border:1px solid var(--border);
}
@media(min-width:600px) { .modal { border-radius:var(--r-xl); } }
.modal-handle { width:34px; height:4px; background:var(--border2); border-radius:99px; margin:0 auto -4px; }
@media(min-width:600px) { .modal-handle { display:none; } }
.modal h3 { font-size:1.05rem; font-weight:800; }
.modal-actions { display:flex; gap:8px; padding-top:3px; }
.modal-actions .btn { flex:1; }

/* Qty control */
.qty-control { display:flex; align-items:center; border:1.5px solid var(--border); border-radius:var(--r-sm); overflow:hidden; width:fit-content; }
.qty-control button { width:38px; height:38px; border:none; background:var(--bg2); font-size:1.1rem; font-weight:700; color:var(--text); cursor:pointer; transition:var(--t); }
.qty-control button:hover { background:var(--border2); }
.qty-val { min-width:44px; text-align:center; font-family:var(--mono); font-size:.95rem; font-weight:700; padding:0 6px; }

/* ── Dashboard ───────────────────────────────────────────────────── */
.ranking-bar { display:flex; align-items:center; gap:9px; margin-bottom:7px; font-size:.8rem; }
.rbar-track { flex:1; height:5px; background:var(--bg2); border-radius:99px; overflow:hidden; }
.rbar-fill { height:100%; background:linear-gradient(90deg,var(--brand),var(--brand-d)); border-radius:99px; transition:width .6s ease; }
.rbar-qtd { font-family:var(--mono); font-size:.73rem; color:var(--text2); min-width:26px; text-align:right; }

/* ── Tables ──────────────────────────────────────────────────────── */
.table-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; }
table { width:100%; border-collapse:collapse; font-size:.82rem; }
thead th {
  text-align:left; padding:9px 13px; background:var(--bg2); color:var(--text2);
  font-size:.7rem; font-weight:800; letter-spacing:.5px; text-transform:uppercase;
  border-bottom:1px solid var(--border); white-space:nowrap;
}
tbody tr { border-bottom:1px solid var(--border); transition:var(--t); }
tbody tr:hover { background:var(--bg2); }
tbody td { padding:9px 13px; vertical-align:middle; }
tbody tr:last-child { border-bottom:none; }

/* ── Toast ───────────────────────────────────────────────────────── */
.toast-wrap {
  position:fixed; bottom:76px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column-reverse; gap:7px; z-index:9999;
  pointer-events:none; min-width:220px; max-width:calc(100vw - 28px);
}
.toast {
  background:var(--text); color:var(--bg); border-radius:var(--r-sm);
  padding:9px 15px; font-size:.82rem; font-weight:600; box-shadow:var(--shadow-lg);
  animation:toast-in .22s ease; pointer-events:all; border-left:4px solid var(--brand);
}
.toast.warn  { border-color:var(--amber); }
.toast.error { border-color:var(--red); }
.toast.ok    { border-color:var(--green); }
@keyframes toast-in { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:none} }

/* ── Page header ─────────────────────────────────────────────────── */
.page-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; gap:12px; flex-wrap:wrap; }
.page-title { font-size:1.15rem; font-weight:800; }
.section-title {
  font-size:.75rem; font-weight:800; text-transform:uppercase; letter-spacing:.6px;
  color:var(--text2); margin-bottom:9px; display:flex; align-items:center; gap:8px;
}
.section-title::after { content:''; flex:1; height:1px; background:var(--border); }

/* ── Financeiro ──────────────────────────────────────────────────── */
.fin-tabs {
  display:flex; gap:0; border-bottom:2px solid var(--border); margin-bottom:18px;
  overflow-x:auto; scrollbar-width:none;
}
.fin-tabs::-webkit-scrollbar { display:none; }
.fin-tab {
  padding:9px 15px; border:none; background:none; font-size:.8rem; font-weight:700;
  color:var(--text2); cursor:pointer; white-space:nowrap; border-bottom:2px solid transparent;
  margin-bottom:-2px; transition:var(--t); display:flex; align-items:center; gap:5px;
}
.fin-tab.active { color:var(--brand); border-bottom-color:var(--brand); }
.fin-tab:hover:not(.active) { color:var(--text); }

.fin-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-sm); margin-bottom:14px; }
.fin-card-head { padding:13px 17px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; gap:10px; background:var(--bg2); }
.fin-card-body { padding:16px; }

.summary-row { display:grid; grid-template-columns:repeat(auto-fill,minmax(155px,1fr)); gap:11px; margin-bottom:18px; }
.summary-card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r);
  padding:15px; display:flex; flex-direction:column; gap:5px;
}
.summary-icon { font-size:1.35rem; }
.summary-label { font-size:.68rem; font-weight:700; color:var(--text2); text-transform:uppercase; letter-spacing:.5px; }
.summary-value { font-size:1.3rem; font-weight:800; font-family:var(--mono); }
.summary-card.s-green { border-color:rgba(34,197,94,.3); }
.summary-card.s-green .summary-value { color:var(--green); }
.summary-card.s-red   { border-color:rgba(239,68,68,.3); }
.summary-card.s-red   .summary-value { color:var(--red); }
.summary-card.s-amber { border-color:rgba(245,158,11,.3); }
.summary-card.s-amber .summary-value { color:var(--amber); }
.summary-card.s-blue  { border-color:rgba(99,102,241,.3); }
.summary-card.s-blue  .summary-value { color:var(--brand); }
.summary-card.s-online { border-color:rgba(16,185,129,.3); }
.summary-card.s-online .summary-value { color:var(--online); }

.filter-bar { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:13px; }
.filter-bar .input { flex:1; min-width:130px; }

/* Gráfico barras */
.chart-wrap { display:flex; align-items:flex-end; gap:5px; height:110px; margin-top:12px; }
.chart-col { display:flex; flex-direction:column; align-items:center; gap:3px; flex:1; }
.chart-bar { width:100%; border-radius:5px 5px 0 0; background:linear-gradient(180deg,var(--brand),var(--brand-d)); min-height:2px; transition:height .4s ease; cursor:pointer; }
.chart-bar.bar-online { background:linear-gradient(180deg,var(--online),#059669); }
.chart-label { font-size:.62rem; color:var(--text3); font-weight:600; }
.chart-val   { font-size:.6rem; font-family:var(--mono); color:var(--text2); }
.chart-legend { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:10px; }
.legend-item { display:flex; align-items:center; gap:5px; font-size:.76rem; font-weight:600; color:var(--text2); }
.legend-dot  { width:9px; height:9px; border-radius:3px; }

/* Contas */
.conta-row { display:flex; align-items:center; gap:9px; padding:9px 14px; border-bottom:1px solid var(--border); font-size:.82rem; }
.conta-row:last-child { border-bottom:none; }
.conta-desc { flex:1; font-weight:600; }
.conta-venc { color:var(--text2); font-size:.76rem; }
.conta-val  { font-family:var(--mono); font-weight:700; }
.conta-val.pagar   { color:var(--red); }
.conta-val.receber { color:var(--green); }

/* Estoque */
.estoque-badge { display:inline-flex; align-items:center; gap:3px; padding:2px 7px; border-radius:99px; font-size:.68rem; font-weight:700; }
.est-ok   { background:rgba(34,197,94,.12);  color:#15803d; }
.est-low  { background:rgba(245,158,11,.12); color:#b45309; }
.est-zero { background:rgba(239,68,68,.12);  color:#b91c1c; }

/* NFe */
.nfe-badge {
  display:inline-flex; align-items:center; gap:3px;
  background:linear-gradient(135deg,#1d4ed8,#1e40af); color:#fff;
  font-size:.68rem; font-weight:800; padding:3px 9px; border-radius:99px;
  letter-spacing:.3px; cursor:pointer; transition:var(--t);
}
.nfe-badge:hover { transform:scale(1.04); box-shadow:0 4px 10px rgba(29,78,216,.3); }

/* ── Online order page ───────────────────────────────────────────── */
.online-hero {
  background:linear-gradient(135deg,#0a0f1e 0%,#1a1040 50%,#0a0f1e 100%);
  padding:28px 18px 22px; text-align:center; position:relative; overflow:hidden;
}
.online-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 65% 30%,rgba(99,102,241,.22) 0%,transparent 65%); }
.online-hero-inner { position:relative; z-index:1; }
.online-hero h1 { color:#fff; font-size:clamp(1.3rem,5vw,1.9rem); margin-bottom:5px; }
.online-hero p  { color:rgba(255,255,255,.6); font-size:.87rem; }
.est-badge {
  display:inline-flex; align-items:center; gap:5px;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.14);
  color:#fff; font-size:.76rem; font-weight:700; padding:4px 11px;
  border-radius:99px; margin-bottom:11px;
}
.status-open { display:inline-flex; align-items:center; gap:5px; background:rgba(16,185,129,.15); color:#10b981; padding:3px 11px; border-radius:99px; font-size:.73rem; font-weight:700; margin-top:9px; }
.status-open::before { content:''; width:6px; height:6px; background:#10b981; border-radius:50%; box-shadow:0 0 6px #10b981; animation:blink 1.5s infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }

/* Online nav */
.online-nav {
  background:var(--surface); border-bottom:1px solid var(--border);
  display:flex; position:sticky; top:0; z-index:200; box-shadow:var(--shadow-sm);
}
.online-nav-item {
  flex:1; display:flex; flex-direction:column; align-items:center; padding:9px 4px;
  border:none; background:none; font-size:.6rem; font-weight:700; color:var(--text3);
  letter-spacing:.5px; text-transform:uppercase; cursor:pointer; transition:var(--t); gap:2px;
}
.online-nav-item .ico { font-size:1.25rem; }
.online-nav-item.active { color:var(--brand); }
.online-nav-item.active .ico { background:var(--brand-glow); padding:3px 10px; border-radius:8px; }

/* Category pills */
.cat-pills { display:flex; gap:7px; overflow-x:auto; padding-bottom:3px; margin-bottom:14px; scrollbar-width:none; }
.cat-pills::-webkit-scrollbar { display:none; }
.cat-pill {
  display:inline-flex; align-items:center; gap:4px; padding:6px 13px;
  border-radius:99px; border:1.5px solid var(--border); background:var(--surface);
  font-size:.78rem; font-weight:700; color:var(--text2); cursor:pointer;
  white-space:nowrap; transition:var(--t); flex-shrink:0;
}
.cat-pill.active { background:var(--brand); border-color:var(--brand); color:#fff; box-shadow:0 4px 10px var(--brand-glow); }

/* Online produto card */
.online-produto {
  display:flex; align-items:center; gap:13px; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--r); padding:13px;
  margin-bottom:9px; cursor:pointer; transition:var(--t);
}
.online-produto:hover { border-color:var(--brand); box-shadow:var(--shadow); transform:translateX(2px); }
.online-produto-img {
  width:68px; height:68px; border-radius:var(--r-sm); background:var(--bg2);
  display:flex; align-items:center; justify-content:center; font-size:1.9rem; flex-shrink:0;
}
.online-produto-nome  { font-size:.92rem; font-weight:700; margin-bottom:3px; }
.online-produto-desc  { font-size:.76rem; color:var(--text2); line-height:1.4; margin-bottom:5px; }
.online-produto-preco { font-family:var(--mono); font-size:.92rem; font-weight:800; color:var(--green); }
.online-produto-add {
  width:32px; height:32px; border-radius:50%; background:var(--brand); color:#fff;
  border:none; font-size:1.05rem; display:flex; align-items:center; justify-content:center;
  flex-shrink:0; box-shadow:0 4px 10px var(--brand-glow); transition:var(--t);
}
.online-produto-add:hover { transform:scale(1.1); }

/* Cart */
.cart-sticky {
  position:sticky; bottom:16px; background:var(--surface); border:2px solid var(--brand);
  border-radius:var(--r-lg); padding:13px 16px; display:flex; align-items:center;
  justify-content:space-between; box-shadow:0 8px 28px var(--brand-glow);
  cursor:pointer; transition:var(--t); z-index:200; gap:11px; margin-top:10px;
}
.cart-sticky:hover { transform:translateY(-2px); box-shadow:0 12px 36px var(--brand-glow); }
.cart-count { background:var(--brand); color:#fff; width:24px; height:24px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:.72rem; font-weight:800; }
.cart-label { font-size:.88rem; font-weight:700; flex:1; }
.cart-total { font-family:var(--mono); font-weight:800; font-size:.98rem; color:var(--green); }

.cart-item {
  display:flex; align-items:center; gap:11px; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--r-sm); padding:11px;
}
.cart-item-info { flex:1; }
.cart-item-name { font-size:.86rem; font-weight:700; }
.cart-item-price { font-family:var(--mono); font-size:.78rem; color:var(--green); }
.qty-mini { width:26px; height:26px; border:1.5px solid var(--border); background:var(--bg2); border-radius:6px; font-size:.88rem; font-weight:700; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:var(--t); }
.qty-mini:hover { background:var(--border2); }
.qty-mini-val { font-family:var(--mono); font-weight:700; font-size:.86rem; min-width:18px; text-align:center; }

/* Delivery opts */
.delivery-opts { display:grid; grid-template-columns:repeat(auto-fit,minmax(96px,1fr)); gap:8px; margin-bottom:13px; }
.delivery-opt {
  padding:13px 10px; border:2px solid var(--border); border-radius:var(--r);
  cursor:pointer; text-align:center; transition:var(--t); background:var(--surface2);
}
.delivery-opt.selected { border-color:var(--brand); background:rgba(99,102,241,.08); }
.delivery-opt .dico   { font-size:1.75rem; margin-bottom:4px; }
.delivery-opt .dtitle { font-size:.8rem; font-weight:700; }
.delivery-opt .dtime  { font-size:.7rem; color:var(--text2); }
.mesa-picker-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(60px,1fr)); gap:8px; }
.mesa-pick-btn {
  background:var(--surface2); border:2px solid var(--border); border-radius:var(--r-sm);
  padding:9px 4px; text-align:center; cursor:pointer; transition:var(--t);
}
.mesa-pick-btn:hover { border-color:var(--border2); }
.mesa-pick-btn.selected { border-color:var(--brand); background:rgba(99,102,241,.08); color:var(--brand); }
.mesa-pick-btn .mp-num { font-family:var(--mono); font-weight:800; font-size:1.05rem; }
.mesa-pick-btn .mp-label { font-size:.66rem; color:var(--text2); text-transform:uppercase; letter-spacing:.4px; }
.mesa-pick-btn.selected .mp-label { color:var(--brand); }
.mesa-pick-empty { font-size:.84rem; color:var(--text2); padding:10px 2px; grid-column:1/-1; }

/* Payment */
.pay-opts, .pay-options { display:grid; grid-template-columns:repeat(2,1fr); gap:7px; }
.pay-opt {
  padding:11px 8px; border:2px solid var(--border); border-radius:var(--r-sm);
  background:var(--surface2); cursor:pointer; text-align:center; transition:var(--t);
  font-size:.8rem; font-weight:700; display:flex; flex-direction:column; align-items:center; gap:3px;
}
.pay-opt .pico { font-size:1.35rem; }
.pay-opt.selected { border-color:var(--brand); background:rgba(99,102,241,.08); color:var(--brand); }

/* Order confirmed */
.pedido-ok {
  background:linear-gradient(135deg,rgba(16,185,129,.1),rgba(5,150,105,.05));
  border:2px solid rgba(16,185,129,.35); border-radius:var(--r-lg);
  padding:28px 20px; text-align:center; display:flex; flex-direction:column;
  align-items:center; gap:12px; margin:14px 0;
}
.check-circle {
  width:68px; height:68px; border-radius:50%;
  background:linear-gradient(135deg,#10b981,#059669);
  display:flex; align-items:center; justify-content:center; font-size:1.9rem; color:#fff;
  box-shadow:0 8px 24px rgba(16,185,129,.38);
  animation:pop-in .38s cubic-bezier(.34,1.56,.64,1);
}
@keyframes pop-in { from{transform:scale(0)} to{transform:scale(1)} }
.pedido-num { font-family:var(--mono); font-size:1.35rem; font-weight:800; color:var(--online); }

/* Tracking */
.tracking { display:flex; align-items:center; gap:0; margin:14px 0; background:var(--bg2); border-radius:99px; overflow:hidden; border:1px solid var(--border); }
.tracking-step { flex:1; padding:9px 4px; text-align:center; font-size:.66rem; font-weight:700; color:var(--text3); letter-spacing:.3px; text-transform:uppercase; transition:var(--t); }
.tracking-step.done   { background:var(--green); color:#fff; }
.tracking-step.active { background:var(--amber);  color:#fff; }

/* Profile */
.profile-avatar { width:68px; height:68px; border-radius:50%; background:linear-gradient(135deg,var(--brand),var(--brand-d)); display:flex; align-items:center; justify-content:center; font-size:1.7rem; color:#fff; font-weight:800; box-shadow:0 6px 18px var(--brand-glow); }
.order-history-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r); padding:13px; margin-bottom:9px; transition:var(--t); }
.order-history-card:hover { box-shadow:var(--shadow); }
.order-num  { font-family:var(--mono); font-size:.76rem; font-weight:700; color:var(--text2); }
.order-date { font-size:.73rem; color:var(--text3); }
.order-items{ font-size:.8rem; color:var(--text2); line-height:1.6; }
.order-total{ font-family:var(--mono); font-size:.92rem; font-weight:800; color:var(--green); margin-top:5px; }

/* Auth tabs */
.auth-tabs { display:flex; gap:4px; background:var(--bg2); border-radius:var(--r-sm); padding:3px; border:1px solid var(--border); margin-bottom:4px; }
.auth-tab { flex:1; padding:7px; border-radius:7px; border:none; background:none; font-size:.78rem; font-weight:700; color:var(--text2); cursor:pointer; transition:var(--t); text-align:center; }
.auth-tab.active { background:var(--surface); color:var(--text); box-shadow:var(--shadow-sm); }

/* Address */
.addr-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r); padding:13px; display:flex; align-items:flex-start; gap:11px; }
.addr-icon { font-size:1.4rem; flex-shrink:0; }

/* ── Hub ─────────────────────────────────────────────────────────── */
.hub-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(155px,1fr)); gap:11px; }
.hub-card {
  background:var(--surface); border:2px solid var(--border); border-radius:var(--r-lg);
  padding:20px 13px; display:flex; flex-direction:column; align-items:center;
  gap:9px; cursor:pointer; text-decoration:none; transition:var(--t); text-align:center;
}
.hub-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-lg); }
.hub-card.h-garcom:hover   { border-color:var(--brand); }
.hub-card.h-cozinha:hover  { border-color:var(--amber); }
.hub-card.h-caixa:hover    { border-color:var(--green); }
.hub-card.h-dono:hover     { border-color:var(--cyan); }
.hub-card.h-fin:hover      { border-color:var(--online); }
.hub-card.h-online:hover   { border-color:var(--online); }
.hub-card.h-master:hover   { border-color:var(--red); }
.hub-card.h-fin   { border-color:rgba(16,185,129,.35); background:rgba(16,185,129,.04); }
.hub-card.h-online{ border-color:rgba(16,185,129,.25); background:rgba(16,185,129,.03); }
.hub-ico   { font-size:2.4rem; line-height:1; }
.hub-title { font-size:.86rem; font-weight:800; color:var(--text); }
.hub-desc  { font-size:.7rem; color:var(--text2); line-height:1.4; }
.new-tag   { background:linear-gradient(135deg,#10b981,#059669); color:#fff; font-size:.58rem; font-weight:800; padding:2px 7px; border-radius:99px; letter-spacing:.3px; }

/* ── Misc utils ──────────────────────────────────────────────────── */
.divider { height:1px; background:var(--border); margin:13px 0; }
.empty-state { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:44px 20px; color:var(--text3); text-align:center; gap:9px; }
.empty-icon  { font-size:2.4rem; opacity:.45; }
.empty-label { font-size:.86rem; font-weight:600; }
.flex   { display:flex; }
.flex-1 { flex:1; }
.gap-8  { gap:8px; }
.gap-12 { gap:12px; }
.mt-8   { margin-top:8px; }
.mt-12  { margin-top:12px; }
.mt-16  { margin-top:16px; }
.mb-8   { margin-bottom:8px; }
.mb-12  { margin-bottom:12px; }
.mb-16  { margin-bottom:16px; }
.text-right  { text-align:right; }
.text-center { text-align:center; }
.text-sm  { font-size:.78rem; }
.text-xs  { font-size:.7rem; }
.text-mono{ font-family:var(--mono); }
.text-muted { color:var(--text2); }
.font-bold  { font-weight:700; }
.w-full { width:100%; }
.red { color:var(--red); }
.green { color:var(--green); }

@media(max-width:600px) {
  .view { padding:13px; }
  .kanban { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .summary-row { grid-template-columns:repeat(2,1fr); }
  .login-card { padding:22px 18px; }
  .mesas-grid { grid-template-columns:repeat(auto-fill,minmax(105px,1fr)); }
}

/* ================================================================
   COMPAT — Classes do app.js (sistema antigo)
   Necessário para garcom/cozinha/caixa/dono funcionarem com o
   novo CSS sem reescrever o app.js inteiro.
   ================================================================ */

/* Portal / Hub do Dono */
.portal-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
  margin-top: 16px;
}
.portal-card {
  background: var(--surface);
  border: 2px solid var(--border);
  border-radius: var(--r-lg);
  padding: 20px 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  transition: var(--t);
  text-align: center;
  font-family: var(--font);
  text-decoration: none;
  color: var(--text);
}
.portal-card:hover {
  border-color: var(--brand);
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}
.portal-ico { font-size: 2rem; line-height: 1; }
.portal-card strong { font-size: .9rem; font-weight: 700; }
.portal-card small { font-size: .72rem; color: var(--text2); line-height: 1.4; }

/* Hero sections */
.hero-operacao {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.hero-operacao h1 { font-size: clamp(1.4rem, 4vw, 2rem); font-weight: 800; margin-bottom: 4px; }
.hero-operacao p { font-size: .85rem; color: var(--text2); max-width: 520px; }
.garcom-hero, .caixa-hero { /* mesmo estilo */ }
.eyebrow { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .7px; color: var(--text2); margin-bottom: 4px; }

/* Quick stats */
.quick-stats {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.quick-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 10px 16px;
  min-width: 80px;
  text-align: center;
  font-size: .72rem;
  color: var(--text2);
  font-weight: 700;
}
.quick-stat strong { font-size: 1.2rem; color: var(--text); font-family: var(--mono); font-weight: 800; }
.quick-stat.livre strong { color: var(--green); }
.quick-stat.ocupada strong { color: var(--amber); }
.quick-stat.total strong { color: var(--brand); }

/* Toolbar */
.toolbar-2026 {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.fab-search, .search-modern {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  padding: 0 12px;
  flex: 1;
  min-width: 180px;
}
.fab-search .ic, .search-modern .ic { font-size: 1rem; color: var(--text3); flex-shrink: 0; }
.fab-search .input, .search-modern .input { border: none; background: transparent; box-shadow: none; padding-left: 0; }
.fab-search .input:focus, .search-modern .input:focus { box-shadow: none; border: none; }

/* Mesa cards */
.mesas-grid, .mesas-grid-2026 {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 10px;
}
.mesa-card-2026 {
  background: var(--surface);
  border: 2px solid var(--border);
  border-radius: var(--r);
  padding: 14px 10px 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  transition: var(--t);
  text-align: center;
  box-shadow: var(--shadow-sm);
  position: relative;
}
.mesa-card-2026:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.mesa-card-2026.livre  { border-color: var(--green); }
.mesa-card-2026.ocupada{ border-color: var(--amber); }
.mesa-card-2026.reservada { border-color: var(--brand); }
.mesa-card-2026.fechamento_pendente { border-color: var(--cyan); }
.mesa-card-2026.conta_encerrada { opacity: .5; }
.mesa-emoji { font-size: 1.7rem; }
.mesa-topline { font-size: .7rem; font-weight: 700; text-transform: uppercase; color: var(--text2); }
.mesa-main-number { font-size: 1.4rem; font-weight: 800; font-family: var(--mono); }
.mesa-name { font-size: .78rem; font-weight: 600; }
.mesa-footerline { font-size: .72rem; color: var(--text2); }
.dot {
  width: 9px; height: 9px; border-radius: 50%;
  position: absolute; top: 9px; right: 9px;
  display: inline-block;
}
.mesa-card-2026.livre  .dot { background: var(--green); box-shadow: 0 0 6px var(--green); }
.mesa-card-2026.ocupada .dot { background: var(--amber); }
.mesa-card-2026.reservada .dot { background: var(--brand); box-shadow: 0 0 6px var(--brand); }
.mesa-card-2026.fechamento_pendente .dot { background: var(--cyan); }
.quick-stat.reservada strong { color: var(--brand); }

/* Secoes */
.section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
  gap: 12px;
}
.section-head h2 { font-size: clamp(1.1rem, 3vw, 1.5rem); font-weight: 800; }
.section-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.compact-actions { gap: 6px; }
.back-row { margin-bottom: 14px; }
.btn-big { padding: 12px 22px; font-size: .95rem; border-radius: var(--r); }

/* Comanda */
.comanda-header { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.comanda-meta { font-size: .82rem; color: var(--text2); }
.comanda-total { font-family: var(--mono); font-weight: 800; color: var(--green); }
.carrinho { display: flex; flex-direction: column; gap: 6px; }
.carrinho-item {
  display: flex; align-items: center; gap: 10px; padding: 10px 13px;
  background: var(--bg2); border-radius: var(--r-sm); font-size: .83rem;
}
.carrinho-totais {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r);
  padding: 13px; display: flex; flex-direction: column; gap: 7px; margin-top: 10px;
}
.cart-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 36px 20px; gap: 10px; color: var(--text3); text-align: center; }

/* Produto */
.produto-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 9px; }
.produto-card {
  background: var(--surface); border: 1.5px solid var(--border); border-radius: var(--r);
  padding: 12px; cursor: pointer; transition: var(--t); display: flex; flex-direction: column; gap: 4px;
}
.produto-card:hover { border-color: var(--brand); transform: translateY(-1px); box-shadow: var(--shadow); }
.pname { font-size: .83rem; font-weight: 700; }
.pdesc { font-size: .7rem; color: var(--text2); }
.pprice { font-family: var(--mono); font-size: .88rem; font-weight: 800; color: var(--green); margin-top: 4px; }
.cat-chip {
  display: inline-flex; align-items: center; gap: 4px; padding: 5px 11px;
  border-radius: 99px; border: 1.5px solid var(--border); background: var(--surface);
  font-size: .76rem; font-weight: 700; color: var(--text2); cursor: pointer; white-space: nowrap; transition: var(--t);
}
.cat-chip.active { background: var(--brand); border-color: var(--brand); color: #fff; }
.cat-scroll { display: flex; gap: 7px; overflow-x: auto; padding-bottom: 3px; margin-bottom: 13px; scrollbar-width: none; }
.cat-scroll::-webkit-scrollbar { display: none; }

/* Cozinha kanban */
.kitchen-board { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; height: 100%; }
.kitchen-col { background: var(--bg2); border-radius: var(--r); border: 1px solid var(--border); display: flex; flex-direction: column; overflow: hidden; }
.kitchen-col > .section-head { padding: 11px 13px; margin: 0; border-bottom: 2px solid; }
.kitchen-col.recebido > .section-head { border-color: var(--amber); }
.kitchen-col.preparo  > .section-head { border-color: var(--cyan); }
.kitchen-col.pronto   > .section-head { border-color: var(--green); }
.t-item {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-sm);
  padding: 11px; margin: 4px; transition: var(--t);
}
.t-item:hover { box-shadow: var(--shadow); }
.t-item.online-order { border-color: var(--online) !important; box-shadow: 0 0 0 1.5px var(--online), 0 4px 14px var(--online-glow) !important; }
.t-mesa { font-size: .7rem; font-weight: 700; color: var(--text2); text-transform: uppercase; letter-spacing: .4px; }
.t-head { font-size: .88rem; font-weight: 700; margin: 2px 0; }
.t-obs  { font-size: .74rem; color: var(--text2); font-style: italic; }
.t-time { font-size: .68rem; color: var(--text3); font-family: var(--mono); }
.t-actions { display: flex; gap: 5px; margin-top: 7px; }
.live-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); display: inline-block; box-shadow: 0 0 6px var(--green); animation: blink 1.5s infinite; }

/* Caixa */
.caixa-grid, .caixa-grid-2026 { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 12px; }
.caixa-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); gap: 10px; align-items: start; }
.caixa-stats { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 9px; margin-bottom: 14px; }
.kpi-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 9px; }
.kpi { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); padding: 12px; }
.kpi-label { font-size: .68rem; font-weight: 700; color: var(--text2); text-transform: uppercase; letter-spacing: .5px; }
.kpi-value { font-size: 1.2rem; font-weight: 800; font-family: var(--mono); }
.kpi-sub { font-size: .72rem; color: var(--text3); }
.mesa-row-2026 {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r);
  padding: 13px 14px; display: flex; align-items: center; justify-content: space-between;
  gap: 10px; box-shadow: var(--shadow-sm); transition: var(--t);
}
.mesa-row-2026:hover { box-shadow: var(--shadow); border-color: var(--border2); }
.mr-info { flex: 1; display: flex; align-items: center; gap: 11px; min-width: 0; }
.mr-num {
  flex-shrink: 0; width: 34px; height: 34px; border-radius: 10px; background: var(--bg2);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--mono); font-weight: 800; font-size: .85rem; color: var(--text2);
}
.mr-info > div:last-child { min-width: 0; }
.mr-meta { font-size: .82rem; }
.mr-value { font-family: var(--mono); font-weight: 700; }
.ticket { font-family: var(--mono); font-size: .8rem; }

/* Form layouts */
.form-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); padding: 16px; }
.form-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; }
.mini-form { display: flex; flex-direction: column; gap: 11px; }
.field-hint { font-size: .72rem; color: var(--text3); margin-top: 2px; }

/* Tabela produtos */
.prod-table { width: 100%; border-collapse: collapse; }
.prod-table th { text-align: left; padding: 9px 13px; background: var(--bg2); color: var(--text2); font-size: .7rem; font-weight: 800; border-bottom: 1px solid var(--border); }
.prod-table td { padding: 9px 13px; border-bottom: 1px solid var(--border); font-size: .83rem; }

/* Dashboard / reports */
.ranking { display: flex; flex-direction: column; gap: 8px; }
.rk-top { font-size: .82rem; font-weight: 600; }
.rk-bar-bg { width: 100%; height: 5px; background: var(--bg2); border-radius: 99px; margin-top: 4px; overflow: hidden; }
.rk-bar { height: 100%; background: linear-gradient(90deg, var(--brand), var(--brand-d)); border-radius: 99px; }
.rk-pos { font-size: .7rem; color: var(--text3); text-align: right; }
.report-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); padding: 16px; margin-bottom: 12px; }
.link-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 10px; }
.quick-links { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }

/* Horários */
.horarios-list { display: flex; flex-direction: column; gap: 8px; }
.horario-row { display: flex; align-items: center; gap: 10px; padding: 10px 13px; background: var(--bg2); border-radius: var(--r-sm); font-size: .83rem; }
.hr-fechado, .hr-abre, .hr-fecha { font-size: .8rem; }

/* Perfil */
.profile-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; }
.status, .tag, .label { font-size: .75rem; }
.check { color: var(--green); font-weight: 700; }
.ci-name, .ci-price, .ci-obs, .ci-status, .ci-info { font-size: .82rem; }
.value { font-family: var(--mono); font-weight: 700; }
.num { font-family: var(--mono); }
.meta { font-size: .8rem; color: var(--text2); }
.row { display: flex; align-items: center; gap: 10px; }

/* Permissões */
.permissoes-grid { display: flex; flex-direction: column; gap: 8px; }
.perm-check { display: flex; align-items: center; gap: 8px; font-size: .83rem; }
.usr-perm { font-size: .72rem; color: var(--text2); }

/* Tabs */
.tabs-row {
  display: flex; gap: 2px; background: var(--bg2); border-radius: var(--r-sm);
  padding: 3px; margin-bottom: 13px; border: 1px solid var(--border);
}
.module-switch-btn {
  padding: 7px 13px; border-radius: 7px; border: 1.5px solid var(--border);
  background: var(--surface2); font-size: .76rem; font-weight: 700;
  color: var(--text2); cursor: pointer; transition: var(--t);
}
.module-switch-btn:hover, .module-switch-btn.active { border-color: var(--brand); color: var(--brand); background: var(--brand-glow); }

/* Status colors */
.ativo   { color: var(--green); }
.inativo { color: var(--red); }
.livre   .dot { background: var(--green); }
.ocupada .dot { background: var(--amber); }
.pendente .dot { background: var(--cyan); }
.recebido .dot { background: var(--amber); }
.preparo  .dot { background: var(--cyan); }
.pronto   .dot { background: var(--green); }

/* Utilitários */
.sm { font-size: .8rem !important; padding: 6px 11px !important; }
.danger { background: var(--red) !important; color: #fff !important; }
.success { background: linear-gradient(135deg,var(--green),var(--green-d)) !important; color: #fff !important; }
.ghost { background: var(--bg2) !important; border: 1.5px solid var(--border) !important; color: var(--text2) !important; }
.primary { background: linear-gradient(135deg,var(--brand),var(--brand-d)) !important; color: #fff !important; }
.block { width: 100% !important; }

/* Online order badge em kanban */
.online-food-badge {
  display: inline-flex; align-items: center; gap: 3px;
  background: linear-gradient(135deg,#10b981,#059669); color: #fff;
  font-size: .6rem; font-weight: 800; padding: 2px 7px; border-radius: 99px;
  box-shadow: 0 0 8px var(--online-glow); animation: online-pulse 2s ease-in-out infinite;
}

@media (max-width: 700px) {
  .kitchen-board { grid-template-columns: 1fr; }
  .portal-grid { grid-template-columns: repeat(2, 1fr); }
  .hero-operacao { flex-direction: column; }
  .toolbar-2026 { flex-wrap: wrap; }
}


/* ================================================================
   Correção geral 2026 — layout compacto, menu e tabelas responsivas
   ================================================================ */
.bottom-nav{overflow-x:auto;gap:4px;padding:6px 6px calc(6px + env(safe-area-inset-bottom));}
.bottom-nav .nav-item{min-width:76px;flex:1 0 76px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:7px 6px;background:transparent;border:0;color:var(--text3);font-size:.62rem;font-weight:800;text-transform:uppercase;border-radius:10px;}
.bottom-nav .nav-item.active{color:var(--brand);background:rgba(99,102,241,.10);}
.bottom-nav .nav-icon{font-size:1.12rem;line-height:1;}
.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap;}
.section-head h2{font-size:clamp(1.15rem,3vw,1.6rem);line-height:1.15;}
.portal-grid,.quick-stats,.summary-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;}
.portal-card{min-height:118px;padding:16px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);box-shadow:var(--shadow-sm);text-align:left;color:var(--text);display:flex;flex-direction:column;gap:5px;justify-content:center;}
.portal-card strong{font-size:1rem;color:var(--text);}.portal-card small{color:var(--text2);line-height:1.35}.portal-ico{font-size:1.9rem;}
.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;} table{width:100%;border-collapse:collapse;min-width:720px;} th,td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle;} th{text-align:left;color:var(--text2);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;}
.fin-tabs,.filter-bar,.cat-pills{display:flex;gap:8px;overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;}.fin-tab{flex:0 0 auto;}
.card,.fin-card{max-width:100%;}.view{padding:clamp(12px,2vw,18px);}
@media(max-width:720px){.topbar{height:auto;min-height:56px;padding:10px 12px;align-items:flex-start}.brand{white-space:normal}.actions{flex-wrap:wrap;justify-content:flex-end}.role-pill{display:none}.portal-grid,.quick-stats,.summary-row,.caixa-grid,.caixa-grid-2026{grid-template-columns:1fr}.login-card{padding:24px 18px}.modal{width:calc(100vw - 20px);}.nfe-grid2{grid-template-columns:1fr!important}.filter-bar{align-items:stretch}.filter-bar .input,.filter-bar .btn{min-width:140px}}

/* ================================================================
   Correções finais — sessões por setor + layout Dono/Master
   ================================================================ */
body[data-owner-page="1"] .view,
body[data-master-page="1"] .view{max-width:1180px;padding:24px 18px 92px;}

.owner-hero,.master-hero{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  border:1px solid var(--border);border-radius:22px;padding:22px;
  background:linear-gradient(135deg,rgba(99,102,241,.12),rgba(255,255,255,.92));
  box-shadow:var(--shadow-sm);margin-bottom:16px;
}
[data-theme="dark"] .owner-hero,[data-theme="dark"] .master-hero{background:linear-gradient(135deg,rgba(99,102,241,.22),rgba(15,23,42,.88));}
.owner-hero h2,.master-hero h2{font-size:clamp(1.45rem,3vw,2rem);margin:3px 0 5px;line-height:1.1;}
.owner-hero p,.master-hero p{color:var(--text2);font-size:.92rem;}
.owner-kpis,.master-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px;}
.owner-modules,.master-panel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px;}
.owner-module-card,.master-panel-card{
  border:1px solid var(--border);background:var(--surface);border-radius:18px;padding:18px;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:flex-start;gap:8px;
  color:var(--text);text-align:left;cursor:pointer;transition:var(--t);min-height:138px;
}
.owner-module-card:hover,.master-panel-card:hover{transform:translateY(-2px);border-color:var(--brand);box-shadow:var(--shadow);}
.owner-module-card span,.master-panel-card span{font-size:2rem;line-height:1;}
.owner-module-card strong,.master-panel-card strong{font-size:1.05rem;}
.owner-module-card small,.master-panel-card small{color:var(--text2);line-height:1.35;}
.master-panel-card.passive{cursor:default;}
.master-panel-card.passive:hover{transform:none;border-color:var(--border);box-shadow:var(--shadow-sm);}
.master-kpi{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:16px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-sm);}
.master-kpi span{font-size:1.7rem}.master-kpi small{color:var(--text2);font-weight:800;text-transform:uppercase;font-size:.68rem;letter-spacing:.05em}.master-kpi strong{font-size:1.45rem;font-family:var(--mono);}

.profile-grid-dono{grid-template-columns:minmax(320px,420px) minmax(460px,1fr);align-items:start;gap:16px;}
.dono-form-card{padding:20px;border-radius:18px;}
.dono-form-card h3{font-size:1.15rem;margin-bottom:12px;}
.dono-form-card .field{margin-bottom:10px;}
.horarios-card{overflow:hidden;}
.horario-row{display:grid;grid-template-columns:96px 108px 1fr 1fr;align-items:center;gap:10px;width:100%;}
.horario-row .check{color:var(--text2);font-weight:800;display:flex;align-items:center;gap:6px;}
.horario-row .input{min-width:0;text-align:center;}
.check input{accent-color:var(--brand);}

@media(max-width:900px){
  .owner-hero,.master-hero{flex-direction:column;align-items:flex-start;}
  .owner-kpis,.master-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .profile-grid-dono{grid-template-columns:1fr;}
  .horario-row{grid-template-columns:1fr 1fr;}
  .horario-row strong{grid-column:1/-1;}
}
@media(max-width:560px){
  body[data-owner-page="1"] .view,body[data-master-page="1"] .view{padding:14px 12px 90px;}
  .owner-kpis,.master-kpi-grid{grid-template-columns:1fr;}
  .owner-modules,.master-panel-grid{grid-template-columns:1fr;}
  .horario-row{grid-template-columns:1fr;}
  .horario-row .input{text-align:left;}
}

/* ===== Correção visual Master/Dono - pacote sessão final ===== */
body[data-master-page="1"]{
  background:
    radial-gradient(circle at 12% 0%, rgba(250,173,32,.22), transparent 32%),
    radial-gradient(circle at 86% 10%, rgba(99,102,241,.18), transparent 30%),
    linear-gradient(180deg,#0b1220 0%,#111827 45%,#f8fafc 45%,#f8fafc 100%);
}
[data-theme="dark"] body[data-master-page="1"]{background:#0b1220;}
body[data-master-page="1"] .topbar{box-shadow:0 10px 30px rgba(15,23,42,.10);}
body[data-master-page="1"] .view{max-width:1220px;padding-top:28px;}
.master-hero{
  color:#fff;border:1px solid rgba(255,255,255,.16)!important;
  background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(255,255,255,.04))!important;
  box-shadow:0 24px 60px rgba(0,0,0,.28)!important;
  backdrop-filter: blur(12px);
}
.master-hero .eyebrow,.master-hero p{color:rgba(255,255,255,.78)!important;}
.master-hero h2{color:#fff!important;}
.master-kpi-grid{margin-top:16px;}
.master-kpi{
  min-height:112px;border:0!important;border-radius:22px!important;
  background:linear-gradient(180deg,#fff,#f8fafc)!important;
  box-shadow:0 18px 40px rgba(15,23,42,.14)!important;
}
.master-kpi strong{font-size:1.75rem!important;color:#0f172a;}
.master-panel-grid{margin-top:18px;}
.master-panel-card{
  min-height:150px;border-radius:24px!important;border:1px solid rgba(148,163,184,.28)!important;
  background:#fff!important;box-shadow:0 18px 42px rgba(15,23,42,.10)!important;
}
.master-panel-card span{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:#fff7ed;border:1px solid #fed7aa;}
.master-panel-card:hover{transform:translateY(-4px)!important;box-shadow:0 24px 56px rgba(15,23,42,.16)!important;}
body[data-master-page="1"] .bottom-nav{box-shadow:0 -10px 30px rgba(15,23,42,.08);}

body[data-owner-page="1"]{
  background:linear-gradient(180deg,#f8fafc 0%,#eef2ff 100%);
}
body[data-owner-page="1"] .view{max-width:1280px;}
body[data-owner-page="1"] .portal-grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;}
body[data-owner-page="1"] .portal-card{
  min-height:142px;border-radius:22px;border:1px solid rgba(148,163,184,.30);
  box-shadow:0 14px 34px rgba(15,23,42,.08);background:#fff;
}
body[data-owner-page="1"] .portal-card:hover{transform:translateY(-3px);box-shadow:0 20px 44px rgba(15,23,42,.12);}
body[data-owner-page="1"] .bottom-nav.hidden{display:none!important;}
@media(max-width:760px){body[data-owner-page="1"] .portal-grid{grid-template-columns:1fr 1fr;} .master-kpi-grid{grid-template-columns:1fr 1fr!important;}}


/* ================================================================
   Fix 2026-06-17 — Master mais profissional + reset de sessão dono
   ================================================================ */
body[data-master-page="1"]{background:linear-gradient(180deg,#f7f9fd 0%,#eef3fb 100%);} 
body[data-master-page="1"] .view{max-width:1280px;}
.master-shell{display:flex;flex-direction:column;gap:16px;}
.master-hero-pro{background:linear-gradient(135deg,#111827 0%,#1f2937 48%,#f59e0b 170%);color:#fff;border:0;padding:26px 28px;box-shadow:0 22px 55px rgba(15,23,42,.22);}
.master-hero-pro .eyebrow,.master-hero-pro p{color:rgba(255,255,255,.78);} 
.master-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;}
.master-actions .btn.ghost{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.22);color:#fff;}
.master-kpi-pro{grid-template-columns:repeat(4,minmax(0,1fr));}
.master-kpi-pro .master-kpi{border:0;background:#fff;box-shadow:0 14px 32px rgba(15,23,42,.08);position:relative;overflow:hidden;}
.master-kpi-pro .master-kpi:after{content:"";position:absolute;right:-28px;top:-28px;width:82px;height:82px;border-radius:50%;background:rgba(99,102,241,.10);} 
.master-kpi em{font-style:normal;color:var(--text2);font-size:.78rem;}
.master-two-col{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr);gap:16px;align-items:start;}
.master-card-large{background:var(--surface);border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow-sm);padding:18px;}
.section-head.compact{margin-bottom:12px;}
.section-head.compact h3{margin:0;font-size:1.18rem;}
.compact-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
.master-client-list{display:flex;flex-direction:column;gap:10px;}
.master-client-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--border);border-radius:14px;background:var(--bg-soft);} 
.master-client-row strong{display:block;line-height:1.2;}.master-client-row small{display:block;color:var(--text2);font-size:.78rem;margin-top:3px;}
body[data-master-page="1"] .bottom-nav{box-shadow:0 -10px 32px rgba(15,23,42,.08);} 
@media(max-width:900px){.master-two-col{grid-template-columns:1fr}.compact-grid,.master-kpi-pro{grid-template-columns:repeat(2,minmax(0,1fr));}.master-hero-pro{align-items:flex-start}.master-actions{justify-content:flex-start}}
@media(max-width:620px){.compact-grid,.master-kpi-pro{grid-template-columns:1fr}.master-hero-pro{padding:20px}.master-actions .btn{width:100%;}}


/* Fix 6 — dashboard dono e master */
.admin-dashboard-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;padding:22px 24px;margin-bottom:16px;border:1px solid var(--border);border-radius:24px;background:linear-gradient(135deg,rgba(99,102,241,.12),rgba(255,255,255,.92));box-shadow:var(--shadow)}
.admin-dashboard-hero h2{font-size:clamp(1.45rem,2.4vw,2.25rem);margin:2px 0 6px}.admin-dashboard-hero p{color:var(--text2);margin:0}.dash-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.dashboard-kpis .kpi{display:flex;gap:12px;align-items:center;min-height:112px}.kpi-icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:rgba(99,102,241,.12);font-size:1.35rem}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(280px,.8fr);gap:16px}.dash-card{padding:18px}.section-head.compact{margin-bottom:10px}.quick-actions{display:flex;flex-direction:column;gap:10px}.quick-actions .section-head{width:100%}
body[data-master-page="1"] .app{background:radial-gradient(circle at 25% 0%,rgba(255,171,36,.20),transparent 28%),linear-gradient(180deg,#101826 0%,#0b111a 100%)}
body[data-master-page="1"] .view{max-width:1180px;margin:0 auto;padding-top:30px}body[data-master-page="1"] .section-head h2,body[data-master-page="1"] .eyebrow{color:#fff}body[data-master-page="1"] .card,body[data-master-page="1"] .kpi{border-radius:22px}.back-owner-floating{position:fixed;right:18px;bottom:92px;z-index:60}
@media(max-width:760px){.admin-dashboard-hero{flex-direction:column;padding:18px}.dashboard-grid{grid-template-columns:1fr}.dash-actions{justify-content:flex-start}.back-owner-floating{right:12px;bottom:84px}}

/* ===== Planejamento SaaS: landing, planos e módulos ===== */
.owner-home-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;background:linear-gradient(135deg,#ffffff,#eef2ff);border:1px solid var(--border);border-radius:24px;padding:24px;margin-bottom:18px;box-shadow:var(--shadow)}
.owner-home-hero h2{font-size:clamp(1.7rem,3vw,2.6rem);margin:4px 0 8px}.owner-home-hero p{color:var(--text2)}
.owner-plan-box{min-width:180px;background:#fff;border:1px solid var(--border);border-radius:20px;padding:16px;box-shadow:var(--shadow-sm)}.owner-plan-box small,.owner-plan-box span{display:block;color:var(--text2)}.owner-plan-box strong{display:block;font-size:1.25rem;margin:4px 0;color:var(--brand)}
.master-form-card{padding:18px;margin-bottom:18px}.modules-plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-top:10px}.module-check{display:grid;grid-template-columns:auto 1fr;gap:8px;align-items:start;border:1px solid var(--border);border-radius:16px;background:#fff;padding:12px;cursor:pointer;box-shadow:var(--shadow-sm)}.module-check:hover{border-color:var(--brand)}.module-check input{margin-top:6px}.module-check span{font-size:1.5rem}.module-check strong{display:block}.module-check small{display:block;color:var(--text2);line-height:1.35;grid-column:2}
@media(max-width:700px){.owner-home-hero{flex-direction:column}.owner-plan-box{width:100%}.modules-plan-grid{grid-template-columns:1fr}}

/* ================================================================
   LANDING LOVABLE PORTADA PARA HTML/CSS/JS
   Mantida dentro da arquitetura do projeto, sem React/Tailwind.
   ================================================================ */
:root{
  --lv-bg:#130f24;
  --lv-foreground:#fbfbff;
  --lv-card:rgba(35,29,58,.66);
  --lv-card-solid:#241e3a;
  --lv-muted:#b9b4ca;
  --lv-border:rgba(255,255,255,.11);
  --lv-primary:#9b5cff;
  --lv-primary-2:#635bff;
  --lv-accent:#47e5d7;
  --lv-danger:#ff5c7c;
  --lv-gradient:linear-gradient(135deg,#9b5cff 0%,#635bff 54%,#47e5d7 100%);
  --lv-hero-bg:radial-gradient(circle at 18% 8%,rgba(155,92,255,.35),transparent 42%),radial-gradient(circle at 85% 18%,rgba(99,91,255,.30),transparent 44%),radial-gradient(circle at 50% 95%,rgba(71,229,215,.18),transparent 52%),#130f24;
  --lv-shadow-glow:0 20px 60px -10px rgba(155,92,255,.45);
  --lv-shadow-soft:0 18px 50px -12px rgba(0,0,0,.60);
  --lv-radius:28px;
}
body.lovable-landing-page{
  margin:0;
  min-height:100dvh;
  font-family:'Sora',system-ui,-apple-system,'Segoe UI',sans-serif;
  color:var(--lv-foreground);
  background:var(--lv-hero-bg);
  background-attachment:fixed;
  overflow-x:hidden;
}
body.lovable-landing-page *,body.lovable-landing-page *:before,body.lovable-landing-page *:after{box-sizing:border-box}
body.lovable-landing-page a{color:inherit;text-decoration:none}
.lv-container,.lv-nav{width:min(1220px,calc(100% - 40px));margin-inline:auto}
.lv-nav{display:flex;align-items:center;justify-content:space-between;gap:22px;padding:28px 0 0}
.lv-brand{display:flex;align-items:center;gap:13px;color:var(--lv-foreground)}
.lv-brand-mark{display:grid;place-items:center;width:44px;height:44px;border-radius:18px;background:var(--lv-gradient);box-shadow:var(--lv-shadow-glow);font-weight:900;color:#fff;font-size:20px}
.lv-brand strong{display:block;font-size:16px;letter-spacing:-.03em}.lv-brand span{display:block;font-size:11px;color:var(--lv-muted);font-weight:600;line-height:1.15}
.lv-nav-links{display:flex;align-items:center;gap:30px;font-size:14px;font-weight:650;color:var(--lv-muted)}.lv-nav-links a:hover{color:#fff}
.lv-nav-actions{display:flex;align-items:center;gap:10px}
.lv-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:14px;padding:12px 18px;font-size:14px;font-weight:800;line-height:1;border:1px solid var(--lv-border);transition:.2s ease;white-space:nowrap}
.lv-btn:hover{transform:translateY(-2px)}.lv-btn-lg{padding:15px 24px;border-radius:18px}.lv-btn-primary{background:var(--lv-gradient);border-color:transparent;color:#fff;box-shadow:var(--lv-shadow-glow)}.lv-btn-ghost{background:rgba(255,255,255,.06);color:rgba(255,255,255,.9);backdrop-filter:blur(14px)}.lv-btn-ghost:hover{background:rgba(255,255,255,.11)}
.lv-hero{position:relative;display:grid;grid-template-columns:minmax(0,1.1fr) minmax(360px,.9fr);gap:52px;align-items:center;padding-top:90px}
.lv-eyebrow{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--lv-border);background:rgba(255,255,255,.06);border-radius:999px;padding:8px 13px;font-size:12px;font-weight:800;color:var(--lv-muted);backdrop-filter:blur(16px)}.lv-eyebrow span{width:7px;height:7px;border-radius:50%;background:var(--lv-accent);box-shadow:0 0 18px rgba(71,229,215,.7)}
.lv-hero h1{margin:24px 0 0;max-width:760px;font-size:clamp(3rem,7vw,7rem);line-height:1.01;letter-spacing:-.075em;font-weight:900}.lv-hero h1 em,.lv-access-card h1 em{font-style:normal;background:var(--lv-gradient);-webkit-background-clip:text;background-clip:text;color:transparent}
.lv-hero p{margin:24px 0 0;max-width:610px;color:var(--lv-muted);font-size:18px;line-height:1.8}.lv-hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}.lv-trust{display:flex;gap:10px;flex-wrap:wrap;margin-top:34px}.lv-trust span{border:1px solid var(--lv-border);background:rgba(255,255,255,.05);border-radius:999px;color:var(--lv-muted);font-size:12px;font-weight:800;padding:8px 13px}
.lv-preview-wrap{position:relative}.lv-preview-glow{position:absolute;inset:-26px;border-radius:44px;background:var(--lv-gradient);filter:blur(42px);opacity:.35;z-index:-1}.lv-glass{background:var(--lv-card);border:1px solid var(--lv-border);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:var(--lv-shadow-soft)}.lv-preview-card{border-radius:32px;padding:20px}.lv-browser-bar{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--lv-border);padding-bottom:16px}.lv-browser-bar div{display:flex;gap:8px}.lv-browser-bar span{display:block;width:12px;height:12px;border-radius:99px;background:rgba(255,92,124,.7)}.lv-browser-bar span:nth-child(2){background:rgba(245,158,11,.8)}.lv-browser-bar span:nth-child(3){background:rgba(34,197,94,.8)}.lv-browser-bar small{color:var(--lv-muted);font-weight:700}.lv-kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding-top:20px}.lv-kpi{border:1px solid var(--lv-border);background:rgba(19,15,36,.42);border-radius:20px;padding:16px}.lv-kpi small{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--lv-muted);font-weight:800}.lv-kpi strong{display:block;font-size:27px;letter-spacing:-.05em;margin-top:4px}.lv-kpi span{display:block;color:var(--lv-accent);font-size:12px;font-weight:800;margin-top:2px}.lv-kanban-card{margin-top:16px;border:1px solid var(--lv-border);background:rgba(19,15,36,.42);border-radius:20px;padding:17px}.lv-kanban-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.lv-kanban-head span{background:rgba(71,229,215,.15);color:var(--lv-accent);border-radius:999px;padding:4px 8px;font-size:10px;font-weight:900}.lv-order{display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid var(--lv-border);padding:12px 0}.lv-order:first-of-type{border-top:0}.lv-order small{display:block;color:var(--lv-muted);margin-top:2px}.lv-order b{color:var(--lv-accent);font-size:12px;white-space:nowrap}
.lv-section{margin-top:132px}.lv-section-title{max-width:680px}.lv-section-title small{display:block;color:var(--lv-accent);font-size:12px;text-transform:uppercase;letter-spacing:.22em;font-weight:900}.lv-section-title h2{margin:12px 0 0;font-size:clamp(2.2rem,4vw,3.55rem);line-height:1.05;letter-spacing:-.06em;font-weight:900}.lv-section-title p{color:var(--lv-muted);margin:14px 0 0;line-height:1.65}.lv-feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:40px}.lv-feature{border-radius:30px;padding:26px;transition:.22s ease}.lv-feature:hover{transform:translateY(-5px);box-shadow:var(--lv-shadow-glow)}.lv-feature span,.lv-modules-grid span,.lv-sector-grid span{display:grid;place-items:center;width:50px;height:50px;border-radius:18px;background:var(--lv-gradient);box-shadow:var(--lv-shadow-glow);font-size:23px}.lv-feature h3{font-size:18px;margin:20px 0 8px;letter-spacing:-.03em}.lv-feature p{margin:0;color:var(--lv-muted);font-size:14px;line-height:1.7}
.lv-plans{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-top:40px}.lv-plan{position:relative;border-radius:30px;padding:30px}.lv-plan-popular{position:relative;border-radius:30px;padding:30px;background:var(--lv-gradient);color:#fff;box-shadow:var(--lv-shadow-glow);transform:translateY(-16px)}.lv-popular-badge{position:absolute;top:-13px;right:24px;background:#fff;color:#130f24;border-radius:999px;padding:7px 12px;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.lv-plan h3{margin:0;font-size:22px;letter-spacing:-.04em}.lv-plan p{margin:8px 0 0;color:var(--lv-muted);font-size:14px;min-height:44px;line-height:1.6}.lv-plan-popular p{color:rgba(255,255,255,.82)}.lv-price{display:flex;align-items:flex-end;gap:5px;margin-top:26px}.lv-price strong{font-size:50px;line-height:.92;letter-spacing:-.07em}.lv-price small{color:var(--lv-muted);font-weight:800;margin-bottom:8px}.lv-plan-popular .lv-price small{color:rgba(255,255,255,.78)}.lv-plan ul{list-style:none;padding:0;margin:28px 0 0;display:grid;gap:12px;font-size:14px}.lv-plan li{display:flex;align-items:flex-start;gap:10px}.lv-plan li:before{content:'✓';display:grid;place-items:center;flex:0 0 20px;width:20px;height:20px;border-radius:50%;background:rgba(71,229,215,.16);color:var(--lv-accent);font-weight:900;font-size:12px}.lv-plan-popular li:before{background:rgba(255,255,255,.22);color:#fff}.lv-plan>a{display:block;margin-top:30px;text-align:center;border:1px solid var(--lv-border);border-radius:18px;padding:14px;font-size:14px;font-weight:900;background:rgba(255,255,255,.06)}.lv-plan-popular>a{background:#fff;color:#130f24;border-color:#fff}
.lv-modules-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:40px}.lv-modules-grid strong,.lv-sector-grid strong{display:block}.lv-modules-grid small,.lv-sector-grid small{display:block;color:var(--lv-muted);font-size:12px;margin-top:3px}.lv-modules-grid b,.lv-sector-grid b{margin-left:auto;color:var(--lv-muted);font-size:20px;transition:.2s}
.lv-final-cta{margin-top:132px;display:flex;align-items:center;justify-content:space-between;gap:24px;border:1px solid var(--lv-border);border-radius:36px;padding:54px;background:var(--lv-gradient);box-shadow:var(--lv-shadow-glow);overflow:hidden}.lv-final-cta h2{font-size:clamp(2rem,3.2vw,3rem);line-height:1.06;letter-spacing:-.055em;margin:0}.lv-final-cta p{margin:10px 0 0;color:rgba(255,255,255,.84)}.lv-final-cta>div:last-child{display:flex;gap:12px;flex-wrap:wrap}.lv-final-light{background:#fff;color:#130f24;border-color:#fff}.lv-final-outline{border-color:rgba(255,255,255,.42);color:#fff;background:transparent}.lv-final-outline:hover{background:rgba(255,255,255,.10)}.lv-footer{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-top:80px;border-top:1px solid var(--lv-border);padding:30px 0;color:var(--lv-muted);font-size:14px}.lv-footer div{display:flex;gap:24px}.lv-footer a:hover{color:#fff}
.lv-access-screen{min-height:100dvh;display:grid;place-items:center;padding:48px 20px}.lv-access-wrap{width:min(760px,100%)}.lv-back{display:inline-flex;color:var(--lv-muted);font-size:13px;font-weight:900;margin-bottom:16px}.lv-back:hover{color:#fff}.lv-access-card{border-radius:34px;padding:44px}.lv-access-pill{display:inline-flex;border-radius:999px;background:rgba(71,229,215,.14);color:var(--lv-accent);padding:7px 12px;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.lv-access-card h1{margin:16px 0 0;font-size:clamp(2.2rem,6vw,4rem);line-height:1.04;letter-spacing:-.06em;font-weight:900}.lv-access-card>p{color:var(--lv-muted);margin:10px 0 0}.lv-sector-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:32px}.lv-owner-row{display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid var(--lv-border);margin-top:32px;padding-top:24px}.lv-owner-row span{color:var(--lv-muted);font-size:14px}
@media(max-width:980px){.lv-nav-links{display:none}.lv-hero{grid-template-columns:1fr;padding-top:54px}.lv-preview-wrap{max-width:640px}.lv-feature-grid,.lv-plans,.lv-modules-grid{grid-template-columns:1fr 1fr}.lv-plan-popular{transform:none}.lv-final-cta{flex-direction:column;align-items:flex-start}.lv-hero h1{font-size:clamp(2.8rem,11vw,5.5rem)}}
@media(max-width:640px){.lv-container,.lv-nav{width:min(100% - 28px,1220px)}.lv-nav{align-items:flex-start}.lv-brand span,.lv-nav-actions .lv-btn-ghost{display:none}.lv-nav-actions .lv-btn{padding:11px 13px}.lv-hero{gap:30px}.lv-hero-actions .lv-btn{width:100%}.lv-trust span{width:100%}.lv-preview-card{padding:15px}.lv-kpi-grid{grid-template-columns:1fr}.lv-feature-grid,.lv-plans,.lv-modules-grid,.lv-sector-grid{grid-template-columns:1fr}.lv-section{margin-top:80px}.lv-final-cta{margin-top:80px;padding:32px 22px;border-radius:28px}.lv-final-cta .lv-btn{width:100%}.lv-footer{flex-direction:column;align-items:flex-start}.lv-access-card{padding:28px 20px;border-radius:28px}.lv-owner-row{align-items:flex-start;flex-direction:column}.lv-owner-row .lv-btn{width:100%}}

/* Legal / Hostinger hardening additions */
.legal-page h1{font-size:clamp(2rem,4vw,4rem);line-height:1.02;margin:0;color:var(--lv-text, #0f172a)}
.legal-page h2{font-size:1.15rem;margin:24px 0 8px;color:var(--lv-text, #0f172a)}
.legal-page p{color:var(--lv-muted, #475569);line-height:1.75;margin:0 0 10px;max-width:980px}
.lv-footer a{margin-left:16px}
@media(max-width:720px){.legal-page section{padding:22px!important}.lv-footer div{display:flex;flex-wrap:wrap;gap:10px}.lv-footer a{margin-left:0}}

/* ================================================================
   MOBILE FIX 2026-06 — Garçom/Caixa/Cozinha/Dono mais bonito no celular
   ================================================================ */
html, body { max-width:100%; overflow-x:hidden; }
.app { width:100%; max-width:100%; }
.view { min-width:0; }

@media (max-width: 760px) {
  body { font-size: 15px; }
  .topbar {
    height: 52px;
    padding: 0 10px;
    position: sticky;
    top: 0;
  }
  .brand { font-size: .82rem; gap: 8px; min-width:0; }
  .brand span:not(.mark) { overflow:hidden; text-overflow:ellipsis; }
  .mark { width: 28px; height: 28px; border-radius: 9px; font-size: .68rem; }
  .actions { gap: 5px; }
  .role-pill { font-size: .6rem; padding: 3px 7px; max-width: 116px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
  .icon-btn { width: 31px; height: 31px; border-radius: 9px; }

  .view {
    padding: 14px 10px calc(88px + env(safe-area-inset-bottom));
    max-width: 100%;
  }

  .hero-operacao,
  .section-head,
  .page-header {
    align-items: stretch;
    gap: 10px;
    margin-bottom: 12px;
  }
  .hero-operacao h1,
  .section-head h2,
  .page-title {
    font-size: 1.35rem;
    line-height: 1.08;
    letter-spacing: -.03em;
  }
  .hero-operacao p {
    font-size: .83rem;
    line-height: 1.45;
    max-width: 100%;
  }
  .eyebrow { font-size: .64rem; }
  .section-actions { width:100%; display:grid; grid-template-columns: 1fr 1fr; gap:8px; }
  .section-actions .btn, .toolbar-2026 .btn { width:100%; }
  .toolbar-2026 { display:grid; grid-template-columns:1fr; gap:8px; margin-bottom: 12px; }
  .fab-search, .search-modern { min-width:0; width:100%; }

  /* resumo no garçom: 2 colunas compactas, não empilhado gigante */
  .quick-stats,
  .stats-grid,
  .summary-row,
  .caixa-stats,
  .kpi-grid {
    display:grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
    margin-bottom: 12px;
  }
  .quick-stat,
  .stat-card,
  .summary-card,
  .kpi {
    min-width:0 !important;
    padding: 10px 8px !important;
    border-radius: 14px !important;
  }
  .quick-stat strong,
  .stat-value,
  .summary-value,
  .kpi-value {
    font-size: 1.08rem !important;
    line-height: 1.05;
  }
  .quick-stat span,
  .stat-label,
  .summary-label,
  .kpi-label,
  .kpi-sub {
    font-size: .62rem !important;
    line-height: 1.25;
  }

  /* mesas em grade 2 colunas com cards menores e mais elegantes */
  .mesas-grid,
  .mesas-grid-2026 {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 9px !important;
  }
  .mesa-card,
  .mesa-card-2026 {
    min-width:0;
    border-radius: 18px !important;
    padding: 12px 8px 10px !important;
    gap: 4px !important;
    box-shadow: 0 4px 14px rgba(15,23,42,.06) !important;
  }
  .mesa-card::before,
  .mesa-card-2026::before { border-radius: 16px; }
  .mesa-icon,
  .mesa-emoji { font-size: 1.35rem !important; }
  .mesa-main-number { font-size: 1.25rem !important; line-height: 1; }
  .mesa-topline { font-size: .58rem !important; letter-spacing:.05em; }
  .mesa-nome,
  .mesa-name { font-size: .68rem !important; line-height: 1.15; }
  .mesa-total,
  .mesa-footerline { font-size: .62rem !important; line-height: 1.25; }
  .mesa-dot,
  .dot { width: 8px !important; height: 8px !important; top: 8px !important; right: 8px !important; }

  /* produtos em 2 colunas, sem quebrar tela */
  .produto-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }
  .produto-card {
    padding: 10px !important;
    border-radius: 14px !important;
    min-width:0;
  }
  .produto-card .pnome,
  .pname { font-size: .76rem !important; line-height:1.2; }
  .produto-card .pdesc,
  .pdesc { font-size: .64rem !important; line-height:1.3; }
  .produto-card .pprice,
  .pprice { font-size: .78rem !important; }

  .card, .form-card, .report-card, .fin-card {
    border-radius: 16px !important;
    padding: 12px !important;
  }
  .card-header, .fin-card-head {
    padding: 0 0 10px 0;
    flex-wrap:wrap;
  }
  .fin-card-head { padding: 11px 12px !important; }
  .fin-card-body { padding: 12px !important; }

  .portal-grid,
  .hub-grid,
  .link-grid,
  .form-grid,
  .profile-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 9px !important;
  }
  .portal-card,
  .hub-card {
    min-height: 104px !important;
    padding: 14px 10px !important;
    border-radius: 16px !important;
    text-align:center !important;
  }
  .portal-ico, .hub-ico { font-size: 1.8rem !important; }
  .portal-card strong, .hub-title { font-size:.78rem !important; line-height:1.2; }
  .portal-card small, .hub-desc { font-size:.62rem !important; line-height:1.25; }

  /* cozinha vira colunas empilhadas com altura automática */
  .kitchen-board,
  .kanban {
    grid-template-columns: 1fr !important;
    height: auto !important;
    gap: 10px !important;
  }
  .kitchen-col,
  .kanban-col { min-height: 180px; }
  .t-item,
  .pedido-card { margin: 6px; border-radius: 14px; }
  .t-actions,
  .pedido-actions { flex-wrap: wrap; }
  .t-actions .btn,
  .pedido-actions .btn { flex:1 1 auto; }

  /* caixa/listas */
  .caixa-grid,
  .caixa-grid-2026,
  .caixa-list {
    grid-template-columns: 1fr !important;
  }
  .mesa-row-2026 {
    align-items:flex-start;
    flex-direction:column;
    border-radius:16px;
  }
  .mr-info { width:100%; }

  .tabs-row,
  .tabs,
  .fin-tabs {
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .tabs-row::-webkit-scrollbar,
  .tabs::-webkit-scrollbar,
  .fin-tabs::-webkit-scrollbar { display:none; }
  .module-switch-btn,
  .tab-btn,
  .fin-tab { flex: 0 0 auto; }

  .table-wrap { border-radius: 12px; }
  table { font-size: .74rem; min-width: 520px; }
  thead th, tbody td { padding: 8px 10px; }

  .bottom-nav {
    position: sticky;
    bottom: 0;
    padding: 6px 6px calc(8px + env(safe-area-inset-bottom)) !important;
    gap: 4px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .bottom-nav::-webkit-scrollbar { display:none; }
  .bottom-nav .nav-item,
  .nav-item {
    min-width: 70px !important;
    flex: 0 0 70px !important;
    padding: 6px 4px !important;
    font-size: .54rem !important;
    border-radius: 12px !important;
  }
  .nav-item .nav-icon,
  .bottom-nav .nav-icon { font-size: 1.05rem !important; }
  .nav-item.active .nav-icon { padding: 2px 8px !important; }
}

@media (max-width: 390px) {
  .view { padding-left: 8px; padding-right: 8px; }
  .mesas-grid,
  .mesas-grid-2026,
  .produto-grid,
  .quick-stats,
  .stats-grid,
  .summary-row,
  .caixa-stats,
  .kpi-grid,
  .portal-grid,
  .hub-grid,
  .link-grid,
  .form-grid,
  .profile-grid {
    gap: 7px !important;
  }
  .mesa-card,
  .mesa-card-2026 { padding: 11px 6px 9px !important; }
  .hero-operacao h1,
  .section-head h2,
  .page-title { font-size: 1.22rem; }
  .btn { padding: 9px 12px; font-size: .78rem; }
}
.lv-modules-grid .lv-module-card{
  display:flex;
  align-items:center;
  gap:16px;
  border:1px solid var(--lv-border);
  background:rgba(255,255,255,.05);
  border-radius:20px;
  padding:20px;
  transition:.2s ease;
  backdrop-filter:blur(12px);
  cursor:default;
}

.lv-modules-grid .lv-module-card:hover{
  border-color:rgba(155,92,255,.8);
  background:rgba(255,255,255,.09);
  box-shadow:var(--lv-shadow-glow);
  transform:translateY(-2px);
}

.lv-modules-grid .lv-module-card strong{
  display:block;
}

.lv-modules-grid .lv-module-card small{
  display:block;
  color:var(--lv-muted);
  font-size:12px;
  margin-top:3px;
}

.lv-modules-grid .lv-module-card b{
  display:none;
}

/* ================================================================
   Landing — Módulos sem link, mantendo card/grid
   ================================================================ */
.lv-modules-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin-top:40px;
}

.lv-modules-grid .lv-module-card,
.lv-sector-grid a{
  display:flex;
  align-items:center;
  gap:16px;
  border:1px solid var(--lv-border);
  background:rgba(255,255,255,.05);
  border-radius:20px;
  padding:20px;
  transition:.2s ease;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}

.lv-modules-grid .lv-module-card{
  color:inherit;
  cursor:default;
}

.lv-modules-grid .lv-module-card:hover,
.lv-sector-grid a:hover{
  border-color:rgba(155,92,255,.8);
  background:rgba(255,255,255,.09);
  box-shadow:var(--lv-shadow-glow);
  transform:translateY(-2px);
}

.lv-modules-grid .lv-module-card strong,
.lv-sector-grid strong{
  display:block;
}

.lv-modules-grid .lv-module-card small,
.lv-sector-grid small{
  display:block;
  color:var(--lv-muted);
  font-size:12px;
  margin-top:3px;
}

.lv-modules-grid .lv-module-card b{
  display:none;
}

.lv-sector-grid b{
  margin-left:auto;
  color:var(--lv-muted);
  font-size:20px;
  transition:.2s;
}

.lv-sector-grid a:hover b{
  transform:translateX(4px);
  color:var(--lv-primary);
}

@media(max-width:980px){
  .lv-modules-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media(max-width:640px){
  .lv-modules-grid{
    grid-template-columns:1fr;
  }
}

/* ================================================================
   RAW Suite — logo oficial aplicada no projeto
   ================================================================ */
.lv-brand{
  gap:14px;
}
.lv-brand-logo{
  display:block;
  width:220px;
  max-width:42vw;
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 18px 34px rgba(99,102,241,.20));
}
.lv-brand:has(.lv-brand-logo){
  min-height:58px;
}
.lv-brand-mark{
  display:none;
}
.app-brand-logo{
  display:block;
  height:34px;
  width:auto;
  max-width:180px;
  object-fit:contain;
}
.app-login-logo{
  display:block;
  width:230px;
  max-width:100%;
  height:auto;
  object-fit:contain;
  margin:0 auto 8px;
  filter:drop-shadow(0 16px 30px rgba(99,102,241,.18));
}
.brand:has(.app-brand-logo){
  gap:12px;
}
.brand:has(.app-brand-logo) .mark{
  display:none;
}
@media(max-width:640px){
  .lv-brand-logo{
    width:160px;
    max-width:58vw;
  }
  .app-brand-logo{
    height:28px;
    max-width:132px;
  }
  .app-login-logo{
    width:190px;
  }
}

/* ================================================================
   FIX FINAL MOBILE SAFARI / CHROME 2026
   Corrige corte lateral, grids, topbar, menu inferior e módulos.
   ================================================================ */
html{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}
body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}
*, *::before, *::after{
  min-width:0;
}
.app{
  width:100%;
  max-width:100vw;
  min-height:100svh;
  height:100svh;
  overflow:hidden;
}
@supports (-webkit-touch-callout:none){
  .app{
    min-height:-webkit-fill-available;
    height:-webkit-fill-available;
  }
}
.view{
  width:100%;
  max-width:100%;
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  padding-bottom:calc(112px + env(safe-area-inset-bottom));
}
.topbar{
  width:100%;
  max-width:100vw;
  overflow:hidden;
}
.brand{
  min-width:0;
  flex:1 1 auto;
  overflow:hidden;
}
.brand > span:not(.mark),
.brand strong,
.brand .app-brand-logo{
  min-width:0;
  max-width:100%;
}
.actions{
  flex:0 0 auto;
  min-width:max-content;
}
.icon-btn{
  flex:0 0 auto;
}
.bottom-nav{
  width:100%;
  max-width:100vw;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
}
.table-wrap,
.fin-card,
.card,
.report-card,
.form-card,
.dashboard-grid,
.fin-card-body,
.chart-wrap{
  max-width:100%;
  overflow-x:auto;
}
.fin-tabs,
.tabs,
.tabs-row,
.cat-scroll,
.cat-pills,
.filter-bar{
  max-width:100%;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
}
.fin-tab,
.tab-btn,
.module-switch-btn,
.cat-chip,
.cat-pill{
  flex:0 0 auto;
}
img, svg, canvas, video{
  max-width:100%;
  height:auto;
}

@media(max-width:760px){
  body{
    background:var(--bg);
  }
  .app{
    height:100svh;
    max-width:100vw;
  }
  .topbar{
    position:sticky;
    top:0;
    z-index:300;
    height:54px;
    min-height:54px;
    padding:8px 10px;
    gap:8px;
  }
  .brand{
    font-size:.78rem;
    line-height:1.1;
  }
  .brand .app-brand-logo{
    height:26px;
    max-width:126px;
    object-fit:contain;
  }
  .role-pill{
    max-width:88px;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    font-size:.58rem;
    padding:3px 7px;
  }
  .actions{
    gap:4px;
  }
  .icon-btn{
    width:30px;
    height:30px;
    border-radius:9px;
    font-size:.86rem;
  }
  .view{
    padding:12px 10px calc(118px + env(safe-area-inset-bottom));
  }
  .hero-operacao,
  .page-header,
  .section-head{
    width:100%;
    align-items:flex-start;
    justify-content:flex-start;
    flex-direction:column;
    gap:9px;
  }
  .hero-operacao h1,
  .section-head h2,
  .page-title{
    width:100%;
    font-size:1.34rem;
    line-height:1.12;
    letter-spacing:-.03em;
    overflow-wrap:anywhere;
  }
  .hero-operacao p,
  .page-header p,
  .section-head p{
    width:100%;
    font-size:.82rem;
    line-height:1.45;
    overflow-wrap:anywhere;
  }
  .section-actions,
  .dash-actions,
  .master-actions{
    width:100%;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
  }
  .section-actions .btn,
  .dash-actions .btn,
  .master-actions .btn{
    width:100%;
  }
  .toolbar-2026,
  .filter-bar{
    width:100%;
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
  }
  .fab-search,
  .search-modern,
  .filter-bar .input,
  .filter-bar .btn{
    width:100%;
    min-width:0;
  }

  /* KPIs compactos em 2 colunas no celular */
  .quick-stats,
  .stats-grid,
  .summary-row,
  .caixa-stats,
  .kpi-grid,
  .dashboard-kpis,
  .owner-kpis,
  .master-kpi-grid{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:8px!important;
    width:100%;
  }
  .quick-stat,
  .stat-card,
  .summary-card,
  .kpi,
  .master-kpi{
    padding:10px 9px!important;
    border-radius:14px!important;
    min-height:auto!important;
    min-width:0!important;
  }
  .quick-stat strong,
  .stat-value,
  .summary-value,
  .kpi-value,
  .master-kpi strong{
    font-size:1.05rem!important;
    line-height:1.05!important;
    word-break:break-word;
  }
  .quick-stat span,
  .stat-label,
  .summary-label,
  .kpi-label,
  .kpi-sub,
  .master-kpi small{
    font-size:.6rem!important;
    line-height:1.25!important;
  }

  /* Mesas e produtos */
  .mesas-grid,
  .mesas-grid-2026,
  .produto-grid{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:9px!important;
    width:100%;
  }
  .mesa-card,
  .mesa-card-2026,
  .produto-card{
    width:100%;
    min-width:0!important;
    border-radius:17px!important;
    padding:11px 8px!important;
    overflow:hidden;
  }
  .mesa-main-number{
    font-size:1.22rem!important;
  }
  .mesa-topline,
  .mesa-nome,
  .mesa-name,
  .mesa-total,
  .mesa-footerline{
    max-width:100%;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }

  /* Cozinha: uma coluna real, sem vazar */
  .kitchen-board,
  .kanban{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
    width:100%!important;
    height:auto!important;
  }
  .kitchen-col,
  .kanban-col{
    width:100%;
    min-height:160px;
    overflow:hidden;
  }
  .kitchen-col > .section-head{
    padding:10px 12px;
    display:flex;
    flex-direction:row;
    align-items:center;
    justify-content:space-between;
  }
  .t-item,
  .pedido-card{
    width:auto;
    margin:7px;
    border-radius:14px;
  }
  .t-actions,
  .pedido-actions{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:6px;
  }
  .t-actions .btn,
  .pedido-actions .btn{
    width:100%;
  }

  /* Financeiro */
  .fin-tabs{
    width:100%;
    padding-left:0;
    margin-left:0;
  }
  .fin-tab{
    padding:8px 12px;
    font-size:.76rem;
  }
  .summary-row{
    margin-top:8px;
  }
  .chart-wrap{
    min-width:520px;
  }
  .fin-card-body > .chart-wrap{
    overflow-x:visible;
  }

  /* Painel dono/master */
  .portal-grid,
  .hub-grid,
  .owner-modules,
  .master-panel-grid,
  .link-grid,
  .form-grid,
  .profile-grid{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:9px!important;
    width:100%;
  }
  .portal-card,
  .hub-card,
  .owner-module-card,
  .master-panel-card{
    min-height:105px!important;
    width:100%;
    padding:13px 9px!important;
    border-radius:16px!important;
    text-align:center!important;
    align-items:center!important;
    justify-content:center!important;
  }
  .portal-card strong,
  .hub-title,
  .owner-module-card strong,
  .master-panel-card strong{
    font-size:.78rem!important;
    line-height:1.2;
  }
  .portal-card small,
  .hub-desc,
  .owner-module-card small,
  .master-panel-card small{
    font-size:.62rem!important;
    line-height:1.3;
  }

  /* Menu inferior fixo e visível no Safari */
  .bottom-nav{
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    z-index:500;
    background:rgba(255,255,255,.96);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    border-top:1px solid rgba(148,163,184,.25);
    box-shadow:0 -10px 28px rgba(15,23,42,.10);
    padding:6px 6px calc(10px + env(safe-area-inset-bottom))!important;
  }
  [data-theme="dark"] .bottom-nav{
    background:rgba(10,15,30,.96);
  }
  .bottom-nav .nav-item,
  .nav-item{
    flex:0 0 66px!important;
    min-width:66px!important;
    padding:6px 4px!important;
    font-size:.52rem!important;
    border-radius:12px!important;
  }
  .nav-item .nav-icon,
  .bottom-nav .nav-icon{
    font-size:1rem!important;
  }
}

@media(max-width:390px){
  .view{
    padding-left:8px;
    padding-right:8px;
  }
  .quick-stats,
  .stats-grid,
  .summary-row,
  .caixa-stats,
  .kpi-grid,
  .dashboard-kpis,
  .owner-kpis,
  .master-kpi-grid,
  .mesas-grid,
  .mesas-grid-2026,
  .produto-grid,
  .portal-grid,
  .hub-grid,
  .owner-modules,
  .master-panel-grid,
  .link-grid,
  .form-grid,
  .profile-grid{
    gap:7px!important;
  }
  .section-actions,
  .dash-actions,
  .master-actions{
    grid-template-columns:1fr;
  }
  .hero-operacao h1,
  .section-head h2,
  .page-title{
    font-size:1.18rem;
  }
  .btn{
    font-size:.76rem;
    padding:9px 11px;
  }
  .bottom-nav .nav-item,
  .nav-item{
    flex-basis:62px!important;
    min-width:62px!important;
  }
}

/* ================================================================
   v4 — Imagem de produto, Planos Master, Bloqueio de módulo
   ================================================================ */

/* ── Produto com imagem (cardápio e cadastro) ─────────────────── */
.produto-card .produto-img {
  width: 100%;
  aspect-ratio: 4/3;
  border-radius: calc(var(--r) - 4px);
  object-fit: cover;
  background: var(--bg2);
  display: block;
  margin-bottom: 8px;
}
.produto-card .produto-img-placeholder {
  width: 100%;
  aspect-ratio: 4/3;
  border-radius: calc(var(--r) - 4px);
  background: var(--bg2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin-bottom: 8px;
  color: var(--text3);
}
.produto-card-img {
  display: flex;
  flex-direction: column;
}

/* Upload de imagem no modal de cadastro */
.img-upload-area {
  border: 2px dashed var(--border2);
  border-radius: var(--r);
  padding: 18px 14px;
  text-align: center;
  cursor: pointer;
  transition: var(--t);
  background: var(--bg2);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: var(--text2);
  font-size: .82rem;
  position: relative;
}
.img-upload-area:hover { border-color: var(--brand); background: var(--brand-glow); color: var(--brand); }
.img-upload-area input[type="file"] {
  position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%;
}
.img-upload-preview {
  width: 100%;
  max-height: 180px;
  border-radius: var(--r-sm);
  object-fit: cover;
  display: block;
}
.img-upload-icon { font-size: 2rem; }
.img-remove-btn {
  font-size: .75rem;
  color: var(--red);
  border: none;
  background: none;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 6px;
  transition: var(--t);
}
.img-remove-btn:hover { background: rgba(220,38,38,.1); }

/* ── Planos Master ───────────────────────────────────────────── */
.planos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
  margin-bottom: 20px;
}
.plano-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 18px;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: var(--t);
}
.plano-card:hover { box-shadow: var(--shadow); border-color: var(--border2); }
.plano-card.ativo { border-color: var(--brand); }
.plano-nome { font-size: 1.05rem; font-weight: 800; }
.plano-preco { font-family: var(--mono); font-size: 1.4rem; font-weight: 800; color: var(--brand); }
.plano-modulos-list {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.plano-mod-tag {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 99px;
  font-size: .68rem;
  font-weight: 700;
  padding: 2px 8px;
  color: var(--text2);
}
.plano-actions { display: flex; gap: 8px; margin-top: auto; }

/* Form de plano */
.plano-form-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 20px;
  margin-bottom: 18px;
}
.modules-plan-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 10px;
  margin: 12px 0;
}
.module-check {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 11px 12px;
  cursor: pointer;
  transition: var(--t);
}
.module-check:has(input:checked) {
  border-color: var(--brand);
  background: var(--brand-glow);
}
.module-check input { margin-top: 1px; accent-color: var(--brand); flex-shrink: 0; }
.module-check span { font-size: 1.1rem; flex-shrink: 0; }
.module-check strong { font-size: .83rem; font-weight: 700; display: block; }
.module-check small { font-size: .72rem; color: var(--text2); line-height: 1.35; }

/* Seletor de plano no cadastro de estabelecimento */
.plan-select-wrap {
  display: flex;
  gap: 10px;
  align-items: center;
}
.plan-select-wrap select.input { flex: 1; }

/* ── Bloqueio de módulo ──────────────────────────────────────── */
.modulo-bloqueado {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 24px;
  text-align: center;
  gap: 14px;
}
.modulo-bloqueado-icon {
  font-size: 3.2rem;
  opacity: .6;
}
.modulo-bloqueado h3 {
  font-size: 1.15rem;
  font-weight: 800;
  margin: 0;
}
.modulo-bloqueado p {
  color: var(--text2);
  font-size: .9rem;
  max-width: 360px;
  line-height: 1.6;
}
.modulo-bloqueado .plano-info-tag {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 10px 16px;
  font-size: .83rem;
  color: var(--text2);
}

/* ── Owner home limpeza ──────────────────────────────────────── */
.owner-home-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 20px;
  padding: 20px 22px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}
.owner-home-hero h2 { font-size: clamp(1.3rem, 3vw, 1.8rem); margin: 4px 0 6px; }
.owner-home-hero p { color: var(--text2); font-size: .88rem; }
.owner-plan-box {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 12px 16px;
  text-align: center;
  white-space: nowrap;
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 130px;
}
.owner-plan-box small { font-size: .68rem; color: var(--text2); font-weight: 700; text-transform: uppercase; letter-spacing: .4px; }
.owner-plan-box strong { font-size: .95rem; font-weight: 800; color: var(--text); }
.owner-plan-box span { font-size: .75rem; color: var(--brand); font-weight: 600; }

/* Master form card limpeza */
.master-form-card { border-radius: var(--r-lg); }

/* ── Remoção de gradientes exagerados no master-hero-pro ──── */
.master-hero-pro {
  background: var(--text) !important;
  box-shadow: var(--shadow) !important;
}
.admin-dashboard-hero {
  background: var(--surface) !important;
}
.owner-hero, .master-hero {
  background: var(--surface) !important;
}

/* ── Sub-módulos do Financeiro (formulário de planos) ────────── */
.submodulos-financeiro {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 8px;
  padding: 10px 14px 12px;
  margin-top: -6px;
  margin-bottom: 4px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-top: none;
  border-radius: 0 0 var(--r) var(--r);
}
.submodulo-check {
  background: var(--surface) !important;
  border-color: var(--border) !important;
  padding: 9px 10px !important;
}
.submodulo-check:has(input:checked) {
  border-color: var(--cyan) !important;
  background: rgba(8,145,178,.07) !important;
}
.has-submodulos {
  border-radius: var(--r) var(--r) 0 0 !important;
  border-bottom: none !important;
  margin-bottom: 0 !important;
}

/* ── Sub-módulos Financeiro v2 — estrutura wrapper ───────────── */
.module-check-financeiro-wrap {
  grid-column: 1 / -1;   /* ocupa linha inteira no grid de módulos */
  display: flex;
  flex-direction: column;
  gap: 0;
}
.module-check-pai {
  border-radius: var(--r) var(--r) 0 0 !important;
  border-bottom-color: transparent !important;
  background: rgba(37,99,235,.06) !important;
}
.submodulos-financeiro {
  border: 1px solid var(--border);
  border-top: none;
  border-radius: 0 0 var(--r) var(--r);
  padding: 12px;
  background: var(--bg2);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 8px;
}
.submod-titulo {
  grid-column: 1 / -1;
  font-size: .7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text3);
  margin-bottom: 2px;
}
.submodulo-check {
  background: var(--surface) !important;
  padding: 8px 10px !important;
  border-radius: var(--r-sm) !important;
  font-size: .8rem;
}
.submodulo-check:has(input:checked) {
  border-color: var(--cyan) !important;
  background: rgba(8,145,178,.07) !important;
}

/* ── Mesa com reserva (garçom) ───────────────────────────────── */
.mesa-card.reservada { border-color: var(--brand) !important; }
.mesa-reserva-info {
  font-size: .7rem;
  color: var(--text2);
  line-height: 1.6;
  padding: 6px 0 2px;
  border-top: 1px solid var(--border);
  margin-top: 6px;
}
.mesa-reserva-linha { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.btn.xs { font-size: .72rem; padding: 4px 10px; border-radius: var(--r-sm); }
.w-full { width: 100%; }
.mt-6 { margin-top: 6px; }
