/* ══════════════════════════════════════════════════════
   ZPOS Premium POS  · v7
   Light design  ·  Purple accent  ·  No dark tones
══════════════════════════════════════════════════════ */

:root {
  --z-brand:    #7c3aed;
  --z-brand-d:  #5b21b6;
  --z-brand-l:  #a78bfa;
  --z-brand-bg: rgba(124,58,237,.08);
  --z-brand-bd: rgba(124,58,237,.22);
  --z-ok:       #10b981;
  --z-warn:     #f59e0b;
  --z-err:      #ef4444;
}

/* ─────── BASE ─────── */
.zpos {
  position: fixed;
  top: 0; left: 240px; right: 0; bottom: 0;
  z-index: 30;
  display: flex; flex-direction: column;
  overflow: hidden;
  background: #f8fafc;
  color: #0f172a;
  font-family: 'Barlow','Segoe UI',system-ui,sans-serif;
  font-size: 14px;
}
@media(max-width:768px){ .zpos { left:0; } }

/* ─────── HEADER ─────── */
.zpos-top {
  display: flex; align-items: center;
  padding: 0 16px; height: 50px; min-height: 50px;
  background: #fff; gap: 12px; flex-shrink: 0;
  border-bottom: 1px solid #e2e8f0;
}
.zpos-brand { display: flex; align-items: center; gap: 9px; }
.zpos-mark {
  width: 30px; height: 30px; flex-shrink: 0;
  background: linear-gradient(135deg, var(--z-brand), var(--z-brand-d));
  border-radius: 8px;
  display: grid; place-items: center;
  font-weight: 900; font-size: 14px; color: #fff;
  box-shadow: 0 3px 10px rgba(124,58,237,.35);
}
.zpos-title { font-size: 13.5px; font-weight: 700; color: #0f172a; }
.zpos-sub   { font-size: 11px; color: #94a3b8; }
.zpos-top-actions { display: flex; align-items: center; gap: 6px; flex-shrink: 0; margin-left: auto; margin-right: 160px; }

.zpos-select {
  appearance: none; -webkit-appearance: none; -moz-appearance: none;
  background: #fff; color: #334155;
  border: 1px solid #e5e9f0; border-radius: 10px;
  height: 34px; padding: 0 30px 0 12px;
  font: inherit; font-size: 12px; font-weight: 600; cursor: pointer; outline: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 9px center;
  box-shadow: 0 1px 2px rgba(15,23,42,.04);
  transition: border-color .15s, box-shadow .15s, background-color .15s;
}
.zpos-select:hover { border-color: #cbd5e1; background-color: #fafbfc; }
.zpos-select:focus { border-color: var(--z-brand); box-shadow: 0 0 0 3px rgba(124,58,237,.12); }
.zpos-select option { background: #fff; color: #0f172a; }

.zpos-ghost {
  background: #fff; color: #475569;
  border: 1px solid #e5e9f0; border-radius: 10px;
  height: 34px; padding: 0 14px;
  font: inherit; font-size: 12px; font-weight: 600; cursor: pointer; white-space: nowrap;
  display: inline-flex; align-items: center; gap: 6px;
  box-shadow: 0 1px 2px rgba(15,23,42,.04);
  transition: background .15s, color .15s, border-color .15s, transform .12s;
}
.zpos-ghost:hover { background: #f8fafc; color: var(--z-brand); border-color: #d8c9f5; transform: translateY(-1px); }
.zpos-ghost:active { transform: translateY(0); }

.zpos-primary {
  background: linear-gradient(135deg, var(--z-brand), var(--z-brand-d));
  color: #fff; border: none; border-radius: 10px;
  height: 34px; padding: 0 16px;
  font: inherit; font-size: 12px; font-weight: 700; cursor: pointer; white-space: nowrap;
  letter-spacing: .01em;
  display: inline-flex; align-items: center; gap: 6px;
  box-shadow: 0 4px 14px -2px rgba(124,58,237,.45);
  transition: filter .15s, transform .12s, box-shadow .15s;
}
.zpos-primary:hover { filter: brightness(1.07); transform: translateY(-1px); box-shadow: 0 7px 20px -4px rgba(124,58,237,.55); }
.zpos-primary:active { transform: translateY(0); filter: brightness(.98); }

/* ─────── STATUS BAR (footer) ─────── */
.zpos-status {
  order: 99;
  display: flex; align-items: center; gap: 18px;
  padding: 4px 16px;
  background: #f8fafc;
  border-top: 1px solid #e2e8f0;
  font-size: 11px; flex-shrink: 0; flex-wrap: wrap;
}
.zpos-status > div { display: flex; align-items: center; gap: 5px; }
.zpos-status span { color: #94a3b8; font-size: 10px; text-transform: uppercase; letter-spacing: .05em; }
.zpos-status b { color: #0f172a; font-weight: 600; }
.zpos-status b.ok  { color: var(--z-ok); }
.zpos-status b.bad { color: var(--z-err); }

/* ─────── TAB BAR ─────── */
.zpos-tabs {
  display: flex; align-items: center;
  padding: 5px 10px;
  background: #fff; border-bottom: 1px solid #e2e8f0;
  flex-shrink: 0; gap: 3px; overflow-x: auto; scrollbar-width: none;
}
.zpos-tabs::-webkit-scrollbar { display: none; }
.zpos-tab {
  padding: 0 14px; height: 30px;
  font: inherit; font-size: 12px; font-weight: 600;
  color: #64748b; background: none; border: none;
  border-radius: 999px;
  cursor: pointer; white-space: nowrap; flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: all .15s;
}
.zpos-tab:hover:not(.active) { background: #f1f5f9; color: #334155; }
.zpos-tab.active {
  background: var(--z-brand);
  color: #fff;
  font-weight: 700;
  box-shadow: 0 2px 10px rgba(124,58,237,.35);
}

/* ─────── MAIN VIEW ─────── */
#zpos-view {
  flex: 1; overflow: hidden; min-height: 0;
  display: flex;
}

/* ════════════════════════════════════════════════
   MODERN VENTA LAYOUT  (.zpv)
   3 columns: category sidebar · product grid · ticket
════════════════════════════════════════════════ */

.zpv {
  display: flex; height: 100%; width: 100%; overflow: hidden;
  background: #fff;
}

/* ── LEFT SIDEBAR (categories) ── */
.zpv-left {
  display: flex; flex-direction: column;
  width: 168px; min-width: 120px;
  background: #fafafa;
  border-right: 1px solid #e2e8f0;
  flex-shrink: 0;
}

.zpv-srch { padding: 10px 10px 6px; }
.zpv-srch input {
  width: 100%; box-sizing: border-box;
  padding: 8px 10px 8px 30px;
  background: #fff; color: #0f172a;
  border: 1.5px solid #e2e8f0; border-radius: 10px;
  font: inherit; font-size: 12.5px; outline: none;
  box-shadow: 0 1px 3px rgba(15,23,42,.06);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%2394a3b8'%3E%3Cpath fill-rule='evenodd' d='M8 4a4 4 0 100 8 4 4 0 000-8zM2 8a6 6 0 1110.89 3.476l4.817 4.817a1 1 0 01-1.414 1.414l-4.816-4.816A6 6 0 012 8z'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-size: 13px; background-position: 9px 50%;
  transition: border-color .15s, box-shadow .15s;
}
.zpv-srch input::placeholder { color: #94a3b8; }
.zpv-srch input:focus {
  border-color: var(--z-brand);
  box-shadow: 0 0 0 3px rgba(124,58,237,.1);
  background-color: #fff;
}

.zpv-cats {
  flex: 1; overflow-y: auto; padding: 4px 8px 16px;
  scrollbar-width: thin; scrollbar-color: #e2e8f0 transparent;
}
.zpv-cat {
  display: flex; align-items: center; gap: 8px;
  width: 100%; padding: 8px 10px; margin-bottom: 2px;
  background: none; border: none; border-radius: 10px;
  font: inherit; font-size: 12.5px; font-weight: 500; color: #64748b;
  cursor: pointer; text-align: left; transition: all .15s;
}
.zpv-cat:hover { background: #f1f5f9; color: #1e293b; }
.zpv-cat.active {
  background: linear-gradient(135deg, var(--z-brand) 0%, var(--z-brand-d) 100%);
  color: #fff; font-weight: 700;
  box-shadow: 0 4px 14px -3px rgba(124,58,237,.4);
}
.zpv-ico { display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; color: #94a3b8; }
.zpv-cico { width: 18px; height: 18px; flex-shrink: 0; color: #94a3b8; }
.zpv-cat:hover .zpv-ico, .zpv-cat:hover .zpv-cico { color: #64748b; }
.zpv-cat.active .zpv-ico, .zpv-cat.active .zpv-cico { color: #fff; }
.zpv-lbl { flex: 1; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.zpv-cnt {
  font-size: 10px; font-weight: 700; padding: 2px 6px; border-radius: 999px;
  background: #e2e8f0; color: #64748b; min-width: 18px; text-align: center;
}
.zpv-cat.active .zpv-cnt { background: rgba(255,255,255,.25); color: #fff; }

/* ── CENTER (product grid) ── */
.zpv-center {
  flex: 1; overflow-y: auto; padding: 14px;
  background: #f4f6f9;
  scrollbar-width: thin; scrollbar-color: #cbd5e1 transparent;
}
.zpv-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
  gap: 14px; align-content: start;
}

.zpv-prod {
  position: relative;
  display: flex; flex-direction: column; align-items: stretch;
  background: #fff; border: 1px solid #eef1f5;
  border-radius: 18px; padding: 0; cursor: pointer;
  font: inherit; color: inherit; text-align: left; overflow: hidden;
  box-shadow: 0 1px 3px rgba(15,23,42,.05), 0 6px 16px -10px rgba(15,23,42,.16);
  transition: transform .2s cubic-bezier(.34,1.4,.5,1), box-shadow .2s, border-color .2s;
}
.zpv-prod:hover {
  transform: translateY(-5px);
  box-shadow: 0 18px 40px -12px rgba(124,58,237,.34), 0 4px 10px rgba(15,23,42,.07);
  border-color: rgba(124,58,237,.4);
}
.zpv-prod:active { transform: scale(.97); transition: transform .06s; }

/* Botón flotante "+" tipo TPV — siempre visible, se realza al hover */
.zpv-prod::after {
  content: '+';
  position: absolute; top: 70px; right: 10px;
  width: 32px; height: 32px; border-radius: 50%;
  background: #fff; color: var(--z-brand);
  display: grid; place-items: center;
  font-size: 21px; font-weight: 700; line-height: 1;
  border: 1px solid #eef1f5;
  box-shadow: 0 3px 10px rgba(15,23,42,.16);
  transition: transform .18s cubic-bezier(.34,1.6,.5,1), background .18s, color .18s, box-shadow .18s;
  z-index: 3; pointer-events: none;
}
.zpv-prod:hover::after {
  background: linear-gradient(135deg, var(--z-brand), var(--z-brand-d));
  color: #fff; transform: scale(1.12) rotate(90deg);
  box-shadow: 0 6px 18px rgba(124,58,237,.45);
}

.zpv-edit-ovr {
  position: absolute; top: 7px; right: 7px;
  width: 26px; height: 26px; border-radius: 8px;
  background: rgba(255,255,255,.95); border: 1px solid #e2e8f0;
  font-size: 12px; cursor: pointer; display: none;
  align-items: center; justify-content: center;
  color: #64748b; transition: all .12s; z-index: 4;
  box-shadow: 0 2px 6px rgba(15,23,42,.16);
  backdrop-filter: blur(4px);
}
.zpv-prod:hover .zpv-edit-ovr { display: flex; }
.zpv-edit-ovr:hover { background: #fff; color: var(--z-brand); border-color: var(--z-brand); transform: scale(1.08); }

.zpv-pico {
  position: relative;
  width: 100%; height: 88px;
  display: flex; align-items: center; justify-content: center;
  font-size: 30px; font-weight: 900; overflow: hidden;
  color: var(--f, #7c3aed);
  background:
    linear-gradient(135deg, rgba(255,255,255,.24), rgba(255,255,255,0) 52%),
    var(--b, #ede9fe);
  border-radius: 0; flex-shrink: 0;
  letter-spacing: -0.5px;
  text-shadow: 0 1px 2px rgba(0,0,0,.13);
}
/* sombra interior inferior para fundir con el cuerpo */
.zpv-pico::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  box-shadow: inset 0 -20px 26px -20px rgba(0,0,0,.2);
}
.zpv-pico img { width: 100%; height: 100%; object-fit: cover; text-shadow: none; }

.zpv-prod-body { padding: 11px 12px 13px; display: flex; flex-direction: column; gap: 3px; }

.zpv-pname {
  font-size: 12.5px; font-weight: 750; color: #0f172a;
  line-height: 1.3; letter-spacing: -0.01em;
  overflow: hidden; display: -webkit-box;
  -webkit-line-clamp: 2; -webkit-box-orient: vertical;
}
.zpv-psub {
  font-size: 9.5px; color: #aab2bf; display: block;
  text-transform: uppercase; letter-spacing: .05em; font-weight: 600;
  overflow: hidden; white-space: nowrap; text-overflow: ellipsis;
}
.zpv-pprice {
  font-size: 16px; font-weight: 850; color: var(--z-brand);
  margin-top: 6px; letter-spacing: -0.3px;
}

.zpv-empty {
  grid-column: 1/-1;
  display: flex; flex-direction: column; align-items: center;
  gap: 10px; padding: 60px 24px; color: #94a3b8; text-align: center;
}
.zpv-empty-ico {
  width: 58px; height: 58px; border-radius: 14px;
  background: #f1f5f9; border: 1px solid #e2e8f0;
  display: grid; place-items: center; font-size: 24px;
}

/* ── RIGHT (ticket panel) ── */
.zpv-right {
  display: flex; flex-direction: column;
  width: 420px; min-width: 300px;
  background: #fff; border-left: 1px solid #e2e8f0;
  flex-shrink: 0; overflow: hidden;
  margin-right: 18px;
}

.zpv-thead {
  display: flex; align-items: center; justify-content: space-between;
  padding: 11px 12px 9px; border-bottom: 1px solid #f1f5f9; flex-shrink: 0;
}
.zpv-ttitle {
  font-size: 12.5px; font-weight: 800; color: #0f172a;
  display: flex; align-items: center; gap: 6px;
}
.zpv-ttitle span { font-size: 11px; font-weight: 500; color: #94a3b8; }

/* Banner de reserva activa enlazada al pedido */
.zpv-resbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px; flex-shrink: 0;
  margin: 0; padding: 7px 12px;
  background: linear-gradient(90deg, rgba(124,58,237,.1), rgba(124,58,237,.04));
  border-bottom: 1px solid #ede9fe;
  font-size: 12px; font-weight: 700; color: var(--z-brand);
}
.zpv-resbar button {
  flex-shrink: 0; width: 22px; height: 22px; border-radius: 6px;
  border: none; background: rgba(124,58,237,.14); color: var(--z-brand);
  cursor: pointer; font-size: 12px; line-height: 1;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .12s;
}
.zpv-resbar button:hover { background: rgba(124,58,237,.28); }

/* Pestañas Hoy / Próximas en la vista de Reservas */
.zpos-restabs { display: flex; gap: 8px; margin-bottom: 14px; }
.zpos-restab {
  flex: 0 0 auto; padding: 8px 18px; border-radius: 999px;
  border: 1.5px solid #e2e8f0; background: #fff; color: #64748b;
  font: inherit; font-size: 13px; font-weight: 700; cursor: pointer;
  transition: all .14s;
}
.zpos-restab:hover { border-color: #cbd5e1; color: #334155; }
.zpos-restab.on {
  background: linear-gradient(135deg, var(--z-brand), var(--z-brand-d));
  color: #fff; border-color: transparent;
  box-shadow: 0 4px 12px -3px rgba(124,58,237,.4);
}

/* ─────── PANTALLA DE APERTURA DE TURNO ─────── */
.zpos-gate {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%; overflow-y: auto; padding: 24px 18px;
  background: #f4f6f9;
}
.zpos-gate-card {
  width: 100%; max-width: 380px; background: #fff;
  border: 1px solid #e8ecf0; border-radius: 20px; padding: 30px 26px 26px;
  box-shadow: 0 14px 44px -16px rgba(15,23,42,.22);
  text-align: center;
}
.zpos-gate-ico {
  width: 58px; height: 58px; margin: 0 auto 14px; border-radius: 16px;
  display: grid; place-items: center; font-size: 26px;
  background: linear-gradient(135deg, var(--z-brand), var(--z-brand-d));
  box-shadow: 0 8px 20px -6px rgba(124,58,237,.5);
}
.zpos-gate-h { font-size: 19px; font-weight: 800; color: #0f172a; margin-bottom: 4px; letter-spacing: -.01em; }
.zpos-gate-p { font-size: 13px; color: #64748b; margin-bottom: 22px; }
.zpos-gate-l {
  display: block; text-align: left; font-size: 11px; font-weight: 700;
  color: #94a3b8; text-transform: uppercase; letter-spacing: .06em; margin: 14px 2px 7px;
}
.zpos-gate-inp {
  width: 100%; padding: 12px 14px; font: inherit; font-size: 15px;
  border: 1.5px solid #e2e8f0; border-radius: 12px; background: #f8fafc; color: #0f172a; outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.zpos-gate-inp:focus { border-color: var(--z-brand); box-shadow: 0 0 0 3px rgba(124,58,237,.12); }
.zpos-gate-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.zpos-gate-chip {
  padding: 6px 12px; border-radius: 999px; border: 1.5px solid #e2e8f0; background: #fff;
  font: inherit; font-size: 12.5px; font-weight: 600; color: #475569; cursor: pointer; transition: all .13s;
}
.zpos-gate-chip:hover { border-color: var(--z-brand); color: var(--z-brand); background: #faf5ff; }
.zpos-gate-turns { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; }
.zpos-gate-turn {
  display: flex; flex-direction: column; align-items: center; gap: 7px;
  padding: 15px 6px 12px; border-radius: 16px; border: 1.5px solid #e8ecf0; background: #fff;
  font: inherit; cursor: pointer; transition: all .16s; position: relative; overflow: hidden;
}
.zpos-gate-turn-ic { font-size: 25px; line-height: 1; transition: transform .16s; }
.zpos-gate-turn-lb { font-size: 12.5px; font-weight: 800; color: #475569; letter-spacing: .01em; }
.zpos-gate-turn:hover { border-color: #cbd5e1; transform: translateY(-3px); box-shadow: 0 8px 18px -7px rgba(15,23,42,.22); }
.zpos-gate-turn:hover .zpos-gate-turn-ic { transform: scale(1.12); }
.zpos-gate-turn.on {
  background: linear-gradient(135deg, var(--z-brand), var(--z-brand-d)); border-color: transparent;
  box-shadow: 0 9px 22px -6px rgba(124,58,237,.5);
}
.zpos-gate-turn.on .zpos-gate-turn-lb { color: #fff; }
.zpos-gate-turn.on::after {
  content: ''; position: absolute; top: 7px; right: 7px; width: 16px; height: 16px;
  border-radius: 50%; background: rgba(255,255,255,.95);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%237c3aed' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: center;
}
.zpos-gate-btn {
  width: 100%; margin-top: 22px; padding: 15px; border: none; border-radius: 13px;
  background: linear-gradient(135deg, var(--z-brand), var(--z-brand-d)); color: #fff;
  font: inherit; font-size: 15.5px; font-weight: 800; cursor: pointer;
  box-shadow: 0 10px 26px -6px rgba(124,58,237,.55); transition: filter .14s, transform .14s;
}
.zpos-gate-btn:hover { filter: brightness(1.06); transform: translateY(-2px); }

.zpv-tclear {
  font: inherit; font-size: 11px; font-weight: 700;
  padding: 4px 9px; background: #fef2f2; color: var(--z-err);
  border: 1px solid #fecaca; border-radius: 7px; cursor: pointer;
  transition: background .12s;
}
.zpv-tclear:hover { background: #fee2e2; }

.zpv-lines {
  flex: 1; overflow-y: auto; padding: 4px 0; min-height: 0;
  scrollbar-width: thin; scrollbar-color: #e2e8f0 transparent;
}
.zpv-ecart {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; height: 100%; gap: 8px;
  color: #94a3b8; text-align: center; padding: 16px;
}
.zpv-ecart-ico {
  width: 44px; height: 44px; border-radius: 12px;
  background: #f8fafc; border: 1px solid #e2e8f0;
  display: grid; place-items: center; font-size: 20px;
}
.zpv-ecart p { font-size: 12px; margin: 0; line-height: 1.5; }

.zpv-line {
  display: flex; align-items: center; gap: 7px;
  padding: 6px 10px; cursor: pointer; border-radius: 8px;
  margin: 0 4px 2px; transition: background .1s;
}
.zpv-line:hover { background: #f8fafc; }
.zpv-line.sel { background: var(--z-brand-bg); }

.zpv-lic {
  width: 28px; height: 28px; border-radius: 6px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; overflow: hidden;
  background: var(--b, #ede9fe); color: var(--f, #7c3aed);
}
.zpv-lic img { width: 100%; height: 100%; object-fit: cover; }
.zpv-linfo { flex: 1; min-width: 0; }
.zpv-lname {
  font-size: 11.5px; font-weight: 600; color: #0f172a;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.zpv-lsub { font-size: 10px; color: #94a3b8; }
.zpv-lctrl { display: flex; align-items: center; gap: 3px; flex-shrink: 0; }
.zpv-lbtn {
  width: 19px; height: 19px; border-radius: 5px; padding: 0;
  background: #f1f5f9; border: 1px solid #e2e8f0;
  font: 700 13px inherit; cursor: pointer; color: #475569;
  display: flex; align-items: center; justify-content: center;
  transition: all .1s;
}
.zpv-lbtn:hover { background: #e2e8f0; color: #0f172a; }
.zpv-lqty { font-size: 12px; font-weight: 700; min-width: 16px; text-align: center; color: #0f172a; }
.zpv-lprice { font-size: 12px; font-weight: 700; color: #0f172a; width: 40px; text-align: right; flex-shrink: 0; }

/* totals */
.zpv-tots {
  padding: 8px 12px; border-top: 1px solid #f1f5f9;
  display: flex; flex-direction: column; gap: 3px; flex-shrink: 0;
}
.zpv-trow {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 11.5px;
}
.zpv-trow .lbl { color: #64748b; }
.zpv-trow .val { font-weight: 600; color: #334155; }
.zpv-trow.grand { border-top: 1.5px solid #e2e8f0; margin-top: 3px; padding-top: 6px; }
.zpv-trow.grand .lbl { font-size: 12.5px; font-weight: 700; color: #0f172a; }
.zpv-trow.grand .val { font-size: 17px; font-weight: 800; color: var(--z-brand); }

/* numpad */
.zpv-numpad { padding: 7px 10px 5px; border-top: 1px solid #f1f5f9; flex-shrink: 0; }
.zpv-nd {
  display: flex; align-items: center; justify-content: flex-end;
  background: #f3f0ff; color: var(--z-brand-d);
  border: 1.5px solid rgba(124,58,237,.18);
  font: 700 19px 'JetBrains Mono','Courier New',monospace;
  border-radius: 8px; padding: 6px 11px; margin-bottom: 5px;
  min-height: 36px; letter-spacing: .06em;
}

.zpv-keys {
  display: grid; grid-template-columns: repeat(5,1fr); gap: 3px;
}
.zpv-key {
  padding: 7px 2px; border-radius: 7px; text-align: center;
  background: #f8fafc; border: 1px solid #e2e8f0;
  font: 600 12px 'JetBrains Mono',monospace; cursor: pointer;
  color: #334155; transition: all .1s;
}
.zpv-key:hover { background: #f1f5f9; color: #0f172a; border-color: #cbd5e1; }
.zpv-key:active { transform: scale(.93); }
.zpv-key.del { background: #fef2f2; border-color: #fecaca; color: var(--z-err); }
.zpv-key.del:hover { background: #fee2e2; }
.zpv-key.eq  { background: var(--z-brand-bg); border-color: var(--z-brand-bd); color: var(--z-brand); font-weight: 700; }
.zpv-key.eq:hover { background: rgba(124,58,237,.14); }

/* payment methods */
.zpv-pays {
  padding: 5px 8px 4px; display: grid; grid-template-columns: 1fr 1fr; gap: 4px;
  border-top: 1px solid #f1f5f9; flex-shrink: 0;
}
.zpv-pay {
  padding: 6px 4px; border-radius: 7px; text-align: center;
  background: #f8fafc; border: 1.5px solid #e2e8f0;
  font: 600 11px inherit; cursor: pointer; color: #64748b;
  transition: all .12s;
}
.zpv-pay:hover { background: #ede9fe; border-color: rgba(124,58,237,.3); color: var(--z-brand); }
.zpv-pay.act  { background: var(--z-brand-bg); border-color: var(--z-brand); color: var(--z-brand); font-weight: 700; }

/* charge CTA */
.zpv-cta { padding: 6px 10px 10px; flex-shrink: 0; }
.zpv-charge {
  width: 100%; padding: 12px 14px; text-align: center;
  background: linear-gradient(135deg, var(--z-brand) 0%, var(--z-brand-d) 100%);
  color: #fff; font: 700 13px inherit; border: none; border-radius: 10px;
  cursor: pointer; letter-spacing: .02em;
  box-shadow: 0 5px 18px -5px rgba(124,58,237,.5), inset 0 1px 0 rgba(255,255,255,.15);
  transition: filter .15s, transform .15s;
}
.zpv-charge:hover:not(:disabled) { filter: brightness(1.1); transform: translateY(-1px); }
.zpv-charge:active:not(:disabled) { transform: translateY(0); }
.zpv-charge:disabled {
  background: #e2e8f0; color: #94a3b8; box-shadow: none; cursor: not-allowed;
}
.zpv-charge b { font-size: 16px; display: block; margin-top: 1px; }

/* ─────── OTHER TABS ─────── */
.zpos-section-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px 8px;
}
.zpos-section-head h2 { font-size: 15px; font-weight: 800; color: #0f172a; margin: 0; }
.zpos-section-head button {
  font: inherit; font-size: 12px; font-weight: 700; padding: 6px 12px;
  background: #fff; color: #0f172a; border: 1px solid #e2e8f0;
  border-radius: 8px; cursor: pointer; transition: background .12s;
}
.zpos-section-head button:hover { background: #f1f5f9; }

.zpos-kpis {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(140px,1fr));
  gap: 10px; padding: 0 18px 14px;
}
.zpos-kpis .kpi {
  background: #fff; border: 1px solid #e2e8f0; border-radius: 12px;
  padding: 12px; box-shadow: 0 1px 4px rgba(15,23,42,.06);
  display: flex; flex-direction: column; gap: 3px;
}
.zpos-kpis .kpi .label { font-size: 10px; color: #94a3b8; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; }
.zpos-kpis .kpi .val   { font-size: 20px; font-weight: 800; color: #0f172a; }
.zpos-kpis .kpi .sub   { font-size: 11px; color: #64748b; }

.zpos-row {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 18px; border-bottom: 1px solid #f1f5f9;
  font-size: 13px; color: #475569;
}
.zpos-empty { color: #94a3b8; font-size: 13px; text-align: center; padding: 40px 24px; }

.zpos-panel { padding: 12px; overflow-y: auto; flex: 1; }

.zpos-close {
  max-width: 480px; margin: 16px auto; background: #fff;
  border: 1px solid #e2e8f0; border-radius: 14px;
  padding: 22px; display: flex; flex-direction: column; gap: 14px;
  box-shadow: 0 4px 24px rgba(15,23,42,.08);
}
.zpos-close h3 { font-size: 14px; font-weight: 800; color: #0f172a; margin: 0; }
.zpos-close-form { display: flex; flex-direction: column; gap: 10px; }
.zpos-close-form label {
  font-size: 10px; color: #64748b; text-transform: uppercase;
  letter-spacing: .06em; font-weight: 700; display: flex; flex-direction: column; gap: 4px;
}
.zpos-charge {
  width: 100%; padding: 12px 16px; text-align: center;
  background: linear-gradient(135deg, var(--z-brand), var(--z-brand-d));
  color: #fff; font: 700 13px inherit; border: none; border-radius: 10px;
  cursor: pointer; box-shadow: 0 4px 16px rgba(124,58,237,.35);
  transition: filter .15s;
}
.zpos-charge:hover { filter: brightness(1.1); }

/* ─────── PRODUCT MANAGER ─────── */
.zpos-logo-img { padding: 0!important; overflow: hidden; background: #fff!important; }
.zpos-logo-img img { width: 100%; height: 100%; object-fit: contain; }

/* Two-column layout with independent scroll */
.zpm-layout {
  display: flex; width: 100%; height: 100%; overflow: hidden;
}
.zpm-col-fam {
  flex: 0 0 300px !important;
  display: flex; flex-direction: column;
  border-right: 1px solid #e2e8f0;
  background: #fff;
  overflow-y: auto; overflow-x: hidden;
  padding: 0 !important;
}
.zpm-col-prod {
  flex: 1 !important;
  display: flex; flex-direction: column;
  background: #f4f6f9;
  overflow-y: auto; overflow-x: hidden;
  padding: 0 !important;
}

/* Sticky column headers */
.zpm-col-fam .zpos-section-head,
.zpm-col-prod .zpos-section-head {
  position: sticky; top: 0; z-index: 2;
  background: #fff;
  border-bottom: 1px solid #e2e8f0;
  padding: 16px 20px 12px;
  flex-shrink: 0;
}
.zpm-col-fam .zpos-section-head h3,
.zpm-col-prod .zpos-section-head h3 {
  font-size: 14px; font-weight: 800; color: #0f172a; margin: 0;
}
.zpm-col-fam .zpos-section-head span,
.zpm-col-prod .zpos-section-head span {
  font-size: 11px; font-weight: 700; color: #7c3aed;
  background: #ede9fe; padding: 2px 8px; border-radius: 999px;
}

/* Family list padding */
.zpm-col-fam .zpm-list { padding: 10px 12px; gap: 2px !important; }

/* Family item — override inline styles */
.zpm-item[style*="flex-wrap:nowrap"],
.zpm-item[style*="gap:8px"] {
  padding: 8px 10px !important;
  border-radius: 9px !important;
  border: 1px solid transparent !important;
  background: transparent !important;
  gap: 9px !important;
  transition: background .1s, border-color .1s;
  flex-wrap: nowrap !important;
}
.zpm-item[style*="flex-wrap:nowrap"]:hover {
  background: #f8f7ff !important;
  border-color: #e0d9ff !important;
}
.zpm-item[style*="flex-wrap:nowrap"] .zpos-mark {
  border-radius: 8px !important;
  background: linear-gradient(135deg, var(--z-brand), var(--z-brand-d)) !important;
  color: #fff !important;
  font-weight: 800 !important;
  font-size: 10px !important;
}
.zpm-item[style*="flex-wrap:nowrap"] input {
  border: none !important;
  background: transparent !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  padding: 2px 4px !important;
}
.zpm-item[style*="flex-wrap:nowrap"] input:focus {
  background: #fff !important;
  border: 1px solid var(--z-brand) !important;
  border-radius: 6px !important;
  padding: 2px 8px !important;
}

/* New family form */
.zpm-col-fam .zpm-new {
  margin: 10px 12px !important;
  padding: 10px 12px !important;
  border: 1.5px dashed #e2e8f0 !important;
  border-radius: 10px !important;
  background: #fafafa !important;
}

/* Products area */
.zpm-col-prod .zpm-new {
  margin: 16px 16px 0 !important;
  padding: 16px !important;
  border: 1.5px dashed #e2e8f0 !important;
  border-radius: 14px !important;
  background: #fff !important;
}
.zpm-col-prod .zpm-new h4 {
  font-size: 11px !important;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #94a3b8 !important;
  margin: 0 0 10px !important;
}
.zpm-col-prod .zpm-list { padding: 16px; gap: 10px !important; }

/* Product item */
.zpm-col-prod .zpm-item {
  padding: 12px 14px !important;
  border-radius: 12px !important;
  border: 1px solid #e8ecf0 !important;
  background: #fff !important;
  transition: border-color .15s, box-shadow .15s;
  box-shadow: 0 1px 3px rgba(15,23,42,.05);
}
.zpm-col-prod .zpm-item:hover {
  border-color: rgba(124,58,237,.3) !important;
  box-shadow: 0 4px 16px rgba(124,58,237,.12) !important;
}
.zpm-col-prod .zpm-item .zpos-logo {
  width: 52px !important; height: 52px !important;
  border-radius: 13px !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  flex: 0 0 52px !important;
}
.zpm-info b { font-size: 14px !important; color: #0f172a; }
.zpm-info span { font-size: 12px !important; color: #94a3b8 !important; margin-top: 1px; }
.zpm-actions button {
  padding: 6px 12px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  border-radius: 8px !important;
  border: 1.5px solid #e2e8f0 !important;
  background: #f8fafc !important;
  cursor: pointer; font-family: inherit;
  color: #64748b;
  transition: all .12s !important;
}
.zpm-actions button:not(.zpm-del):hover {
  background: #ede9fe !important;
  border-color: var(--z-brand) !important;
  color: var(--z-brand) !important;
}
.zpm-del { color: #ef4444 !important; background: #fff5f5 !important; border-color: #fecaca !important; }
.zpm-del:hover { background: #fef2f2 !important; border-color: #ef4444 !important; }

/* Inline editor */
.zpm-editor { flex-basis: 100%; margin-top: 12px; padding-top: 12px; border-top: 1px dashed #e2e8f0; display: flex; flex-direction: column; gap: 10px; }
.zpm-editor label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: #94a3b8; display: flex; flex-direction: column; gap: 4px; }
.zpm-row { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.zpm-row input,.zpm-row select { padding: 7px 10px; border: 1.5px solid #e2e8f0; border-radius: 9px; font: inherit; font-size: 13px; background: #fff; color: #0f172a; outline: none; min-width: 0; }
.zpm-row input:focus,.zpm-row select:focus { border-color: var(--z-brand); }
.zpm-row input[type=color] { padding: 2px; width: 40px; height: 34px; border-radius: 6px; }
.zpm-upload { align-items: center; justify-content: center; min-width: 110px; height: 44px; border: 2px dashed #cbd5e1; border-radius: 10px; cursor: pointer; overflow: hidden; font-size: 11px; display: inline-flex; color: #94a3b8; font-weight: 600; transition: all .12s; }
.zpm-upload:hover { border-color: var(--z-brand); color: var(--z-brand); background: #f5f3ff; }
.zpm-upload img { height: 100%; object-fit: contain; }
.zpm-upload input { display: none; }

/* ─────── CONFIRM MODAL ─────── */
.zpos-confirm-ovr {
  position: fixed; inset: 0; z-index: 9999;
  display: flex; align-items: center; justify-content: center;
  background: rgba(15, 23, 42, .45);
  backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px);
  opacity: 0; transition: opacity .16s ease;
  padding: 20px;
}
.zpos-confirm-ovr.show { opacity: 1; }
.zpos-confirm-box {
  background: #fff; border-radius: 18px;
  width: 100%; max-width: 380px;
  padding: 28px 26px 22px;
  text-align: center;
  box-shadow: 0 24px 64px -12px rgba(15, 23, 42, .35), 0 0 0 1px rgba(15,23,42,.04);
  transform: translateY(12px) scale(.96);
  transition: transform .2s cubic-bezier(.34, 1.56, .64, 1);
  font-family: inherit;
}
.zpos-confirm-ovr.show .zpos-confirm-box { transform: translateY(0) scale(1); }
.zpos-confirm-ico {
  width: 56px; height: 56px; margin: 0 auto 16px;
  display: flex; align-items: center; justify-content: center;
  font-size: 26px; border-radius: 16px;
  background: #ede9fe; color: var(--z-brand);
}
.zpos-confirm-box.is-danger .zpos-confirm-ico {
  background: #fef2f2; color: #ef4444;
}
.zpos-confirm-title {
  font-size: 17px; font-weight: 800; color: #0f172a;
  margin-bottom: 6px; letter-spacing: -.01em;
}
.zpos-confirm-msg {
  font-size: 13.5px; color: #64748b; line-height: 1.55;
  margin-bottom: 22px;
}
.zpos-confirm-actions {
  display: flex; gap: 10px;
}
.zpos-confirm-actions button {
  flex: 1; padding: 11px 14px;
  font: 700 13.5px inherit; border-radius: 11px;
  cursor: pointer; transition: all .13s;
  border: 1.5px solid transparent;
}
.zpos-confirm-cancel {
  background: #f1f5f9; color: #475569; border-color: #e2e8f0;
}
.zpos-confirm-cancel:hover { background: #e2e8f0; }
.zpos-confirm-ok {
  background: linear-gradient(135deg, var(--z-brand), var(--z-brand-d));
  color: #fff;
  box-shadow: 0 4px 14px rgba(124, 58, 237, .35);
}
.zpos-confirm-ok:hover { filter: brightness(1.08); transform: translateY(-1px); }
.zpos-confirm-box.is-danger .zpos-confirm-ok {
  background: linear-gradient(135deg, #ef4444, #dc2626);
  box-shadow: 0 4px 14px rgba(239, 68, 68, .35);
}
.zpos-confirm-ok:focus-visible { outline: 2px solid #fff; outline-offset: -4px; }
@media (max-width: 600px) {
  .zpos-confirm-actions { flex-direction: column-reverse; }
}

/* ─────── SCROLLBARS ─────── */
.zpos *::-webkit-scrollbar { width: 5px; height: 5px; }
.zpos *::-webkit-scrollbar-track { background: transparent; }
.zpos *::-webkit-scrollbar-thumb { background: #e2e8f0; border-radius: 999px; }
.zpos *::-webkit-scrollbar-thumb:hover { background: #cbd5e1; }

/* ─────── MOBILE ─────── */
@media (max-width: 600px) {
  .zpos-top { padding: 0 12px; height: 46px; }
  .zpos-sub, .zpos-status { display: none; }
  .zpv { flex-direction: column; }
  .zpv-left {
    width: 100%; min-width: 0; flex-direction: row;
    border-right: none; border-bottom: 1px solid #e2e8f0;
  }
  .zpv-srch { display: none; }
  .zpv-cats { flex-direction: row; overflow-x: auto; padding: 6px; gap: 4px; }
  .zpv-cat { white-space: nowrap; padding: 6px 10px; }
  .zpv-cnt { display: none; }
  .zpv-right { width: 100%; min-width: 0; }
}


/* TIPOGRAFIA TPV - Open Sans (cuerpo) + Barlow (display) */
.zpos, .zpos input, .zpos select, .zpos textarea, .zpos button {
  font-family: 'Barlow','Segoe UI',system-ui,sans-serif;
}
.zpos-title, .zpos-tab, .zpos-restab,
.zpv-ttitle, .zpv-pprice, .zpv-pname, .zpv-pico,
.zpos-total b, .zpos-charge, .zpv-charge, .zpv-charge b,
.zpos-gate-h, .zpos-gate-btn, .zpos-gate-turn,
.zpos-status b, .zpos-section-head h3,
.zpv-trow .val, #zpc-nd, .zpv-numpad button {
  font-family: 'Barlow','Segoe UI',system-ui,sans-serif;
}


/* Logo Usumba Rock en la pantalla Abrir turno */
.zpos-gate-logo{margin:2px auto 14px}
.zpos-gate-logo img{width:170px;max-width:72%;height:auto;display:block;margin:0 auto}


/* Cuadrar filas de Familias dentro de la columna (sin cortar botones) */
.zpm-col-fam .zpm-list .zpm-item{overflow:hidden!important}
.zpm-col-fam .zpm-list .zpm-item input{min-width:0!important;flex:1 1 0!important}
.zpm-col-fam .zpm-list .zpm-item .zpos-mark{flex:0 0 28px!important}
.zpm-col-fam .zpm-list .zpm-item button{flex:0 0 auto!important;padding:5px 9px!important;font-size:11.5px!important;white-space:nowrap!important}
.zpm-col-fam .zpm-list .zpm-item .zpm-del{padding:5px 8px!important}


/* Selector de Familia en Nuevo artículo (asociación clara) */
.zpm-fam-lbl{flex-basis:100%;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#7c3aed;margin:4px 2px -2px}
.zpm-fam-select{
  flex-basis:100%!important; appearance:none;-webkit-appearance:none;
  padding:11px 36px 11px 14px!important; border:1.5px solid #c7b6f5!important; border-radius:11px!important;
  background:#faf8ff!important; color:#0f172a!important; font-weight:700!important; font-size:14px!important; cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237c3aed' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")!important;
  background-repeat:no-repeat!important; background-position:right 12px center!important;
}
.zpm-fam-select:focus{border-color:#7c3aed!important;box-shadow:0 0 0 3px rgba(124,58,237,.15)!important;outline:none}


/* ─────── CIERRES POR TURNO ─────── */
.zpos-shifts { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px,1fr)); gap: 12px; padding: 0 18px 14px; }
.zpos-shift-card { background:#fff; border:1px solid #eef1f5; border-radius:18px; padding:16px; box-shadow:0 1px 3px rgba(15,23,42,.05), 0 6px 18px -10px rgba(15,23,42,.16); transition:transform .16s, box-shadow .16s; }
.zpos-shift-card:hover { transform:translateY(-2px); box-shadow:0 12px 28px -10px rgba(15,23,42,.24); }
.zpos-shift-card.is-open { border-color:transparent; box-shadow:0 0 0 1.5px var(--z-brand-l), 0 12px 28px -8px rgba(124,58,237,.32); background:linear-gradient(180deg,#faf8ff,#fff 55%); }
.zpos-shift-top { display:flex; align-items:center; gap:11px; margin-bottom:13px; }
.zpos-shift-ic { width:42px; height:42px; flex-shrink:0; border-radius:13px; display:grid; place-items:center; font-size:21px; background:#f1f5f9; }
.zpos-shift-card.is-open .zpos-shift-ic { background:linear-gradient(135deg,var(--z-brand),var(--z-brand-d)); box-shadow:0 5px 14px -3px rgba(124,58,237,.45); }
.zpos-shift-h { display:flex; flex-direction:column; line-height:1.25; flex:1; min-width:0; }
.zpos-shift-h b { font-size:15px; font-weight:800; color:#0f172a; letter-spacing:-.01em; }
.zpos-shift-h span { font-size:11.5px; color:#94a3b8; font-weight:600; }
.zpos-shift-badge { font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.05em; padding:4px 10px; border-radius:999px; background:#f1f5f9; color:#64748b; white-space:nowrap; display:inline-flex; align-items:center; gap:6px; }
.zpos-shift-badge.open { background:var(--z-brand); color:#fff; box-shadow:0 3px 10px -2px rgba(124,58,237,.5); }
.zpos-shift-badge.open::before { content:''; width:6px; height:6px; border-radius:50%; background:#fff; animation:zpsPulse 1.4s infinite; }
@keyframes zpsPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.35;transform:scale(.65)} }
.zpos-shift-kpis { display:grid; grid-template-columns:1fr 1fr; gap:9px; }
.zpos-shift-kpis div { background:#f8fafc; border:1px solid #f1f5f9; border-radius:12px; padding:9px 11px; display:flex; flex-direction:column; gap:3px; }
.zpos-shift-card.is-open .zpos-shift-kpis div { background:#fff; border-color:#ede9fe; }
.zpos-shift-kpis span { font-size:9.5px; color:#94a3b8; text-transform:uppercase; letter-spacing:.06em; font-weight:800; }
.zpos-shift-kpis b { font-size:16px; font-weight:800; color:#0f172a; letter-spacing:-.02em; }
.zpos-shift-kpis b.pos { color:#16a34a; }
.zpos-shift-kpis b.neg { color:#dc2626; }
.zpos-day-total { margin:4px 18px 0; background:linear-gradient(135deg,var(--z-brand),var(--z-brand-d)); color:#fff; border-radius:14px; padding:16px 18px; box-shadow:0 6px 20px rgba(124,58,237,.3); }
.zpos-day-total-row { display:flex; align-items:center; justify-content:space-between; }
.zpos-day-total-row span { font-size:13px; font-weight:700; opacity:.9; text-transform:uppercase; letter-spacing:.05em; }
.zpos-day-total-row b { font-size:26px; font-weight:800; }
.zpos-day-total-sub { font-size:12px; opacity:.85; margin-top:4px; }
.zpos-close-actions { display:flex; gap:10px; margin-top:14px; padding:0 18px 18px; }
.zpos-close-actions button { flex:1; }
.zpos-section-head + .zpos-shifts, .zpos-shifts, .zpos-day-total { }
.zpos-print-btn { margin-left:10px; font-size:15px; background:#fff; border:1px solid #e2e8f0; border-radius:8px; padding:5px 9px; cursor:pointer; line-height:1; transition:background .12s,border-color .12s; }
.zpos-print-btn:hover { background:#ede9fe; border-color:#c7b6f5; }

/* ─────── DISEÑAR TICKET ─────── */
.zpos-tk-layout { display:grid; grid-template-columns:minmax(260px,1fr) minmax(300px,360px); gap:18px; padding:0 18px 18px; align-items:start; }
.zpos-tk-form { display:flex; flex-direction:column; gap:12px; }
.zpos-tk-form > label { font-size:10px; color:#64748b; text-transform:uppercase; letter-spacing:.06em; font-weight:700; display:flex; flex-direction:column; gap:5px; }
.zpos-tk-form input[type=text], .zpos-tk-form input:not([type]), .zpos-tk-form input[type=tel] { padding:10px 12px; border:1px solid #e2e8f0; border-radius:10px; font:inherit; font-size:14px; }
.zpos-tk-form .tk-check { flex-direction:row; align-items:center; gap:8px; text-transform:none; font-size:13px; color:#0f172a; font-weight:600; }
.zpos-tk-form .tk-check input { width:18px; height:18px; accent-color:var(--z-brand); }
.zpos-tk-prev { position:sticky; top:8px; }
.zpos-tk-prev-label { font-size:10px; color:#94a3b8; text-transform:uppercase; letter-spacing:.08em; font-weight:700; margin-bottom:8px; text-align:center; }
.zpos-tk-paper { background:#fff; border-radius:6px; box-shadow:0 10px 30px rgba(15,23,42,.18); margin:0 auto; width:280px; overflow:hidden; }
.zpos-tk-paper .tk { width:280px; }

/* ─────── PROMPT IMPRIMIR TRAS COBRO ─────── */
.zpos-print-prompt { position:fixed; right:20px; bottom:20px; z-index:9999; background:#fff; border:1px solid #e2e8f0; border-radius:14px; box-shadow:0 12px 36px rgba(15,23,42,.22); padding:14px 16px; display:flex; align-items:center; gap:10px; animation:zppslide .25s ease; }
.zpos-print-prompt span { font-size:13px; font-weight:700; color:#0f172a; }
.zpos-print-prompt button { width:auto; padding:9px 14px; }
.zpos-print-prompt .zpos-ghost { padding:9px 12px; }
@keyframes zppslide { from{ transform:translateY(12px); opacity:0; } to{ transform:translateY(0); opacity:1; } }

@media (max-width:760px){
  .zpos-tk-layout { grid-template-columns:1fr; }
  .zpos-tk-prev { position:static; }
  .zpos-close-actions { flex-direction:column; }
}


/* Eliminar pestaña Caja (Movimientos de caja) del TPV */
#zpos-tab-caja{display:none!important}
/* ════════════════════════════════════════════════════════════════
   === REDESIGN POS PREMIUM ===  (Stripe / Square / Linear style)
   Paleta #6D4AFF · Inter · radios 16-18 · sombras suaves · glass sutil
   Scoped a .zpos · !important para ganar a inline styles y reglas previas
═══════════════════════════════════════════════════════════════════ */
.zpos{
  --p:#6D4AFF; --ph:#5B35F5; --p-soft:#F2EFFF; --p-soft2:#E9E4FF;
  --bg:#F6F7FB; --surface:#FFFFFF; --ink:#16181D; --muted:#6B7280;
  --bd:#ECEEF4; --ok:#10B981; --dg:#EF4444; --wn:#F59E0B;
  --r:16px; --rc:18px;
  --sh:0 10px 30px rgba(16,24,40,.08);
  --sh-sm:0 1px 2px rgba(16,24,40,.04), 0 1px 3px rgba(16,24,40,.06);
  --sh-md:0 6px 18px -8px rgba(16,24,40,.14);
  --sh-lg:0 18px 44px -16px rgba(16,24,40,.20);
  /* recolor: todo lo que usa var(--z-brand) adopta el morado nuevo */
  --z-brand:#6D4AFF; --z-brand-d:#5B35F5; --z-brand-l:#A99BFF;
  background:var(--bg)!important; color:var(--ink)!important;
  font-family:'Inter','Segoe UI',system-ui,sans-serif!important;
}
.zpos *{ font-family:'Inter','Segoe UI',system-ui,sans-serif!important; }
.zpos ::-webkit-scrollbar{ width:8px; height:8px; }
.zpos ::-webkit-scrollbar-thumb{ background:#dfe3ec; border-radius:99px; }
.zpos ::-webkit-scrollbar-thumb:hover{ background:#cdd3e0; }

/* ── HEADER ───────────────────────────────────────────── */
.zpos .zpos-top{ height:64px!important; min-height:64px!important; padding:0 22px!important; background:var(--surface)!important; border-bottom:1px solid var(--bd)!important; gap:14px!important; }
.zpos .zpos-mark{ width:34px!important; height:34px!important; border-radius:11px!important; background:linear-gradient(135deg,var(--p),var(--ph))!important; box-shadow:0 6px 16px -5px rgba(109,74,255,.5)!important; font-size:15px!important; }
.zpos .zpos-title{ font-size:14.5px!important; font-weight:700!important; color:var(--ink)!important; letter-spacing:-.01em!important; }
.zpos .zpos-sub{ font-size:11.5px!important; color:var(--muted)!important; }
.zpos .zpos-top-actions{ gap:8px!important; margin-right:168px!important; }
.zpos .zpos-select, .zpos .zpos-ghost{
  height:40px!important; border-radius:12px!important; border:1px solid var(--bd)!important;
  background:var(--surface)!important; color:var(--ink)!important; font-size:12.5px!important; font-weight:600!important;
  box-shadow:var(--sh-sm)!important; transition:all .16s!important;
}
.zpos .zpos-select{ padding:0 34px 0 14px!important; }
.zpos .zpos-ghost{ padding:0 16px!important; gap:7px!important; }
.zpos .zpos-select:hover, .zpos .zpos-ghost:hover{ border-color:#dcdfea!important; background:#fcfcff!important; transform:translateY(-1px)!important; }
.zpos .zpos-select:focus{ border-color:var(--p)!important; box-shadow:0 0 0 3px rgba(109,74,255,.14)!important; }
.zpos .zpos-ghost:hover{ color:var(--p)!important; }
.zpos .zpos-primary{
  height:40px!important; border-radius:12px!important; padding:0 18px!important; font-size:12.5px!important; font-weight:700!important;
  background:linear-gradient(135deg,var(--p),var(--ph))!important;
  box-shadow:0 8px 20px -7px rgba(109,74,255,.5), inset 0 1px 0 rgba(255,255,255,.18)!important; transition:all .16s!important;
}
.zpos .zpos-primary:hover{ transform:translateY(-1px)!important; filter:brightness(1.05)!important; box-shadow:0 12px 26px -8px rgba(109,74,255,.6)!important; }

/* ── TABS · segmented control ─────────────────────────── */
.zpos .zpos-tabs{ padding:7px 14px!important; background:var(--surface)!important; border-bottom:1px solid var(--bd)!important; gap:4px!important; }
.zpos .zpos-tab{ height:36px!important; padding:0 16px!important; border-radius:11px!important; font-size:12.5px!important; font-weight:600!important; color:var(--muted)!important; transition:all .15s!important; }
.zpos .zpos-tab:hover:not(.active){ background:var(--p-soft)!important; color:var(--ink)!important; }
.zpos .zpos-tab.active{ background:var(--p)!important; color:#fff!important; font-weight:700!important; box-shadow:0 6px 16px -6px rgba(109,74,255,.55)!important; }

/* ── STATUS BAR (footer) ──────────────────────────────── */
.zpos .zpos-status{ padding:7px 22px!important; background:var(--surface)!important; border-top:1px solid var(--bd)!important; gap:22px!important; }
.zpos .zpos-status span{ color:#9aa1ad!important; }
.zpos .zpos-status b{ color:var(--ink)!important; font-weight:700!important; }

/* ── LAYOUT base ──────────────────────────────────────── */
.zpos .zpv{ background:var(--bg)!important; gap:0!important; }
.zpos .zpv-center{ background:var(--bg)!important; padding:20px!important; }
.zpos .zpv-right{ width:392px!important; min-width:320px!important; background:var(--surface)!important; border-left:1px solid var(--bd)!important; margin-right:0!important; }

/* ── SIDEBAR categorías ───────────────────────────────── */
.zpos .zpv-left{ width:188px!important; min-width:160px!important; background:var(--surface)!important; border-right:1px solid var(--bd)!important; }
.zpos .zpv-srch input{ height:42px!important; border-radius:12px!important; border:1px solid var(--bd)!important; font-size:13px!important; box-shadow:var(--sh-sm)!important; }
.zpos .zpv-srch input:focus{ border-color:var(--p)!important; box-shadow:0 0 0 3px rgba(109,74,255,.13)!important; }
.zpos .zpv-cats{ padding:8px 10px 16px!important; gap:3px!important; }
.zpos .zpv-cat{ padding:10px 12px!important; border-radius:12px!important; font-size:13px!important; font-weight:600!important; color:#525866!important; gap:10px!important; transition:all .15s!important; }
.zpos .zpv-cat:hover{ background:var(--p-soft)!important; color:var(--ink)!important; }
.zpos .zpv-cat.active{ background:var(--p-soft2)!important; color:var(--ph)!important; font-weight:700!important; box-shadow:none!important; }
.zpos .zpv-cat .zpv-cico, .zpos .zpv-cat .zpv-ico{ color:#9aa1ad!important; }
.zpos .zpv-cat:hover .zpv-cico, .zpos .zpv-cat:hover .zpv-ico, .zpos .zpv-cat.active .zpv-cico, .zpos .zpv-cat.active .zpv-ico{ color:var(--p)!important; }
.zpos .zpv-cnt{ font-size:11px!important; font-weight:700!important; min-width:22px!important; height:20px!important; display:inline-flex!important; align-items:center!important; justify-content:center!important; padding:0 7px!important; border-radius:999px!important; background:#eef0f5!important; color:#8b92a0!important; }
.zpos .zpv-cat.active .zpv-cnt{ background:#fff!important; color:var(--ph)!important; box-shadow:var(--sh-sm)!important; }

/* ── TARJETAS DE PRODUCTO ──────────────────────────────── */
.zpos .zpv-grid{ grid-template-columns:repeat(auto-fill,minmax(158px,1fr))!important; gap:16px!important; }
.zpos .zpv-prod{
  border-radius:var(--rc)!important; border:1px solid var(--bd)!important; background:var(--surface)!important; overflow:visible!important;
  box-shadow:var(--sh-sm)!important; transition:transform .2s cubic-bezier(.34,1.4,.5,1), box-shadow .2s, border-color .2s!important;
}
.zpos .zpv-prod:hover{ transform:translateY(-5px)!important; box-shadow:var(--sh)!important; border-color:#e0dcfb!important; }
.zpos .zpv-prod:active{ transform:translateY(-1px) scale(.99)!important; }
/* imagen ~55% de la tarjeta */
.zpos .zpv-pico{
  aspect-ratio:1.5/1!important; height:auto!important; border-radius:var(--rc) var(--rc) 0 0!important; overflow:hidden!important;
  font-size:30px!important; font-weight:800!important; letter-spacing:-.5px!important; text-shadow:none!important;
}
.zpos .zpv-pico img{ border-radius:var(--rc) var(--rc) 0 0!important; }
.zpos .zpv-pico::after{ display:none!important; }
/* bloques sin imagen: gradiente sutil en vez de color sólido */
.zpos .zpv-pico:not(:has(img)){
  background:linear-gradient(155deg, color-mix(in srgb, var(--b,#6D4AFF) 16%, #fff), color-mix(in srgb, var(--b,#6D4AFF) 7%, #fff))!important;
  color:var(--b,#6D4AFF)!important;
}
.zpos .zpv-prod-body{ padding:12px 13px 14px!important; gap:3px!important; }
.zpos .zpv-pname{ font-size:13px!important; font-weight:700!important; color:var(--ink)!important; letter-spacing:-.01em!important; }
.zpos .zpv-psub{ font-size:10px!important; font-weight:600!important; letter-spacing:.05em!important; text-transform:uppercase!important; color:#a3a9b4!important; }
.zpos .zpv-pprice{ font-size:17px!important; font-weight:800!important; color:var(--ink)!important; margin-top:7px!important; letter-spacing:-.02em!important; }
/* botón + flotante */
.zpos .zpv-prod::after{
  content:'+'!important; position:absolute!important; top:auto!important; bottom:60px!important; right:11px!important;
  width:34px!important; height:34px!important; border-radius:50%!important;
  background:var(--surface)!important; color:var(--p)!important; border:1px solid var(--bd)!important;
  display:grid!important; place-items:center!important; font-size:22px!important; font-weight:400!important; line-height:1!important;
  box-shadow:0 4px 12px rgba(16,24,40,.16)!important; z-index:3!important; pointer-events:none!important;
  transition:transform .18s cubic-bezier(.34,1.6,.5,1), background .18s, color .18s, box-shadow .18s!important;
}
.zpos .zpv-prod:hover::after{ background:linear-gradient(135deg,var(--p),var(--ph))!important; color:#fff!important; transform:scale(1.12) rotate(90deg)!important; box-shadow:0 8px 18px -4px rgba(109,74,255,.55)!important; }
.zpos .zpv-edit-ovr{ border-radius:10px!important; backdrop-filter:blur(6px)!important; background:rgba(255,255,255,.86)!important; }

/* ── CARRITO premium ──────────────────────────────────── */
.zpos .zpv-thead{ padding:18px 18px 14px!important; border-bottom:1px solid var(--bd)!important; }
.zpos .zpv-ttitle{ font-size:14px!important; font-weight:800!important; color:var(--ink)!important; letter-spacing:-.01em!important; }
.zpos .zpv-ttitle span{ color:var(--muted)!important; font-weight:600!important; }
.zpos .zpv-tclear{ border-radius:9px!important; background:#fef2f2!important; color:var(--dg)!important; font-weight:700!important; padding:5px 11px!important; }
.zpos .zpv-lines{ padding:10px 14px!important; }
/* línea de producto */
.zpos .zpv-line{ padding:11px!important; border-radius:14px!important; border:1px solid transparent!important; transition:background .14s, border-color .14s!important; }
.zpos .zpv-line:hover{ background:#fafaff!important; border-color:var(--bd)!important; }
.zpos .zpv-lname{ font-size:13px!important; font-weight:700!important; color:var(--ink)!important; }
.zpos .zpv-lsub{ font-size:11px!important; color:#a3a9b4!important; }
.zpos .zpv-lprice{ font-size:14px!important; font-weight:800!important; color:var(--ink)!important; letter-spacing:-.01em!important; }
.zpos .zpv-lqty, .zpos .zpv-lctrl{ gap:6px!important; }
.zpos .zpv-lbtn{ width:28px!important; height:28px!important; border-radius:9px!important; border:1px solid var(--bd)!important; background:var(--surface)!important; color:var(--ink)!important; font-weight:700!important; box-shadow:var(--sh-sm)!important; transition:all .13s!important; }
.zpos .zpv-lbtn:hover{ border-color:var(--p)!important; color:var(--p)!important; background:var(--p-soft)!important; }
/* empty state */
.zpos .zpv-ecart{ padding:46px 24px!important; color:var(--muted)!important; }
.zpos .zpv-ecart-ico{ width:72px!important; height:72px!important; border-radius:20px!important; background:linear-gradient(160deg,var(--p-soft),#fff)!important; color:var(--p)!important; display:grid!important; place-items:center!important; font-size:30px!important; margin:0 auto 14px!important; box-shadow:var(--sh-sm)!important; }
/* totales */
.zpos .zpv-tots{ padding:16px 18px!important; border-top:1px solid var(--bd)!important; background:#fcfcff!important; }
.zpos .zpv-trow{ padding:4px 0!important; }
.zpos .zpv-trow .lbl{ font-size:12.5px!important; color:var(--muted)!important; }
.zpos .zpv-trow .val{ font-size:13px!important; font-weight:600!important; color:#475569!important; }
.zpos .zpv-trow.grand{ margin-top:8px!important; padding-top:12px!important; border-top:1.5px dashed var(--bd)!important; }
.zpos .zpv-trow.grand .lbl{ font-size:14px!important; font-weight:800!important; color:var(--ink)!important; }
.zpos .zpv-trow.grand .val{ font-size:26px!important; font-weight:800!important; color:var(--p)!important; letter-spacing:-.02em!important; }

/* ── NUMPAD ───────────────────────────────────────────── */
.zpos .zpv-numpad{ padding:0 16px!important; }
.zpos .zpv-nd{ height:54px!important; border-radius:14px!important; background:var(--p-soft)!important; color:var(--ph)!important; font-size:24px!important; font-weight:800!important; padding:0 16px!important; letter-spacing:-.01em!important; display:flex!important; align-items:center!important; justify-content:flex-end!important; }
.zpos .zpv-keys{ gap:8px!important; }
.zpos .zpv-key{
  height:48px!important; border-radius:13px!important; border:1px solid var(--bd)!important; background:var(--surface)!important;
  color:var(--ink)!important; font-size:16px!important; font-weight:700!important; box-shadow:var(--sh-sm)!important; transition:all .12s!important;
}
.zpos .zpv-key:hover{ border-color:#dcdfea!important; background:#fafbff!important; transform:translateY(-1px)!important; box-shadow:var(--sh-md)!important; }
.zpos .zpv-key:active{ transform:translateY(0) scale(.96)!important; }
.zpos .zpv-key.del{ color:var(--dg)!important; background:#fef4f4!important; border-color:#fbdcdc!important; }
.zpos .zpv-key.eq{ color:#fff!important; background:linear-gradient(135deg,var(--p),var(--ph))!important; border-color:transparent!important; box-shadow:0 6px 14px -5px rgba(109,74,255,.5)!important; }
/* operadores en gris secundario (÷ × − + % ) */
.zpos .zpv-keys .zpv-key:nth-child(4){ color:var(--muted)!important; }

/* ── MÉTODOS DE PAGO ──────────────────────────────────── */
.zpos .zpv-pays{ gap:8px!important; padding:14px 16px 6px!important; }
.zpos .zpv-pay{ height:46px!important; border-radius:13px!important; border:1.5px solid var(--bd)!important; background:var(--surface)!important; color:#475569!important; font-size:13px!important; font-weight:700!important; box-shadow:var(--sh-sm)!important; transition:all .14s!important; }
.zpos .zpv-pay:hover{ border-color:#cfd4e0!important; transform:translateY(-1px)!important; }
.zpos .zpv-pay.act{ border-color:var(--p)!important; background:var(--p-soft)!important; color:var(--ph)!important; box-shadow:0 0 0 3px rgba(109,74,255,.12)!important; }

/* ── BOTÓN COBRAR (protagonista) ──────────────────────── */
.zpos .zpv-cta{ padding:12px 16px 18px!important; }
.zpos .zpv-charge{
  height:64px!important; border-radius:16px!important; font-size:16px!important; font-weight:800!important; letter-spacing:.01em!important;
  background:linear-gradient(135deg,var(--p),var(--ph))!important; color:#fff!important; gap:10px!important;
  display:flex!important; align-items:center!important; justify-content:center!important;
  box-shadow:0 14px 32px -10px rgba(109,74,255,.6), inset 0 1px 0 rgba(255,255,255,.2)!important;
  transition:transform .15s, box-shadow .15s, filter .15s!important;
}
.zpos .zpv-charge::before{
  content:''!important; width:21px!important; height:21px!important; flex-shrink:0!important;
  background:currentColor!important;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='2' y='5' width='20' height='14' rx='2'/%3E%3Cline x1='2' y1='10' x2='22' y2='10'/%3E%3C/svg%3E") center/contain no-repeat!important;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='2' y='5' width='20' height='14' rx='2'/%3E%3Cline x1='2' y1='10' x2='22' y2='10'/%3E%3C/svg%3E") center/contain no-repeat!important;
}
.zpos .zpv-charge b{ font-size:18px!important; font-weight:800!important; }
.zpos .zpv-charge:hover:not([disabled]){ transform:translateY(-2px)!important; filter:brightness(1.05)!important; box-shadow:0 20px 40px -12px rgba(109,74,255,.7)!important; }
.zpos .zpv-charge:active:not([disabled]){ transform:translateY(0) scale(.99)!important; }
.zpos .zpv-charge[disabled]{ background:#e8eaf0!important; color:#a8aebb!important; box-shadow:none!important; }
.zpos .zpv-charge[disabled]::before{ opacity:.5!important; }

/* ── RESPONSIVE (tablet / táctil 15") ─────────────────── */
@media (max-width:1100px){
  .zpos .zpv-right{ width:340px!important; min-width:300px!important; }
  .zpos .zpv-grid{ grid-template-columns:repeat(auto-fill,minmax(140px,1fr))!important; }
}
@media (max-width:820px){
  .zpos .zpv{ flex-direction:column!important; }
  .zpos .zpv-left{ width:100%!important; flex-direction:row!important; border-right:none!important; border-bottom:1px solid var(--bd)!important; }
  .zpos .zpv-right{ width:100%!important; }
  .zpos .zpv-charge{ height:58px!important; }
}


/* === REDESIGN · CIERRE (formulario de cierre) === */
.zpos .zpos-close{ max-width:560px!important; margin:16px auto!important; padding:0!important; background:transparent!important; box-shadow:none!important; border:none!important; }
.zpos .zpos-close-form{ display:flex!important; flex-direction:column!important; gap:16px!important; padding:0!important; }
.zpos .zpos-close-form label{ display:flex!important; flex-direction:column!important; gap:7px!important; font-size:11px!important; font-weight:700!important; text-transform:uppercase!important; letter-spacing:.05em!important; color:var(--muted)!important; }
.zpos .zpos-close-form input, .zpos .zpos-close-form textarea{ height:48px!important; border-radius:14px!important; border:1.5px solid var(--bd)!important; background:var(--surface)!important; padding:0 14px!important; font-size:14px!important; font-weight:600!important; color:var(--ink)!important; box-shadow:0 1px 2px rgba(16,24,40,.05)!important; transition:border-color .15s, box-shadow .15s!important; outline:none!important; }
.zpos .zpos-close-form textarea{ height:auto!important; min-height:88px!important; padding:12px 14px!important; font-weight:500!important; resize:vertical!important; line-height:1.5!important; }
.zpos .zpos-close-form input:focus, .zpos .zpos-close-form textarea:focus{ border-color:var(--p)!important; box-shadow:0 0 0 3px rgba(109,74,255,.14)!important; }
.zpos .zpos-close-actions{ gap:12px!important; margin-top:18px!important; padding:0!important; }
.zpos .zpos-close-actions button{ height:54px!important; border-radius:15px!important; font-size:14.5px!important; font-weight:800!important; flex:1!important; }
.zpos .zpos-day-total{ border-radius:18px!important; box-shadow:0 14px 32px -12px rgba(109,74,255,.5)!important; }
.zpos .zpos-day-total-row b{ letter-spacing:-.02em!important; }
