*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter','Segoe UI',system-ui,sans-serif;background:#D6EEF8;display:flex;justify-content:stretch;align-items:flex-start;min-height:100vh;padding:0;font-weight:400;-webkit-font-smoothing:antialiased}
:root{
  --sidebar-w:220px;--top-h:52px;
  --col-primary:#133C55;--col-accent:#59A5D8;
  --col-bg:#EEF7FC;--col-card:#fff;--col-border:#D0E9F5;--col-text:#0C2233;
  --col-muted:#5B7E94;--col-success:#1A8A6E;--col-success-bg:#D4F0E8;
  --col-danger:#C0392B;--col-danger-bg:#FDECEA;--col-info:#386FA4;--col-info-bg:#D8E9F9;
  --radius:6px;--radius-lg:10px;
  --shadow-xs:0 1px 3px rgba(0,0,0,0.06);
  --shadow-sm:0 2px 8px rgba(0,0,0,0.07);
  --shadow-md:0 4px 16px rgba(0,0,0,0.08);
}
.app{display:flex;height:100vh;width:100%;max-width:100%;background:var(--col-bg);border-radius:0;overflow:hidden;border:none;font-size:13px;color:var(--col-text);position:relative}

/* SIDEBAR */
.sidebar{width:var(--sidebar-w);background:var(--col-primary);display:flex;flex-direction:column;flex-shrink:0}
.sidebar-logo{padding:16px;border-bottom:1px solid rgba(255,255,255,0.1);overflow:hidden;flex-shrink:0}
.logo-title{color:#fff;font-size:15px;font-weight:700;letter-spacing:0.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.logo-sub{color:rgba(255,255,255,0.5);font-size:10px;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.sidebar-nav{padding:12px 0;flex:1}
.nav-section{padding:6px 16px 4px;font-size:10px;color:rgba(255,255,255,0.4);text-transform:uppercase;letter-spacing:1px;margin-top:8px}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;color:rgba(255,255,255,0.75);cursor:pointer;transition:all 0.15s;border-left:3px solid transparent;font-size:13px}
.nav-item:hover{background:rgba(255,255,255,0.08);color:#fff}
.nav-item.active{background:rgba(255,255,255,0.12);color:#fff;border-left-color:var(--col-accent)}
/* Sidebar — Grupos colapsables */
.nav-group-header{display:flex;justify-content:space-between;align-items:center;padding:6px 16px 4px;font-size:10px;color:rgba(255,255,255,0.4);text-transform:uppercase;letter-spacing:1px;margin-top:8px;cursor:pointer;user-select:none;transition:color 0.15s}
.nav-group-header:hover{color:rgba(255,255,255,0.75)}
.nav-group-chevron{transition:transform 0.22s;font-size:13px;opacity:0.55;flex-shrink:0}
.nav-group.open .nav-group-chevron{transform:rotate(180deg)}
.nav-group-items{overflow:hidden}
.nav-group-items.collapsed{display:none}
/* SIDEBAR FOOTER — usuario / logout */
.sidebar-footer{padding:12px 14px;border-top:1px solid rgba(255,255,255,0.1);margin-top:auto;flex-shrink:0}
.sidebar-user-email{font-size:10px;color:rgba(255,255,255,0.5);margin-bottom:8px;word-break:break-all;line-height:1.3}
.btn-logout{display:flex;align-items:center;gap:7px;width:100%;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);border-radius:6px;padding:7px 10px;color:rgba(255,255,255,0.75);font-size:12px;font-family:inherit;cursor:pointer;transition:all 0.15s}
.btn-logout:hover{background:rgba(255,255,255,0.15);color:#fff}
/* INDEX — header usuario/logout */
.idx-user{display:flex;align-items:center;gap:10px;margin-left:auto}
.idx-user-email{font-size:12px;color:rgba(255,255,255,0.6)}
.idx-btn-logout{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);border-radius:6px;padding:6px 12px;color:#fff;font-size:12px;font-family:inherit;cursor:pointer;transition:all 0.15s;white-space:nowrap}
.idx-btn-logout:hover{background:rgba(255,255,255,0.2)}
.nav-item i{font-size:16px;opacity:0.8}
.create-dropdown{position:relative;margin:12px}
.create-btn{background:var(--col-accent);color:#fff;font-weight:700;border-radius:6px;padding:9px 12px;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;font-size:13px}
.create-btn:hover{background:#4490C4}
.create-menu{display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--col-card);border-radius:var(--radius);border:1px solid #eef0f5;z-index:200;overflow:hidden;box-shadow:var(--shadow-md)}
.create-menu.open{display:block}
.create-menu-item{padding:10px 14px;font-size:13px;color:var(--col-text);cursor:pointer;display:flex;align-items:center;gap:8px}
.create-menu-item:hover{background:var(--col-bg)}
.create-menu-item i{color:var(--col-primary)}

/* MAIN */
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{height:var(--top-h);background:var(--col-card);border-bottom:1px solid #eef0f5;box-shadow:var(--shadow-xs);display:flex;align-items:center;padding:0 20px;gap:12px;flex-shrink:0}
.topbar-title{font-weight:600;font-size:15px;color:var(--col-primary);flex:1}
.badge{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.badge-info{background:var(--col-info-bg);color:var(--col-info)}
.badge-danger{background:var(--col-danger-bg);color:var(--col-danger)}
.badge-success{background:var(--col-success-bg);color:var(--col-success)}
.content{flex:1;overflow:auto;padding:20px}
.view{display:none}.view.active{display:block}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--radius);font-size:12px;font-weight:500;cursor:pointer;border:1px solid #e8eaef;background:var(--col-card);color:var(--col-text);transition:all 0.12s;letter-spacing:0.1px}
.btn:hover{background:var(--col-bg)}
.btn-primary{background:#386FA4;color:#fff;border-color:#386FA4}
.btn-primary:hover{background:#2d5e8e}
.btn-accent{background:var(--col-accent);color:#fff;border-color:var(--col-accent);font-weight:600}
.btn-accent:hover{background:#4490C4}
.btn-danger{background:var(--col-danger);color:#fff;border-color:var(--col-danger)}
.btn-danger:hover{background:#991b1b}
.btn-sm{padding:3px 9px;font-size:11px}
.btn-ghost{border:none;background:transparent;color:var(--col-muted)}
.btn-ghost:hover{color:var(--col-primary);background:var(--col-bg)}

/* LISTS & TABLES */
.list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.search-bar{display:flex;align-items:center;gap:8px;background:var(--col-card);border:1px solid #e8eaef;border-radius:var(--radius);padding:5px 11px;width:240px;box-shadow:var(--shadow-xs)}
.search-bar i{color:var(--col-muted);font-size:16px}
.search-bar input{border:none;outline:none;font-size:13px;background:transparent;color:var(--col-text);width:100%}
.summary-cards{display:flex;gap:12px;margin-bottom:16px}
.summary-card{flex:1;background:var(--col-card);border:1px solid #eef0f5;border-radius:var(--radius);padding:10px 14px;display:flex;flex-direction:column;gap:3px;cursor:pointer;transition:all 0.18s;box-shadow:var(--shadow-xs)}
.summary-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.summary-card.active-filter{box-shadow:0 0 0 2px var(--col-primary);background-color:#f8fafc}
.summary-card-title{font-size:9.5px;font-weight:700;text-transform:uppercase;color:#9ca3af;letter-spacing:0.6px}
.summary-card-value{font-size:17px;font-weight:700;color:var(--col-text)}
.summary-card-value.danger{color:var(--col-danger)}
.summary-card-value.warn{color:var(--col-accent)}
.summary-card-value.info{color:var(--col-info)}
.summary-card-value.success{color:var(--col-success)}
.table-card{background:var(--col-card);border-radius:var(--radius-lg);border:1px solid #eef0f5;overflow:hidden;box-shadow:var(--shadow-xs)}
table{width:100%;border-collapse:collapse}
th{background:#f8f9fc;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.6px;color:#9ca3af;padding:7px 10px;text-align:left;border-bottom:1px solid #eef0f4}
td{padding:6px 10px;border-bottom:1px solid #f0f2f6;color:var(--col-text);vertical-align:middle;font-size:12.5px;font-weight:400}
tr:last-child td{border-bottom:none}
tr:hover td{background:#f8fafd;cursor:pointer;transition:background 0.1s}
.td-name{font-weight:600;color:var(--col-primary)}
.chk-cell{width:36px;text-align:center;padding-right:0}
.chk-cell input[type="checkbox"]{cursor:pointer;transform:scale(1.1);accent-color:var(--col-primary)}

/* DETAIL */
.detail-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.detail-avatar{width:46px;height:46px;border-radius:50%;background:var(--col-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;flex-shrink:0}
.detail-avatar.cli{background:#1A8A6E}
.detail-meta h2{font-size:16px;font-weight:700;color:var(--col-primary)}
.detail-meta p{font-size:12px;color:var(--col-muted);margin-top:2px}
.tabs{display:flex;gap:0;border-bottom:2px solid var(--col-border);margin-bottom:16px}
.tab{padding:8px 16px;font-size:12px;font-weight:500;color:#9ca3af;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all 0.12s}
.tab.active{color:var(--col-primary);border-bottom-color:var(--col-accent);font-weight:600}
.tab:hover:not(.active){color:var(--col-text)}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.info-field{background:#f8f9fc;border-radius:var(--radius);padding:7px 10px;border:1px solid #f0f2f6}
.info-field label{font-size:10px;text-transform:uppercase;letter-spacing:0.5px;color:var(--col-muted);font-weight:600}
.info-field .val{font-size:14px;font-weight:500;color:var(--col-text);margin-top:2px}
.tab-content{display:none}.tab-content.active{display:block}

/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:100;align-items:center;justify-content:center;border-radius:0}
.modal-overlay.open{display:flex}
.modal{background:var(--col-card);border-radius:var(--radius-lg);width:520px;max-height:540px;overflow:auto;box-shadow:0 8px 40px rgba(0,0,0,0.14),0 2px 8px rgba(0,0,0,0.06);border:1px solid #eef0f5}
.modal-head{padding:12px 18px;border-bottom:1px solid #f0f2f6;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--col-card);z-index:1}
.modal-head h3{font-size:15px;font-weight:700;color:var(--col-primary)}
.modal-body{padding:14px 18px}
.modal-footer{padding:10px 18px;border-top:1px solid #f0f2f6;display:flex;justify-content:flex-end;gap:8px;position:sticky;bottom:0;background:var(--col-card)}
.form-group{margin-bottom:10px}
.form-group label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:#9ca3af;margin-bottom:3px}
.form-group input,.form-group select{width:100%;padding:6px 9px;border:1px solid #e8eaef;border-radius:var(--radius);font-size:12.5px;color:var(--col-text);background:var(--col-card);outline:none;transition:border 0.15s;font-family:inherit}
.form-group input:focus,.form-group select:focus{border-color:var(--col-primary)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* HISTORIAL */
.hist-item{border:1px solid var(--col-border);border-radius:var(--radius);padding:8px 12px;margin-bottom:8px;display:flex;align-items:center;gap:12px}
.hist-item input[type="checkbox"]{cursor:pointer;transform:scale(1.1);accent-color:var(--col-primary)}
.hist-date{font-size:11px;color:var(--col-muted);min-width:80px}
.hist-medio{font-size:12px;color:var(--col-info);font-weight:500}
.hist-valor{margin-left:auto;font-weight:700;color:var(--col-success);font-size:14px}
.hist-nota{font-size:12px;color:var(--col-muted);margin-top:2px}
.empty-state{text-align:center;padding:40px;color:var(--col-muted)}
.empty-state i{font-size:36px;display:block;margin-bottom:8px;opacity:0.4}
.mapping-row{display:flex;align-items:center;gap:10px;margin-bottom:8px;border-bottom:1px dashed var(--col-border);padding-bottom:8px}
.mapping-row label{flex:1;margin:0;font-size:12px}
.mapping-row select{flex:1}

/* ÚLTIMOS PAGOS / COBROS */
.pago-factura-tag{background:var(--col-info-bg);color:var(--col-info);font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap}
.cobro-factura-tag{background:#D4F0E8;color:#1A8A6E;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap}
.fila-consolidada:hover td{background:#D8E9F9 !important;cursor:pointer}
/* ================================================================ */
/* DELIVERY — KANBAN                                                  */
/* ================================================================ */
.delivery-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-shrink:0}
.kanban-board{display:flex;gap:8px;overflow-x:visible;padding-bottom:8px;min-height:0;flex:1;align-items:flex-start}
.kanban-col{flex:1 1 0;min-width:0;background:#f0f2f7;border-radius:var(--radius-lg);display:flex;flex-direction:column;max-height:calc(100vh - 220px)}
.kanban-col-head{padding:10px 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.6px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.kanban-col-body{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:8px}
.kanban-card{background:var(--col-card);border-radius:var(--radius);border:1px solid #eef0f5;padding:9px 11px;cursor:pointer;transition:all 0.15s;position:relative;box-shadow:var(--shadow-xs)}
.kanban-card:hover{border-color:#d4d8e2;box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.kanban-card.dragging{opacity:0.4;transform:scale(0.97)}
.kanban-col.drag-over .kanban-col-body{background:rgba(232,160,32,0.08);border-radius:0 0 var(--radius-lg) var(--radius-lg);outline:2px dashed var(--col-accent)}
.kcard-name{font-weight:600;font-size:12px;color:var(--col-primary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kcard-dir{font-size:11px;color:var(--col-muted);margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kcard-tiempo{font-size:11px;font-weight:600;margin-bottom:6px;display:flex;align-items:center;gap:4px}
.kcard-total{font-size:13px;font-weight:700;color:var(--col-accent)}
.kcard-actions{display:flex;gap:4px;margin-top:8px;border-top:1px solid var(--col-border);padding-top:8px}
.kcard-btn{flex:1;font-size:10px;font-weight:600;padding:4px 6px;border-radius:5px;border:none;cursor:pointer;transition:all 0.15s;text-align:center}
.kcard-btn.prev{background:#f0f2f7;color:var(--col-muted)}
.kcard-btn.prev:hover{background:#e2e4ea;color:var(--col-text)}
.kcard-btn.next{background:var(--col-accent);color:#fff}
.kcard-btn.next:hover{background:#4490C4}
.kcard-btn.done{background:var(--col-success-bg);color:var(--col-success)}
.kcard-count{background:rgba(255,255,255,0.35);color:inherit;border-radius:10px;padding:1px 7px;font-size:10px;font-weight:700}
.col-programado .kanban-col-head{background:#e0e7ff;color:#3730a3}
.col-preparacion .kanban-col-head{background:#fef3c7;color:#92400e}
.col-listo .kanban-col-head{background:#d1fae5;color:#065f46}
.col-despachado .kanban-col-head{background:#D8E9F9;color:#386FA4}
.col-entregado .kanban-col-head{background:#f3f4f6;color:#6b7280}
.modal-delivery{width:min(1160px,calc(100vw - 32px));max-height:min(92vh,860px);border:1px solid rgba(89,165,216,0.14);box-shadow:0 18px 50px rgba(89,165,216,0.22);overflow:hidden!important;display:flex;flex-direction:column}
.del-section{margin-bottom:18px}
.del-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.6px;color:var(--col-muted);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--col-border)}
.mode-toggle{display:flex;gap:6px;margin-bottom:12px}
.mode-btn{padding:5px 14px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--col-border);background:var(--col-bg);color:var(--col-muted);transition:all 0.15s}
.mode-btn.active{background:var(--col-accent);color:#fff;border-color:var(--col-accent)}
.cliente-result{border:1px solid var(--col-border);border-radius:var(--radius);overflow:hidden;margin-top:4px;max-height:130px;overflow-y:auto}
.cliente-result-item{padding:8px 12px;cursor:pointer;font-size:12px;border-bottom:1px solid var(--col-border);transition:background 0.1s}
.cliente-result-item:last-child{border-bottom:none}
.cliente-result-item:hover{background:#fdf3e0}
.cliente-seleccionado{background:#fdf3e0;border:1px solid var(--col-accent);border-radius:var(--radius);padding:10px 12px;display:flex;align-items:center;justify-content:space-between;margin-top:4px}
.prod-resultado{padding:8px 12px;cursor:pointer;font-size:12px;border-bottom:1px solid var(--col-border);display:flex;justify-content:space-between;align-items:center;transition:background 0.1s}
.prod-resultado:last-child{border-bottom:none}
.prod-resultado:hover{background:#fdf3e0}
.item-pedido{display:flex;align-items:center;gap:8px;padding:7px 10px;border-bottom:1px solid var(--col-border);font-size:12px}
.item-pedido:last-child{border-bottom:none}
.item-qty-btn{width:22px;height:22px;border-radius:50%;background:var(--col-bg);border:1px solid var(--col-border);cursor:pointer;font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1}
.item-qty-btn:hover{background:var(--col-border)}
.totales-box{background:var(--col-bg);border-radius:var(--radius);padding:12px 14px}
.total-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;margin-bottom:8px}
.total-row:last-child{margin-bottom:0;border-top:1px solid var(--col-border);padding-top:10px;font-size:15px;font-weight:700}
.total-input{width:90px;padding:4px 8px;border:1px solid var(--col-border);border-radius:5px;font-size:12px;text-align:right;outline:none;background:var(--col-card);color:var(--col-text)}
.total-input:focus{border-color:var(--col-accent)}
.doc-msg{font-size:10px;margin-top:3px;font-weight:600}
.doc-validando{color:var(--col-muted)}
.doc-ok{color:var(--col-success)}
.doc-error{color:var(--col-danger)}
.cuanto-antes-row{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:12px;color:var(--col-text);cursor:pointer}
/* ================================================================ */
/* PRODUCCIÓN                                                        */
/* ================================================================ */
.op-card{background:var(--col-card);border-radius:var(--radius-lg);border:1px solid #eef0f5;box-shadow:var(--shadow-xs);padding:14px 16px;cursor:pointer;transition:all 0.15s}
.op-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px);border-color:#d4d8e2}
.op-estado{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:0.3px}
.op-estado.pendiente{background:#D8E9F9;color:#386FA4}
.op-estado.en-proceso{background:#fef3c7;color:#92400e}
.op-estado.completada{background:#D4F0E8;color:#1A8A6E}
.op-estado.cancelada{background:#f3f4f6;color:#6b7280}
.op-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.bom-editor-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px dashed var(--col-border)}
.bom-editor-row:last-child{border-bottom:none}
.prod-seccion{background:var(--col-card);border-radius:var(--radius-lg);border:1px solid #eef0f5;padding:14px 16px;margin-bottom:14px;box-shadow:var(--shadow-xs)}
.prod-seccion-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.6px;color:#9ca3af;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.alerta-stock{background:#fff5f5;border:1px solid #fecaca;border-radius:var(--radius);padding:8px 12px;font-size:12px;color:var(--col-danger);display:flex;align-items:center;gap:8px;margin-bottom:6px}
.alerta-stock i{flex-shrink:0}
.rendimiento-bar{height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden;margin-top:4px}
.rendimiento-fill{height:100%;border-radius:3px;transition:width 0.3s}


.modal-delivery .modal-head{background:linear-gradient(135deg,#ffffff 0%,#f8fafc 60%,#fdf3e0 100%)}
.modal-delivery .modal-head h3{display:flex;align-items:center;gap:7px;font-size:16px}
.delivery-modal-intro{background:#f8fafc;border:1px solid var(--col-border);border-radius:var(--radius-lg);padding:10px 12px;margin-bottom:16px;color:var(--col-muted);font-size:12px;display:flex;align-items:center;gap:8px}
.delivery-modal-intro i{color:var(--col-accent);font-size:18px}
.delivery-date-options{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.delivery-date-option{border:1px solid var(--col-border);background:#fff;border-radius:var(--radius-lg);padding:10px 12px;cursor:pointer;transition:all 0.15s;display:flex;align-items:flex-start;gap:9px;min-height:68px}
.delivery-date-option:hover{border-color:var(--col-accent);box-shadow:0 4px 12px rgba(89,165,216,0.06)}
.delivery-date-option.active{border-color:var(--col-accent);background:#fff8ed;box-shadow:0 0 0 2px rgba(232,160,32,0.14)}
.delivery-date-option input[type="checkbox"]{margin-top:2px;accent-color:var(--col-accent)}
.delivery-date-option strong{display:block;color:var(--col-primary);font-size:13px;margin-bottom:2px}
.delivery-date-option span{display:block;color:var(--col-muted);font-size:11px;line-height:1.3}
.delivery-programado-fields{display:none;background:#fff;border:1px solid var(--col-border);border-radius:var(--radius-lg);padding:12px;margin-top:8px}
.delivery-programado-fields.open{display:block}
.discount-panel{background:#fff;border:1px solid var(--col-border);border-radius:var(--radius-lg);padding:12px;margin-top:6px;width:100%}
.discount-panel-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}
.discount-title{font-size:12px;font-weight:700;color:var(--col-primary);display:flex;align-items:center;gap:6px}
.segmented-control{display:inline-flex;background:var(--col-bg);border:1px solid var(--col-border);border-radius:999px;padding:3px;gap:3px}
.segmented-control .segment-btn{border:0;background:transparent;color:var(--col-muted);border-radius:999px;padding:5px 12px;font-size:11px;font-weight:700;cursor:pointer;transition:all 0.15s;font-family:inherit}
.segmented-control .segment-btn.active{background:var(--col-primary);color:#fff;box-shadow:0 2px 8px rgba(89,165,216,0.18)}
.discount-field{display:none;align-items:center;gap:6px;justify-content:flex-end}
.discount-field.open{display:flex}
.select-premium{appearance:none;background-color:#fff;background-image:linear-gradient(45deg,transparent 50%,var(--col-muted) 50%),linear-gradient(135deg,var(--col-muted) 50%,transparent 50%);background-position:calc(100% - 16px) 50%,calc(100% - 11px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;border:1px solid var(--col-border);border-radius:var(--radius);color:var(--col-text);font-family:inherit;outline:none;padding:8px 34px 8px 10px;transition:border 0.15s,box-shadow 0.15s}
.select-premium:focus{border-color:var(--col-primary);box-shadow:0 0 0 3px rgba(89,165,216,0.08)}
.item-qty-input{width:42px;height:24px;border:1px solid var(--col-border);border-radius:7px;text-align:center;font-size:12px;font-weight:700;color:var(--col-primary);outline:none;background:#fff;font-family:inherit}
.item-qty-input:focus{border-color:var(--col-accent);box-shadow:0 0 0 3px rgba(232,160,32,0.12)}
.kcard-fiscal{display:flex;align-items:center;gap:4px;font-size:10px;font-weight:700;border-radius:20px;padding:3px 7px;margin-top:7px;width:max-content;max-width:100%}
.kcard-fiscal.pending{background:var(--col-danger-bg);color:var(--col-danger)}
.kcard-fiscal.ok{background:var(--col-success-bg);color:var(--col-success)}
.record-lock-alert{display:none;align-items:flex-start;gap:8px;background:#f8fafc;border:1px solid var(--col-border);border-radius:var(--radius);padding:9px 11px;margin-bottom:12px;color:var(--col-muted);font-size:12px}
.record-lock-alert.locked{display:flex;background:#fff8ed;border-color:#f5d38a;color:#92400e}
.record-lock-alert.open{display:flex}
.btn:disabled{opacity:.55;cursor:not-allowed;filter:saturate(.75)}
.fila-anulada{background:#fff5f5 !important}
.fila-anulada-rep{background:#fff5f5 !important}
.fila-anulada td{color:#9ca3af !important;pointer-events:none;font-style:italic}
.fila-anulada td:last-child{pointer-events:auto}
.fila-anulada:hover td{background:#fff5f5 !important;cursor:default}
.badge-anulado{background:#fff1f1;color:#dc2626;border:1px solid #fecaca;font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;letter-spacing:0.3px}
.fac-item-wrap{display:flex;flex-direction:column;gap:3px;margin-bottom:2px}
.fac-nota-input{width:100%;font-size:10px;padding:4px 8px;border:1px dashed var(--col-border);border-radius:5px;outline:none;color:var(--col-muted);background:#fafbfd;font-family:inherit;box-sizing:border-box}
.fac-nota-input:focus{border-color:var(--col-accent);background:#fff}
.fac-nota-global{width:100%;font-size:11px;padding:6px 9px;border:1px solid var(--col-border);border-radius:var(--radius);outline:none;font-family:inherit;resize:vertical;box-sizing:border-box;color:var(--col-text);background:#fff}
.fac-nota-global:focus{border-color:var(--col-accent)}
.btn:disabled:hover{background:inherit}
@media print{
  body.ticket-print-mode{background:#fff;padding:0;margin:0;display:block;min-height:auto}
  .ticket-print-container{width:70mm;margin:0 auto;height:auto}
}

/* Detalle delivery dentro del historial de factura */
.fac-delivery-badge{display:inline-flex;align-items:center;gap:5px;background:#fdf3e0;border:1px solid var(--col-accent);color:#92400e;font-size:10px;font-weight:700;padding:2px 9px;border-radius:20px;letter-spacing:0.3px}
.fac-det-bloque{background:var(--col-bg);border-radius:var(--radius);padding:10px 12px;margin-bottom:12px}
.fac-det-titulo{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:var(--col-muted);margin-bottom:8px}
.fac-det-prod{display:flex;justify-content:space-between;align-items:center;font-size:12px;padding:4px 0;border-bottom:1px dashed var(--col-border)}
.fac-det-prod:last-child{border-bottom:none}
.fac-det-row{display:flex;justify-content:space-between;font-size:12px;padding:3px 0}
.fac-det-total{display:flex;justify-content:space-between;font-size:13px;font-weight:700;padding:8px 0 0;border-top:1px solid var(--col-border);margin-top:4px}


/* ================================================================ */
/* REPORTES — VENTAS CON TABS, FILTROS Y DATAVIZ                    */
/* ================================================================ */
#view-delivery{display:none;flex-direction:column;height:100%}
#view-delivery.active{display:flex}
#view-rep-ventas .tabs{margin-bottom:0;background:var(--col-card);border:1px solid var(--col-border);border-bottom:2px solid var(--col-border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:0 12px}
#view-rep-ventas .tab{display:flex;align-items:center;gap:6px;white-space:nowrap}
.report-filter-bar{background:var(--col-card);border:1px solid var(--col-border);border-top:0;border-radius:0 0 var(--radius-lg) var(--radius-lg);padding:12px 14px;margin-bottom:16px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.report-filter-title{display:flex;align-items:center;gap:8px;color:var(--col-primary);font-weight:700;font-size:13px;white-space:nowrap}
.report-filter-title i{font-size:17px;color:var(--col-accent)}
.report-filter-title small{display:block;font-size:10px;font-weight:600;color:var(--col-muted);margin-top:1px;text-transform:uppercase;letter-spacing:0.4px}
.report-filter-main{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}
.report-filter-field{display:flex;flex-direction:column;gap:4px;min-width:150px}
.report-filter-field label{font-size:10px;text-transform:uppercase;letter-spacing:0.5px;color:var(--col-muted);font-weight:700}
.report-filter-field select,.report-filter-field input{height:32px;border:1px solid var(--col-border);border-radius:var(--radius);background:var(--col-card);color:var(--col-text);font-size:12px;padding:6px 10px;outline:none;font-family:inherit}
.report-filter-field select:focus,.report-filter-field input:focus{border-color:var(--col-primary)}
.report-date-control{display:none;align-items:flex-end;gap:8px}
.report-filter-caption{font-size:11px;color:var(--col-muted);background:var(--col-bg);border:1px solid var(--col-border);border-radius:20px;padding:7px 12px;white-space:nowrap;min-height:32px;display:flex;align-items:center}
.report-panel-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.report-panel-title{font-size:13px;font-weight:700;color:var(--col-primary);display:flex;align-items:center;gap:7px}
.report-chart-card{background:var(--col-card);border:1px solid var(--col-border);border-radius:var(--radius-lg);padding:14px;margin-bottom:16px;overflow:hidden}
.report-chart-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:12px}
.report-chart-head strong{font-size:13px;color:var(--col-primary);display:flex;align-items:center;gap:7px}
.report-chart-head small{font-size:11px;color:var(--col-muted);text-align:right}
.hbar-chart{display:flex;flex-direction:column;gap:9px}
.hbar-row{display:grid;grid-template-columns:minmax(120px,190px) 1fr minmax(80px,110px);align-items:center;gap:10px}
.hbar-label{font-size:12px;font-weight:600;color:var(--col-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hbar-label small{display:block;font-size:10px;color:var(--col-muted);font-weight:500;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hbar-track{height:18px;background:var(--col-bg);border:1px solid var(--col-border);border-radius:20px;overflow:hidden;position:relative}
.hbar-fill{height:100%;background:var(--col-accent);border-radius:20px;transition:width 0.25s ease}
.hbar-value{font-size:12px;font-weight:700;color:var(--col-success);text-align:right;white-space:nowrap}
.report-empty-chart{padding:26px 14px;text-align:center;color:var(--col-muted);background:var(--col-bg);border:1px dashed var(--col-border);border-radius:var(--radius);font-size:12px}
.pareto-wrap{width:100%;overflow-x:auto}
.pareto-svg{width:100%;min-width:620px;height:250px;display:block;background:#fff;border:1px solid var(--col-border);border-radius:var(--radius)}
.pareto-bar{fill:var(--col-accent)}
.pareto-line{stroke:var(--col-primary);stroke-width:2.5;fill:none}
.pareto-dot{fill:var(--col-primary)}
.pareto-axis{stroke:var(--col-border);stroke-width:1}
.pareto-grid{stroke:var(--col-border);stroke-width:0.7;stroke-dasharray:3 4}
.pareto-text{font-family:'Segoe UI',sans-serif;font-size:10px;fill:var(--col-muted)}
.pareto-value{font-family:'Segoe UI',sans-serif;font-size:10px;font-weight:700;fill:var(--col-primary)}
.pareto-legend{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:6px 12px;margin-top:10px;font-size:11px;color:var(--col-muted)}
.pareto-legend span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rank-badge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:22px;border-radius:20px;background:var(--col-info-bg);color:var(--col-info);font-size:11px;font-weight:800}
.rank-badge.gold{background:#fdf3e0;color:#92400e}
.metric-muted{color:var(--col-muted);font-size:11px}

/* === KPI GROUPED LAYOUT (Reportes de Ventas) ===================== */
.kpi-section{margin-bottom:12px}
.kpi-section-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--col-muted);display:flex;align-items:center;gap:6px;margin-bottom:6px;padding:0 2px}
.kpi-section-label i{font-size:13px;color:var(--col-accent)}
.kpi-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}
.kpi-group-flat{grid-template-columns:repeat(5,1fr)}
.kpi-card{background:var(--col-card);border:1px solid #eef0f5;border-left:3px solid #e2e5eb;border-radius:var(--radius);padding:12px 16px;display:flex;flex-direction:column;gap:2px;box-shadow:var(--shadow-xs)}
.kpi-card-icon{font-size:16px;color:#c4c8d4;margin-bottom:4px;line-height:1}
.kpi-card-blue{border-left-color:var(--col-info)}.kpi-card-blue .kpi-card-icon{color:var(--col-info)}
.kpi-card-green{border-left-color:var(--col-success)}.kpi-card-green .kpi-card-icon{color:var(--col-success)}
.kpi-card-red{border-left-color:var(--col-danger)}.kpi-card-red .kpi-card-icon{color:var(--col-danger)}
.kpi-card-orange{border-left-color:var(--col-accent)}.kpi-card-orange .kpi-card-icon{color:var(--col-accent)}
.kpi-group-info .kpi-card{border-left-color:var(--col-info)}
.kpi-group-cartera .kpi-card{border-left-color:var(--col-success)}
.kpi-group-actividad .kpi-card{border-left-color:var(--col-accent)}
.rep-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.rep-detail-cell{padding:12px 14px;border-right:1px solid #f0f2f6;border-bottom:1px solid #f0f2f6}
.rep-detail-cell:nth-child(2n){border-right:none}
.rep-detail-cell:nth-last-child(-n+2){border-bottom:none}
.rep-detail-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--col-muted);display:flex;align-items:center;gap:5px;margin-bottom:4px}
.rep-detail-label i{font-size:12px}
.rep-detail-value{font-size:20px;font-weight:800;color:var(--col-text);line-height:1.1;letter-spacing:-.3px}
.rep-detail-value.info{color:var(--col-info)}.rep-detail-value.danger{color:var(--col-danger)}.rep-detail-value.accent{color:var(--col-accent)}.rep-detail-value.muted{color:var(--col-muted)}
.rep-detail-sub{font-size:10px;color:#b0b7c3;margin-top:2px}
.kpi-card-title{font-size:9px;font-weight:800;text-transform:uppercase;color:#9ca3af;letter-spacing:.7px;line-height:1.2}
.kpi-card-sub{font-size:10px;color:#b0b7c3;line-height:1.3;margin-bottom:4px}
.kpi-card-value{font-size:22px;font-weight:800;color:var(--col-text);line-height:1.1;letter-spacing:-.3px}
.kpi-card-value.info{color:var(--col-info)}
.kpi-card-value.success{color:var(--col-success)}
.kpi-card-value.danger{color:var(--col-danger)}
.kpi-card-value.accent{color:var(--col-accent)}
.kpi-card-value.muted{color:var(--col-muted)}
.report-row-2col{display:flex;gap:14px;align-items:flex-start;flex-wrap:wrap}
.report-row-2col>.report-chart-card{margin-bottom:16px}
.medio-pago-row{display:grid;grid-template-columns:1fr 44px 36px 80px;align-items:center;gap:7px;margin-bottom:8px;font-size:12px}
.medio-pago-label{font-weight:600;color:var(--col-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.medio-pago-bar{height:8px;background:var(--col-bg);border:1px solid var(--col-border);border-radius:20px;overflow:hidden}
.medio-pago-fill{height:100%;background:linear-gradient(90deg,var(--col-accent),#f59e0b);border-radius:20px}
.medio-pago-pct{font-size:10px;color:var(--col-muted);text-align:right;white-space:nowrap}
.medio-pago-val{font-weight:700;color:var(--col-success);text-align:right;white-space:nowrap;font-size:12px}
.evol-total-row td{font-weight:800;background:#f8f9fc;border-top:2px solid var(--col-border)!important;color:var(--col-primary)}


/* ================================================================ */
/* INVENTARIO - PRODUCTO: FICHA TECNICA, FINANZAS Y KARDEX COMPACTO */
/* ================================================================ */
.prod-info-compact{display:grid;gap:12px}
.prod-info-section{background:var(--col-card);border:1px solid var(--col-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden}
.prod-section-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-bottom:1px solid var(--col-border);background:#f8f9fc;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--col-muted)}
.prod-section-head span{display:flex;align-items:center;gap:7px}.prod-section-head i{font-size:15px;color:var(--col-accent)}
.prod-basics-grid{display:grid;grid-template-columns:repeat(4,minmax(130px,1fr));gap:0;border-top:0}
.prod-mini-field{padding:9px 12px;border-right:1px solid #f0f2f6;border-bottom:1px solid #f0f2f6;min-height:58px;background:#fff}
.prod-mini-field:nth-child(4n){border-right:none}.prod-mini-field.full{grid-column:span 2}
.prod-mini-field label{display:block;font-size:9.5px;text-transform:uppercase;letter-spacing:.45px;color:var(--col-muted);font-weight:800;margin-bottom:3px}
.prod-mini-field .val{font-size:12.5px;font-weight:600;color:var(--col-text);line-height:1.35}
.prod-cost-strip{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;background:#fffbeb;border-bottom:1px solid #fde68a}
.prod-cost-strip .cost-main{display:flex;align-items:baseline;gap:9px;flex-wrap:wrap}.prod-cost-strip label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#92400e;font-weight:800}.prod-cost-strip strong{font-size:18px;color:#92400e}.prod-cost-strip em{font-size:11px;color:#a16207;font-style:normal;font-weight:600}
.price-strategy-table{border:0;border-radius:0;box-shadow:none}.price-strategy-table th{font-size:9.5px}.price-strategy-table td{font-size:12px;padding:7px 10px}.price-strategy-table .price-cell{font-weight:800;color:var(--col-success)}.price-strategy-table .profit-cell{font-weight:700;color:var(--col-primary)}.price-strategy-table .metric-cell{font-weight:700;color:var(--col-info)}
.prod-stock-line{display:flex;gap:10px;align-items:center;flex-wrap:wrap;padding:10px 12px;background:#fff}.prod-stock-pill{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--col-border);background:var(--col-bg);border-radius:999px;padding:6px 10px;font-size:12px;color:var(--col-muted)}.prod-stock-pill strong{color:var(--col-primary)}
.ficha-workbench{background:var(--col-card);border:1px solid var(--col-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:14px}
.ficha-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.ficha-title{font-size:13px;font-weight:800;color:var(--col-primary);display:flex;align-items:center;gap:7px}.ficha-title i{color:var(--col-accent)}.ficha-subtitle{font-size:11px;color:var(--col-muted);margin-top:3px;line-height:1.35}.ficha-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.ficha-table-card{overflow:visible}.ficha-editor-table{table-layout:fixed}.ficha-editor-table th{font-size:9.5px}.ficha-editor-table td{padding:7px 8px;vertical-align:top}.ficha-editor-table tr:hover td{cursor:default;background:#fff}.ficha-editor-table .ficha-row-error td{background:#fff5f5!important}.ficha-insumo-cell{position:relative;display:flex;align-items:center;gap:7px}.ficha-predictive{position:relative;flex:1;min-width:0}.ficha-search-input,.ficha-qty-input{width:100%;border:1px solid var(--col-border);border-radius:var(--radius);padding:7px 9px;font-size:12px;font-family:inherit;color:var(--col-text);outline:none;background:#fff}.ficha-search-input:focus,.ficha-qty-input:focus{border-color:var(--col-primary);box-shadow:0 0 0 3px rgba(89,165,216,.08)}.ficha-qty-input{text-align:right;font-weight:700;color:var(--col-primary)}
.ficha-suggest{display:none;position:absolute;z-index:400;left:0;right:0;top:calc(100% + 3px);background:#fff;border:1px solid var(--col-border);border-radius:var(--radius);box-shadow:var(--shadow-md);max-height:190px;overflow-y:auto}.ficha-suggest.open{display:block}.ficha-suggest-item{padding:8px 10px;cursor:pointer;border-bottom:1px solid #f0f2f6;font-size:12px;display:flex;align-items:center;justify-content:space-between;gap:8px}.ficha-suggest-item:last-child{border-bottom:none}.ficha-suggest-item:hover{background:#fdf3e0}.ficha-suggest-item strong{color:var(--col-primary);font-weight:700}.ficha-suggest-item small{color:var(--col-muted);font-size:10px;white-space:nowrap}.ficha-muted{font-size:11px;color:var(--col-muted)}.ficha-money{font-weight:700;color:var(--col-info);white-space:nowrap}.ficha-total{font-weight:800;color:var(--col-primary);white-space:nowrap}.ficha-summary{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:10px;padding:10px 12px;background:#f8f9fc;border:1px solid var(--col-border);border-radius:var(--radius);font-size:12px}.ficha-summary strong{font-size:16px;color:var(--col-danger)}
.kardex-compact{display:grid;gap:10px}.kardex-compact-head{background:var(--col-card);border:1px solid var(--col-border);border-radius:var(--radius-lg);padding:11px 12px;display:flex;align-items:center;justify-content:space-between;gap:12px;box-shadow:var(--shadow-xs)}.kardex-title{font-size:13px;font-weight:800;color:var(--col-primary);display:flex;align-items:center;gap:7px}.kardex-title i{color:var(--col-accent)}.kardex-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:5px}.kardex-chip{border:1px solid var(--col-border);background:var(--col-bg);border-radius:999px;padding:5px 9px;font-size:11px;color:var(--col-muted)}.kardex-chip strong{color:var(--col-primary)}.kardex-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.kardex-table-card{border-radius:var(--radius-lg);overflow:hidden}.kardex-scroll{max-height:255px;overflow:auto}.kardex-scroll.expanded{max-height:70vh}.kardex-table th{position:sticky;top:0;z-index:1}.kardex-table td{font-size:12px}.kardex-table tr:hover td{cursor:default}.kardex-detalle{font-weight:600;color:var(--col-text)}.kardex-doc{font-weight:800;color:var(--col-info)}.kardex-cant-in{font-weight:800;color:var(--col-success)}.kardex-cant-out{font-weight:800;color:var(--col-danger)}
@media(max-width:980px){.prod-basics-grid{grid-template-columns:repeat(2,minmax(130px,1fr))}.prod-mini-field:nth-child(4n){border-right:1px solid #f0f2f6}.prod-mini-field:nth-child(2n){border-right:none}.ficha-toolbar,.kardex-compact-head{flex-direction:column;align-items:stretch}.ficha-actions,.kardex-actions{justify-content:flex-start}}



/* ================================================================ */
/* INVENTARIO - MATERIA PRIMA: BADGE, FORMULARIO CONDICIONAL        */
/* ================================================================ */
.product-type-badge{display:inline-flex;align-items:center;gap:6px;width:max-content;margin-top:4px;margin-bottom:2px;padding:4px 10px;border-radius:999px;font-size:10.5px;font-weight:800;letter-spacing:.35px;text-transform:uppercase;border:1px solid transparent;line-height:1}
.product-type-badge i{font-size:13px}.product-type-badge-neutral{background:var(--col-bg);color:var(--col-muted);border-color:var(--col-border)}
.product-type-badge.materia{background:var(--col-danger-bg);color:var(--col-danger);border-color:#fecaca}.product-type-badge.intermedio{background:#fef3c7;color:#92400e;border-color:#fde68a}.product-type-badge.venta{background:var(--col-success-bg);color:var(--col-success);border-color:#bbf7d0}
.form-group.locked-field input,.form-group.locked-field select,.form-group.locked-field textarea{background:#f3f4f6!important;color:#6b7280!important;border-color:#e5e7eb!important;cursor:not-allowed;box-shadow:none!important}
.form-group.locked-field label:after{content:' Bloqueado';font-size:9px;color:#9ca3af;font-weight:800;margin-left:5px;letter-spacing:.2px;text-transform:uppercase}.mp-field-hint{display:none;font-size:10px;color:var(--col-muted);margin-top:3px;line-height:1.3}.form-group.locked-field .mp-field-hint{display:block}.form-row.cost-only{grid-template-columns:1fr}.financial-hidden{display:none!important}.merma-control-note{font-size:10px;color:var(--col-muted);margin-top:2px;line-height:1.3}.merma-locked-note{color:#9ca3af}.merma-active-note{color:#92400e;font-weight:600}.modal-producto-mp .modal-head{background:linear-gradient(135deg,#ffffff 0%,#fff8ed 100%)}



/* INVENTARIO - N4 Producto Compuesto y reglas BOM estrictas */
.product-type-badge.compuesto{background:#f3e8ff;color:#6d28d9;border-color:#ddd6fe}
.bom-rule-chip{display:inline-flex;align-items:center;gap:5px;border:1px solid var(--col-border);background:#f8f9fc;color:var(--col-muted);border-radius:999px;padding:5px 9px;font-size:10.5px;font-weight:700;white-space:nowrap}
.bom-rule-chip strong{color:var(--col-primary)}
.nivel-compuesto-badge{background:#f3e8ff!important;color:#6d28d9!important;border-color:#ddd6fe!important}



/* ================================================================ */
/* INVENTARIO - AUDITORIA, KPI FILTERS Y CONTEO FISICO              */
/* ================================================================ */
.summary-card.kpi-filter{cursor:pointer;position:relative}
.summary-card.kpi-filter:after{content:'Filtro';position:absolute;right:10px;top:8px;font-size:8.5px;font-weight:800;text-transform:uppercase;letter-spacing:.55px;color:#b6bdc8;opacity:0;transition:opacity .12s}
.summary-card.kpi-filter:hover:after,.summary-card.kpi-filter.active-filter:after{opacity:1}
.summary-card.inventory-valuation-card{cursor:default;border-top:2px solid var(--col-primary);min-width:190px}
.summary-card.inventory-valuation-card:hover{transform:none;box-shadow:var(--shadow-xs)}
.inv-count-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.inv-count-intro{background:#fff;border:1px solid var(--col-border);border-left:4px solid var(--col-accent);border-radius:var(--radius-lg);padding:12px 14px;margin-bottom:14px;display:flex;align-items:flex-start;gap:10px;box-shadow:var(--shadow-xs)}
.inv-count-intro i{font-size:20px;color:var(--col-accent);margin-top:1px}.inv-count-intro strong{display:block;color:var(--col-primary);font-size:13px;margin-bottom:2px}.inv-count-intro span{font-size:12px;color:var(--col-muted);line-height:1.35}
.inv-count-note{display:flex;align-items:center;gap:8px;min-width:min(100%,420px);background:#fff;border:1px solid var(--col-border);border-radius:var(--radius);padding:6px 10px;box-shadow:var(--shadow-xs)}
.inv-count-note i{color:var(--col-muted);font-size:16px}.inv-count-note input{border:0;outline:0;background:transparent;font-size:12px;width:100%;font-family:inherit;color:var(--col-text)}
.count-input{width:92px;border:1px solid var(--col-border);border-radius:var(--radius);padding:6px 8px;font-size:12px;text-align:right;font-weight:700;color:var(--col-primary);outline:none;background:#fff;font-family:inherit}
.count-input:focus{border-color:var(--col-accent);box-shadow:0 0 0 3px rgba(232,160,32,.12)}
.count-diff{font-weight:800}.count-diff.pos{color:var(--col-success)}.count-diff.neg{color:var(--col-danger)}.count-diff.zero{color:var(--col-muted)}
.count-row-applied td{background:#f0fdf4!important}.count-feedback{display:none;margin-bottom:12px;border:1px solid #bbf7d0;background:#f0fdf4;color:#15803d;border-radius:var(--radius);padding:8px 10px;font-size:12px;font-weight:600}.count-feedback.open{display:block}
.stock-adjust-summary{background:#f8f9fc;border:1px solid var(--col-border);border-radius:var(--radius-lg);padding:10px 12px;margin-bottom:12px;display:grid;gap:4px}
.stock-adjust-summary strong{font-size:14px;color:var(--col-primary)}.stock-adjust-summary span{font-size:12px;color:var(--col-muted)}
.modal-error{display:none;background:var(--col-danger-bg);border:1px solid #fca5a5;color:var(--col-danger);font-size:12px;border-radius:var(--radius);padding:8px 10px;margin-top:8px;font-weight:600}.modal-error.open{display:block}



/* ================================================================ */
/* CONTEO DE INVENTARIO - HISTORIAL DOCUMENTAL Y BATCH GRID         */
/* ================================================================ */
.audit-history-intro{align-items:center}
.count-doc-kpis .summary-card-value{font-size:16px}
.count-doc-positive{color:var(--col-success);font-weight:800}
.count-doc-negative{color:var(--col-danger);font-weight:800}
.count-doc-zero{color:var(--col-muted);font-weight:800}
.count-doc-link{font-weight:800;color:var(--col-primary);letter-spacing:.2px}
.count-batch-modal{width:min(1040px,calc(100% - 42px));max-height:680px}
.count-batch-toolbar{display:grid;grid-template-columns:1.2fr .8fr;gap:12px;margin-bottom:12px}
.count-batch-note{background:#f8f9fc;border:1px solid var(--col-border);border-radius:var(--radius-lg);padding:10px 12px;color:var(--col-muted);font-size:12px;line-height:1.35}
.count-batch-note strong{color:var(--col-primary)}
.count-batch-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:12px}
.count-batch-summary .mini-stat{background:#fff;border:1px solid var(--col-border);border-radius:var(--radius);padding:8px 10px}
.count-batch-summary .mini-stat label{display:block;font-size:9.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--col-muted);font-weight:800;margin-bottom:2px}
.count-batch-summary .mini-stat div{font-size:13px;font-weight:800;color:var(--col-primary)}
.count-batch-grid-wrap{border:1px solid var(--col-border);border-radius:var(--radius-lg);overflow:hidden;background:#fff}
.count-batch-scroll{max-height:360px;overflow:auto}
.count-batch-table th{position:sticky;top:0;z-index:2}
.count-batch-table td{font-size:12px}
.count-batch-table input.count-input{width:108px}
.count-level-rule{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;color:var(--col-muted);background:#f8f9fc;border:1px solid var(--col-border);border-radius:999px;padding:4px 8px;margin-top:4px}
.count-row-pending td{background:#fffaf0}
.count-row-ok td{background:#f8fffb}
.count-detail-modal{width:min(900px,calc(100% - 42px));max-height:640px}
.count-detail-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
@media(max-width:900px){.count-batch-toolbar{grid-template-columns:1fr}.count-batch-summary,.count-detail-summary{grid-template-columns:1fr 1fr}.audit-history-intro{align-items:flex-start;flex-direction:column}.audit-history-intro .btn{margin-left:0!important}}


/* INVENTARIO - CONTEO DOCUMENTAL Y HOJA MASIVA INLINE */
.count-doc-panel{display:grid;gap:14px}
.count-doc-head{background:#fff;border:1px solid var(--col-border);border-left:4px solid var(--col-primary);border-radius:var(--radius-lg);padding:12px 14px;display:flex;align-items:flex-start;justify-content:space-between;gap:14px;box-shadow:var(--shadow-xs)}
.count-doc-head .count-title{display:flex;gap:10px;align-items:flex-start}.count-doc-head i{font-size:20px;color:var(--col-accent);margin-top:1px}.count-doc-head strong{display:block;color:var(--col-primary);font-size:13px;margin-bottom:2px}.count-doc-head span{display:block;font-size:12px;color:var(--col-muted);line-height:1.35}
.count-doc-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.count-doc-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--col-border);background:var(--col-bg);border-radius:999px;padding:6px 10px;font-size:11px;font-weight:700;color:var(--col-muted);white-space:nowrap}.count-doc-chip strong{color:var(--col-primary)}
.count-history-table tr:hover td{cursor:default}.count-doc-id{font-weight:900;color:var(--col-primary);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.count-money{font-weight:800;color:var(--col-primary);white-space:nowrap}.count-var-pos{font-weight:900;color:var(--col-success)}.count-var-neg{font-weight:900;color:var(--col-danger)}.count-var-zero{font-weight:800;color:var(--col-muted)}
.count-batch-panel{display:none}.count-batch-panel.open{display:block}.count-batch-panel .count-batch-grid-wrap{max-height:calc(100vh - 330px);min-height:260px;overflow:auto;border:0;border-radius:var(--radius-lg);background:#fff}.count-batch-panel .count-batch-grid th{position:sticky;top:0;z-index:2}.count-batch-panel .count-batch-grid tr:hover td{cursor:default;background:#fff}.count-batch-panel .count-batch-grid td{font-size:12px}
.count-batch-panel .count-batch-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:10px;margin-bottom:12px}.count-batch-metric{background:#fff;border:1px solid var(--col-border);border-radius:var(--radius);padding:9px 11px;box-shadow:var(--shadow-xs)}.count-batch-metric label{display:block;font-size:9.5px;text-transform:uppercase;letter-spacing:.55px;color:#9ca3af;font-weight:800;margin-bottom:3px}.count-batch-metric strong{font-size:14px;color:var(--col-primary)}
.count-batch-footer{position:sticky;bottom:0;background:#fff;border:1px solid var(--col-border);border-radius:var(--radius-lg);padding:10px 12px;margin-top:12px;display:flex;justify-content:space-between;align-items:center;gap:12px;box-shadow:var(--shadow-sm);z-index:5}.count-batch-footer small{font-size:11px;color:var(--col-muted);line-height:1.35}.count-input.count-error{border-color:#fca5a5;background:#fff5f5;color:var(--col-danger)}
.count-history-table tr.count-history-row:hover td{cursor:pointer;background:#f8fafd}.count-history-table tr.count-history-row:hover .count-doc-id{text-decoration:underline}
.count-detail-panel{display:none}.count-detail-panel.open{display:block}.count-readonly-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px;margin-bottom:12px}.count-readonly-grid .form-group{margin-bottom:0}.count-readonly-grid input[disabled]{background:#f8f9fc;color:var(--col-text);font-weight:700;border-color:#e8eaef;opacity:1;cursor:not-allowed}.count-immutable-alert{display:flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid var(--col-border);border-left:4px solid var(--col-primary);border-radius:var(--radius);padding:8px 10px;margin-bottom:12px;font-size:12px;color:var(--col-muted);font-weight:600}.count-immutable-alert i{font-size:16px;color:var(--col-primary)}.count-detail-grid-wrap{max-height:calc(100vh - 340px);overflow:auto}.count-detail-table th{position:sticky;top:0;z-index:2}.count-detail-table tr:hover td{cursor:default;background:#fff}
@media print{body.count-letter-print{background:#fff;margin:0;padding:0}.letter-print-only{display:block;width:100%}}
@media(max-width:900px){.count-doc-head,.count-batch-footer{flex-direction:column;align-items:stretch}.count-doc-actions{justify-content:flex-start}}


/* ================================================================ */
/* INVENTARIO - N5 GASTOS, LISTAS MAESTRAS Y SELECT BUSCADOR         */
/* ================================================================ */
.product-type-badge.gasto{background:#f3f4f6;color:#374151;border-color:#d1d5db}
.nivel-gasto-badge{background:#f3f4f6!important;color:#374151!important;border-color:#d1d5db!important}
.product-form-locked-note{display:none;background:#f8fafc;border:1px dashed var(--col-border);border-radius:var(--radius);padding:8px 10px;margin-bottom:10px;color:var(--col-muted);font-size:11px;line-height:1.35}
.product-form-locked-note.open{display:block}.expense-fields-hidden{display:none!important}.expense-classification-box{background:#f8fafc;border:1px solid var(--col-border);border-radius:var(--radius-lg);padding:10px 12px;margin:10px 0 12px}.expense-classification-title{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.55px;color:var(--col-muted);display:flex;align-items:center;gap:6px;margin-bottom:8px}.expense-classification-title i{color:var(--col-primary);font-size:15px}.select-master{appearance:none;background-color:#fff;background-image:linear-gradient(45deg,transparent 50%,var(--col-muted) 50%),linear-gradient(135deg,var(--col-muted) 50%,transparent 50%);background-position:calc(100% - 16px) 50%,calc(100% - 11px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:34px!important}.family-typeahead-wrap{position:relative}.family-suggestions{display:none;position:absolute;z-index:450;left:0;right:0;top:calc(100% + 3px);background:#fff;border:1px solid var(--col-border);border-radius:var(--radius);box-shadow:var(--shadow-md);max-height:180px;overflow-y:auto}.family-suggestions.open{display:block}.family-suggestion-item{padding:8px 10px;border-bottom:1px solid #f0f2f6;cursor:pointer;font-size:12px;display:flex;justify-content:space-between;gap:8px}.family-suggestion-item:last-child{border-bottom:none}.family-suggestion-item:hover{background:#fdf3e0}.family-suggestion-item small{color:var(--col-muted);font-size:10px}.n5-cost-audit{background:#fff;border:1px solid var(--col-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:14px}.n5-cost-audit h3{font-size:14px;color:var(--col-primary);display:flex;align-items:center;gap:7px;margin-bottom:6px}.n5-cost-audit p{font-size:12px;color:var(--col-muted);line-height:1.35;margin-bottom:12px}.n5-audit-chip{display:inline-flex;align-items:center;gap:5px;border:1px solid var(--col-border);background:#f8fafc;border-radius:999px;padding:5px 9px;font-size:11px;color:var(--col-muted);margin-right:6px;margin-bottom:6px}.n5-audit-chip strong{color:var(--col-primary)}


/* ================================================================ */
/* COMPRAS Y GASTOS - FLUJOS N5 Y GASTOS DIRECTOS                   */
/* ================================================================ */
.expense-module-hero{background:#fff;border:1px solid var(--col-border);border-left:4px solid var(--col-primary);border-radius:var(--radius-lg);padding:13px 15px;margin-bottom:14px;display:flex;justify-content:space-between;align-items:flex-start;gap:14px;box-shadow:var(--shadow-xs)}
.expense-module-hero strong{display:flex;align-items:center;gap:8px;color:var(--col-primary);font-size:14px;margin-bottom:3px}.expense-module-hero i{font-size:18px;color:var(--col-accent)}.expense-module-hero p{font-size:12px;color:var(--col-muted);line-height:1.35;max-width:760px}.expense-module-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.expense-flow-note{background:#f8fafc;border:1px solid var(--col-border);border-radius:var(--radius-lg);padding:10px 12px;margin-bottom:12px;font-size:12px;color:var(--col-muted);line-height:1.35;display:flex;gap:8px;align-items:flex-start}.expense-flow-note i{font-size:17px;color:var(--col-primary);margin-top:1px}.expense-flow-note strong{color:var(--col-primary)}
.expense-form-card{background:#fff;border:1px solid var(--col-border);border-radius:var(--radius-lg);padding:14px 16px;box-shadow:var(--shadow-xs)}.expense-form-card h3{font-size:14px;color:var(--col-primary);display:flex;align-items:center;gap:8px;margin-bottom:4px}.expense-form-card .sub{font-size:12px;color:var(--col-muted);line-height:1.35;margin-bottom:12px}.expense-form-section{border-top:1px solid var(--col-border);padding-top:12px;margin-top:12px}.expense-form-section-title{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.55px;color:#9ca3af;margin-bottom:8px;display:flex;align-items:center;gap:6px}.expense-form-section-title i{font-size:14px;color:var(--col-accent)}
.expense-total-box{background:#f8fafc;border:1px solid var(--col-border);border-radius:var(--radius-lg);padding:11px 13px;margin-top:12px;display:flex;justify-content:space-between;align-items:center;gap:10px}.expense-total-box span{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--col-muted);font-weight:800}.expense-total-box strong{font-size:18px;color:var(--col-primary)}
.expense-product-info{display:none;background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius);padding:8px 10px;margin-top:6px;font-size:11px;color:#92400e;line-height:1.35}.expense-product-info.open{display:block}.expense-product-info strong{color:#133C55}.expense-form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}.expense-edit-banner{display:none;background:#fff8ed;border:1px solid #f5d38a;color:#92400e;border-radius:var(--radius);padding:8px 10px;margin-bottom:12px;font-size:12px;font-weight:700;align-items:center;gap:7px}.expense-edit-banner.open{display:flex}.expense-edit-banner i{font-size:16px}
.expense-table tr:hover td{cursor:default}.expense-table tr.expense-row-active:hover td{background:#f8fafd;cursor:pointer}.expense-table tr.fila-gasto-anulado td{background:#fff5f5!important;color:#9ca3af!important;font-style:italic}.expense-table tr.fila-gasto-anulado:hover td{cursor:default;background:#fff5f5!important}.expense-type-pill{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:3px 8px;font-size:10px;font-weight:800;border:1px solid var(--col-border);white-space:nowrap}.expense-type-pill.tangible{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}.expense-type-pill.directo{background:#fdf3e0;color:#92400e;border-color:#f5d38a}.expense-type-pill.anulado{background:#fff1f1;color:#dc2626;border-color:#fecaca}.expense-status{font-weight:800;font-size:10px;text-transform:uppercase;letter-spacing:.45px}.expense-status.ok{color:var(--col-success)}.expense-status.void{color:var(--col-danger)}.expense-actions{display:flex;gap:5px;justify-content:flex-end;white-space:nowrap}.expense-actions .btn{padding:3px 7px;font-size:10.5px}.expense-filter-row{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}.expense-filter-row .search-bar{width:300px}.expense-zero-note{font-size:10px;color:var(--col-muted);display:block;margin-top:2px}.expense-money{font-weight:800;color:var(--col-primary);white-space:nowrap}.expense-money.zero{color:var(--col-muted)}
@media(max-width:900px){.expense-module-hero{flex-direction:column}.expense-module-actions{justify-content:flex-start}.expense-filter-row .search-bar{width:100%}}


/* ================================================================ */
/* COMPRAS MULTILINEA - MASTER DETAIL N1 / N5                       */
/* ================================================================ */
.purchase-master-grid{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:10px;margin-bottom:12px}
.purchase-lines-wrap{border:1px solid var(--col-border);border-radius:var(--radius-lg);overflow:hidden;background:#fff;box-shadow:var(--shadow-xs);position:relative}
.purchase-lines-table{width:100%;table-layout:fixed;border-collapse:collapse}
.purchase-lines-table tr:hover td{cursor:default;background:#fff}
.purchase-lines-table th{position:sticky;top:0;z-index:2;background:#f8f9fc}
.purchase-lines-table td{vertical-align:top;font-size:12px}
.purchase-lines-table select,.purchase-lines-table input{width:100%;max-width:100%;box-sizing:border-box;border:1px solid var(--col-border);border-radius:var(--radius);background:#fff;color:var(--col-text);font-family:inherit;font-size:12px;outline:none;padding:6px 8px}
.purchase-lines-table input:focus,.purchase-lines-table select:focus{border-color:var(--col-primary);box-shadow:0 0 0 3px rgba(89,165,216,.08)}
.purchase-product-meta{font-size:10.5px;color:var(--col-muted);line-height:1.35;margin-top:5px;min-height:16px}
.purchase-product-meta strong{color:var(--col-primary)}
.purchase-readonly-money{font-weight:800;color:var(--col-primary);white-space:nowrap;text-align:right;display:block;padding-top:6px}
.purchase-line-subtotal{font-weight:900;color:var(--col-success);white-space:nowrap;text-align:right;display:block;padding-top:6px}
.purchase-line-badge{display:inline-flex;align-items:center;gap:4px;border-radius:999px;padding:2px 7px;font-size:10px;font-weight:800;border:1px solid var(--col-border);white-space:nowrap;margin-top:4px}
.purchase-line-badge.n1{background:#FDECEA;color:#C0392B;border-color:#F5B7B1}.purchase-line-badge.n3{background:#D4F0E8;color:#1A8A6E;border-color:#A8D5C0}.purchase-line-badge.n5{background:#f3f4f6;color:#374151;border-color:#d1d5db}
.purchase-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(140px,1fr));gap:10px;margin-top:12px}
.purchase-summary-card{background:#f8fafc;border:1px solid var(--col-border);border-radius:var(--radius);padding:9px 11px}.purchase-summary-card label{display:block;font-size:9.5px;text-transform:uppercase;letter-spacing:.55px;color:#9ca3af;font-weight:800;margin-bottom:3px}.purchase-summary-card strong{font-size:15px;color:var(--col-primary)}
.purchase-actions-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px;flex-wrap:wrap}.purchase-actions-row small{font-size:11px;color:var(--col-muted);line-height:1.35}.purchase-actions-row .right-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.expense-type-pill.compra{background:#D4F0E8;color:#1A8A6E;border-color:#A8D5C0}.expense-type-pill.mixta{background:#D8E9F9;color:#386FA4;border-color:#A8C8E8}
.expense-line-mini{display:block;color:var(--col-muted);font-size:10px;margin-top:2px;line-height:1.25}.expense-line-mini b{color:var(--col-primary)}
@media(max-width:1100px){.purchase-master-grid,.purchase-summary-grid{grid-template-columns:1fr 1fr}}
@media(max-width:720px){.purchase-master-grid,.purchase-summary-grid{grid-template-columns:1fr}}


/* â”€â”€ Typeahead / Autocomplete en líneas de compra â”€â”€ */
.nc-ac-wrap{position:relative}
.nc-ac-input{width:100%;padding:6px 9px;border:2px solid #9ca3af;border-radius:var(--radius);font-size:12.5px;font-family:inherit;color:#111827;background:#fff;outline:none;transition:border 0.15s}
.nc-ac-input:focus{border-color:var(--col-primary);box-shadow:0 0 0 3px rgba(89,165,216,0.08)}
.nc-ac-input::placeholder{color:#9ca3af;font-weight:400}
.nc-ac-dropdown{display:none;position:fixed;top:0;left:0;right:auto;width:320px;background:#fff;border:1.5px solid #9ca3af;border-radius:var(--radius);z-index:5000;max-height:240px;overflow-y:auto;box-shadow:0 16px 36px rgba(0,0,0,0.22)}
.nc-ac-item{padding:8px 11px;cursor:pointer;font-size:12px;border-bottom:1px solid #f0f2f6;display:flex;align-items:center;gap:8px}
.nc-ac-item:last-child{border-bottom:none}
.nc-ac-item:hover,.nc-ac-item.nc-hov{background:#E4F3FB}
.nc-ac-item .nc-tag{font-size:10px;font-weight:700;padding:2px 7px;border-radius:12px;flex-shrink:0}
.nc-tag-n1{background:#D8E9F9;color:#386FA4}
.nc-tag-n3{background:#D4F0E8;color:#1A8A6E}
.nc-tag-n5{background:#f3e8ff;color:#7c3aed}
.nc-ac-chip{background:#E4F3FB;border:1.5px solid var(--col-accent);border-radius:var(--radius);padding:5px 9px;display:flex;align-items:center;gap:7px;font-size:12px}
.nc-ac-chip-name{flex:1;font-weight:600;color:var(--col-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nc-ac-clear{background:none;border:none;cursor:pointer;color:#9ca3af;font-size:16px;line-height:1;padding:0;flex-shrink:0;transition:color 0.1s}
.nc-ac-clear:hover{color:var(--col-danger)}
.nc-ac-dropdown.open{display:block}
.purchase-lines-outer{overflow:hidden!important;position:relative;width:100%;max-width:100%}
.purchase-lines-table{overflow:hidden}
.purchase-lines-table td{overflow:hidden}
.purchase-line-delete-btn{min-width:30px;width:30px;height:30px;padding:0!important;justify-content:center;color:var(--col-danger)!important;border-color:#fecaca!important;background:#fff5f5!important}.purchase-line-delete-btn[hidden]{display:none!important}
.purchase-line-delete-btn:hover{background:#fee2e2!important;border-color:#fca5a5!important}
#modal-nueva-compra{z-index:300}
#modal-nueva-compra .modal{width:min(1120px,98vw)!important;overflow:hidden!important}
#modal-nueva-compra .modal-body{overflow:visible!important;max-width:100%;box-sizing:border-box}
#modal-nueva-compra .modal-footer{z-index:3}

/* Inputs de tabla con contraste elevado */
.purchase-lines-table thead th{background:#133C55 !important;color:#fff !important;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;padding:9px 10px;border:none}
.purchase-lines-table tbody tr{border-bottom:1px solid #d1d5db}
.purchase-lines-table tbody tr:hover{background:#f8fafc}
.cg-compra-cantidad,.cg-compra-valor{border:2px solid #9ca3af !important;border-radius:var(--radius) !important;padding:6px 8px !important;font-size:12.5px !important;color:#111827 !important;background:#fff !important;width:100%;font-family:inherit;outline:none;transition:border 0.15s}
.cg-compra-cantidad:focus,.cg-compra-valor:focus{border-color:var(--col-primary) !important;box-shadow:0 0 0 2px rgba(89,165,216,0.08)}
.purchase-costo-unitario,.purchase-line-subtotal{font-size:12.5px;font-weight:600;color:#111827}.purchase-lines-table th:nth-child(1){width:32%}.purchase-lines-table th:nth-child(2){width:10%}.purchase-lines-table th:nth-child(3){width:7%}.purchase-lines-table th:nth-child(4){width:14%}.purchase-lines-table th:nth-child(5){width:13%}.purchase-lines-table th:nth-child(6){width:14%}.purchase-lines-table th:nth-child(7){width:10%}.purchase-lines-table td:nth-child(1){min-width:0}.purchase-lines-table td:nth-child(2),.purchase-lines-table td:nth-child(4),.purchase-lines-table td:nth-child(5),.purchase-lines-table td:nth-child(6){white-space:nowrap}.purchase-lines-table td:nth-child(7){text-align:center}.purchase-lines-table .nc-ac-chip{min-width:0}.purchase-lines-table .nc-ac-chip-name{min-width:0}@media(max-width:900px){#modal-nueva-compra{padding:10px!important}.purchase-lines-table thead{display:none}.purchase-lines-table,.purchase-lines-table tbody,.purchase-lines-table tr,.purchase-lines-table td{display:block;width:100%}.purchase-lines-table tr{padding:10px;border-bottom:1px solid var(--col-border)}.purchase-lines-table td{padding:6px 0!important;text-align:left!important;white-space:normal!important}.purchase-lines-table td::before{content:attr(data-label);display:block;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.45px;color:var(--col-muted);margin-bottom:3px}.purchase-lines-table td:nth-child(7){text-align:right!important}.purchase-line-delete-btn{margin-left:auto}}


/* ================================================================ */
/* FIX UI/UX - NUEVA FACTURA DE COMPRA: MODAL SIN OVERFLOW + POKA-YOKE */
/* ================================================================ */
#modal-nueva-compra{
  box-sizing:border-box;
  padding:20px!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
}
#modal-nueva-compra .modal{
  width:min(1180px,calc(100vw - 40px))!important;
  max-width:100%!important;
  overflow:hidden!important;
  display:flex;
  flex-direction:column;
}
#modal-nueva-compra .modal-head,
#modal-nueva-compra .modal-body,
#modal-nueva-compra .modal-footer{
  width:100%;
  max-width:100%;
  min-width:0;
  box-sizing:border-box;
}
#modal-nueva-compra .modal-body{
  overflow-x:hidden!important;
}
#modal-nueva-compra .purchase-master-grid{
  grid-template-columns:repeat(4,minmax(0,1fr));
}
#modal-nueva-compra .purchase-lines-outer{
  width:100%;
  max-width:100%;
  min-width:0;
  overflow:hidden!important;
}
#modal-nueva-compra .purchase-lines-table{
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  table-layout:fixed!important;
  border-collapse:collapse!important;
}
#modal-nueva-compra .purchase-lines-table th,
#modal-nueva-compra .purchase-lines-table td{
  min-width:0;
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
}
#modal-nueva-compra .purchase-lines-table th:nth-child(1){width:31%}
#modal-nueva-compra .purchase-lines-table th:nth-child(2){width:9%}
#modal-nueva-compra .purchase-lines-table th:nth-child(3){width:6%}
#modal-nueva-compra .purchase-lines-table th:nth-child(4){width:14%}
#modal-nueva-compra .purchase-lines-table th:nth-child(5){width:14%}
#modal-nueva-compra .purchase-lines-table th:nth-child(6){width:16%}
#modal-nueva-compra .purchase-lines-table th:nth-child(7){width:10%}
#modal-nueva-compra .purchase-costo-unitario,
#modal-nueva-compra .purchase-line-subtotal{
  display:block;
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
}
.purchase-line-action-cell{
  text-align:center;
  white-space:nowrap;
}
.purchase-line-required{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  border-radius:var(--radius);
  border:1px dashed var(--col-border);
  color:var(--col-muted);
  background:#f8f9fc;
  cursor:not-allowed;
}
@media(max-width:1100px){
  #modal-nueva-compra .purchase-lines-table thead th{font-size:10px;padding:8px 5px!important}
  #modal-nueva-compra .purchase-lines-table td{padding-left:5px!important;padding-right:5px!important}
  #modal-nueva-compra .cg-compra-cantidad,
  #modal-nueva-compra .cg-compra-valor,
  #modal-nueva-compra .purchase-costo-unitario,
  #modal-nueva-compra .purchase-line-subtotal{font-size:11.5px!important}
}
@media(max-width:900px){
  #modal-nueva-compra{padding:10px!important}
  #modal-nueva-compra .modal{width:100%!important;max-width:calc(100vw - 20px)!important}
  #modal-nueva-compra .purchase-master-grid{grid-template-columns:1fr!important}
}

/* ================================================================ */
/* TABLAS MAESTRAS — Panel de administración de catálogos           */
/* ================================================================ */
#view-inv-maestras{width:100%;box-sizing:border-box}

/* Encabezado: bloque vertical, alineado a la izquierda */
.maestras-header{margin-bottom:16px}
.maestras-header h2{font-size:16px;font-weight:700;color:var(--col-primary);display:flex;align-items:center;gap:8px;margin:0 0 5px;line-height:1.3}
.maestras-header h2 i{font-size:17px;color:var(--col-accent)}
.maestras-header p{font-size:12px;color:var(--col-muted);margin:0;line-height:1.6}

/* Barra de tabs + botón de acción en la misma fila */
.maestras-tabbar{display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid var(--col-border);margin-bottom:16px;gap:8px}
.maestras-tabbar-tabs{display:flex;align-self:flex-end}
.maestras-tabbar-action{padding-bottom:4px;flex-shrink:0}

/* Estado vacío centrado geométricamente */
.maestras-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:240px;text-align:center;color:var(--col-muted);padding:24px 16px}
.maestras-empty i{font-size:42px;margin-bottom:12px;opacity:0.35;display:block}
.maestras-empty-title{font-size:14px;font-weight:600;color:var(--col-text);margin-bottom:5px}
.maestras-empty-sub{font-size:12px;color:var(--col-muted)}

/* Filtro de familias */
.maestras-filter-bar{margin-bottom:12px}
.maestras-filter-bar select{border:1px solid var(--col-border);border-radius:var(--radius);padding:5px 10px;font-size:12px;background:var(--col-card);color:var(--col-text);outline:none}
.maestras-filter-bar select:focus{border-color:var(--col-primary)}

@media(max-width:640px){
  .maestras-tabbar{flex-wrap:wrap;gap:4px}
  .maestras-tabbar-tabs{flex-wrap:wrap}
  .maestras-tabbar-action{width:100%;display:flex;justify-content:flex-end}
}

/* ================================================================
   POS — Nuevo Pedido: interfaz visual por departamento + cuadrícula
   ================================================================ */

/* Contenedor principal: categorías izq. + área de productos der. */
.pos-layout{display:flex;gap:0;border:1px solid var(--col-border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:10px;min-height:260px;background:var(--col-card)}

/* Panel de categorías (columna izquierda) */
.pos-cats{width:130px;flex-shrink:0;background:var(--col-bg);border-right:1px solid var(--col-border);overflow-y:auto;max-height:300px;display:flex;flex-direction:column;padding:6px;gap:2px}
.pos-cats-loading{font-size:11px;color:var(--col-muted);padding:10px 6px;display:flex;align-items:center;gap:5px}
.pos-cats-loading i{font-size:13px}
.pos-dept-btn{width:100%;text-align:left;padding:8px 10px;font-size:12px;font-weight:500;background:transparent;border:none;border-radius:var(--radius);cursor:pointer;color:var(--col-text);transition:background 0.15s,color 0.15s;line-height:1.3;font-family:inherit}
.pos-dept-btn:hover{background:rgba(89,165,216,0.07)}
.pos-dept-btn.active{background:var(--col-primary);color:#fff;font-weight:600}

/* Panel derecho: buscador + cuadrícula */
.pos-grid-wrap{flex:1;display:flex;flex-direction:column;min-width:0}
.pos-search-bar{position:relative;padding:8px 8px 0}
.pos-search-bar i{position:absolute;left:18px;top:50%;transform:translateY(-20%);font-size:13px;color:var(--col-muted);pointer-events:none}
.pos-search-bar input{width:100%;padding:6px 10px 6px 30px;border:1px solid var(--col-border);border-radius:var(--radius);font-size:12px;outline:none;font-family:inherit;background:var(--col-bg);color:var(--col-text)}
.pos-search-bar input:focus{border-color:var(--col-primary);background:#fff}
.pos-search-results{position:absolute;left:8px;right:8px;top:calc(100% - 2px);z-index:50;border-radius:0 0 var(--radius) var(--radius)}

/* Cuadrícula de productos */
.pos-grid{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(98px,1fr));gap:6px;padding:8px;overflow-y:auto;max-height:240px;align-content:start}
.pos-prod-card{display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:5px;padding:10px 7px 8px;background:var(--col-card);border:1px solid var(--col-border);border-radius:8px;cursor:pointer;transition:border-color 0.15s,box-shadow 0.15s,transform 0.1s;text-align:center;font-family:inherit;min-height:68px}
.pos-prod-card:hover{border-color:var(--col-primary);box-shadow:0 2px 8px rgba(89,165,216,0.12);transform:translateY(-1px)}
.pos-prod-card:active{transform:scale(0.96);box-shadow:none}
.pos-prod-nombre{font-size:11px;font-weight:600;color:var(--col-text);line-height:1.3;word-break:break-word;flex:1}
.pos-prod-precio{font-size:11px;font-weight:700;color:var(--col-accent);white-space:nowrap}
.pos-prod-badge{font-size:9px;padding:1px 5px;border-radius:10px;background:#e8f5e9;color:var(--col-success);font-weight:600}
.pos-prod-badge.agotado{background:#fee2e2;color:var(--col-danger)}
.pos-empty{font-size:12px;color:var(--col-muted);padding:24px 16px;text-align:center;grid-column:1/-1}

/* Sección de pedido actual (debajo del POS) */
.del-order-items{border:1px solid var(--col-border);border-radius:var(--radius-lg);overflow:hidden;margin-top:6px}
.del-order-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--col-bg);border-bottom:1px solid var(--col-border);font-size:12px;font-weight:600;color:var(--col-primary)}
.del-order-header i{margin-right:5px;font-size:13px}
#pos-items-count{font-size:11px;color:var(--col-muted);font-weight:400}
.del-order-items #del-items-body{padding:4px 0}

@media(max-width:600px){
  .pos-layout{flex-direction:column;min-height:auto}
  .pos-cats{width:100%;max-height:none;flex-direction:row;flex-wrap:wrap;border-right:none;border-bottom:1px solid var(--col-border)}
  .pos-dept-btn{width:auto;padding:6px 10px}
  .pos-grid{max-height:220px;grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}
}

/* ================================================================
   NUEVO PEDIDO — Vista pantalla completa 50% / 50%
   Izquierda: Factura (1A encabezado / 1B ítems / 1C pie)
   Derecha:   Selector de productos
   ================================================================ */

/* Cuadrícula exactamente 50 / 50 */
.npedido-main{
  display:grid;
  grid-template-columns:1fr 1fr;
  flex:1;min-height:0;overflow:hidden;
}

/* ═══ COLUMNA IZQUIERDA — 3 zonas apiladas ═══════════════════════ */
.npedido-left{
  display:flex;flex-direction:column;
  overflow:hidden;
  border-right:2px solid var(--col-border);
  background:var(--col-card);
}

/* 1A ── Encabezado (cliente + logística + medio de pago) */
.npedido-order-head{
  flex-shrink:0;
  overflow-y:auto;
  max-height:340px;            /* más altura: incluye medio de pago */
  padding:10px 14px 8px;
  border-bottom:1px solid var(--col-border);
}

/* Secciones del encabezado */
.fac-section{margin-bottom:9px}
.fac-section:last-child{margin-bottom:0}
.fac-section-label{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:0.5px;color:var(--col-muted);margin-bottom:4px;
}
.fac-input{
  width:100%;padding:6px 10px;box-sizing:border-box;
  border:1px solid var(--col-border);border-radius:var(--radius);
  font-size:12px;outline:none;font-family:inherit;
  background:#fff;color:var(--col-text);
}
.fac-input:focus{border-color:var(--col-primary);}
.fac-select-input{
  width:100%;padding:6px 10px;box-sizing:border-box;
  border:1px solid var(--col-border);border-radius:var(--radius);
  font-size:12px;outline:none;font-family:inherit;
  background:#fff;color:var(--col-text);
}
.fac-row-2{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:5px}
.fac-field{display:flex;flex-direction:column;gap:2px}
.fac-label{font-size:10px;color:var(--col-muted);font-weight:500}

/* Chip cliente seleccionado */
.fac-cli-chip{
  display:flex;align-items:center;justify-content:space-between;
  gap:6px;padding:6px 8px;margin-top:4px;
  background:#f0f6ff;border:1px solid #c7d9f5;border-radius:var(--radius);
}
.fac-cli-nombre{font-weight:600;font-size:12px;color:var(--col-primary)}
.fac-cli-dir{font-size:10px;color:var(--col-muted)}

/* Logística compacta */
.fac-logistica-row{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:5px}
.fac-logistica-opt{
  display:flex;align-items:center;gap:7px;
  padding:7px 10px;
  border:1px solid var(--col-border);border-radius:var(--radius);
  font-size:11px;cursor:pointer;
  background:var(--col-bg);
  transition:border-color 0.15s,background 0.15s;
}
.fac-logistica-opt:hover{border-color:var(--col-primary);}
.fac-logistica-btn{background:var(--col-bg);font-family:inherit;text-align:left;width:100%}
.fac-logistica-txt strong{font-size:11px;display:block}
.fac-logistica-txt{line-height:1.3}
.fac-logistica-opt i{font-size:15px;color:var(--col-accent);flex-shrink:0}

/* 1B ── Cuerpo: lista de ítems tipo factura */
.npedido-order-body{
  flex:1;min-height:60px;overflow-y:auto;
  background:var(--col-bg);
}
/* Quitar bordes extra para sticky */
.npedido-order-body .del-order-items{
  border:none;border-radius:0;overflow:visible;margin-top:0;
}
.npedido-order-body .del-order-header{
  position:sticky;top:0;z-index:2;
  padding:7px 12px;
  background:var(--col-card);
  border-bottom:1px solid var(--col-border);
  font-size:11px;font-weight:600;color:var(--col-primary);
}
.fac-items-count{
  font-size:10px;font-weight:500;color:var(--col-muted);
  background:var(--col-bg);padding:1px 7px;border-radius:10px;
  border:1px solid var(--col-border);
}
/* Cabecera de columnas tipo factura */
.fac-items-head{
  display:grid;
  grid-template-columns:1fr 64px 70px 68px 24px;
  gap:0 4px;
  padding:4px 12px 3px;
  font-size:9px;font-weight:700;text-transform:uppercase;
  letter-spacing:0.4px;color:var(--col-muted);
  border-bottom:1px solid var(--col-border);
  background:var(--col-card);
}
.fac-col-precio,.fac-col-qty,.fac-col-sub{text-align:right}

/* Ítems compactos — estilo renglón de factura */
.fac-item-row{
  display:grid;
  grid-template-columns:1fr 64px 70px 68px 24px;
  gap:0 4px;
  align-items:center;
  padding:5px 12px;
  border-bottom:1px solid var(--col-border);
  font-size:12px;
  background:#fff;
  transition:background 0.1s;
}
.fac-item-row:last-child{border-bottom:none}
.fac-item-row:hover{background:#fafbff}
.fac-item-nombre{
  font-size:12px;font-weight:500;color:var(--col-text);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.fac-item-precio{
  text-align:right;font-size:11px;color:var(--col-muted);
}
.fac-item-qty-ctrl{
  display:flex;align-items:center;justify-content:flex-end;gap:3px;
}
.fac-item-subtotal{
  text-align:right;font-size:12px;font-weight:600;color:var(--col-text);
}
.fac-item-del{
  width:20px;height:20px;border-radius:50%;
  background:transparent;border:1px solid #e5e7eb;
  cursor:pointer;font-size:12px;color:#9ca3af;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.12s,color 0.12s;line-height:1;
  font-family:inherit;
}
.fac-item-del:hover{background:#fee2e2;border-color:#fca5a5;color:var(--col-danger)}

/* Controles de cantidad en ítems (más pequeños) */
.fac-item-row .item-qty-btn{
  width:18px;height:18px;font-size:12px;flex-shrink:0;
}
.fac-item-row .item-qty-input{
  width:30px;height:20px;font-size:11px;
}

/* Estado vacío */
.npedido-order-empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:80px;height:100%;color:var(--col-muted);text-align:center;
  gap:6px;padding:20px;pointer-events:none;
}
.npedido-order-empty i{font-size:28px;opacity:0.2}
.npedido-order-empty span{font-size:11px}
.npedido-order-body #del-items-body{max-height:none!important}

/* 1C ── Pie: totales + descuento + delivery + botones */
.npedido-order-foot{
  flex-shrink:0;
  border-top:2px solid var(--col-border);
  padding:8px 14px 10px;
  background:var(--col-card);
}

/* Totales tipo factura */
.fac-totales{margin-bottom:8px}
.fac-trow{
  display:flex;align-items:center;justify-content:space-between;
  padding:4px 0;
  font-size:12px;
  border-bottom:1px dotted var(--col-border);
  gap:8px;
}
.fac-trow:last-child{border-bottom:none}
.fac-tlabel{color:var(--col-muted);font-size:11px;white-space:nowrap}
.fac-tval{font-weight:600;font-size:12px;color:var(--col-text)}
.fac-num-input{
  width:90px;padding:3px 8px;text-align:right;
  border:1px solid var(--col-border);border-radius:var(--radius);
  font-size:12px;font-family:inherit;outline:none;
  background:#fff;
}
.fac-num-input:focus{border-color:var(--col-primary)}

/* Fila de descuento: controles a la izquierda, valor a la derecha */
.fac-desc-row{align-items:center;flex-wrap:nowrap;gap:6px}
.fac-desc-left{display:flex;align-items:center;gap:5px;flex:1;min-width:0;overflow:hidden}
.fac-desc-tabs{display:flex;border:1px solid var(--col-border);border-radius:5px;overflow:hidden;flex-shrink:0}
.fac-tab{
  padding:2px 8px;font-size:10px;font-weight:700;cursor:pointer;
  background:transparent;border:none;font-family:inherit;
  color:var(--col-muted);transition:background 0.1s,color 0.1s;
}
.fac-tab.active{background:var(--col-primary);color:#fff}
/* Selector de cupón compacto */
#del-desc-tipo{max-width:115px;font-size:11px!important;padding:3px 5px!important}

/* Total final: énfasis */
.fac-total-final{
  border-top:2px solid var(--col-border);
  border-bottom:none!important;
  padding:6px 0 2px!important;
  font-weight:700;
}
.fac-total-final span:first-child{font-size:13px;color:var(--col-text)}
.fac-total-final span:last-child{font-size:16px;font-weight:800;color:var(--col-accent)}

/* Descuento: valor negativo en rojo — único display compartido entre modo $ y modo % */
.desc-valor-negativo{
  color:var(--col-danger);font-weight:700;font-size:12px;
  white-space:nowrap;flex-shrink:0;
}

/* Botones de acción */
.fac-acciones{
  display:flex;gap:8px;margin-top:8px;
}
.fac-acciones .btn{flex:1;font-size:12px}
.fac-acciones .btn-primary{flex:1.3}

/* ═══ COLUMNA DERECHA — solo selector de productos ═══════════════ */
.npedido-right{
  display:flex;flex-direction:column;
  padding:10px;
  overflow:hidden;
  background:var(--col-bg);
}
.npedido-right-title{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:0.6px;color:var(--col-muted);
  margin-bottom:7px;display:flex;align-items:center;gap:5px;
  padding-bottom:6px;border-bottom:1px solid var(--col-border);flex-shrink:0;
}

/* Buscador */
.npedido-right .pos-search-bar{
  flex-shrink:0;padding:0 0 5px;position:relative;
}
.npedido-right .pos-search-bar i{
  position:absolute;left:10px;top:50%;transform:translateY(-50%);
  font-size:13px;color:var(--col-muted);pointer-events:none;
}
.npedido-right .pos-search-bar input{
  width:100%;padding:7px 10px 7px 30px;box-sizing:border-box;
  border:1px solid var(--col-border);border-radius:var(--radius);
  font-size:12px;outline:none;font-family:inherit;
  background:var(--col-card);color:var(--col-text);
}
.npedido-right .pos-search-bar input:focus{border-color:var(--col-primary);background:#fff}

/* Resultados de búsqueda en flujo normal */
.pos-search-inline-results{
  flex-shrink:0;
  border:1px solid var(--col-border);border-radius:var(--radius);
  background:var(--col-card);box-shadow:0 4px 14px rgba(0,0,0,0.08);
  overflow-y:auto;max-height:180px;margin-bottom:6px;
}
.pos-search-inline-results .prod-resultado{
  padding:7px 12px;cursor:pointer;font-size:12px;
  display:flex;justify-content:space-between;align-items:center;
  border-bottom:1px solid var(--col-border);transition:background 0.1s;
}
.pos-search-inline-results .prod-resultado:last-child{border-bottom:none}
.pos-search-inline-results .prod-resultado:hover{background:var(--col-bg)}

/* pos-layout ocupa todo el espacio disponible */
.npedido-right .pos-layout{
  flex:1;min-height:120px;margin-bottom:0;
  border:none;border-radius:0;
}
.npedido-right .pos-cats{max-height:none!important;height:100%;width:115px}
.npedido-right .pos-grid-wrap{display:flex;flex-direction:column;min-height:0;flex:1}
.npedido-right .pos-grid{flex:1;max-height:none!important;overflow-y:auto;align-content:start}

/* ── Responsive ≤ 860px: apilar columnas ── */
@media(max-width:860px){
  .npedido-main{grid-template-columns:1fr;overflow-y:auto}
  .npedido-left{border-right:none;border-bottom:2px solid var(--col-border)}
  .npedido-order-head{max-height:none}
  .npedido-right{min-height:340px}
  .npedido-right .pos-layout{min-height:180px}
  .npedido-right .pos-grid{max-height:180px!important}
  .fac-row-2,.fac-logistica-row{grid-template-columns:1fr}
}

/* ================================================================
   VISTA PANTALLA COMPLETA — NUEVO PEDIDO
   Reemplaza el modal flotante. Ocupa todo el .content disponible.
   ================================================================ */

/* El .content elimina padding y scroll cuando el POS está activo */
.content.pos-view-active{
  overflow:hidden;
  padding:0;
}

/* La vista POS ocupa todo el .content */
#view-nuevo-pedido{
  height:100%;
  overflow:hidden;
  flex-direction:column;
  background:var(--col-bg);
}
#view-nuevo-pedido.active{ display:flex; }

/* ── Cabecera POS: título + acciones ─────────────────────────── */
.pos-screen-head{
  flex-shrink:0;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 18px 0 14px;
  height:52px;
  background:var(--col-card);
  border-bottom:2px solid var(--col-border);
  gap:10px;
}
.pos-screen-head-left{
  display:flex;align-items:center;gap:10px;
  min-width:0;overflow:hidden;
}
.pos-screen-head-title{
  font-size:15px;font-weight:700;color:var(--col-primary);
  display:flex;align-items:center;gap:7px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  margin:0;
}
.pos-back-btn{
  flex-shrink:0;
  border-color:var(--col-border);
  font-size:12px;
}
.pos-screen-head-right{
  display:flex;align-items:center;gap:8px;
  flex-shrink:0;
}

/* ── El npedido-main ocupa el resto de la altura disponible ──── */
#view-nuevo-pedido .npedido-main{
  flex:1;min-height:0;
}

/* ── Responsive ≤ 860px ── */
@media(max-width:860px){
  .pos-screen-head{height:44px;padding:0 10px;}
  .pos-screen-head-title{font-size:13px;}
}

/* ── Pareto sub-tabs ── */
.pareto-subtabs{display:flex;gap:4px;background:var(--col-bg);border:1px solid var(--col-border);border-radius:var(--radius);padding:4px;width:fit-content;margin-bottom:16px}
.pareto-subtab-btn{padding:6px 18px;border-radius:calc(var(--radius) - 2px);font-size:12px;font-weight:600;cursor:pointer;color:var(--col-muted);border:none;background:transparent;transition:all .15s;font-family:inherit}
.pareto-subtab-btn:hover{background:var(--col-card);color:var(--col-text)}
.pareto-subtab-btn.active{background:var(--col-card);color:var(--col-primary);box-shadow:var(--shadow-xs)}
/* ── Pareto legend grid ── */
.pareto-legend-grid{display:flex;flex-wrap:wrap;gap:6px;padding:10px 12px 4px;border-top:1px solid var(--col-border);margin-top:8px}
.pareto-legend-abc{font-size:11px;padding:3px 8px 3px 6px;border-left:3px solid #ccc;background:var(--col-bg);border-radius:0 4px 4px 0;color:var(--col-text);white-space:nowrap;line-height:1.4}

/* ══════════════════════════════════════════════════════════════════
   ESTADO DE RESULTADOS — P&L Document
   ══════════════════════════════════════════════════════════════════ */
.pl-doc{max-width:820px;margin:0 auto;background:var(--col-card);border:1px solid var(--col-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px 36px;font-family:inherit}
.pl-header{text-align:center;margin-bottom:14px;padding-bottom:12px;border-bottom:2px solid var(--col-border)}
.pl-header h2{font-size:16px;font-weight:800;color:var(--col-primary);margin:0 0 2px;letter-spacing:0.2px}
.pl-header .pl-empresa{font-size:12px;font-weight:600;color:var(--col-text);margin:0 0 3px}
.pl-header .pl-periodo{font-size:11px;color:var(--col-muted);font-weight:500;margin:0}
.pl-section-hdr{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.9px;color:var(--col-muted);margin:12px 0 2px;padding-bottom:4px;border-bottom:1px solid var(--col-border)}
.pl-row{display:flex;align-items:baseline;padding:3px 0;font-size:13px}
.pl-row.pl-sub{padding:2px 0 2px 22px;font-size:12px;color:var(--col-muted)}
.pl-row.pl-cuenta{padding-top:3px;padding-bottom:3px}
.pl-row.pl-subtotal{border-top:1px solid var(--col-border);margin-top:2px;padding-top:5px;font-weight:700}
.pl-row.pl-resultado{border-top:2px solid var(--col-border);margin-top:3px;padding-top:6px;padding-bottom:6px;font-weight:800;font-size:14px}
.pl-row.pl-neto{border-top:3px double var(--col-primary);margin-top:8px;padding-top:8px;font-weight:800;font-size:15px;color:var(--col-primary)}
.pl-sign{width:30px;text-align:left;font-size:11px;font-weight:700;color:var(--col-muted);flex-shrink:0}
.pl-label{flex:1;color:var(--col-text)}
.pl-amount{width:130px;text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0;font-weight:600;font-size:13.5px}
.pl-amount.pos{color:var(--col-success)}
.pl-amount.neg{color:var(--col-danger)}
.pl-amount.neu{color:var(--col-text)}
.pl-amount.info{color:var(--col-info)}
.pl-amount.acc{color:var(--col-accent)}
.pl-divider{height:1px;background:var(--col-border);margin:10px 0}
.pl-nota{margin-top:24px;padding:12px 16px;background:var(--col-bg);border:1px dashed var(--col-border);border-radius:var(--radius);font-size:12px;color:var(--col-muted);display:flex;align-items:flex-start;gap:8px}
.pl-nota i{flex-shrink:0;font-size:16px;margin-top:1px}
.pl-kpi-row{display:flex;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.pl-kpi{flex:1;min-width:150px;background:var(--col-bg);border:1px solid var(--col-border);border-radius:var(--radius);padding:10px 14px}
.pl-kpi-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.6px;color:var(--col-muted);margin-bottom:3px}
.pl-kpi-val{font-size:18px;font-weight:800;font-variant-numeric:tabular-nums}
.pl-kpi-val.pos{color:var(--col-success)}
.pl-kpi-val.neg{color:var(--col-danger)}
.pl-kpi-val.info{color:var(--col-info)}
.pl-margin-badge{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;margin-left:8px;vertical-align:middle}
.pl-margin-badge.pos{background:var(--col-success-bg);color:var(--col-success)}
.pl-margin-badge.neg{background:var(--col-danger-bg);color:var(--col-danger)}
@media print{
  /* ── Ocultar todo lo que no es el documento P&L ── */
  .sidebar,.topbar,.report-filter-bar,.pl-kpi-row,.pl-nota,.er-no-print{display:none!important}

  /* ── Reset layout general ── */
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  html,body{background:#fff!important;display:block!important;margin:0!important;padding:0!important;min-height:auto!important;height:auto!important}
  .app{display:block!important;background:#fff!important;height:auto!important;overflow:visible!important;border-radius:0!important}
  .main{margin-left:0!important;padding:0!important;width:100%!important;min-height:auto!important;height:auto!important;display:block!important;background:#fff!important}
  .content{padding:0!important;overflow:visible!important;background:#fff!important;min-height:auto!important;height:auto!important}
  #view-estado-resultados{padding:0!important;background:transparent!important}
  #er-doc-container{display:block!important;padding:0!important;background:transparent!important}

  /* ── Documento P&L: limpio y ejecutivo ── */
  .pl-doc{
    display:block!important;
    border:none!important;
    box-shadow:none!important;
    border-radius:0!important;
    padding:0!important;
    max-width:100%!important;
    margin:0 auto!important;
    background:transparent!important;
    font-size:11pt;
  }
  .pl-header h2{font-size:15pt}
  .pl-row{padding:4px 0}
  .pl-amount{font-size:11pt}
  .pl-neto .pl-amount{font-size:13pt}

  /* ── Página A4 con márgenes ejecutivos ── */
  @page{size:A4 portrait;margin:18mm 22mm 18mm 22mm}
}

/* ══════════════════════════════════════════════════════════════════
   ENCABEZADO DE IMPRESIÓN — aparece solo en @media print
   ══════════════════════════════════════════════════════════════════ */
#print-header-empresa{display:none}
@media print{
  #print-header-empresa{
    display:flex!important;
    align-items:center;
    gap:14px;
    padding-bottom:10px;
    margin-bottom:12px;
    border-bottom:2px solid #ccc;
  }
  #print-header-empresa .ph-logo{
    width:60px;height:60px;object-fit:contain;flex-shrink:0;border-radius:6px;
  }
  #print-header-empresa .ph-info{flex:1;text-align:left}
  #print-header-empresa .ph-marca{font-size:10pt;color:#666;font-weight:500;margin-bottom:1px}
  #print-header-empresa .ph-nombre{font-size:15pt;font-weight:800;color:#1a3a5c;margin-bottom:2px}
  #print-header-empresa .ph-datos{font-size:8.5pt;color:#555;line-height:1.5}
}

/* ══════════════════════════════════════════════════════════════════
   MÓDULO DE CONFIGURACIÓN
   ══════════════════════════════════════════════════════════════════ */
/* ── Config tabs ── */
.config-tabs{display:flex;gap:0;border-bottom:2px solid var(--col-border);margin-bottom:20px}
.config-tab-btn{padding:10px 22px;font-size:13px;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--col-muted);border-bottom:3px solid transparent;margin-bottom:-2px;font-family:inherit;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:6px}
.config-tab-btn:hover{color:var(--col-text)}
.config-tab-btn.active{color:var(--col-primary);border-bottom-color:var(--col-primary)}
.config-tab-pane{display:none}
.config-tab-pane.active{display:block}

/* ── Config form card ── */
.config-form-card{background:var(--col-card);border:1px solid var(--col-border);border-radius:var(--radius-lg);padding:24px 28px;max-width:680px;margin-bottom:20px}
.config-form-card h3{font-size:13px;font-weight:700;color:var(--col-text);margin:0 0 16px;padding-bottom:10px;border-bottom:1px solid var(--col-border);display:flex;align-items:center;gap:7px}
.config-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.config-field-row.single{grid-template-columns:1fr}
.config-field{display:flex;flex-direction:column;gap:4px}
.config-field label{font-size:11px;font-weight:600;color:var(--col-muted);text-transform:uppercase;letter-spacing:0.5px}
.config-field input[type="text"],.config-field input[type="tel"]{width:100%;padding:8px 10px;font-size:13px;border:1px solid var(--col-border);border-radius:var(--radius);background:var(--col-bg);color:var(--col-text);font-family:inherit;box-sizing:border-box;transition:border-color .15s}
.config-field input:focus{outline:none;border-color:var(--col-primary)}

/* ── Logo upload ── */
.config-logo-area{display:flex;align-items:center;gap:16px;padding:14px;border:2px dashed var(--col-border);border-radius:var(--radius-lg);background:var(--col-bg);transition:border-color .15s}
.config-logo-area:hover{border-color:var(--col-primary)}
.config-logo-preview{width:72px;height:72px;object-fit:contain;border-radius:8px;border:1px solid var(--col-border);background:#fff;flex-shrink:0}
.config-logo-placeholder{width:72px;height:72px;border-radius:8px;border:1px dashed var(--col-border);background:#fff;display:flex;align-items:center;justify-content:center;color:var(--col-muted);font-size:24px;flex-shrink:0}
.config-logo-text{flex:1}
.config-logo-text strong{display:block;font-size:13px;font-weight:600;color:var(--col-text);margin-bottom:2px}
.config-logo-text small{font-size:11px;color:var(--col-muted)}
.config-logo-actions{display:flex;gap:8px;margin-top:8px}

/* ── Usuarios tab ── */
.usr-grid{display:grid;grid-template-columns:1fr;gap:12px;max-width:800px}
.usr-card{background:var(--col-card);border:1px solid var(--col-border);border-radius:var(--radius-lg);padding:16px 20px}
.usr-card-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.usr-avatar{width:36px;height:36px;border-radius:50%;background:var(--col-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}
.usr-card-info{flex:1}
.usr-card-name{font-size:13px;font-weight:700;color:var(--col-text)}
.usr-card-email{font-size:11px;color:var(--col-muted)}
.usr-card-badge{font-size:10px;padding:2px 7px;border-radius:20px;font-weight:600}
.usr-card-badge.admin{background:#dbeafe;color:#1d4ed8}
.usr-card-badge.activo{background:var(--col-success-bg);color:var(--col-success)}
.usr-perms{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.usr-perm-chip{font-size:10px;padding:2px 8px;border-radius:20px;background:var(--col-bg);border:1px solid var(--col-border);color:var(--col-muted);display:flex;align-items:center;gap:4px}
.usr-perm-chip.on{background:#eff6ff;border-color:var(--col-info);color:var(--col-info)}
.usr-perm-chip i{font-size:9px}

/* ── Modal usuarios / config ── */
.perm-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px}
.perm-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border:1px solid var(--col-border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s,background .15s;font-size:12px!important;font-weight:500;color:var(--col-text)!important;text-transform:none!important;letter-spacing:0!important}
.perm-item:hover{border-color:var(--col-primary);background:var(--col-bg)}
.perm-item input[type="checkbox"]{accent-color:var(--col-primary);width:14px;height:14px;flex-shrink:0}
.perm-item i{font-size:14px;color:var(--col-muted)}

