/* ==========================================================================
   Colina · Proagrin — Hoja de estilos  (look inspirado en Tabler)
   Paleta: verde de marca + grises fríos limpios, tarjetas nítidas.
   ========================================================================== */
:root{
  /* Marca */
  --verde:#2f9e44; --verde-osc:#1f7a3d; --verde-cla:#40c057; --verde-claro2:#e6f5ec;
  --lima:#5bbd4b;
  /* Superficies (estilo Tabler: gris frío muy claro + blanco) */
  --bg:#f4f6fa; --card:#ffffff; --crema:#f4f6fa; --crema2:#ffffff;
  /* Texto y líneas */
  --tinta:#1a2231; --gris:#667085; --gris-cla:#eef1f6; --linea:#e6e8ee;
  /* Estados */
  --rojo:#e03131; --naranja:#e8590c; --amarillo:#f4c430;
  --azul:#1c7ed6;
  /* Sombras suaves */
  --sombra:0 1px 2px rgba(24,39,75,.05),0 4px 14px rgba(24,39,75,.06);
  --sombra-fuerte:0 10px 30px rgba(24,39,75,.12);
  --radio:14px; --radio-sm:9px;
  --sidebar:248px;
  font-size:15px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:"Inter","Segoe UI",system-ui,-apple-system,sans-serif;color:var(--tinta);
  background:var(--bg);-webkit-font-smoothing:antialiased;letter-spacing:-.01em}
h1,h2,h3{margin:0}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
input,select{font-family:inherit;font-size:1rem}

/* ---- Pantalla de carga ---- */
.boot{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;background:var(--bg)}
.boot-logo{font-size:56px}
.boot-title{font-size:22px;font-weight:800;color:var(--verde-osc)}
.boot-sub{color:var(--gris);letter-spacing:3px;font-size:12px;text-transform:uppercase}
.boot-spin{margin-top:18px;width:34px;height:34px;border:3px solid var(--verde-claro2);border-top-color:var(--verde);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ==========================================================================
   Layout general — barra lateral CLARA (estilo Tabler)
   ========================================================================== */
.shell{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar);flex:0 0 var(--sidebar);background:var(--card);
  border-right:1px solid var(--linea);color:var(--tinta);
  display:flex;flex-direction:column;padding:16px 14px;position:sticky;top:0;height:100vh}
