/* ================================================================
   ERP Logística — Sistema Modular  v2.0
   CSS compartido: menú general + módulos
   ================================================================ */
:root {
  --brand:      #1a3c6e;
  --brand-2:    #2563eb;
  --accent:     #f59e0b;
  --danger:     #dc2626;
  --success:    #16a34a;
  --warning:    #d97706;
  --info:       #0891b2;
  --bg:         #f1f5f9;
  --sidebar-bg: #0f2348;
  --card-bg:    #ffffff;
  --border:     #e2e8f0;
  --text:       #1e293b;
  --text-2:     #64748b;
  --text-muted: #94a3b8;
  --tbl-hdr:    #1e40af;
  --sidebar-w:  255px;
  --header-h:   58px;
  --radius:     8px;
  --radius-lg:  12px;
  --shadow-sm:  0 1px 3px rgba(0,0,0,.08);
  --shadow-md:  0 4px 12px rgba(0,0,0,.12);
  --shadow-lg:  0 10px 30px rgba(0,0,0,.16);
  --font:       'Inter','Segoe UI',system-ui,sans-serif;
  --mono:       'JetBrains Mono','Consolas',monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh}
a{color:var(--brand-2);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Menú principal (dashboard) ────────────────────────────── */
.menu-wrap{min-height:100vh;background:linear-gradient(135deg,#0f2348 0%,#1a3c6e 60%,#1d4ed8 100%)}
.menu-header{padding:2rem 2rem 1rem;text-align:center;color:#fff}
.menu-header .logo-box{width:72px;height:72px;background:var(--accent);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 1rem}
.menu-header h1{font-size:1.8rem;font-weight:800;letter-spacing:-.01em}
.menu-header p{color:#93c5fd;font-size:.9rem;margin-top:.3rem}
.menu-user{display:flex;align-items:center;justify-content:center;gap:.7rem;margin-top:1.2rem;padding:.7rem 1.4rem;background:rgba(255,255,255,.08);border-radius:99px;width:fit-content;margin-left:auto;margin-right:auto}
.menu-user .av{width:34px;height:34px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:var(--brand)}
.menu-user span{color:#fff;font-size:.85rem}
.menu-user a{color:#fca5a5;font-size:.8rem;margin-left:.5rem}

.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.2rem;padding:2rem;max-width:1200px;margin:0 auto}
.mod-card{background:#fff;border-radius:var(--radius-lg);padding:1.4rem 1.5rem;display:flex;align-items:flex-start;gap:1rem;cursor:pointer;transition:transform .15s,box-shadow .15s;text-decoration:none!important;border:2px solid transparent}
.mod-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.mod-card.disabled{opacity:.55;cursor:not-allowed;pointer-events:none}
.mod-card .icon-box{width:54px;height:54px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}
.mod-card h3{font-size:.95rem;font-weight:700;color:var(--brand);margin-bottom:.3rem}
.mod-card p{font-size:.78rem;color:var(--text-2);line-height:1.5}
.mod-card .badge-dev{display:inline-block;background:#fef3c7;color:#92400e;border-radius:4px;padding:.1rem .4rem;font-size:.65rem;font-weight:700;margin-top:.4rem}
.menu-footer{text-align:center;padding:1.5rem;color:#475569;font-size:.75rem}

/* ── Layout módulos ─────────────────────────────────────────── */
.erp-wrap{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--header-h) 1fr;grid-template-areas:"side hdr" "side main";min-height:100vh}
.erp-sidebar{grid-area:side;background:var(--sidebar-bg);display:flex;flex-direction:column;overflow-y:auto;position:sticky;top:0;height:100vh}
.sidebar-logo{padding:1rem 1.1rem;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:.7rem}
.sidebar-logo .ico{width:34px;height:34px;background:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:800;color:#0f2348;font-size:.88rem;flex-shrink:0}
.sidebar-logo .txt{color:#fff;font-size:.88rem;font-weight:700;line-height:1.2}
.sidebar-logo .sub{color:#475569;font-size:.63rem;text-transform:uppercase;letter-spacing:.08em}
.sidebar-sec{padding:.35rem 0;border-bottom:1px solid rgba(255,255,255,.04)}
.sidebar-sec-title{padding:.4rem 1.1rem .18rem;font-size:.61rem;text-transform:uppercase;letter-spacing:.1em;color:#475569;font-weight:600}
.nav-item{display:flex;align-items:center;gap:.6rem;padding:.5rem 1.1rem;color:#cbd5e1;font-size:.83rem;border-left:3px solid transparent;transition:all .15s;text-decoration:none!important;cursor:pointer}
.nav-item:hover{background:rgba(255,255,255,.05);color:#fff;border-left-color:var(--accent)}
.nav-item.active{background:rgba(37,99,235,.22);color:#fff;border-left-color:var(--brand-2)}
.nav-item .ic{width:17px;text-align:center;opacity:.65;flex-shrink:0}
.nav-item.active .ic,.nav-item:hover .ic{opacity:1}
.nav-sub .nav-item{font-size:.79rem;padding:.36rem 1.1rem .36rem 1.5rem}

.erp-header{grid-area:hdr;background:var(--brand);display:flex;align-items:center;justify-content:space-between;padding:0 1.4rem;box-shadow:var(--shadow-md);position:sticky;top:0;z-index:100}
.hdr-title{color:#fff;font-size:.93rem;font-weight:700;display:flex;align-items:center;gap:.5rem}
.hdr-bc{font-size:.78rem;font-weight:400;color:#93c5fd;margin-left:.3rem}
.hdr-right{display:flex;align-items:center;gap:.9rem;color:#fff}
.avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;color:var(--brand);flex-shrink:0}
.erp-main{grid-area:main;padding:1.3rem;overflow-y:auto}

/* ── Page header ── */
.page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.3rem;gap:1rem;flex-wrap:wrap}
.page-hdr h1{font-size:1.15rem;font-weight:700;color:var(--brand);display:flex;align-items:center;gap:.5rem}
.page-hdr .sub{font-size:.76rem;color:var(--text-2);margin-top:.12rem}
.page-hdr .acts{display:flex;gap:.5rem;flex-wrap:wrap}

/* ── Stats ── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:1rem;margin-bottom:1.3rem}
.stat-card{background:var(--card-bg);border-radius:var(--radius-lg);padding:1.1rem;box-shadow:var(--shadow-sm);border:1px solid var(--border);display:flex;align-items:flex-start;gap:.85rem}
.stat-card .icon{width:44px;height:44px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}
.icon.blue{background:#dbeafe;color:#1d4ed8}
.icon.amber{background:#fef3c7;color:#d97706}
.icon.green{background:#dcfce7;color:#16a34a}
.icon.red{background:#fee2e2;color:#dc2626}
.icon.purple{background:#ede9fe;color:#7c3aed}
.stat-card .val{font-size:1.45rem;font-weight:700;line-height:1}
.stat-card .lbl{font-size:.74rem;color:var(--text-2);margin-top:.18rem}

/* ── Cards ── */
.card{background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:1rem}
.card-hdr,.card-header{padding:.85rem 1.15rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:#fafbfc}
.card-hdr h2,.card-header h2{font-size:.87rem;font-weight:700;color:var(--brand);display:flex;align-items:center;gap:.4rem}
.card-body{padding:1.15rem}
.card-foot,.card-footer{padding:.75rem 1.15rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.6rem;background:#fafbfc}

/* ── Tabs ── */
.tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:1.15rem;overflow-x:auto;gap:.05rem}
.tab-btn{padding:.55rem 1rem;font-size:.81rem;font-weight:600;color:var(--text-2);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:all .15s;border-radius:var(--radius) var(--radius) 0 0}
.tab-btn:hover{color:var(--brand);background:#f8fafc}
.tab-btn.active{color:var(--brand-2);border-bottom-color:var(--brand-2);background:#fff}
.tab-pane{display:none}.tab-pane.active{display:block}

/* ── Forms ── */
.fgrid,.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(205px,1fr));gap:.85rem}
.fgrid.c2,.form-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.fgrid.c3,.form-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.fgrid.c4,.form-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.fg,.form-group{display:flex;flex-direction:column;gap:.22rem}
.fg.full,.form-group.full{grid-column:1/-1}
.fg.c2,.form-group.col-2{grid-column:span 2}
label{font-size:.72rem;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em}
label .req{color:var(--danger)}
input[type=text],input[type=number],input[type=date],input[type=email],
input[type=tel],input[type=password],input[type=search],select,textarea{
  width:100%;padding:.44rem .7rem;border:1.5px solid var(--border);border-radius:var(--radius);
  font-size:.84rem;font-family:var(--font);background:#fff;color:var(--text);
  transition:border-color .15s,box-shadow .15s;appearance:none}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand-2);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
input[readonly],input.ro{background:#f1f5f9;color:var(--text-2);cursor:default}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%2364748b'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .7rem center;padding-right:2rem}
textarea{resize:vertical;min-height:68px}
.check-row{display:flex;align-items:center;gap:.5rem;padding:.22rem 0}
.check-row input[type=checkbox]{width:15px;height:15px;accent-color:var(--brand-2);cursor:pointer;flex-shrink:0}
.check-row label{font-size:.82rem;text-transform:none;letter-spacing:0;color:var(--text);font-weight:400;cursor:pointer}

/* ── IIBB table ── */
.iibb-table{width:100%;border-collapse:collapse;font-size:.78rem}
.iibb-table th{background:#1e3a5f;color:#fff;padding:.4rem .52rem;text-align:left;font-weight:600;font-size:.69rem;white-space:nowrap}
.iibb-table th.grp-ret{background:#145232}
.iibb-table th.grp-per{background:#0f3050}
.iibb-table td{padding:.26rem .4rem;border-bottom:1px solid var(--border);vertical-align:middle}
.iibb-table tr:nth-child(even) td{background:#f8fafc}
.iibb-table tr:hover td{background:#eff6ff}
.iibb-table input{padding:.24rem .35rem!important;font-size:.76rem!important}
.prov-badge{display:inline-block;background:#e0f2fe;color:#0369a1;border-radius:4px;padding:.1rem .35rem;font-size:.69rem;font-weight:700}

/* ── Data tables ── */
.tbl-wrap,.table-wrapper{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}
table.data{width:100%;border-collapse:collapse;font-size:.82rem}
table.data thead th{background:var(--tbl-hdr);color:#fff;padding:.58rem .82rem;text-align:left;white-space:nowrap;position:sticky;top:0;z-index:2}
table.data tbody tr{border-bottom:1px solid var(--border)}
table.data tbody tr:hover{background:#eff6ff}
table.data tbody tr:nth-child(even){background:#f8fafc}
table.data tbody tr:nth-child(even):hover{background:#eff6ff}
table.data td{padding:.5rem .82rem;vertical-align:middle}
td.num{text-align:right;font-family:var(--mono);font-size:.78rem}
td.ctr{text-align:center}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;padding:.12rem .48rem;border-radius:999px;font-size:.69rem;font-weight:600;white-space:nowrap}
.badge-pendiente{background:#fef3c7;color:#92400e}
.badge-lista{background:#dbeafe;color:#1e40af}
.badge-facturada{background:#dcfce7;color:#14532d}
.badge-anulada{background:#fee2e2;color:#991b1b}
.badge-ok{background:#dcfce7;color:#14532d}
.badge-warn{background:#fef3c7;color:#92400e}
.badge-err{background:#fee2e2;color:#991b1b}
.badge-off{background:#f1f5f9;color:#64748b}
.badge-ri{background:#dbeafe;color:#1e40af}
.badge-ex{background:#dcfce7;color:#14532d}
.badge-mo{background:#fef3c7;color:#92400e}
.badge-cf{background:#f3f4f6;color:#374151}
.debe{color:var(--danger)}
.haber{color:var(--success)}
.saldo-deudor{color:var(--danger);font-weight:700}
.saldo-acreedor{color:var(--success);font-weight:700}

/* ── Botones ── */
.btn{display:inline-flex;align-items:center;gap:.38rem;padding:.44rem .95rem;border-radius:var(--radius);font-size:.83rem;font-weight:600;font-family:var(--font);cursor:pointer;border:none;transition:all .15s;text-decoration:none!important;white-space:nowrap;line-height:1.4}
.btn-primary{background:var(--brand-2);color:#fff}.btn-primary:hover{background:#1d4ed8;color:#fff}
.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#15803d;color:#fff}
.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c;color:#fff}
.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover{background:#b45309;color:#fff}
.btn-sec,.btn-secondary{background:#e2e8f0;color:var(--text)}.btn-sec:hover,.btn-secondary:hover{background:#cbd5e1}
.btn-outline{background:transparent;border:1.5px solid var(--brand-2);color:var(--brand-2)}.btn-outline:hover{background:#eff6ff}
.btn-sm{padding:.26rem .62rem;font-size:.75rem}
.btn-lg{padding:.62rem 1.35rem;font-size:.9rem}
.btn:disabled{opacity:.45;cursor:not-allowed}

/* ── Filter / Alerts / Pagination ── */
.filter-bar{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1.05rem;margin-bottom:1rem;display:flex;flex-wrap:wrap;gap:.65rem;align-items:flex-end}
.alert{padding:.75rem .95rem;border-radius:var(--radius);margin-bottom:.85rem;font-size:.84rem;display:flex;align-items:flex-start;gap:.58rem;border-left:4px solid}
.alert-success,.alert-ok{background:#f0fdf4;border-color:var(--success);color:#166534}
.alert-error,.alert-err{background:#fef2f2;border-color:var(--danger);color:#991b1b}
.alert-warning,.alert-warn{background:#fffbeb;border-color:var(--warning);color:#92400e}
.alert-info{background:#f0f9ff;border-color:var(--info);color:#075985}
.pagination{display:flex;align-items:center;gap:.38rem;justify-content:flex-end;padding-top:.85rem}
.page-btn{min-width:30px;height:30px;padding:0 .42rem;border:1.5px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--text-2);font-size:.77rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;text-decoration:none}
.page-btn:hover{background:#eff6ff;border-color:var(--brand-2);color:var(--brand-2)}
.page-btn.active{background:var(--brand-2);border-color:var(--brand-2);color:#fff}
.page-info{font-size:.77rem;color:var(--text-2);padding:0 .38rem}

/* ── Modal ── */
.modal-overlay,.modal-bg{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.48);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;visibility:hidden;transition:all .2s}
.modal-overlay.open,.modal-bg.open{opacity:1;visibility:visible}
.modal{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:680px;max-height:90vh;overflow-y:auto;transform:translateY(-18px);transition:transform .2s}
.modal-overlay.open .modal,.modal-bg.open .modal{transform:translateY(0)}
.modal-hdr,.modal-header{padding:.85rem 1.15rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:#f8fafc}
.modal-hdr h3,.modal-header h3{font-size:.88rem;font-weight:700;color:var(--brand)}
.modal-body{padding:1.15rem}
.modal-foot,.modal-footer{padding:.75rem 1.15rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.6rem;background:#f8fafc}

/* ── Login ── */
.login-wrap,.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f2348 0%,#1a3c6e 55%,#1d4ed8 100%)}
.login-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:2.1rem 1.7rem;width:100%;max-width:385px}
.login-logo{text-align:center;margin-bottom:1.35rem}
.login-logo .lic,.logo-icon{width:60px;height:60px;background:var(--brand);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin:0 auto .85rem;font-size:1.7rem}
.login-logo h1{font-size:1.2rem;color:var(--brand);font-weight:800}
.login-logo p{font-size:.78rem;color:var(--text-2)}

/* ── Tarifas / Constancias ── */
.tarifas-section{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-top:1rem}
.tarifas-section th{background:#1e3a5f;color:#fff;font-size:.73rem;padding:.38rem .55rem}
.tarifas-section td{padding:.32rem .48rem}
.page-title{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.3rem;gap:1rem;flex-wrap:wrap}
.page-title h1{font-size:1.15rem;font-weight:700;color:var(--brand);display:flex;align-items:center;gap:.5rem}
.page-title__sub{font-size:.76rem;color:var(--text-2);margin-top:.12rem}
.page-title__actions{display:flex;gap:.5rem;flex-wrap:wrap}

/* ── Responsive ── */
@media(max-width:900px){:root{--sidebar-w:0px}.erp-sidebar{display:none}.erp-wrap{grid-template-columns:1fr;grid-template-areas:"hdr""main"}.fgrid.c3,.fgrid.c4,.form-grid.cols-3,.form-grid.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.erp-main{padding:.85rem .6rem}.fgrid,.fgrid.c2,.form-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.filter-bar{flex-direction:column}.modules-grid{grid-template-columns:1fr;padding:1rem}}
@media print{.erp-sidebar,.erp-header,.filter-bar,.pagination,.btn,.page-hdr .acts,.page-title__actions{display:none!important}.erp-main{padding:0}.card{box-shadow:none}thead th{-webkit-print-color-adjust:exact}}

/* ── Live Search Cliente ── */

/* ── Autocomplete Clientes ─────────────────────────────────── */
.ac-lista {
    font-family: 'JetBrains Mono', 'Consolas', 'SF Mono', 'Fira Code', monospace;
}
.ac-cli-item {
    padding: 10px 14px 0 14px;
    cursor: pointer;
    transition: background .08s;
}
.ac-cli-item:hover,
.ac-cli-item.sel {
    background: #f0f5ff;
}
.ac-cli-l1 {
    font-size: 13px;
    font-weight: 600;
    color: #2563eb;
    line-height: 1.5;
    letter-spacing: .02em;
    white-space: pre;
}
.ac-cli-l2 {
    font-size: 12.5px;
    font-weight: 400;
    color: #334155;
    line-height: 1.5;
    padding-bottom: 9px;
    border-bottom: 1px solid #e5e7eb;
}
.ac-cli-item:last-child .ac-cli-l2 {
    border-bottom: none;
}
