/* ============================================================
   Pampakero de Cris — Design System
   Tema "parrilla": carbón + brasa/terracota + crema.
   Glassmorphism cálido. Targets grandes para táctil y TV.
   ============================================================ */

:root {
  /* Fondos */
  --bg:        #16100c;   /* carbón base */
  --bg2:       #1f1611;
  --surface:   #2a1d15;   /* tarjetas */
  --surface2:  #34251b;   /* items dentro de tarjetas */

  /* Marca / acentos */
  --ember:     #e2682b;   /* brasa naranja — acento principal */
  --ember2:    #c44d18;
  --terra:     #b8472a;   /* terracota */
  --gold:      #e6a23c;   /* dorado / pollo */
  --crema:     #f3e9dc;   /* texto principal */

  /* Insumos (color por proteína) */
  --c-pollo:   #e6a23c;   /* dorado */
  --c-pato:    #b8472a;   /* terracota oscuro */
  --c-chuleton:#d98c5f;   /* cerdo */

  /* Texto */
  --text:      #f3e9dc;
  --text2:     #c9b6a3;
  --text3:     #8c7868;

  /* Semánticos */
  --ok:        #7fb069;
  --warn:      #e6a23c;
  --red:       #e0584b;
  --blue:      #6fa8c4;

  /* Geometría */
  --r:   14px;
  --r2:  20px;
  --topbar-h: 64px;

  /* Bordes glass */
  --bd:  rgba(243,233,220,.12);
  --bd2: rgba(243,233,220,.20);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body { height: 100%; }

body {
  font-family: 'Inter', system-ui, sans-serif;
  color: var(--text);
  background: var(--bg);
  background-image:
    radial-gradient(900px 600px at 12% -5%, rgba(226,104,43,.16), transparent 60%),
    radial-gradient(700px 500px at 95% 0%, rgba(184,71,42,.14), transparent 55%),
    radial-gradient(800px 700px at 50% 110%, rgba(230,162,60,.08), transparent 60%);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

/* ===================== TOPBAR ===================== */
.topbar {
  height: var(--topbar-h);
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 0 20px;
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(15,10,7,.78);
  backdrop-filter: blur(28px) saturate(160%);
  border-bottom: 1px solid var(--bd);
}
.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 800;
  font-size: 18px;
  letter-spacing: .3px;
}
.brand__badge {
  width: 38px; height: 38px;
  display: grid; place-items: center;
  border-radius: 11px;
  background: linear-gradient(135deg, var(--ember), var(--terra));
  box-shadow: 0 6px 18px rgba(226,104,43,.4);
  font-size: 20px;
}
.brand small { display: block; font-size: 11px; font-weight: 500; color: var(--text3); letter-spacing: 1.5px; text-transform: uppercase; }

.nav-tabs { display: flex; gap: 6px; margin-left: auto; }
.nav-tab {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 16px;
  border-radius: 11px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--text2);
  font-size: 14px; font-weight: 600;
  cursor: pointer;
  transition: .18s;
}
.nav-tab i { font-size: 18px; }
.nav-tab:hover { background: rgba(243,233,220,.06); color: var(--text); }
.nav-tab.active {
  background: linear-gradient(135deg, rgba(226,104,43,.28), rgba(226,104,43,.12));
  border-color: rgba(226,104,43,.35);
  color: var(--crema);
}

/* ===================== LAYOUT ===================== */
.view { display: none; animation: secEnter .24s ease; }
.view.active { display: block; }
@keyframes secEnter { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

.wrap { max-width: 1500px; margin: 0 auto; padding: 22px; }

/* ===================== CAJA ===================== */
.caja-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 22px;
  align-items: start;
}
@media (max-width: 980px) { .caja-grid { grid-template-columns: 1fr; } }

/* Banco de proteínas */
.banco {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-bottom: 22px;
}
.banco-card {
  position: relative;
  padding: 16px 18px;
  border-radius: var(--r2);
  background: rgba(42,29,21,.5);
  backdrop-filter: blur(20px) saturate(150%);
  border: 1px solid var(--bd);
  overflow: hidden;
}
.banco-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--c, var(--ember));
  box-shadow: 0 0 14px var(--c, var(--ember));
}
.banco-card__label { font-size: 13px; color: var(--text2); display: flex; align-items: center; gap: 8px; font-weight: 600; }
.banco-card__label i { color: var(--c, var(--ember)); font-size: 18px; }
.banco-card__num { font-size: 38px; font-weight: 800; line-height: 1.1; margin-top: 6px; font-variant-numeric: tabular-nums; }
.banco-card__sub { font-size: 12px; color: var(--text3); margin-top: 2px; }
.banco-card.low .banco-card__num { color: var(--warn); }
.banco-card.empty .banco-card__num { color: var(--red); }

