/* =====================================================
   PROYECTO RESTAURANTE — CSS FINAL UNIFICADO (v3)
   - Sidebar mini por hover (iconos) + modo manual
   - Panel lateral con formularios por módulo
   - Dark mode
   - Sala (mesas elegantes, precuenta, pedidos)
   - Tablas, formularios, botones, utilidades
   ===================================================== */

/* ---------- Variables ---------- */
:root{
  --bg:#f6f7fb; --fg:#0f172a; --muted:#64748b; --white:#fff;
  --primary:#22c55e; --primary-600:#16a34a; --primary-50:#ecfdf5;
  --danger:#ef4444; --danger-50:#fef2f2;
  --warning:#f59e0b; --warning-50:#fffbeb;
  --info:#0ea5e9; --info-50:#eff6ff;

  --card-bg:#fff; --card-border:#e5e7eb;

  --sb-bg:#0f172a; --sb-fg:#e5e7eb; --sb-muted:#9ca3af;
  --sb-hover:#1f2937; --sb-active:#111827; --sb-border:#273246; --sb-accent:var(--primary);
  --sb-width:264px; --sb-mini:72px;

  --sp-width:280px;

  --radius:12px; --gap:10px; --pad:12px;
  --shadow:0 10px 30px -12px rgba(2,6,23,.35);
  --transition:.24s cubic-bezier(.2,.6,.2,1);
}