.marca{display:flex;align-items:center;gap:11px;padding:6px 8px 16px;margin-bottom:6px;border-bottom:1px solid var(--linea)}
.marca-logo{font-size:26px;background:var(--verde-claro2);color:var(--verde-osc);width:44px;height:44px;border-radius:12px;display:grid;place-items:center}
.marca-txt strong{display:block;font-size:17px;line-height:1.15;color:var(--tinta);font-weight:800}
.marca-txt small{color:var(--gris);font-size:12px}
.nav{display:flex;flex-direction:column;gap:2px;flex:1;margin-top:8px}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;color:var(--gris);font-weight:600;font-size:.93rem;transition:.15s}
.nav-item:hover{background:var(--gris-cla);color:var(--tinta)}
.nav-item.activo{background:var(--verde);color:#fff;box-shadow:0 4px 12px rgba(47,158,68,.35)}
.nav-item.activo .nav-ico{opacity:1}
.nav-ico{font-size:1.1rem;width:22px;text-align:center;opacity:.9}
.marca-matriz{margin-top:12px;padding-top:14px;border-top:1px solid var(--linea);text-align:center}
.chip-matriz{display:inline-block;background:var(--tinta);color:var(--lima);font-weight:800;letter-spacing:2px;font-size:11px;padding:5px 12px;border-radius:7px}
.marca-matriz small{display:block;color:var(--gris);font-size:11px;margin-top:5px}

.contenido{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--linea);padding:11px 24px}
.menu-toggle{display:none;background:none;border:none;font-size:22px;cursor:pointer}
.topbar-titulo{font-weight:700;font-size:1.1rem}
.topbar-der{margin-left:auto;display:flex;gap:12px;align-items:center}
.badge{font-size:11px;font-weight:700;padding:5px 11px;border-radius:20px}
.badge-nube{background:#e7f0ff;color:var(--azul)}
.badge-local{background:var(--gris-cla);color:var(--gris)}
.outlet{padding:24px;overflow:auto}

/* ==========================================================================
   Piezas comunes
   ========================================================================== */
.vista{max-width:1180px;margin:0 auto}
.vista-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.vista-head h2{font-size:1.5rem;color:var(--tinta);font-weight:800}
.sub{color:var(--gris);margin:3px 0 0;font-size:.9rem}
.mini{color:var(--gris);font-weight:500;font-size:.85rem}

.btn{border:none;border-radius:9px;padding:10px 17px;font-weight:700;font-size:.92rem;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:7px;justify-content:center}
.btn:active{transform:translateY(1px)}
.btn-primario{background:var(--verde);color:#fff;box-shadow:0 2px 8px rgba(47,158,68,.3)}
.btn-primario:hover{background:var(--verde-osc)}
.btn-ghost{background:var(--card);color:var(--tinta);border:1px solid var(--linea)}
.btn-ghost:hover{background:var(--gris-cla)}
.btn-peligro{background:var(--rojo);color:#fff}
.btn.ancho{width:100%;margin-top:8px}

/* Íconos de línea (SVG) */
.ic{display:inline-block;vertical-align:-.15em;flex:0 0 auto}
.badge .ic{vertical-align:-.2em}

.ibtn{background:none;border:none;cursor:pointer;font-size:1.02rem;padding:6px;border-radius:8px;transition:.12s}
.ibtn:hover{background:var(--gris-cla)}

/* KPIs — tarjetas de estadística estilo dashboard */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.kpi{background:var(--card);border:1px solid var(--linea);border-radius:var(--radio);padding:18px;display:flex;gap:14px;align-items:center;box-shadow:var(--sombra);transition:.15s}
.kpi:hover{box-shadow:var(--sombra-fuerte);transform:translateY(-2px)}
.kpi-ico{font-size:1.5rem;width:50px;height:50px;flex:0 0 50px;border-radius:13px;background:var(--verde-claro2);color:var(--verde-osc);display:grid;place-items:center}
.kpi-num{font-size:1.45rem;font-weight:800;color:var(--tinta);line-height:1.1;letter-spacing:-.02em}
.kpi-lbl{color:var(--gris);font-size:.82rem;margin-top:2px}
.kpi-verde .kpi-ico{background:var(--verde);color:#fff}
.kpi-verde .kpi-num{color:var(--verde-osc)}
.kpi-alerta .kpi-ico{background:#fdecec;color:var(--rojo)}
.kpi-alerta .kpi-num{color:var(--rojo)}

/* Paneles */
.panel{background:var(--card);border:1px solid var(--linea);border-radius:var(--radio);padding:20px;box-shadow:var(--sombra);margin-bottom:18px}
.panel h3{font-size:1.02rem;color:var(--tinta);margin-bottom:14px;font-weight:700}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.dos-cols{display:flex;flex-direction:column;gap:10px}
.dos-cols>div{display:flex;justify-content:space-between;border-bottom:1px solid var(--linea);padding-bottom:9px}
.dato-lbl{color:var(--gris)}
.dato-val{font-weight:700}
.verde,.dato-val.verde{color:var(--verde)}
.rojo{color:var(--rojo)} .naranja{color:var(--naranja)}
.vacio{color:var(--gris);text-align:center;padding:18px;font-style:italic}
.ver-mas{color:var(--verde);font-weight:600;display:inline-block;margin-top:8px}

.lista-top{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.lista-top li{display:flex;align-items:center;gap:11px}
.rank,.lista-top .pos{background:var(--verde-claro2);color:var(--verde-osc);width:26px;height:26px;border-radius:8px;display:grid;place-items:center;font-size:.8rem;font-weight:800;flex:0 0 26px}
.lista-top .tn{flex:1}
.lista-top .tc{color:var(--gris);font-size:.85rem;font-weight:600}

/* ==========================================================================
   Tablas
   ========================================================================== */
.tabla-wrap{overflow:auto;background:var(--card);border:1px solid var(--linea);border-radius:var(--radio);box-shadow:var(--sombra)}
.tabla{width:100%;border-collapse:collapse;font-size:.92rem}
.tabla thead th{background:#f8fafc;color:var(--gris);text-align:left;padding:12px 15px;font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;position:sticky;top:0;border-bottom:1px solid var(--linea)}
.tabla td{padding:12px 15px;border-top:1px solid var(--linea);vertical-align:middle}
.tabla tbody tr{transition:.1s}
.tabla tbody tr:hover{background:#f8fafc}
.tabla .num{text-align:right;white-space:nowrap}
.tabla .fuerte{font-weight:700}
.tabla .acc{text-align:right;white-space:nowrap}
.mini-tabla{font-size:.88rem}
.mini-tabla td,.mini-tabla th{padding:9px 11px}
.pnombre{font-weight:600}
.pmeta{color:var(--gris);font-size:.78rem;margin-top:2px}
.fila-alerta{background:#fff8f1}
.fila-alerta:hover{background:#fff1e2}
.stock-pill{display:inline-block;min-width:34px;text-align:center;padding:3px 9px;border-radius:20px;background:var(--verde-claro2);color:var(--verde-osc);font-weight:700;font-size:.85rem}
.stock-pill.sbajo{background:#fdeccb;color:var(--naranja)}
.stock-pill.s0{background:#fadcdc;color:var(--rojo)}
.tag{font-size:.7rem;font-weight:700;padding:3px 8px;border-radius:6px;white-space:nowrap}
.tag-agr{background:var(--verde-claro2);color:var(--verde-osc)}
.tag-avi{background:#fdeede;color:#b5651d}

/* ==========================================================================
   Filtros / búsqueda
   ========================================================================== */
.barra-filtros{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;align-items:center}
.buscador{flex:1;min-width:220px}
.barra-filtros input,.barra-filtros select,.f-campo input,.f-campo select,.f-inline input{
  padding:10px 13px;border:1px solid var(--linea);border-radius:var(--radio-sm);background:var(--card);outline:none;transition:.15s;color:var(--tinta)}
.barra-filtros input:focus,.f-campo input:focus,.f-campo select:focus{border-color:var(--verde-cla);box-shadow:0 0 0 3px var(--verde-claro2)}
.f-inline{display:flex;align-items:center;gap:6px;color:var(--gris);font-size:.9rem}
.chips-rango{display:flex;gap:6px}
.chip{background:var(--gris-cla);border:none;padding:8px 14px;border-radius:20px;cursor:pointer;font-weight:600;font-size:.85rem}
.chip:hover{background:var(--verde-claro2);color:var(--verde-osc)}

/* ==========================================================================
   Formularios
   ========================================================================== */
.f-row{display:flex;gap:12px}
.f-campo{display:flex;flex-direction:column;gap:6px;margin-bottom:13px;flex:1}
.f-campo>span{font-size:.82rem;font-weight:600;color:var(--tinta)}
.f-campo>span small{font-weight:400;display:block;font-size:.72rem;color:var(--gris)}
.f-2{flex:2}
.f-nota{background:var(--bg);padding:11px;border-radius:var(--radio-sm)}
.margen-calc{background:var(--verde-claro2)!important;font-weight:700;color:var(--verde-osc)}

/* ==========================================================================
   Modal
   ========================================================================== */
.modal-overlay{position:fixed;inset:0;background:rgba(16,24,40,.55);display:grid;place-items:center;padding:16px;z-index:100;opacity:0;transition:.2s;backdrop-filter:blur(2px)}
.modal-overlay.visible{opacity:1}
.modal{background:var(--card);border-radius:var(--radio);width:100%;max-height:92vh;overflow:auto;box-shadow:var(--sombra-fuerte);transform:translateY(12px);transition:.2s}
.modal-overlay.visible .modal{transform:none}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:17px 20px;border-bottom:1px solid var(--linea);position:sticky;top:0;background:var(--card);z-index:1}
.modal-head h3{color:var(--tinta);font-weight:700}
.modal-x{background:none;border:none;font-size:26px;line-height:1;cursor:pointer;color:var(--gris)}
.modal-body{padding:20px}
.modal-acciones{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}
.confirm-msg{margin:0 0 8px;color:var(--tinta)}

/* ==========================================================================
   Toast
   ========================================================================== */
#toast-root{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{background:var(--tinta);color:#fff;padding:12px 20px;border-radius:11px;box-shadow:var(--sombra-fuerte);opacity:0;transform:translateY(12px);transition:.3s;font-weight:600;max-width:90vw}
.toast.visible{opacity:1;transform:none}
.toast-ok{background:var(--verde)}
.toast-err{background:var(--rojo)}

/* ==========================================================================
   Punto de Venta (POS)
   ========================================================================== */
.pos{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:20px;width:100%;max-width:1240px;margin:0 auto;align-items:start}
.pos-catalogo{min-width:0}
.pos-buscar{width:100%;padding:13px 16px;border:1px solid var(--linea);border-radius:var(--radio);margin-bottom:14px;font-size:1.05rem;background:var(--card)}
.pos-buscar:focus{outline:none;border-color:var(--verde-cla);box-shadow:0 0 0 3px var(--verde-claro2)}
.pos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:11px}
.prod-card{text-align:left;background:var(--card);border:1px solid var(--linea);border-radius:var(--radio-sm);padding:13px;cursor:pointer;transition:.12s;display:flex;flex-direction:column;gap:5px}
.prod-card:hover{border-color:var(--verde-cla);box-shadow:var(--sombra);transform:translateY(-2px)}
.prod-card.agotado{opacity:.5;cursor:not-allowed}
.pc-nombre{font-weight:700;font-size:.9rem;line-height:1.15}
.pc-meta{color:var(--gris);font-size:.74rem}
.pc-pie{display:flex;justify-content:space-between;align-items:center;margin-top:auto}
.pc-precio{color:var(--verde);font-weight:800}
.pc-stock{font-size:.72rem;color:var(--gris)}

.pos-carrito{background:var(--card);border:1px solid var(--linea);border-radius:var(--radio);box-shadow:var(--sombra);padding:17px;position:sticky;top:80px;display:flex;flex-direction:column;max-height:calc(100vh - 100px)}
.pos-carrito h3{color:var(--tinta);margin-bottom:10px;font-weight:700}
.carrito-items{overflow:auto;flex:1;margin:0 -4px;padding:0 4px}
.carrito-vacio{padding:40px 10px}
.ci{border-bottom:1px solid var(--linea);padding:11px 0}
.ci-top{display:flex;justify-content:space-between;align-items:center}
.ci-nombre{font-weight:600;font-size:.9rem}
.ci-x{background:none;border:none;color:var(--rojo);cursor:pointer;font-size:1rem}
.ci-linea{display:flex;align-items:center;gap:8px;margin-top:7px}
.ci-modo,.ci-modo-fijo{font-size:.78rem;color:var(--gris);flex:1;padding:6px;border:1px solid var(--linea);border-radius:8px;background:var(--card)}
.ci-modo-fijo{border:none;background:none}
.ci-cant{display:flex;align-items:center;gap:4px}
.ci-b{width:27px;height:27px;border:1px solid var(--linea);background:var(--card);border-radius:7px;cursor:pointer;font-weight:700;font-size:1rem}
.ci-b:hover{background:var(--gris-cla)}
.ci-input{width:52px;text-align:center;padding:5px;border:1px solid var(--linea);border-radius:7px}
.ci-sub{font-weight:700;min-width:64px;text-align:right}
.carrito-pie{border-top:2px solid var(--linea);margin-top:8px;padding-top:12px}
.total-linea{display:flex;justify-content:space-between;align-items:center;font-size:1.05rem;font-weight:700;margin:6px 0}
.total-num{font-size:1.5rem;color:var(--verde-osc);font-weight:800;letter-spacing:-.02em}
.pos-pago{width:100%}
.vuelto-linea{text-align:right;font-weight:700;min-height:20px}
.carrito-botones{display:flex;gap:10px;margin-top:10px}
.carrito-botones .btn-ghost{flex:0 0 auto}
.btn-cobrar{flex:1;font-size:1.05rem}

/* ==========================================================================
   Impresión
   ========================================================================== */
.print-head{display:none}
@media print{
  .sidebar,.topbar,.no-print,.vista-head .btn,.barra-filtros{display:none!important}
  .outlet{padding:0}
  .print-head{display:block;text-align:center;margin-bottom:14px}
  body{background:#fff}
  .panel,.kpi,.tabla-wrap{box-shadow:none;border-color:#ccc}
}

/* ==========================================================================
   Login
   ========================================================================== */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:20px;
  background:linear-gradient(135deg,var(--verde-osc),var(--verde) 55%,var(--lima))}
.login-card{background:var(--card);border-radius:18px;box-shadow:var(--sombra-fuerte);
  padding:36px 32px;width:100%;max-width:390px;text-align:center;display:flex;flex-direction:column}
.login-logo{font-size:52px;color:var(--verde);line-height:1}
.login-logo-img{max-width:120px;max-height:120px;margin:0 auto 6px;object-fit:contain}
.login-card h1{font-size:1.35rem;color:var(--tinta);margin:6px 0 2px;font-weight:800}
.login-matriz{letter-spacing:2px;font-size:12px;color:var(--gris);text-transform:uppercase;margin:0 0 20px}
.login-card .f-campo{text-align:left}
.login-card input{padding:12px 14px;border:1px solid var(--linea);border-radius:var(--radio-sm)}
.login-card input:focus{border-color:var(--verde-cla);box-shadow:0 0 0 3px var(--verde-claro2);outline:none}
.btn-login{margin-top:8px}
.login-error{color:var(--rojo);font-size:.88rem;font-weight:600;min-height:18px;margin-bottom:4px}
.login-pista{font-size:.78rem;color:var(--gris);margin:14px 0 0}

/* Logo e info de usuario en el shell */
.marca-logo-img{width:44px;height:44px;border-radius:12px;object-fit:cover;background:#fff}
.usuario-box{display:flex;flex-direction:column;line-height:1.15;text-align:right}
.usuario-nombre{font-weight:700;font-size:.85rem}
.usuario-rol{font-size:.72rem;color:var(--gris)}
.btn-salir{padding:8px 14px;font-size:.85rem}

/* Configuración: caja de logo */
.logo-box{display:flex;gap:14px;align-items:center;margin-bottom:16px}
.logo-preview{width:96px;height:96px;border:2px dashed var(--linea);border-radius:14px;display:grid;place-items:center;overflow:hidden;background:var(--bg);flex:0 0 auto}
.logo-preview img{width:100%;height:100%;object-fit:contain}
.logo-vacio{font-size:38px;color:var(--verde-cla)}
.logo-btns{display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.logo-subir{cursor:pointer}
.logo-nota{color:var(--gris);font-size:.75rem}

/* Usuarios */
.f-check{display:flex;align-items:center;gap:8px;margin:10px 0;font-size:.9rem}
.perm-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;background:var(--bg);
  border:1px solid var(--linea);border-radius:10px;padding:12px;margin-top:4px}
.perm-grid label{display:flex;gap:8px;align-items:center;font-size:.86rem;cursor:pointer}
.perm-grid input{accent-color:var(--verde)}
@media(max-width:480px){.perm-grid{grid-template-columns:1fr}}
.fila-inactiva{opacity:.55}
.roles-info ul{margin:6px 0 0;padding-left:18px;color:var(--gris);line-height:1.7;font-size:.9rem}
.roles-info b{color:var(--tinta)}

/* ==========================================================================
   Pedidos por WhatsApp
   ========================================================================== */
.btn-wa{background:#25D366;color:#fff;font-weight:700;box-shadow:0 2px 8px rgba(37,211,102,.35)}
.btn-wa:hover{background:#1da851}
.wa-preview{background:var(--bg);border:1px solid var(--linea);border-radius:10px;padding:13px 15px;
  font-size:.85rem;line-height:1.5;white-space:pre-wrap;word-break:break-word;max-height:320px;overflow:auto;color:var(--tinta);font-family:inherit;margin:0}
.cant-pedir{width:80px;text-align:right;padding:7px 9px;border:1px solid var(--linea);border-radius:8px}
.cant-pedir:focus{border-color:var(--verde-cla);outline:none;box-shadow:0 0 0 3px var(--verde-claro2)}

/* ==========================================================================
   Formas de pago (POS)
   ========================================================================== */
.metodo-pago{display:flex;gap:6px;margin:10px 0}
.mp{flex:1;padding:9px 4px;border:1px solid var(--linea);background:var(--card);border-radius:9px;cursor:pointer;font-weight:700;font-size:.85rem;color:var(--gris)}
.mp:hover{border-color:var(--verde-cla)}
.mp.activo{background:var(--verde);color:#fff;border-color:var(--verde)}
.nota-pago{font-size:.85rem;color:var(--gris);text-align:center;padding:8px;background:var(--bg);border-radius:9px;margin-bottom:6px}

/* ==========================================================================
   Pestañas (Contabilidad)
   ========================================================================== */
.tabs{display:flex;gap:4px;border-bottom:2px solid var(--linea);margin-bottom:16px;flex-wrap:wrap}
.tab{background:none;border:none;padding:10px 16px;cursor:pointer;font-weight:700;font-size:.92rem;color:var(--gris);border-bottom:3px solid transparent;margin-bottom:-2px}
.tab:hover{color:var(--tinta)}
.tab.activo{color:var(--verde-osc);border-bottom-color:var(--verde)}
.asiento-cab td{background:#f8fafc;border-top:2px solid var(--linea)}
.asiento-linea{gap:8px;align-items:center;margin-bottom:6px}
.asiento-linea select,.asiento-linea input{padding:8px 10px;border:1px solid var(--linea);border-radius:8px}
.asiento-lineas{margin:10px 0}
tfoot td{border-top:2px solid var(--linea);padding:11px 15px}

/* Etiquetas de vencimiento */
.tag-venc{background:#fadcdc;color:var(--rojo)}
.tag-porvencer{background:#fdeccb;color:var(--naranja)}

/* Barra del comparativo mensual (Reportes → Análisis) */
.barra-mes{height:14px;min-width:2px;border-radius:4px;background:linear-gradient(90deg,var(--verde-cla),var(--verde))}

/* ==========================================================================
   Responsive — adaptable a cualquier dispositivo
   ========================================================================== */
html,body{overflow-x:hidden}
.scrim{display:none}

/* --- Pantallas medianas (laptop chica / tablet horizontal) --- */
@media(max-width:1100px){
  .pos{grid-template-columns:minmax(0,1fr) 330px;gap:14px}
}

/* --- Tablet vertical --- */
@media(max-width:960px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:1fr}
  .pos{grid-template-columns:1fr}
  .pos-carrito{position:static;max-height:none}
  .outlet{padding:18px}
}

/* --- Teléfono --- */
@media(max-width:760px){
  :root{font-size:14px}

  /* Menú lateral deslizante con telón */
  .sidebar{position:fixed;z-index:50;left:-110%;transition:.25s;height:100vh;height:100dvh;
    width:80%;max-width:300px;box-shadow:var(--sombra-fuerte)}
  .sidebar.abierto{left:0}
  .sidebar.abierto + .scrim{display:block;position:fixed;inset:0;z-index:40;background:rgba(16,24,40,.5)}
  .menu-toggle{display:block;padding:6px 10px;border-radius:8px}
  .menu-toggle:active{background:var(--gris-cla)}

  /* Barra superior compacta */
  .topbar{padding:10px 12px;gap:8px}
  .topbar-titulo{font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
  .usuario-box{display:none}
  .btn-salir{padding:8px 10px}

  .outlet{padding:12px}
  .panel{padding:14px;border-radius:12px}
  .vista-head{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:14px}
  .vista-head h2{font-size:1.25rem}
  .vista-head .btn{width:100%}

  /* Filtros y formularios apilados */
  .barra-filtros{flex-direction:column;align-items:stretch;gap:8px}
  .buscador{min-width:0}
  .f-row{flex-direction:column;gap:0}
  /* Evita que el teléfono haga zoom al tocar un campo (iOS amplía si <16px) */
  input,select,textarea{font-size:16px}

  /* Botones cómodos para el dedo */
  .btn{padding:12px 16px;min-height:44px}
  .ibtn{padding:9px;min-width:40px;min-height:40px}
  .chip{padding:10px 14px}
  .mp{padding:12px 4px}
  .modal-acciones{flex-wrap:wrap}
  .modal-acciones .btn{flex:1;min-width:120px}

  /* KPIs compactos (2 por fila) */
  .kpis{gap:10px;margin-bottom:14px}
  .kpi{padding:12px;gap:10px}
  .kpi-ico{width:40px;height:40px;flex:0 0 40px;border-radius:10px}
  .kpi-num{font-size:1.15rem}
  .kpi-lbl{font-size:.74rem}

  /* Tablas: letra menor + desplazamiento horizontal suave */
  .tabla{font-size:.85rem}
  .tabla td,.tabla thead th{padding:9px 10px}
  .tabla-wrap{-webkit-overflow-scrolling:touch}

  /* Pestañas (Contabilidad) deslizables */
  .tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}
  .tab{white-space:nowrap;padding:10px 12px}

  /* POS en teléfono */
  .pos-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}
  .pos-buscar{padding:12px 14px}
  .pos-carrito{padding:13px}
  .carrito-botones{flex-wrap:wrap}
  .carrito-botones .btn{min-width:110px}
  .btn-cobrar{flex:1 1 100%}

  /* Login */
  .login-card{padding:26px 20px;border-radius:16px}

  /* Modal a pantalla casi completa */
  .modal-overlay{padding:8px}
  .modal{max-height:96vh;border-radius:12px}
  .modal-body{padding:14px}
}

/* --- Teléfonos angostos --- */
@media(max-width:400px){
  .pos-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .topbar .badge{display:none}
}