/* Tarjetas de platos */
.section-title { font-size: 14px; font-weight: 700; color: var(--text2); text-transform: uppercase; letter-spacing: 1.2px; margin: 4px 2px 14px; }

.platos {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
}
.plato-card {
  position: relative;
  padding: 18px;
  border-radius: var(--r2);
  background: rgba(42,29,21,.46);
  backdrop-filter: blur(16px) saturate(140%);
  border: 1px solid var(--bd);
  cursor: pointer;
  transition: .18s;
  display: flex; flex-direction: column; gap: 10px;
}
.plato-card:hover { transform: translateY(-2px); border-color: var(--bd2); box-shadow: 0 10px 26px rgba(0,0,0,.3); }
.plato-card.agotado { opacity: .42; pointer-events: none; filter: grayscale(.6); }
.plato-card__top { display: flex; align-items: center; justify-content: space-between; }
.plato-card__icon { font-size: 30px; }
.plato-card__stock {
  font-size: 13px; font-weight: 700;
  padding: 4px 10px; border-radius: 999px;
  background: rgba(127,176,105,.16); color: var(--ok);
}
.plato-card__stock.low { background: rgba(230,162,60,.16); color: var(--warn); }
.plato-card__name { font-size: 18px; font-weight: 800; }
.plato-card__desc { font-size: 13px; color: var(--text3); }