/* ---------- Dark Theme Overrides ---------- */
html[data-theme="dark"]{
  --bg:#0b1220; --fg:#e5e7eb; --muted:#94a3b8;
  --card-bg:#0f172a; --card-border:#233047;
  --sb-bg:#0b1220; --sb-fg:#cbd5e1; --sb-muted:#94a3b8;
  --sb-hover:#111827; --sb-active:#101826; --sb-border:#1f2a3c;
}
html[data-theme="dark"] .header{ background:#0f172a; box-shadow:none; border-bottom:1px solid var(--card-border) }
html[data-theme="dark"] .table thead th{ background:#0f172a; color:#cbd5e1 }
html[data-theme="dark"] .table tbody td{ border-top:1px solid #1f2a3c; color:#cbd5e1 }
html[data-theme="dark"] .btn.ghost{ color:#e5e7eb; border-color:#334155 }
html[data-theme="dark"] .modal{ background:#0f172a; border:1px solid var(--card-border) }
html[data-theme="dark"] .legend .pill{ background:#0f172a; border-color:#233047; color:#cbd5e1 }

/* ---------- Reset & base ---------- */
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--fg);font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
hr{border:0;border-top:1px solid var(--card-border);margin:12px 0}

/* ---------- Header / Layout ---------- */
.header{
  height:56px;background:#fff;display:flex;align-items:center;gap:10px;
  padding:0 16px;box-shadow:0 1px 3px rgba(0,0,0,.08);position:sticky;top:0;z-index:40
}
#menu-toggle,#theme-toggle{
  background:transparent;border:0;font-size:18px;width:36px;height:36px;
  display:grid;place-items:center;color:var(--fg);cursor:pointer;border-radius:10px
}
#menu-toggle:hover,#theme-toggle:hover{background:rgba(148,163,184,.15)}
.layout{display:flex;min-height:calc(100vh - 56px)}
.content{flex:1;padding:16px;transition:margin var(--transition)}
@media (min-width:1024px){ .content{ margin-left: var(--sb-width) } }

/* ---------- Sidebar ---------- */
.sidebar{
  width:var(--sb-width);background:var(--sb-bg);color:var(--sb-fg);
  padding:var(--pad);display:flex;flex-direction:column;gap:6px;
  position:sticky;top:56px;height:calc(100vh - 56px);
  overflow-y:auto;scrollbar-width:thin;scrollbar-color:#334155 transparent;
  transition:width var(--transition)
}
.sidebar::-webkit-scrollbar{width:8px}
.sidebar::-webkit-scrollbar-thumb{background:#334155;border-radius:8px}
.sidebar nav ul{list-style:none;padding:0;margin:0}
.sidebar nav li{margin:4px 0}
.sidebar nav a{
  display:grid;grid-template-columns:22px 1fr auto;align-items:center;gap:var(--gap);
  padding:10px 12px;color:var(--sb-fg);border-radius:var(--radius);
  transition:background var(--transition),color var(--transition);
  outline:none
}
.sidebar nav a:hover{background:var(--sb-hover)}
.sidebar nav a:focus-visible{box-shadow:0 0 0 3px rgba(34,197,94,.35)}
.menu-icon{width:22px;display:inline-flex;justify-content:center;font-size:16px;opacity:.95}
.label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.caret{margin-left:auto;color:var(--sb-muted);font-size:12px;transition:transform var(--transition)}
.sidebar nav a.is-active{background:var(--sb-active);box-shadow:inset 0 0 0 1px var(--sb-border)}
.sidebar nav a.is-active .menu-icon{color:var(--sb-accent)}
.divider{height:1px;background:linear-gradient(90deg,transparent,rgba(148,163,184,.25),transparent);margin:8px 4px}

/* Submenús */
.submenu{
  margin:4px 0 0 34px;border-left:1px dashed rgba(148,163,184,.25);
  padding-left:10px;overflow:hidden;transition:height var(--transition)
}
.submenu[aria-hidden="true"]{height:0}
.submenu[aria-hidden="false"]{height:auto}
.submenu a{font-size:14px;color:#cbd5e1;background:transparent !important}
.submenu a:hover{color:#fff}

/* ---------- Modo MINI por botón (compat.) ---------- */
body.sidebar-mini .sidebar{width:var(--sb-mini)}
body.sidebar-mini .content{margin-left:var(--sb-mini)}
body.sidebar-mini .sidebar nav a{grid-template-columns:1fr;justify-items:center;padding:10px 8px}
body.sidebar-mini .sidebar .label,
body.sidebar-mini .sidebar .caret,
body.sidebar-mini .sidebar .submenu{display:none !important}

/* Tooltips en mini */
body.sidebar-mini .sidebar nav a[data-label]:hover::after{
  content:attr(data-label);position:fixed;left:calc(var(--sb-mini) + 10px);
  transform:translateY(-50%);top:var(--_tooltipY, 0);
  background:#111827;color:#fff;padding:6px 10px;border-radius:8px;font-size:12px;
  box-shadow:var(--shadow);white-space:nowrap;pointer-events:none;z-index:100
}

/* ---------- Auto-mini (desktop) por hover ---------- */
@media (min-width:1024px){
  body.sidebar-auto .sidebar{width:var(--sb-mini)}
  body.sidebar-auto .content{margin-left:var(--sb-mini)}
  body.sidebar-auto .sidebar nav a{grid-template-columns:1fr;justify-items:center;padding:10px 8px}
  body.sidebar-auto .sidebar .label,
  body.sidebar-auto .sidebar .caret,
  body.sidebar-auto .sidebar .submenu{display:none !important}
  /* Expandir solo al hover (JS añade .sb-hover al <body>) */
  body.sidebar-auto.sb-hover .sidebar{width:var(--sb-width)}
  body.sidebar-auto.sb-hover .content{margin-left:var(--sb-width)}
  body.sidebar-auto.sb-hover .sidebar nav a{grid-template-columns:22px 1fr auto;justify-items:stretch}
  body.sidebar-auto.sb-hover .sidebar .label,
  body.sidebar-auto.sb-hover .sidebar .caret,
  body.sidebar-auto.sb-hover .sidebar .submenu{display:revert}
}
/* Tooltips cuando está auto-mini y no hover */
body.sidebar-auto:not(.sb-hover) .sidebar nav a[data-label]:hover::after{
  content:attr(data-label);position:fixed;left:calc(var(--sb-mini) + 10px);
  transform:translateY(-50%);top:var(--_tooltipY, 0);
  background:#111827;color:#fff;padding:6px 10px;border-radius:8px;font-size:12px;
  box-shadow:var(--shadow);white-space:nowrap;pointer-events:none;z-index:100
}

/* ---------- Móvil off-canvas ---------- */
.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.38);display:none;z-index:70;backdrop-filter:blur(1px)}
@media (max-width:1023px){
  .sidebar{position:fixed;top:56px;left:0;bottom:0;width:min(86vw, var(--sb-width));transform:translateX(-100%);box-shadow:var(--shadow);z-index:80}
  body.sidebar-open .sidebar{transform:translateX(0)}
  body.sidebar-open .sidebar-overlay{display:block}
  .content{margin-left:0 !important}
}

/* ---------- Side Panel (lista de formularios) ---------- */
.side-panel{
  position:fixed; top:56px; bottom:0; left:var(--sb-mini);
  width:var(--sp-width); background:var(--card-bg); color:var(--fg);
  border-right:1px solid var(--card-border); box-shadow:var(--shadow);
  transform:translateX(-120%); opacity:0; transition:transform var(--transition), opacity var(--transition), left var(--transition);
  z-index:75; display:flex; flex-direction:column;
}
.side-panel header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--card-border)}
.side-panel .title{font-weight:700}
.side-panel .list{padding:10px; overflow:auto}
.side-panel .item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:10px;cursor:pointer;border:1px solid var(--card-border);background:var(--card-bg); margin-bottom:8px}
.side-panel .item:hover{background:#f8fafc}
.side-panel .item i{width:18px;text-align:center;opacity:.9}
.side-panel .close{background:transparent;border:0;cursor:pointer;font-size:18px;color:var(--muted)}

@media (min-width:1024px){
  body.panel-open .side-panel{transform:none;opacity:1}
  body.sidebar-auto.sb-hover .side-panel{left:var(--sb-width)}
  body.panel-open.sidebar-mini .content{margin-left:calc(var(--sb-mini) + var(--sp-width))}
  body.panel-open.sidebar-auto:not(.sb-hover) .content{margin-left:calc(var(--sb-mini) + var(--sp-width))}
  body.panel-open.sidebar-auto.sb-hover .content{margin-left:calc(var(--sb-width) + var(--sp-width))}
}
@media (max-width:1023px){
  .side-panel{left:0; transform:translateX(-100%)}
  body.panel-open .side-panel{transform:translateX(0); opacity:1}
}

/* ---------- Componentes base ---------- */
.card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;margin-bottom:16px;border:1px solid var(--card-border)}
.section-title{font-size:18px;font-weight:700;color:var(--fg);margin:0 0 12px}
.muted{color:var(--muted)}
.kbd{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;background:#11182710;border:1px solid var(--card-border);border-bottom-width:2px;border-radius:6px;padding:2px 6px;font-size:12px}

/* Botones */
.btn{
  display:inline-flex;align-items:center;gap:8px;border:0;padding:8px 12px;border-radius:10px;cursor:pointer;
  background:#111827;color:#fff;transition:transform .08s ease,opacity .2s ease
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0) scale(.98)}
.btn.primary{background:var(--primary)}
.btn.primary:hover{filter:brightness(.95)}
.btn.danger{background:var(--danger)}
.btn.warning{background:var(--warning);color:#111827}
.btn.info{background:var(--info)}
.btn.ghost{background:transparent;color:var(--fg);border:1px dashed #cbd5e16b}

/* Inputs */
.input,.select,.textarea{
  width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--card-border);background:var(--white);color:var(--fg);
  outline:none;transition:box-shadow var(--transition),border-color var(--transition)
}
.input:focus,.select:focus,.textarea:focus{border-color:#94a3b8;box-shadow:0 0 0 4px rgba(2,132,199,.12)}
.input[readonly]{background:#0b12200a;color:var(--muted)}

/* Form grid */
.form-grid{display:grid;gap:12px}
.form-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.form-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.form-grid.cols-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:1023px){ .form-grid.cols-2,.form-grid.cols-3,.form-grid.cols-4{grid-template-columns:1fr} }
.form-row{display:flex;flex-direction:column;gap:6px}
.form-row label{font-size:13px;color:#475569}

/* Toolbars/Filtros */
.toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:10px}
.filter-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.filter-bar .input,.filter-bar .select{max-width:220px}

/* Tablas */
.table{width:100%;border-collapse:collapse;background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--card-border)}
.table thead th{background:#f1f5f9;color:#334155;font-weight:600;text-align:left;padding:12px}
html[data-theme="dark"] .table thead th{background:#0f172a;color:#cbd5e1}
.table tbody td{border-top:1px solid #eef2f7;padding:12px;color:#475569}
html[data-theme="dark"] .table tbody td{border-top:1px solid #1f2a3c;color:#cbd5e1}
.table tbody tr:hover{background:#f8fafc}
html[data-theme="dark"] .table tbody tr:hover{background:#111827}
.table .cell-actions{display:flex;gap:6px;align-items:center}
.table .act{width:34px;height:34px;display:grid;place-items:center;border-radius:8px;border:1px solid #e5e7eb;background:#fff;cursor:pointer}
.table .act.edit{color:#0ea5e9}.table .act.delete{color:#ef4444}.table .act.print{color:#111827}

/* Paginación */
.pagination{display:flex;gap:6px;align-items:center;margin-top:10px}
.pagination .page{min-width:34px;height:34px;display:grid;place-items:center;border-radius:8px;border:1px solid var(--card-border);background:var(--card-bg);cursor:pointer}
.pagination .page.is-active{background:#111827;color:#fff;border-color:#111827}

/* Badges / estados */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;padding:2px 8px;border-radius:999px}
.badge.blue{background:#dbeafe;color:#1e3a8a}
.badge.green{background:#dcfce7;color:#166534}
.badge.amber{background:#fef3c7;color:#92400e}
.badge.rose{background:#ffe4e6;color:#9f1239}
.status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid var(--card-border);background:var(--card-bg);font-size:12px}
.status.paid{border-color:#bbf7d0;color:#166534;background:#f0fdf4}
.status.pending{border-color:#fde68a;color:#92400e;background:#fffbeb}
.status.canceled{border-color:#fecaca;color:#991b1b;background:#fef2f2}

/* Tabs */
.tabs{display:flex;gap:8px;border-bottom:1px solid var(--card-border);margin-bottom:10px}
.tab{padding:8px 12px;border-radius:10px 10px 0 0;cursor:pointer;background:#f8fafc;color:#334155}
html[data-theme="dark"] .tab{background:#0f172a;color:#cbd5e1}
.tab[aria-selected="true"]{background:var(--card-bg);border:1px solid var(--card-border);border-bottom-color:var(--card-bg)}

/* Breadcrumbs */
.breadcrumbs{display:flex;gap:8px;align-items:center;color:var(--muted);font-size:13px;margin:0 0 8px}
.breadcrumbs a{color:#0ea5e9}

/* Vacío/placeholder */
.empty{border:1px dashed var(--card-border);border-radius:12px;padding:18px;color:var(--muted);background:#fafbfd}
html[data-theme="dark"] .empty{background:#0f172a}

/* ---------- SALA (mesas elegantes + acciones) ---------- */
.sala-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:12px}
.legend{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.legend .pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;font-size:12px;background:#f1f5f9;color:#0f172a;border:1px solid var(--card-border)}
.legend .dot{width:10px;height:10px;border-radius:999px}
.dot.free{background:#3b82f6}.dot.busy{background:#10b981}.dot.exit{background:#f59e0b}.dot.res{background:#ec4899}
.ubicaciones{display:flex;gap:8px;overflow:auto;padding-bottom:4px;scrollbar-width:thin}
.ubicaciones .chip{background:#111827;color:#fff;border:0;border-radius:999px;padding:7px 12px;cursor:pointer;font-size:13px;box-shadow:0 4px 12px -8px rgba(0,0,0,.4)}
.ubicaciones .chip.is-active{background:var(--primary)}
.sala-actions{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}
.mesa-grid{margin-top:14px;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}

/* Tarjetas de mesa */
.mesa-card{--ring:#e5e7eb;--bg:linear-gradient(145deg,#ffffff,#f8fafc);position:relative;isolation:isolate;aspect-ratio:1.15/1;min-height:160px;border-radius:16px;padding:12px;background:var(--bg);box-shadow:0 10px 30px -15px rgba(2,6,23,.35),inset 0 0 0 2px var(--ring);display:flex;flex-direction:column;justify-content:space-between;transition:transform .18s ease,box-shadow .18s ease}
.mesa-card:hover{transform:translateY(-2px);box-shadow:0 16px 40px -18px rgba(2,6,23,.45),inset 0 0 0 2px var(--ring)}
.mesa-card.libre{--ring:#bfdbfe;--bg:linear-gradient(180deg,#fff,#f0f7ff)}
.mesa-card.ocupada{--ring:#a7f3d0;--bg:linear-gradient(180deg,#fff,#eefcf6)}
.mesa-card.por-salir{--ring:#fde68a;--bg:linear-gradient(180deg,#fff,#fff7e6)}
.mesa-card.reservado{--ring:#fbcfe8;--bg:linear-gradient(180deg,#fff,#fff2fa)}
.mesa-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.mesa-name{font-weight:700;color:var(--fg);font-size:16px;letter-spacing:.2px;display:flex;align-items:center;gap:8px}
.mesa-name .plate{width:26px;height:26px;display:grid;place-items:center;border-radius:8px;background:#0ea5e915;color:#0ea5e9}
.mesa-meta{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:12px}
.meta-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;border:1px solid #e2e8f0;background:#fff}
html[data-theme="dark"] .meta-badge{background:#0f172a;border-color:#233047;color:#cbd5e1}
.meta-badge .dot{width:8px;height:8px;border-radius:999px}
.timer{font-variant-numeric:tabular-nums}
.mesa-amount{font-size:18px;color:var(--fg);font-weight:800}
.mesa-actions{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:8px}
.mesa-actions .left{display:flex;gap:8px}
.icon-btn{width:40px;height:40px;display:grid;place-items:center;border-radius:12px;border:1px solid var(--card-border);background:var(--card-bg);color:#111827;cursor:pointer;transition:transform .08s ease,background .2s ease}
html[data-theme="dark"] .icon-btn{color:#e5e7eb}
.icon-btn:hover{transform:translateY(-1px)}
.icon-btn.primary{background:var(--primary);color:#fff;border-color:var(--primary-600)}
.icon-btn.warning{background:var(--warning);color:#111827;border-color:var(--warning)}
.badge-corner{position:absolute;top:8px;right:8px;font-size:11px;background:#0f172a;color:#fff;padding:3px 6px;border-radius:999px;opacity:.85}

/* Botones mesa (compatibilidad anterior) */
.table-btn{display:inline-block;width:120px;height:80px;margin:6px;border-radius:10px;color:#fff;font-size:12px;padding:8px;box-shadow:0 2px 10px rgba(0,0,0,.12)}
.table-free{background:#3b82f6}.table-occupied{background:#10b981}.table-exit{background:#f59e0b}.table-reserved{background:#ec4899}
.table-btn .time{position:absolute;bottom:4px;right:4px;font-size:10px;color:rgba(255,255,255,.85)}

/* Menú contextual (Sala) */
.context-menu{
  position:fixed; z-index:120; min-width:180px; background:var(--card-bg);
  border:1px solid var(--card-border); border-radius:12px; box-shadow:var(--shadow); display:none;
}
.context-menu .item{ padding:10px 12px; display:flex; align-items:center; gap:8px; cursor:pointer; color:var(--fg) }
.context-menu .item:hover{ background:#f8fafc }
html[data-theme="dark"] .context-menu .item:hover{ background:#111827 }

/* Modales Sala */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;z-index:90}
.modal{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);background:var(--card-bg);border-radius:14px;min-width:min(680px,92vw);max-height:80vh;overflow:auto;display:none;z-index:91;box-shadow:0 30px 80px -30px rgba(0,0,0,.45);border:1px solid var(--card-border)}
.modal header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--card-border)}
.modal .body{padding:14px 16px}
.modal .footer{padding:12px 16px;border-top:1px solid var(--card-border);display:flex;justify-content:flex-end;gap:10px}
.btn-close{background:#111827;color:#fff;border:0;border-radius:999px;padding:6px 10px;cursor:pointer;font-size:12px}
.ticket-table{width:100%;border-collapse:collapse;font-size:14px}
.ticket-table thead th{text-align:left;background:#f8fafc;padding:8px;border-bottom:1px solid var(--card-border);color:#334155}
html[data-theme="dark"] .ticket-table thead th{background:#0f172a;color:#cbd5e1}
.ticket-table tbody td{padding:8px;border-bottom:1px dashed var(--card-border)}
.ticket-total{display:flex;justify-content:flex-end;gap:18px;padding:10px 0;font-weight:800;font-size:16px}
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}
.prod-card{border:1px solid var(--card-border);border-radius:12px;padding:10px;background:var(--card-bg);display:flex;flex-direction:column;gap:6px}
.prod-name{font-weight:600;color:var(--fg)}
.prod-price{color:#16a34a;font-weight:700}
.add-line{display:flex;gap:8px;align-items:center}
.qty{width:56px}

/* ---------- Login / Auth (opcional) ---------- */
.auth-wrap{min-height:100vh;display:grid;place-items:center;background:linear-gradient(180deg,#f8fafc,#eef2ff)}
.auth-card{background:#fff;border-radius:16px;box-shadow:0 30px 80px -28px rgba(2,6,23,.25);width:min(880px,94vw);display:grid;grid-template-columns:1.1fr 1fr;overflow:hidden}
@media (max-width:920px){ .auth-card{grid-template-columns:1fr} }
.auth-hero{background:linear-gradient(180deg,#0ea5e9,#22c55e);color:#fff;display:grid;place-items:center;padding:28px}
.auth-body{padding:24px}
.auth-title{font-size:24px;font-weight:800;margin:0 0 6px}
.auth-sub{color:#475569;margin:0 0 18px}

/* ---------- Utilidades ---------- */
.grid{display:grid;gap:10px}
.flex{display:flex;gap:10px}
.center{display:grid;place-items:center}
.right{margin-left:auto}
.mt-0{margin-top:0}.mt-4{margin-top:16px}.mt-6{margin-top:24px}
.mb-0{margin-bottom:0}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}
.p-0{padding:0}.p-2{padding:8px}.p-3{padding:12px}.p-4{padding:16px}
.round{border-radius:999px}
.hide{display:none !important}
.only-print{display:none}
.no-print{display:block}

/* ---------- SweetAlert2 ---------- */
.swal2-popup{border-radius:16px}
.swal2-styled.swal2-confirm{background:var(--primary) !important}
.swal2-styled.swal2-deny{background:var(--danger) !important}
.swal2-styled.swal2-cancel{background:#111827 !important}

/* ---------- Impresión ticket 80mm ---------- */
@media print{
  body{background:#fff}
  .no-print{display:none !important}
  .only-print{display:block !important}
  .ticket-80{width:80mm;margin:0 auto}
  .ticket-80 *{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px}
  .ticket-80 h3{text-align:center;margin:4px 0 8px}
  .ticket-80 table{width:100%;border-collapse:collapse}
  .ticket-80 th,.ticket-80 td{border-bottom:1px dashed #ccc;padding:4px;text-align:left}
}

/* ---------- Reduce motion ---------- */
@media (prefers-reduced-motion: reduce){
  .sidebar,.content,.submenu,.sidebar nav a,.caret,.btn,.input,.select,.textarea,.mesa-card{transition:none !important}
}