/* Toggle de variante dentro de la tarjeta */
.variante { display: flex; flex-direction: column; gap: 6px; margin-top: 2px; }
.variante__label { font-size: 11px; color: var(--text3); text-transform: uppercase; letter-spacing: .8px; }
.seg { display: flex; background: var(--surface2); border-radius: 10px; padding: 3px; gap: 3px; }
.seg button {
  flex: 1; border: 0; background: transparent; color: var(--text2);
  padding: 7px 6px; border-radius: 8px; font-size: 13px; font-weight: 600; cursor: pointer; transition: .15s;
}
.seg button.on { background: var(--ember); color: #fff; box-shadow: 0 3px 10px rgba(226,104,43,.4); }

.plato-card__add {
  margin-top: auto;
  border: 0; border-radius: 11px;
  background: linear-gradient(135deg, var(--ember), var(--ember2));
  color: #fff; font-weight: 700; font-size: 14px;
  padding: 11px; cursor: pointer; transition: .15s;
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.plato-card__add:hover { filter: brightness(1.08); }
.plato-card__add:active { transform: scale(.97); }

/* ===================== TICKET (pedido en construcción) ===================== */
.ticket {
  position: sticky; top: calc(var(--topbar-h) + 22px);
  border-radius: var(--r2);
  background: rgba(31,22,17,.6);
  backdrop-filter: blur(24px) saturate(150%);
  border: 1px solid var(--bd2);
  padding: 18px;
  display: flex; flex-direction: column; gap: 14px;
  max-height: calc(100vh - var(--topbar-h) - 44px);
}
.ticket__head { display: flex; align-items: center; justify-content: space-between; }
.ticket__head h3 { font-size: 16px; font-weight: 800; }
.ticket__mesa {
  width: 110px; background: var(--surface2); border: 1px solid var(--bd);
  color: var(--text); border-radius: 9px; padding: 8px 10px; font-size: 14px;
}
.ticket__list { display: flex; flex-direction: column; gap: 8px; overflow-y: auto; flex: 1; min-height: 60px; }
.ticket__empty { color: var(--text3); font-size: 14px; text-align: center; padding: 24px 0; }
.ti {
  display: flex; align-items: center; gap: 10px;
  background: var(--surface2); border-radius: 11px; padding: 10px 12px;
}
.ti__body { flex: 1; }
.ti__name { font-weight: 700; font-size: 14px; }
.ti__var { font-size: 12px; color: var(--gold); }
.ti__del { border: 0; background: transparent; color: var(--text3); cursor: pointer; font-size: 18px; padding: 4px; }
.ti__del:hover { color: var(--red); }

.ticket__send {
  border: 0; border-radius: 12px; padding: 14px;
  background: linear-gradient(135deg, var(--ok), #5e8a4e);
  color: #fff; font-weight: 800; font-size: 15px; cursor: pointer; transition: .15s;
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.ticket__send:hover { filter: brightness(1.08); }
.ticket__send:disabled { opacity: .4; cursor: not-allowed; filter: none; }

/* ===================== COCINA (KDS) ===================== */
.kds-head { display: flex; align-items: center; gap: 14px; margin-bottom: 18px; }
.kds-head h2 { font-size: 22px; font-weight: 800; }
.kds-count { font-size: 14px; color: var(--text2); background: var(--surface); padding: 6px 14px; border-radius: 999px; }

.kds-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 18px;
}
.kds-empty { text-align: center; color: var(--text3); padding: 80px 0; font-size: 16px; }

.orden {
  border-radius: var(--r2);
  background: rgba(42,29,21,.55);
  backdrop-filter: blur(18px) saturate(150%);
  border: 1px solid var(--bd);
  overflow: hidden;
  display: flex; flex-direction: column;
  animation: secEnter .3s ease;
}
.orden.urgente { border-color: rgba(224,88,75,.6); box-shadow: 0 0 0 1px rgba(224,88,75,.3), 0 0 22px rgba(224,88,75,.18); }
.orden.media   { border-color: rgba(230,162,60,.5); }

.orden__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px;
  background: rgba(0,0,0,.2);
  border-bottom: 1px solid var(--bd);
}
.orden__num { font-size: 20px; font-weight: 800; display: flex; align-items: center; gap: 10px; }
.orden__num .mesa { font-size: 13px; font-weight: 600; color: var(--text2); background: var(--surface2); padding: 3px 9px; border-radius: 8px; }
.orden__time { font-size: 13px; font-weight: 700; color: var(--text2); display: flex; align-items: center; gap: 5px; }
.orden.urgente .orden__time { color: var(--red); }
.orden.media .orden__time { color: var(--warn); }

.orden__items { padding: 12px 16px; display: flex; flex-direction: column; gap: 8px; }
.oitem { display: flex; align-items: flex-start; gap: 10px; }
.oitem__icon { font-size: 20px; line-height: 1.3; }
.oitem__name { font-weight: 700; font-size: 15px; }
.oitem__presas { font-size: 13px; color: var(--text2); margin-top: 1px; }
.oitem__var { font-size: 13px; color: var(--gold); font-weight: 600; }

/* Checklist de entrega */
.entrega { padding: 8px 16px 12px; border-top: 1px solid var(--bd); }
.entrega__title { font-size: 11px; color: var(--text3); text-transform: uppercase; letter-spacing: .8px; margin-bottom: 8px; }
.entrega__steps { display: flex; flex-direction: column; gap: 4px; }
.estep {
  display: flex; align-items: center; gap: 11px;
  padding: 9px 10px; border-radius: 10px; cursor: pointer;
  background: var(--surface2); transition: .15s;
}
.estep:hover { background: #3d2c20; }
.estep__box {
  width: 24px; height: 24px; border-radius: 7px;
  border: 2px solid var(--bd2); display: grid; place-items: center;
  flex-shrink: 0; transition: .15s; color: transparent;
}
.estep__lbl { font-size: 14px; font-weight: 600; display: flex; align-items: center; gap: 7px; }
.estep__lbl i { color: var(--text3); }
.estep.done { background: rgba(127,176,105,.12); }
.estep.done .estep__box { background: var(--ok); border-color: var(--ok); color: #fff; }
.estep.done .estep__lbl { color: var(--text2); text-decoration: line-through; }
.estep.done .estep__lbl i { color: var(--ok); }

.orden__foot { padding: 12px 16px; display: flex; gap: 8px; margin-top: auto; }
.btn-listo {
  flex: 1; border: 0; border-radius: 11px; padding: 12px;
  background: linear-gradient(135deg, var(--ok), #5e8a4e);
  color: #fff; font-weight: 800; font-size: 14px; cursor: pointer; transition: .15s;
  display: flex; align-items: center; justify-content: center; gap: 7px;
}
.btn-listo:hover { filter: brightness(1.08); }
.btn-cancel {
  border: 1px solid var(--bd2); border-radius: 11px; padding: 12px 14px;
  background: transparent; color: var(--text3); cursor: pointer; transition: .15s; font-size: 16px;
}
.btn-cancel:hover { color: var(--red); border-color: rgba(224,88,75,.5); }

/* ===================== PREPARAR DÍA (modal) ===================== */
.modal-bg {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(0,0,0,.6); backdrop-filter: blur(4px);
  display: none; align-items: center; justify-content: center; padding: 20px;
}
.modal-bg.open { display: flex; }
.modal {
  width: 100%; max-width: 420px;
  background: rgba(31,22,17,.94);
  backdrop-filter: blur(36px) saturate(160%);
  border: 1px solid var(--bd2);
  border-radius: var(--r2);
  padding: 24px;
  animation: modalIn .25s cubic-bezier(.2,.8,.3,1.1);
}
@keyframes modalIn { from { opacity: 0; transform: scale(.96); } to { opacity: 1; transform: none; } }
.modal h3 { font-size: 19px; font-weight: 800; margin-bottom: 4px; }
.modal p.sub { font-size: 13px; color: var(--text3); margin-bottom: 18px; }
.field { margin-bottom: 14px; }
.field label { display: flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 600; margin-bottom: 7px; }
.field label i { font-size: 18px; }
.stepper { display: flex; align-items: center; gap: 10px; }
.stepper button {
  width: 42px; height: 42px; border-radius: 11px; border: 1px solid var(--bd2);
  background: var(--surface2); color: var(--text); font-size: 22px; cursor: pointer; transition: .15s;
}
.stepper button:hover { background: #3d2c20; }
.stepper input {
  flex: 1; text-align: center; font-size: 20px; font-weight: 800;
  background: var(--surface); border: 1px solid var(--bd); color: var(--text);
  border-radius: 11px; padding: 10px; font-variant-numeric: tabular-nums;
}
.stepper .eq { font-size: 13px; color: var(--text3); min-width: 92px; }
.modal__actions { display: flex; gap: 10px; margin-top: 20px; }
.btn {
  flex: 1; border: 0; border-radius: 12px; padding: 13px; font-weight: 700; font-size: 15px; cursor: pointer; transition: .15s;
}
.btn--primary { background: linear-gradient(135deg, var(--ember), var(--ember2)); color: #fff; }
.btn--primary:hover { filter: brightness(1.08); }
.btn--ghost { background: transparent; border: 1px solid var(--bd2); color: var(--text2); }
.btn--ghost:hover { color: var(--text); }

.btn-prep {
  margin-left: auto;
  border: 1px solid var(--bd2); border-radius: 11px; padding: 9px 16px;
  background: var(--surface); color: var(--text); font-weight: 600; font-size: 14px; cursor: pointer; transition: .15s;
  display: flex; align-items: center; gap: 8px;
}
.btn-prep:hover { border-color: var(--ember); color: var(--ember); }

/* ===================== TOAST ===================== */
#toastCont { position: fixed; bottom: 22px; right: 22px; z-index: 200; display: flex; flex-direction: column; gap: 10px; }
.toast {
  padding: 13px 18px; border-radius: 12px; font-weight: 600; font-size: 14px;
  background: rgba(31,22,17,.95); backdrop-filter: blur(20px); border: 1px solid var(--bd2);
  color: var(--text); box-shadow: 0 10px 30px rgba(0,0,0,.4);
  transform: translateX(120%); opacity: 0; transition: .3s;
  border-left: 4px solid var(--ember);
}
.toast.show { transform: none; opacity: 1; }
.toast--ok { border-left-color: var(--ok); }
.toast--error { border-left-color: var(--red); }
.toast--warn { border-left-color: var(--warn); }

/* ===================== CONFIG WARNING ===================== */
.cfg-warn {
  margin: 22px; padding: 18px 20px; border-radius: var(--r);
  background: rgba(230,162,60,.1); border: 1px solid rgba(230,162,60,.35);
  color: var(--gold); font-size: 14px; line-height: 1.6;
}
.cfg-warn code { background: rgba(0,0,0,.3); padding: 2px 6px; border-radius: 5px; }

::-webkit-scrollbar { width: 9px; height: 9px; }
::-webkit-scrollbar-thumb { background: rgba(243,233,220,.14); border-radius: 6px; }
::-webkit-scrollbar-track { background: transparent; }

/* ============================================================
   v2 — Tipo de pedido, datos, bebidas, totales, pagos, pedidos
   ============================================================ */

/* Datos del pedido (tipo + nombre + hora) */
.pedido-datos { display: flex; flex-direction: column; gap: 12px; }
.tipo-sel { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.tipo-sel button {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 14px 8px; border-radius: var(--r);
  background: rgba(42,29,21,.46); border: 1px solid var(--bd);
  color: var(--text2); font-weight: 700; font-size: 14px; cursor: pointer; transition: .15s;
}
.tipo-sel button i { font-size: 26px; }
.tipo-sel button:hover { border-color: var(--bd2); color: var(--text); }
.tipo-sel button.on {
  color: #fff; border-color: transparent;
  background: linear-gradient(135deg, var(--ember), var(--terra));
  box-shadow: 0 6px 18px rgba(226,104,43,.34);
}
.datos-row { display: flex; gap: 10px; }
.inp {
  flex: 1; background: var(--surface); border: 1px solid var(--bd); color: var(--text);
  border-radius: 11px; padding: 12px 14px; font-size: 15px; font-family: inherit;
}
.inp::placeholder { color: var(--text3); }
.inp:focus { outline: none; border-color: var(--ember); }
.inp--hora { flex: 0 0 130px; }

/* Bebidas */
.bebidas { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 10px; margin-bottom: 8px; }
.beb-card {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 13px; border-radius: var(--r);
  background: rgba(42,29,21,.42); border: 1px solid var(--bd);
}
.beb-card__body { flex: 1; min-width: 0; }
.beb-card__name { font-size: 14px; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.beb-card__price { font-size: 12px; color: var(--text3); }
.beb-add {
  width: 34px; height: 34px; flex-shrink: 0; border: 0; border-radius: 9px;
  background: var(--ember); color: #fff; font-size: 20px; cursor: pointer; transition: .15s;
}
.beb-add:hover { filter: brightness(1.1); }
.beb-add:active { transform: scale(.92); }

/* Precio en tarjeta de plato */
.plato-card__price { font-size: 13px; font-weight: 700; color: var(--gold); }

/* Ticket — tipo, total, cantidades */
.ticket__tipo { font-size: 12px; font-weight: 700; padding: 4px 10px; border-radius: 999px; background: var(--surface2); color: var(--text2); }
.ticket__tipo.recoger { background: rgba(111,168,196,.18); color: var(--blue); }
.ticket__tipo.delivery { background: rgba(230,162,60,.18); color: var(--gold); }
.ticket__tipo.mesa { background: rgba(127,176,105,.18); color: var(--ok); }

.ti__qty { display: flex; align-items: center; gap: 6px; }
.ti__qty button {
  width: 24px; height: 24px; border: 1px solid var(--bd2); background: var(--surface);
  color: var(--text); border-radius: 7px; font-size: 15px; cursor: pointer; line-height: 1;
}
.ti__qty span { min-width: 18px; text-align: center; font-weight: 700; font-size: 14px; }
.ti__price { font-size: 13px; color: var(--text2); font-weight: 600; min-width: 56px; text-align: right; }

.ticket__total {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 4px; border-top: 1px solid var(--bd); margin-top: 2px;
  font-size: 15px; color: var(--text2);
}
.ticket__total b { font-size: 24px; color: var(--crema); font-variant-numeric: tabular-nums; }

/* Caja de pago */
.pago-box { display: flex; flex-direction: column; gap: 10px; background: var(--surface2); border-radius: var(--r); padding: 12px; }
.pago-row { display: flex; align-items: center; gap: 10px; }
.pago-row label { font-size: 14px; font-weight: 600; flex: 1; }
.inp--monto { flex: 0 0 100px; text-align: right; padding: 9px 12px; }
.pago-row .bs { color: var(--text3); font-weight: 600; }
.metodo-sel { display: flex; gap: 8px; }
.metodo-sel button {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 7px;
  padding: 10px; border-radius: 9px; border: 1px solid var(--bd);
  background: var(--surface); color: var(--text2); font-weight: 600; font-size: 14px; cursor: pointer; transition: .15s;
}
.metodo-sel button i { font-size: 18px; }
.metodo-sel button.on { background: var(--ember); color: #fff; border-color: transparent; }
.saldo-row { font-size: 14px; color: var(--text2); text-align: right; }
.saldo-row b { color: var(--gold); }

/* Banner agregar */
.banner-agregar {
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(230,162,60,.12); border: 1px solid rgba(230,162,60,.4);
  color: var(--gold); padding: 12px 16px; border-radius: var(--r); margin-bottom: 16px; font-size: 14px;
}
.banner-agregar button { background: transparent; border: 1px solid rgba(230,162,60,.5); color: var(--gold); border-radius: 8px; padding: 6px 12px; cursor: pointer; font-weight: 600; }

/* Badge de tipo en cocina */
.tipo-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 14px; font-weight: 800; padding: 6px 12px; border-radius: 10px; text-transform: uppercase; letter-spacing: .5px;
}
.tipo-badge.recoger { background: rgba(111,168,196,.2); color: var(--blue); }
.tipo-badge.delivery { background: rgba(230,162,60,.2); color: var(--gold); }
.tipo-badge.mesa { background: rgba(127,176,105,.2); color: var(--ok); }
.orden__cliente { font-size: 15px; font-weight: 700; margin-top: 4px; }
.orden__hora { font-size: 13px; color: var(--text2); }
.orden__pago { font-size: 12px; font-weight: 700; padding: 3px 9px; border-radius: 8px; }
.orden__pago.debe { background: rgba(224,88,75,.16); color: var(--red); }
.orden__pago.pagado { background: rgba(127,176,105,.16); color: var(--ok); }

/* ===================== VISTA PEDIDOS ===================== */
.filtros { display: flex; gap: 6px; margin-left: auto; flex-wrap: wrap; }
.filtros button {
  padding: 8px 14px; border-radius: 10px; border: 1px solid var(--bd);
  background: transparent; color: var(--text2); font-weight: 600; font-size: 13px; cursor: pointer; transition: .15s;
}
.filtros button:hover { color: var(--text); }
.filtros button.on { background: var(--ember); color: #fff; border-color: transparent; }

.pedidos-list { display: flex; flex-direction: column; gap: 10px; }
.prow {
  display: grid; grid-template-columns: auto 1fr auto auto; align-items: center; gap: 14px;
  padding: 14px 16px; border-radius: var(--r);
  background: rgba(42,29,21,.46); border: 1px solid var(--bd);
}
.prow__tipo { font-size: 24px; }
.prow__main { min-width: 0; }
.prow__name { font-size: 16px; font-weight: 700; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.prow__name .num { font-size: 13px; color: var(--text3); }
.prow__sub { font-size: 13px; color: var(--text3); margin-top: 2px; }
.prow__est { font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 6px; text-transform: uppercase; }
.prow__est.cocina { background: rgba(111,168,196,.16); color: var(--blue); }
.prow__est.entregado { background: rgba(127,176,105,.16); color: var(--ok); }
.prow__est.cancelado { background: rgba(224,88,75,.16); color: var(--red); }
.prow__money { text-align: right; }
.prow__total { font-size: 18px; font-weight: 800; }
.prow__saldo { font-size: 13px; margin-top: 2px; }
.prow__saldo.debe { color: var(--gold); font-weight: 700; }
.prow__saldo.ok { color: var(--ok); }
.prow__acts { display: flex; gap: 8px; }
.prow__acts button {
  border: 1px solid var(--bd2); background: var(--surface); color: var(--text);
  border-radius: 9px; padding: 9px 12px; font-size: 13px; font-weight: 600; cursor: pointer; transition: .15s;
  display: flex; align-items: center; gap: 6px;
}
.prow__acts button:hover { border-color: var(--ember); color: var(--ember); }
.prow__acts button.cobrar { background: var(--ok); color: #fff; border-color: transparent; }
.prow__acts button.cobrar:hover { filter: brightness(1.08); color: #fff; }
.pedidos-empty { text-align: center; color: var(--text3); padding: 70px 0; font-size: 16px; }
@media (max-width: 760px) {
  .prow { grid-template-columns: auto 1fr; }
  .prow__money, .prow__acts { grid-column: 2; }
  .prow__acts { flex-wrap: wrap; }
}

/* Detalle de pedido (modal) */
.det-line { display: flex; justify-content: space-between; padding: 7px 0; border-bottom: 1px solid var(--bd); font-size: 14px; }
.det-line:last-child { border: 0; }
.det-tot { display: flex; justify-content: space-between; font-size: 16px; font-weight: 800; margin-top: 10px; padding-top: 10px; border-top: 2px solid var(--bd2); }
.det-pagos { margin-top: 14px; }
.det-pagos h4 { font-size: 13px; color: var(--text2); text-transform: uppercase; letter-spacing: .8px; margin-bottom: 8px; }
.det-pago { display: flex; justify-content: space-between; font-size: 13px; color: var(--text2); padding: 4px 0; }
