﻿:root{
  /* ── Paleta NAVY (identidad primaria) ── */
  --navy-900:#0F2744; --navy-800:#163257; --navy-700:#1B4A7A;
  --navy-600:#2B5D93; --navy-500:#4A7FB5; --navy-100:#EBF2FA; --navy-50:#F5F9FD;

  /* ── Rojo corporativo ── */
  --red:#C8102E; --red-dim:#8B0B1F; --red-glow:rgba(200,16,46,.12);
  --red-soft:#FDECEA;

  /* ── Estados ── */
  --green:#1A7A4A; --green-dim:#125A36; --green-bg:#E8F5EE;
  --yellow:#C87000; --yellow-bg:#FFF4E0;
  --orange:#D04010; --orange-bg:#FDE5DA;
  --blue:#2B5D93;   --blue-bg:#EBF2FA;
  --purple:#5B2C8D; --purple-bg:#F0E8FF;

  /* ── Neutrales (mapeo a tokens legacy) ── */
  --bg0:#F9FAFB;    /* fondo global de la app */
  --bg1:#FFFFFF;    /* header / topbar */
  --bg2:#FFFFFF;    /* tarjetas */
  --bg3:#F9FAFB;    /* secundario (zebra, headers tabla) */
  --bg4:#F3F4F6;    /* terciario (inputs, chips) */
  --border:#E5E7EB; --border2:#D1D5DB;
  --txt:#1F2937;    /* texto principal */
  --txt2:#4B5563;   /* texto secundario */
  --txt3:#6B7280;   /* texto terciario / labels */

  /* ── Radios y sombras premium ── */
  --radius:10px; --radius2:8px;
  --shadow:0 1px 2px rgba(15,39,68,.05),0 1px 3px rgba(15,39,68,.08);
  --shadow2:0 12px 32px rgba(15,39,68,.12),0 4px 8px rgba(15,39,68,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:'Inter','Barlow',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
  background:var(--bg0);color:var(--txt);min-height:100vh;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  font-size:14px;line-height:1.5;
}
a,button,input,select,textarea{font:inherit}

/* ═══ LOADER ═══ */
#loader{
  position:fixed;inset:0;z-index:9999;
  background:var(--navy-900);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;
  transition:opacity .6s ease;
}
#loader.fade{opacity:0;pointer-events:none}
.loader-logo{width:260px;opacity:0;transform:scale(.85);animation:logoIn .9s cubic-bezier(.16,1,.3,1) .2s forwards}
.loader-bar-wrap{width:260px;height:3px;background:rgba(255,255,255,.12);border-radius:2px;overflow:hidden}
.loader-bar{height:100%;width:0;background:linear-gradient(90deg,var(--red-dim),var(--red));animation:barFill 2.5s ease .5s forwards}
.loader-txt{font-family:'Inter',sans-serif;font-size:11px;letter-spacing:2.5px;color:rgba(255,255,255,.55);text-transform:uppercase;opacity:0;animation:fadeIn .5s ease 1s forwards;font-weight:600}
.loader-name{font-family:'Inter',sans-serif;font-size:22px;font-weight:800;letter-spacing:1.5px;color:#fff;text-transform:uppercase;opacity:0;animation:fadeIn .5s ease .7s forwards;margin-top:12px}
.loader-slogan{font-family:'Inter',sans-serif;font-size:12px;color:rgba(255,255,255,.5);letter-spacing:.5px;opacity:0;animation:fadeIn .5s ease .9s forwards;margin-bottom:18px;text-align:center;max-width:300px}
@keyframes logoIn{to{opacity:1;transform:scale(1)}}
@keyframes barFill{to{width:100%}}
@keyframes fadeIn{to{opacity:1}}

/* ═══ HEADER ═══ */
header{
  background:var(--bg1);border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:50;
}
.hdr-inner{max-width:1400px;margin:0 auto;padding:0 20px;display:flex;align-items:center;gap:16px;height:60px}
.hdr-logo{height:32px;display:block}
.hdr-divider{width:1px;height:28px;background:var(--border)}
.hdr-title{
  font-family:'Inter',sans-serif;
  font-size:15px;font-weight:700;letter-spacing:.2px;
  color:var(--navy-900);line-height:1.2;
}
.hdr-sub{font-size:10.5px;color:var(--txt3);letter-spacing:1.2px;text-transform:uppercase;font-weight:600}
.hdr-right{margin-left:auto;display:flex;align-items:center;gap:10px}

/* ── Inventario dropdown ── */
.inv-dropdown{position:relative;display:inline-block}
.inv-btn{background:var(--green-bg);border:1px solid rgba(26,122,74,.28);color:var(--green);padding:6px 12px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:700;display:flex;align-items:center;gap:5px;white-space:nowrap;transition:.15s}
.inv-btn:hover{background:#D7EEDF}
.inv-btn .inv-arrow{font-size:9px;opacity:.7;transition:.2s}
.inv-dropdown:hover .inv-arrow,.inv-dropdown.open .inv-arrow{transform:rotate(180deg)}
.inv-menu{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid var(--border);border-radius:10px;min-width:210px;box-shadow:var(--shadow2);z-index:600;display:none;overflow:hidden}
.inv-dropdown:hover .inv-menu,.inv-dropdown.open .inv-menu{display:block}
.inv-menu-title{padding:8px 14px;font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:1.2px;color:var(--txt3);border-bottom:1px solid var(--border)}
.inv-menu a{display:flex;align-items:center;gap:10px;padding:10px 14px;font-size:12.5px;font-weight:600;color:var(--txt);text-decoration:none;transition:.12s}
.inv-menu a:hover{background:var(--navy-50);color:var(--navy-900)}
.inv-menu a .inv-item-icon{font-size:16px;width:22px;text-align:center;color:var(--navy-700)}
.inv-menu a .inv-item-label{flex:1}
.inv-menu a .inv-item-arrow{font-size:10px;opacity:.4;color:var(--txt3)}
@media(max-width:640px){
  .inv-menu{right:auto;left:0;min-width:190px}
  .inv-btn span:not(.inv-arrow){display:none}
}
.badge-alert{
  background:var(--red);color:#fff;border-radius:999px;
  width:20px;height:20px;font-size:10.5px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 1px 2px rgba(200,16,46,.3);
}

/* ═══ NAV ═══ */
nav{background:var(--bg1);border-bottom:1px solid var(--border);overflow-x:auto}
.nav-inner{max-width:1400px;margin:0 auto;padding:0 20px;display:flex;gap:0}
.nav-btn{
  border:0;background:transparent;color:var(--txt3);
  padding:13px 16px;font-family:'Inter',sans-serif;
  font-size:12.5px;font-weight:600;letter-spacing:.3px;
  cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;
  display:flex;align-items:center;gap:8px;transition:all .2s;
}
.nav-btn:hover{color:var(--navy-900);background:var(--navy-50)}
.nav-btn.active{color:var(--red);border-bottom-color:var(--red);background:var(--red-soft)}
.nav-btn .nb{
  background:var(--red);color:#fff;border-radius:999px;
  min-width:18px;height:18px;font-size:10px;font-weight:800;
  display:flex;align-items:center;justify-content:center;padding:0 4px;
}
/* ── Separadores de grupo de navegación ── */
.nav-group{display:flex;align-items:stretch;position:relative}
.nav-group+.nav-group::before{
  content:'';display:block;width:1px;
  background:var(--border);margin:8px 0;align-self:stretch;
}
.nav-group-label{
  position:absolute;top:4px;left:50%;transform:translateX(-50%);
  font-size:8px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--txt3);opacity:.5;white-space:nowrap;pointer-events:none;
  display:none;
}

/* ═══ SUPERADMIN PANEL ═══ */
#panelSuperadmin{display:none;max-width:1400px;margin:0 auto;padding:24px 20px}
.sa-nav{display:flex;gap:6px;margin-bottom:24px;border-bottom:1px solid var(--border);padding-bottom:0}
.sa-tab{border:0;background:transparent;color:var(--txt3);padding:10px 16px;font-family:'Inter',sans-serif;font-size:12.5px;font-weight:600;letter-spacing:.3px;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}
.sa-tab:hover{color:var(--navy-900)}.sa-tab.active{color:var(--purple);border-bottom-color:var(--purple)}
.sa-panel{display:none}.sa-panel.active{display:block}
.sa-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.sa-title{font-family:'Inter',sans-serif;font-size:22px;font-weight:700;letter-spacing:-.2px;color:var(--navy-900)}
.sa-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:24px}
.sa-kpi{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.sa-kpi-val{font-size:28px;font-weight:800;font-family:'Inter',sans-serif;color:var(--navy-900);letter-spacing:-.3px;line-height:1}
.sa-kpi-lbl{font-size:10.5px;color:var(--txt3);letter-spacing:1px;text-transform:uppercase;margin-top:6px;font-weight:700}
.sa-table{width:100%;border-collapse:collapse;font-size:13px}
.sa-table th{text-align:left;padding:10px 12px;font-size:10.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--txt3);border-bottom:1px solid var(--border);background:var(--bg3)}
.sa-table td{padding:11px 12px;border-bottom:1px solid var(--border);color:var(--txt2)}
.sa-table tr:hover td{background:var(--navy-50)}
.pill{display:inline-flex;align-items:center;padding:2px 10px;border-radius:999px;font-size:11px;font-weight:700}
.pill-activa{background:var(--green-bg);color:var(--green);border:1px solid #B8E1CA}.pill-suspendida{background:var(--red-soft);color:var(--red);border:1px solid #F5BBC3}
.pill-demo{background:var(--yellow-bg);color:var(--yellow);border:1px solid #F6D89A}.pill-vencida{background:var(--bg4);color:var(--txt2);border:1px solid var(--border)}
.sa-form{display:grid;gap:14px}.sa-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sa-form-row.three{grid-template-columns:1fr 1fr 1fr}
/* Usuarios jerárquicos */
.sa-empresa-group{margin-bottom:20px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:var(--shadow)}
.sa-empresa-group-header{background:var(--bg3);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.sa-empresa-group-nombre{font-family:'Inter',sans-serif;font-size:13px;font-weight:700;letter-spacing:.3px;color:var(--navy-900)}
.sa-user-row{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border);transition:background .15s}
.sa-user-row:last-child{border-bottom:0}
.sa-user-row:hover{background:var(--navy-50)}
.sa-user-row.admin-row{background:#F3F8FD;cursor:pointer}
.sa-user-row.admin-row:hover{background:#E8F1FA}
.sa-user-row.child-row{padding-left:40px;background:transparent}
.sa-user-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;background:var(--navy-100);color:var(--navy-700)}
.sa-user-info{flex:1;min-width:0}
.sa-user-email{font-size:13px;color:var(--navy-900);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sa-user-meta{font-size:11px;color:var(--txt3);margin-top:1px;text-transform:uppercase;letter-spacing:.5px}
.sa-user-actions{display:flex;gap:6px;align-items:center;flex-shrink:0}
.sa-add-user-row{padding:10px 16px;display:flex;align-items:center;gap:8px;color:var(--txt3);font-size:12px;cursor:pointer;transition:background .15s;border-top:1px dashed var(--border2)}
.sa-add-user-row:hover{background:var(--bg3);color:var(--navy-900)}
/* ─── Semáforos SA ─── */
.sa-semaforo{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;border:1px solid var(--border);margin-bottom:8px;font-size:12px;background:#fff}
.sa-semaforo.verde{background:var(--green-bg);border-color:#B8E1CA;color:var(--green)}
.sa-semaforo.amarillo{background:var(--yellow-bg);border-color:#F6D89A;color:var(--yellow)}
.sa-semaforo.naranja{background:var(--orange-bg);border-color:#F9BFA3;color:var(--orange)}
.sa-semaforo.rojo{background:var(--red-soft);border-color:#F5BBC3;color:var(--red)}
.sa-uso-bar{height:8px;border-radius:4px;background:var(--bg4);overflow:hidden;flex:1;min-width:80px}
.sa-uso-fill{height:100%;border-radius:4px;transition:width .4s}
.sa-uso-fill.verde{background:#3AAF6A}
.sa-uso-fill.amarillo{background:#E8A020}
.sa-uso-fill.naranja{background:#D04010}
.sa-uso-fill.rojo{background:var(--red)}
/* ─── Vencimientos ─── */
.sa-venc-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:8px;background:var(--bg3);border:1px solid var(--border);margin-bottom:6px;font-size:12px}
.sa-venc-item.urgente{border-color:#F5BBC3;background:var(--red-soft)}
.sa-venc-item.proximo{border-color:#F6D89A;background:var(--yellow-bg)}
/* ─── Métricas ─── */
.sa-met-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-bottom:18px}
.sa-met-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:14px;text-align:center;box-shadow:var(--shadow)}
.sa-met-val{font-family:'Inter',sans-serif;font-size:26px;font-weight:800;color:var(--navy-900);letter-spacing:-.3px}
.sa-met-lbl{font-size:10px;color:var(--txt3);text-transform:uppercase;letter-spacing:1px;margin-top:4px;font-weight:600}
/* ─── Financiero ─── */
.sa-fin-plan-bar{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}
.sa-fin-plan-bar:last-child{border-bottom:0}

/* ═══ MAIN ═══ */
main{max-width:1400px;margin:0 auto;padding:24px 20px}
.tab-content{display:none}.tab-content.active{display:block}

/* ═══ CARDS ═══ */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:box-shadow .2s,border-color .2s}
.card:hover{border-color:var(--border2);box-shadow:0 4px 12px rgba(15,39,68,.08)}
.card-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--bg3)}
.card-header h3{font-family:'Inter',sans-serif;font-size:14px;font-weight:700;letter-spacing:.2px;color:var(--navy-900);display:flex;align-items:center;gap:8px}
.card-body{padding:18px}

/* ═══ KPI CARDS ═══ */
.kpi-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-bottom:18px}
@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}
.kpi{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:12px 14px;position:relative;overflow:hidden;
  box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;
}
.kpi:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(15,39,68,.1)}
.kpi::before{
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:3px;background:var(--navy-600);
}
.kpi-icon{font-size:16px;margin-bottom:4px;color:var(--navy-700)}
.kpi-val{font-family:'Inter',sans-serif;font-size:24px;font-weight:800;line-height:1;color:var(--navy-900);letter-spacing:-.5px}
.kpi-label{font-size:9.5px;color:var(--txt3);text-transform:uppercase;letter-spacing:1px;margin-top:3px;font-weight:700}
.kpi-sub{font-size:11.5px;color:var(--txt3);margin-top:8px;font-weight:500}

/* ═══ ESTADO PILLS ═══ */
.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.2px;white-space:nowrap;border:1px solid transparent}
.pill-disponible{background:var(--green-bg);color:var(--green);border-color:#B8E1CA}
.pill-trabajando{background:var(--blue-bg);color:var(--blue);border-color:#C7DAF0}
.pill-varada{background:var(--red-soft);color:var(--red);border-color:#F5BBC3}
.pill-alistamiento{background:var(--yellow-bg);color:var(--yellow);border-color:#F6D89A}
.pill-devolucion{background:var(--purple-bg);color:var(--purple);border-color:#D7C4F0}
.pill-devuelto{background:var(--orange-bg);color:var(--orange);border-color:#F9BFA3}
.pill-alert{background:var(--red-soft);color:var(--red);border-color:#F5BBC3}
.pill-ok{background:var(--green-bg);color:var(--green);border-color:#B8E1CA}

/* ═══ BOTONES ═══ */
.btn{border:1px solid transparent;cursor:pointer;border-radius:var(--radius2);padding:0 16px;height:38px;font-family:'Inter',sans-serif;font-weight:600;font-size:13px;display:inline-flex;align-items:center;justify-content:center;gap:7px;transition:all .15s;letter-spacing:.1px;white-space:nowrap}
.btn-primary{background:var(--navy-800);color:#fff;box-shadow:0 1px 2px rgba(15,39,68,.1)}
.btn-primary:hover{background:var(--navy-900);box-shadow:0 2px 4px rgba(15,39,68,.15)}
.btn-secondary{background:#fff;color:var(--txt2);border-color:var(--border2)}
.btn-secondary:hover{background:var(--bg3);color:var(--navy-900);border-color:var(--gray-400,#9CA3AF)}
.btn-success{background:var(--green);color:#fff}.btn-success:hover{background:var(--green-dim)}
.btn-warning{background:var(--yellow);color:#fff}.btn-warning:hover{filter:brightness(.95)}
.btn-ghost{background:transparent;color:var(--navy-700);border-color:transparent}
.btn-ghost:hover{background:var(--navy-100);color:var(--navy-900)}
.btn-sm{height:32px;padding:0 12px;font-size:12px;border-radius:6px}
.btn-xs{height:28px;padding:0 10px;font-size:11.5px;border-radius:5px}
/* Accent corporativo (rojo) — usar cuando el CTA debe destacar por color */
.btn.btn-accent{background:var(--red);color:#fff;border-color:var(--red);box-shadow:0 1px 2px rgba(200,16,46,.2)}
.btn.btn-accent:hover{background:var(--red-dim)}

/* ═══ TABLA ═══ */
thead{background:var(--bg3)}
thead tr{border-bottom:2px solid var(--border)}
th{padding:6px 10px;text-align:left;font-family:'Inter',sans-serif;font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--txt3);white-space:nowrap;border:1px solid var(--border)}
td{padding:3px 8px;line-height:1.2;border:1px solid var(--border);font-size:12px;vertical-align:middle;color:var(--txt2)}
tbody tr{transition:background .12s;border-bottom:1px solid var(--border)}
tbody tr:hover{background:var(--navy-50)}

/* ═══ FORM ═══ */
.form-grid{display:grid;gap:14px}
.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.form-row.three{grid-template-columns:repeat(3,1fr)}
@media(max-width:640px){.form-row,.form-row.three{grid-template-columns:1fr}}
.field label{display:block;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--txt3);margin-bottom:6px}
/* Formulario horizontal: label izquierda, input derecha */
.cli-field-h{display:flex!important;align-items:center;gap:12px}
.cli-field-h label{width:180px!important;min-width:180px!important;flex-shrink:0!important;margin-bottom:0!important;display:block!important;text-align:right}
.cli-field-h input,.cli-field-h select,.cli-field-h textarea{flex:1!important;min-width:0!important;width:auto!important}
.cli-field-h.align-top{align-items:flex-start}
.cli-field-h.align-top label{padding-top:9px}
@media(max-width:560px){.cli-field-h{flex-direction:column;align-items:stretch}.cli-field-h label{width:100%;min-width:0;padding-top:0!important}}
.log-two-col{display:grid;grid-template-columns:1fr 420px;gap:16px;align-items:stretch}
@media(max-width:768px){.log-two-col{grid-template-columns:1fr}}
input,select,textarea{
  width:100%;padding:9px 12px;
  background:#fff;border:1px solid var(--border2);
  border-radius:var(--radius2);color:var(--txt);
  outline:none;transition:border-color .2s,box-shadow .2s;
  font-family:inherit;font-size:13px;
}
input:focus,select:focus,textarea:focus{border-color:var(--navy-500);box-shadow:0 0 0 3px rgba(74,127,181,.12)}

/* ═══ ACCESIBILIDAD — FOCO VISIBLE ═══ */
:focus-visible{
  outline:2px solid var(--navy-500);
  outline-offset:2px;
}
:focus:not(:focus-visible){
  outline:none;
}
.btn:focus-visible,.nav-btn:focus-visible,.filter-btn:focus-visible,.close-btn:focus-visible,.btn-go:focus-visible{
  outline:2px solid var(--navy-500);
  outline-offset:3px;
  box-shadow:0 0 0 4px rgba(74,127,181,.15);
}
.svc-input:focus-visible,.svc-select:focus-visible{
  outline:2px solid var(--navy-500);
  outline-offset:1px;
}
/* Skip link — oculto hasta foco */
.skip-link{
  position:fixed;top:-100px;left:16px;z-index:99999;
  background:var(--navy-800);color:#fff;
  padding:10px 18px;border-radius:8px;font-weight:700;font-size:14px;
  text-decoration:none;transition:top .15s;
}
.skip-link:focus{top:16px;}

select option{background:#fff;color:var(--txt)}
textarea{resize:vertical;min-height:80px}
input[type=checkbox]{width:18px;height:18px;accent-color:var(--navy-700);cursor:pointer}

/* ═══ MODAL ═══ */
.modal-backdrop{
  position:fixed;inset:0;background:rgba(15,39,68,.42);
  display:none;align-items:center;justify-content:center;z-index:200;padding:16px;
  backdrop-filter:blur(4px);
}
.modal-backdrop.show{display:flex}
/* Modales que se abren desde dentro de otro modal — deben apilarse por encima */
#modalNuevoMant,
#modalHvVarada,
#modalHvVaradaStop,
#modalSeguimientos { z-index: 400; }
#modalCortePago { z-index: 500; }
.modal{
  background:var(--bg2);border:1px solid var(--border);border-radius:14px;
  max-width:680px;width:100%;max-height:90vh;overflow:auto;
  box-shadow:var(--shadow2);
  animation:modalIn .25s cubic-bezier(.16,1,.3,1);
}
.modal.modal-wide{max-width:900px}
@keyframes modalIn{from{opacity:0;transform:translateY(20px) scale(.97)}}
.modal-head{
  padding:16px 20px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:var(--bg3);
  position:sticky;top:0;z-index:10;
}
.modal-head h3{font-family:'Inter',sans-serif;font-size:16px;font-weight:700;letter-spacing:.2px;color:var(--navy-900)}
.modal-body{padding:20px}
.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;background:var(--bg3)}
.close-btn{border:1px solid var(--border2);background:#fff;color:var(--txt3);width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.close-btn:hover{color:var(--navy-900);border-color:var(--gray-400);background:var(--bg3)}

/* ═══ ALERT ITEMS ═══ */
.alert-item{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius2);
  padding:13px 16px;display:flex;align-items:center;gap:12px;
  border-left:3px solid transparent;
  box-shadow:var(--shadow);
}
.alert-item.critica{border-left-color:var(--red);background:var(--red-soft)}
.alert-item.alta{border-left-color:var(--orange);background:var(--orange-bg)}
.alert-item.media{border-left-color:var(--yellow);background:var(--yellow-bg)}
.alert-item.ok{border-left-color:var(--green);background:var(--green-bg)}
.alert-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot-critica{background:var(--red)}
.dot-alta{background:var(--orange)}
.dot-media{background:var(--yellow)}
.dot-ok{background:var(--green)}

/* ═══ TOAST ═══ */
#toasts{position:fixed;bottom:20px;right:20px;z-index:9000;display:flex;flex-direction:column;gap:8px}
.toast{
  background:#fff;border:1px solid var(--border);border-radius:10px;
  padding:12px 16px;min-width:260px;max-width:340px;
  display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;
  animation:toastIn .3s ease;box-shadow:var(--shadow2);
  color:var(--txt);
}
.toast.success{border-left:3px solid var(--green)}
.toast.error{border-left:3px solid var(--red)}
.toast.warning{border-left:3px solid var(--yellow)}
@keyframes toastIn{from{opacity:0;transform:translateX(30px)}}

/* ═══ SECCION HEADERS ═══ */
.sec-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.sec-title{font-family:'Inter',sans-serif;font-size:24px;font-weight:700;letter-spacing:-.3px;color:var(--navy-900);line-height:1.2}
.sec-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ═══ TARJETAS DE EQUIPOS — FASE 2 ═══ */
.maq-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;transition:all .2s;cursor:pointer;
  border-left:3px solid var(--border);
  box-shadow:var(--shadow);
  height:100%;
}
.maq-card:hover{border-color:var(--border2);border-left-color:var(--maq-accent,var(--navy-600));transform:translateY(-2px);box-shadow:0 4px 12px rgba(15,39,68,.1)}

/* Acento de color por tipo de activo */
.maq-card[data-tipo="plataforma_elevadora"]{ --maq-accent:#C8102E; border-left-color:#C8102E }
.maq-card[data-tipo="vehiculo"]            { --maq-accent:#2B5D93; border-left-color:#2B5D93 }
.maq-card[data-tipo="retroexcavadora"]     { --maq-accent:#C87000; border-left-color:#C87000 }
.maq-card[data-tipo="excavadora"]          { --maq-accent:#D04010; border-left-color:#D04010 }
.maq-card[data-tipo="montacargas"]         { --maq-accent:#5B2C8D; border-left-color:#5B2C8D }
.maq-card[data-tipo="generador"]           { --maq-accent:#1A7A4A; border-left-color:#1A7A4A }
.maq-card[data-tipo="compresor"]           { --maq-accent:#0891B2; border-left-color:#0891B2 }
.maq-card[data-tipo="torre_iluminacion"]   { --maq-accent:#CA8A04; border-left-color:#CA8A04 }
.maq-card[data-tipo="otro"]               { --maq-accent:#6B7280; border-left-color:#6B7280 }

.maq-card-top{padding:14px 16px;display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.maq-id{font-family:'Inter',sans-serif;font-size:18px;font-weight:800;color:var(--maq-accent,var(--navy-800));letter-spacing:-.2px;line-height:1}
.maq-model{font-size:13px;color:var(--txt2);margin-top:4px;font-weight:600}
.maq-serial{font-size:11px;color:var(--txt3);margin-top:3px;font-family:'SF Mono',ui-monospace,Menlo,Monaco,Consolas,monospace;letter-spacing:.3px}
.maq-card-body{padding:0 16px 14px;border-top:1px solid var(--border)}
.maq-info-row{display:flex;gap:16px;flex-wrap:wrap;padding-top:10px}
.maq-info-item{display:flex;flex-direction:column;gap:1px}
.maq-info-label{font-size:9.5px;text-transform:uppercase;letter-spacing:1px;color:var(--txt3);font-weight:700}
.maq-info-val{font-size:12.5px;color:var(--txt);font-weight:600}
.maq-cliente{font-size:13px;font-weight:700;color:var(--navy-900);margin-bottom:1px}
.maq-obra{font-size:11.5px;color:var(--txt3)}
.maq-dates{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}
.maq-date-item{font-size:11px;color:var(--txt3)}
.maq-date-item span{color:var(--txt);font-weight:700}
.maq-card-foot{padding:10px 16px;border-top:1px solid var(--border);display:flex;gap:6px;flex-wrap:wrap;align-items:center;background:var(--bg3)}
.days-badge{
  font-size:11px;font-weight:700;padding:3px 8px;border-radius:5px;
}
.days-ok{background:var(--green-bg);color:var(--green)}
.days-warn{background:var(--yellow-bg);color:var(--yellow)}
.days-urgent{background:var(--orange-bg);color:var(--orange)}
.days-expired{background:var(--red-soft);color:var(--red)}

/* ═══ GRID MÁQUINAS ═══ */
.maq-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;align-items:stretch}
/* ═══ VISTA MINI MÁQUINAS ═══ */
.maq-grid.vista-mini{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}

.maq-card-mini{
  background:var(--bg2);
  border:1px solid var(--border);
  border-left:3px solid var(--maq-accent,var(--red));
  border-radius:var(--radius);
  padding:8px 10px;
  cursor:pointer;
  transition:transform .15s,border-color .15s,box-shadow .15s;
  display:flex;flex-direction:column;gap:4px;
  min-width:0;
}
.maq-card-mini:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 4px 10px rgba(0,0,0,.15)}
.maq-card-mini.active{border-color:var(--maq-accent,var(--red));box-shadow:0 0 0 2px rgba(229,0,15,.25)}
.maq-card-mini[data-tipo="plataforma_elevadora"]{--maq-accent:#C8102E}
.maq-card-mini[data-tipo="vehiculo"]{--maq-accent:#2B5D93}
.maq-card-mini[data-tipo="retroexcavadora"]{--maq-accent:#C87000}
.maq-card-mini[data-tipo="excavadora"]{--maq-accent:#D04010}
.maq-card-mini[data-tipo="montacargas"]{--maq-accent:#5B2C8D}
.maq-card-mini[data-tipo="generador"]{--maq-accent:#1A7A4A}
.maq-card-mini[data-tipo="compresor"]{--maq-accent:#0891B2}
.maq-card-mini[data-tipo="torre_iluminacion"]{--maq-accent:#CA8A04}
.maq-card-mini[data-tipo="otro"]{--maq-accent:#6B7280}

.maq-expand-panel{
  background:var(--bg2);
  border:1px solid var(--border);
  border-left:4px solid var(--red);
  border-radius:var(--radius);
  margin-bottom:14px;
  overflow:hidden;
  animation:maqSlideDown .2s ease;
  max-width:560px;
  margin-left:auto;
  margin-right:auto;
}
.maq-expand-panel-inner{
  display:grid;
  grid-template-columns:minmax(0,420px) 1fr;
  gap:0;
}
.maq-expand-panel-card{
  padding:16px;
  border-right:1px solid var(--border);
}
.maq-expand-panel-extra{
  padding:16px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
@media(max-width:700px){
  .maq-expand-panel-inner{grid-template-columns:1fr}
  .maq-expand-panel-card{border-right:none;border-bottom:1px solid var(--border)}
}
@keyframes maqSlideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* ═══ CAJA MENOR ═══ */
.caja-saldo{
  background:linear-gradient(135deg,var(--navy-900),var(--navy-800));
  border:1px solid var(--navy-800);border-radius:var(--radius);
  padding:24px;text-align:center;
  box-shadow:var(--shadow);
}
.caja-saldo-label{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.6);margin-bottom:8px;font-weight:700}
.caja-saldo-val{font-family:'Inter',sans-serif;font-size:42px;font-weight:800;letter-spacing:-.5px}
.caja-saldo-val.pos{color:#5EEAA4}
.caja-saldo-val.neg{color:#FF8A95}
.mov-ingreso{border-left:3px solid var(--green)}
.mov-egreso{border-left:3px solid var(--red)}

/* ═══ CHECKLIST ═══ */
.check-list{display:grid;gap:8px}
.check-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:8px}
.check-item label{font-size:13px;font-weight:600;cursor:pointer;color:var(--txt)}

/* ═══ SCROLL SLIM ═══ */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--gray-300,#D1D5DB);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:#9CA3AF}

/* ═══ RESPONSIVE ═══ */
@media(max-width:640px){
  /* ── Header ── */
  .hdr-title{font-size:13px}
  .hdr-sub{display:none}
  #fechaHdr{display:none}
  .hdr-inner{gap:10px}

  /* ── Main padding ── */
  main{padding:12px 10px}

  /* ── Nav ── */
  .nav-btn{padding:11px 9px;font-size:11px;letter-spacing:.3px}

  /* ── Modales full-width ── */
  .modal,.modal.modal-wide{max-width:100% !important;margin:0;border-radius:14px 14px 0 0;max-height:95vh}
  .modal-backdrop{align-items:flex-end;padding:0}

  /* ── Dashboard grid → columna única ── */
  #dashGridMain{grid-template-columns:1fr !important}

  /* ── Caja: tabla + sidebar → columna única ── */
  #cajaLayout{grid-template-columns:1fr !important}

  /* ── Tabla servicios cotización ── */
  .svc-tbl th:nth-child(2),.svc-tbl td:nth-child(2){display:none} /* ocultar tipo cobro */
  .svc-toolbar{flex-direction:column;align-items:flex-start;gap:8px}
  .svc-toolbar > div{width:100%}
  #svc_predefinido{width:100% !important}

  /* ── Rent grid → 1 columna ── */
  .rent-grid{grid-template-columns:1fr}

  /* ── Tabla mínima más estrecha en móvil ── */
  table{min-width:520px}

  /* ── KPI valores más pequeños ── */
  .kpi-val{font-size:26px}
  .rent-kpi-val{font-size:24px}

  /* ── Sección títulos ── */
  .sec-title{font-size:20px}
  .sec-head{gap:10px}
  .sec-actions{width:100%}
  .sec-actions .btn{flex:1;justify-content:center}

  /* ── Filter bar scroll horizontal ── */
  .filter-bar{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}
  .filter-bar::-webkit-scrollbar{height:3px}
  .filter-btn{white-space:nowrap;flex-shrink:0}

  /* ── Caja resumen sidebar ── */
  .reem-resumen{margin-top:0}

  /* ── Toast más pequeño ── */
  #toasts{bottom:12px;right:10px;left:10px}
  .toast{min-width:unset;max-width:100%}
}

/* ── Tablet breakpoint: 641–900px ── */
@media(min-width:641px) and (max-width:900px){
  #dashGridMain{grid-template-columns:1fr !important}
  .rent-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
  table{min-width:600px}
}

/* ═══ LAYOUT GRIDS RESPONSIVOS ═══ */
.dash-grid-main{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.caja-layout{display:grid;grid-template-columns:1fr 240px;gap:16px;align-items:start}
.hv-stats-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.hv-resumen-row{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;font-size:13px}
@media(max-width:900px){
  .dash-grid-main{grid-template-columns:1fr}
  .caja-layout{grid-template-columns:1fr}
  .hv-stats-grid-3{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:500px){
  .hv-resumen-row{grid-template-columns:1fr}
}

/* ── Scroll suave en tablas — sombra indica contenido scrollable ── */
.tbl-wrap{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  background:
    linear-gradient(to right, #fff 10px, transparent 10px) left,
    linear-gradient(to left,  #fff 10px, transparent 10px) right,
    radial-gradient(farthest-side at 0 50%, rgba(15,39,68,.08), transparent) left,
    radial-gradient(farthest-side at 100% 50%, rgba(15,39,68,.08), transparent) right;
  background-repeat:no-repeat;
  background-size:20px 100%, 20px 100%, 12px 100%, 12px 100%;
  background-attachment:local, local, scroll, scroll;
  border-radius:var(--radius);
}
table{width:100%;border-collapse:collapse;min-width:700px;background:#fff}

/* ═══ HOJA DE VIDA — MOVIMIENTOS ═══ */
.hv-mov-row{display:grid;grid-template-columns:105px 105px 1fr 1fr 90px;gap:8px;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border);font-size:12.5px}
.hv-mov-row:last-child{border-bottom:none}
.hv-mov-header{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--txt3);background:var(--bg3);padding:8px 12px;border-radius:6px 6px 0 0;border-bottom:1px solid var(--border)}
.hv-mov-activo{background:var(--blue-bg);border-left:3px solid var(--blue)}
.hv-mov-finalizado{border-left:3px solid var(--green)}
.hv-mov-cancelado{opacity:.5}
.hv-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:32px;color:var(--txt3);font-size:13px}
.hv-loading::before{content:'';width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--navy-700);border-radius:50%;animation:hv-spin .7s linear infinite;flex-shrink:0}
@keyframes hv-spin{to{transform:rotate(360deg)}}
@media(max-width:600px){.hv-mov-row{grid-template-columns:1fr 1fr;gap:4px}}

/* ═══ HOJA DE VIDA — FICHA DEL EQUIPO (Fase 3) ═══ */
.hv-ficha-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}
.hv-ficha-item{display:flex;flex-direction:column;gap:2px}
.hv-ficha-lbl{font-size:9.5px;text-transform:uppercase;letter-spacing:1px;color:var(--txt3);font-weight:700}
.hv-ficha-val{font-size:13px;color:var(--navy-900);font-weight:600;font-family:'Inter',sans-serif;letter-spacing:.1px}
@media(max-width:500px){.hv-ficha-grid{grid-template-columns:repeat(2,1fr)}}

/* ═══ HOJA DE VIDA — MEDIDORES (Fase 4) ═══ */
.lect-row{display:grid;grid-template-columns:90px 110px 1fr 100px;gap:8px;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border);font-size:12.5px}
.lect-row:last-child{border-bottom:none}
.lect-header{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--txt3);background:var(--bg3);padding:8px 12px;border-bottom:1px solid var(--border)}
.lect-val{font-family:'Inter',sans-serif;font-size:15px;font-weight:700;color:var(--navy-900)}
.medidor-kpi{background:#fff;border:1px solid var(--border);border-radius:10px;padding:16px 20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow)}
.medidor-kpi-num{font-family:'Inter',sans-serif;font-size:30px;font-weight:800;line-height:1;color:var(--navy-900);letter-spacing:-.4px}
.medidor-kpi-lbl{font-size:11px;color:var(--txt3);text-transform:uppercase;letter-spacing:1px;margin-top:4px;font-weight:600}
@media(max-width:500px){.lect-row{grid-template-columns:80px 90px 1fr}}

/* ═══ MÓDULO CLIENTES ═══ */
.cli-search-wrap{position:relative;width:100%}
.cli-autocomplete{
  position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:500;
  background:#fff;border:1px solid var(--border);border-radius:var(--radius2);
  box-shadow:var(--shadow2);max-height:220px;overflow-y:auto;display:none;
}
.cli-autocomplete.show{display:block}
.cli-ac-item{
  padding:10px 14px;cursor:pointer;display:flex;flex-direction:column;gap:2px;
  border-bottom:1px solid var(--border);transition:background .1s;
}
.cli-ac-item:last-child{border-bottom:none}
.cli-ac-item:hover,.cli-ac-item.active{background:var(--navy-50)}
.cli-ac-nombre{font-size:13px;font-weight:700;color:var(--navy-900)}
.cli-ac-meta{font-size:11px;color:var(--txt3)}
.cli-selected-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--blue-bg);border:1px solid #C7DAF0;
  border-radius:6px;padding:5px 10px;font-size:12px;font-weight:700;color:var(--blue);
  margin-top:4px;
}
.cli-selected-badge button{
  border:0;background:transparent;color:var(--blue);cursor:pointer;
  font-size:14px;line-height:1;padding:0 2px;
}

/* ═══ VENCIMIENTO HIGHLIGHT ═══ */
.row-expired{background:#FFF5F5 !important;box-shadow:inset 3px 0 0 var(--red)}
.row-urgent{background:#FFF8F2 !important;box-shadow:inset 3px 0 0 var(--orange)}
.row-warn{background:#FFFBEF !important;box-shadow:inset 3px 0 0 var(--yellow)}

/* ═══ EMPTY STATE ═══ */
.empty{text-align:center;padding:48px 20px;color:var(--txt3)}
.empty-icon{font-size:40px;margin-bottom:12px;opacity:.35;color:var(--gray-400,#9CA3AF)}
.empty-txt{font-size:13.5px}

/* SEPARATOR */
.sep{height:1px;background:var(--border);margin:16px 0}

/* FILTER BAR */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.filter-btn{border:1px solid var(--border2);background:#fff;color:var(--txt2);padding:6px 13px;border-radius:999px;font-family:'Inter',sans-serif;font-size:12px;font-weight:600;cursor:pointer;letter-spacing:.1px;transition:all .15s}
.filter-btn.active{background:var(--navy-100);color:var(--navy-800);border-color:#C7DAF0}
.filter-btn:hover:not(.active){color:var(--navy-900);border-color:var(--gray-400,#9CA3AF);background:var(--bg3)}

/* ═══ REEMBOLSO HEADER CARD ═══ */
.reem-header{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:16px;box-shadow:var(--shadow)}
.reem-header-top{background:linear-gradient(90deg,var(--navy-900),var(--navy-800));padding:14px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--navy-800)}
.reem-titulo{font-family:'Inter',sans-serif;font-size:16px;font-weight:700;letter-spacing:.2px;color:#fff}
.reem-nro{font-family:'Inter',sans-serif;font-size:14px;font-weight:800;color:#FFD58A;letter-spacing:1.5px}
.reem-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:0}
@media(max-width:900px){.reem-meta{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.reem-meta{grid-template-columns:1fr}}
.reem-meta-item{padding:10px 16px;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
.reem-meta-item:nth-child(4n){border-right:0}
.reem-meta-label{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--txt3);margin-bottom:3px}
.reem-meta-val{font-size:13px;font-weight:700;color:var(--navy-900)}

/* ═══ RESUMEN REEMBOLSO ═══ */
.reem-resumen{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:grid;gap:8px}
.reem-res-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:4px 0;color:var(--txt2)}
.reem-res-row.sep{border-top:1px solid var(--border);margin-top:4px;padding-top:10px}
.reem-res-row.total{font-family:'Inter',sans-serif;font-size:16px;font-weight:800;color:var(--navy-900)}

/* ═══ TABLA GASTOS MINI TEXT ═══ */
#gastosTable th,#gastosTable td{padding:8px 10px;font-size:12px}
#gastosTable th{font-size:10px;letter-spacing:1px}
.num-cell{text-align:right;font-variant-numeric:tabular-nums;font-family:'SF Mono',ui-monospace,Menlo,Monaco,Consolas,monospace}

/* ═══ MÓDULO ALQUILER — PILLS DE ESTADO ═══ */
.pill-reservado{background:var(--yellow-bg);color:var(--yellow);border:1px solid #F6D89A}
.pill-activo{background:var(--blue-bg);color:var(--blue);border:1px solid #C7DAF0}
.pill-pendiente_recogida{background:var(--orange-bg);color:var(--orange);border:1px solid #F9BFA3}
.pill-finalizado{background:var(--green-bg);color:var(--green);border:1px solid #B8E1CA}
.pill-cancelado{background:var(--bg4);color:var(--txt2);border:1px solid var(--border)}
.pill-borrador{background:var(--bg4);color:var(--txt2);border:1px solid var(--border)}
.pill-prog_devolucion{background:var(--purple-bg);color:var(--purple);border:1px solid #D7C4F0}
.pill-aprobada{background:var(--green-bg);color:var(--green);border:1px solid #B8E1CA}
.pill-enviada{background:#DBEAFE;color:#1E40AF;border:1px solid #BFDBFE}

/* ═══ RENT CARDS ═══ */
.rent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}
.rent-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .2s;box-shadow:var(--shadow)}
.rent-card:hover{border-color:var(--border2);box-shadow:0 4px 12px rgba(15,39,68,.1);transform:translateY(-1px)}
.rent-card-top{padding:14px 16px;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;border-bottom:1px solid var(--border)}
.rent-card-body{padding:14px 16px;display:grid;gap:8px}
.rent-card-footer{padding:10px 16px;background:var(--bg3);border-top:1px solid var(--border);display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.rent-id{font-family:'Inter',sans-serif;font-size:18px;font-weight:800;color:var(--navy-800);letter-spacing:-.2px}
.rent-cliente{font-size:14px;font-weight:700;color:var(--navy-900)}
.rent-meta{font-size:12px;color:var(--txt3);display:flex;align-items:center;gap:5px}
.rent-equipo{font-family:'Inter',sans-serif;font-size:14px;font-weight:700;color:var(--navy-700);letter-spacing:.1px}
.rent-sep{flex:1}

/* ═══ BOTÓN GO ═══ */
.btn-go{
  background:linear-gradient(135deg,#125A36,#1A7A4A);color:#fff;
  font-size:13px;font-weight:700;letter-spacing:.2px;
  box-shadow:0 1px 2px rgba(26,122,74,.25);border-radius:var(--radius2);
  padding:0 16px;height:36px;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:6px;
  transition:all .2s;
}
.btn-go:hover{filter:brightness(1.05);box-shadow:0 2px 8px rgba(26,122,74,.3);transform:translateY(-1px)}

/* ═══ COT TABLE ═══ */
.cot-row-borrador td{opacity:.75}
.cot-row-cancelado td{opacity:.45;text-decoration:line-through}

/* ═══ RENTAL KPI MINI ═══ */
.rent-kpi-bar{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:10px}
@media(max-width:900px){.rent-kpi-bar{grid-template-columns:repeat(3,1fr)}}
@media(max-width:500px){.rent-kpi-bar{grid-template-columns:repeat(2,1fr)}}
.rent-kpi{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:8px;text-align:center;box-shadow:var(--shadow)}
.rent-kpi-val{font-family:'Inter',sans-serif;font-size:20px;font-weight:800;line-height:1;color:var(--navy-900);letter-spacing:-.3px}
.rent-kpi-lbl{font-size:10px;color:var(--txt3);text-transform:uppercase;letter-spacing:1px;margin-top:3px;font-weight:600}

/* ═══ MODAL DETALLE ALQUILER ═══ */
.alq-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}
@media(max-width:500px){.alq-info-grid{grid-template-columns:1fr}}
.alq-info-item{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:10px 12px}
.alq-info-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--txt3);font-weight:700;margin-bottom:3px}
.alq-info-val{font-size:13px;font-weight:700;color:var(--navy-900)}

/* ═══ SERVICIOS COTIZACIÓN ═══ */
.svc-wrap{background:#fff;border:1px solid var(--border);border-radius:var(--radius2);overflow:hidden;margin-top:4px}
.svc-toolbar{padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid var(--border);background:var(--bg3)}
.svc-toolbar-title{font-family:'Inter',sans-serif;font-size:12px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--txt3)}
.svc-tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.svc-tbl th{padding:8px 10px;text-align:left;font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--txt3);background:var(--bg3);white-space:nowrap;border-bottom:1px solid var(--border)}
.svc-tbl td{padding:6px 8px;border-top:1px solid var(--border);vertical-align:middle;color:var(--txt)}
.svc-tbl tr:last-child td{border-bottom:none}
.svc-input{background:#fff;border:1px solid var(--border2);border-radius:5px;color:var(--txt);padding:6px 8px;font-size:12.5px;font-family:inherit;width:100%;outline:none;transition:border-color .15s}
.svc-input:focus{border-color:var(--navy-500);box-shadow:0 0 0 2px rgba(74,127,181,.12)}
.svc-select{background:#fff;border:1px solid var(--border2);border-radius:5px;color:var(--txt);padding:6px 8px;font-size:12.5px;font-family:inherit;width:100%;outline:none;cursor:pointer}
.svc-total-cell{font-family:'Inter',sans-serif;font-size:14px;font-weight:700;color:var(--green);text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}
.svc-footer{padding:10px 12px;display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border);background:var(--bg3)}
.svc-subtotal{font-family:'Inter',sans-serif;font-size:13px;color:var(--txt3)}
.svc-subtotal strong{color:var(--green);font-size:16px;font-weight:800}
.svc-empty{padding:18px;text-align:center;font-size:12.5px;color:var(--txt3)}

/* ═══ PRINT STYLES ═══ */
@media print{
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  body{background:#fff!important;color:#000!important;font-family:'Inter','Segoe UI',Arial,sans-serif;font-size:10pt}
  header,nav,#toasts,.sec-head .sec-actions,.btn-print-hide,
  .modal-backdrop,#loader,.hdr-right button{display:none!important}
  main{padding:0!important;max-width:100%!important}
  .tab-content{display:none!important}
  #tab-caja{display:block!important}
  #gastosActions,#cajaLayout .reem-resumen-wrap{display:none!important}
  .card{border:1px solid #ccc!important;box-shadow:none!important;background:#fff!important}
  #printReembolso{display:block!important}
  .no-print{display:none!important}
  thead{background:#eee!important}
  th{color:#fff!important;background:#0F2744!important}
  td{color:#000!important;border-top:1px solid #ddd!important}
}

/* ═══ FASE 2 — BULK BAR / SAVED FILTERS / CRONOGRAMA ═══ */
tr.bulk-selected td{background:var(--blue-bg) !important}
.bulk-bar{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  background:var(--blue-bg);border:1px solid #C7DAF0;
  border-radius:var(--radius2);padding:8px 12px;margin-bottom:12px;
}
.bulk-count{
  font-family:'Inter',sans-serif;font-size:13px;font-weight:800;
  color:var(--blue);letter-spacing:.1px;margin-right:4px;
}
.saved-filters-bar{
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  min-height:0;margin-bottom:8px;
}
.saved-filter-chip{
  display:inline-flex;align-items:center;gap:4px;
  background:#fff;border:1px solid var(--border2);
  border-radius:999px;padding:4px 10px 4px 12px;
  font-size:11.5px;font-weight:600;color:var(--txt2);cursor:pointer;
  transition:all .15s;
}
.saved-filter-chip:hover{border-color:var(--navy-500);color:var(--navy-900);background:var(--navy-50)}
.saved-filter-chip button{
  border:0;background:transparent;color:var(--txt3);cursor:pointer;
  font-size:13px;line-height:1;padding:0 2px;transition:color .1s;
}
.saved-filter-chip button:hover{color:var(--red)}
.save-filter-btn{
  border:1px dashed var(--border2);background:transparent;color:var(--txt3);
  border-radius:999px;padding:4px 12px;font-size:11.5px;font-weight:600;
  cursor:pointer;transition:all .15s;
}
.save-filter-btn:hover{border-color:var(--navy-500);color:var(--navy-700);background:var(--navy-50)}

/* ── CRONOGRAMA ── */
.crono-table{border-collapse:collapse;font-size:11px;min-width:900px;background:#fff}
.crono-table th{
  background:var(--bg3);padding:6px 8px;font-size:10px;font-weight:700;
  letter-spacing:.5px;text-transform:uppercase;color:var(--txt3);
  border-right:1px solid var(--border);white-space:nowrap;
  position:sticky;top:0;z-index:2;
}
.crono-table th.crono-today{background:var(--red-soft);color:var(--red)}
.crono-table td{border-top:1px solid var(--border);border-right:1px solid var(--border);padding:0;height:36px;min-width:28px;position:relative}
.crono-row-head{
  background:var(--bg3);padding:6px 10px;font-size:12px;font-weight:700;
  white-space:nowrap;position:sticky;left:0;z-index:1;min-width:130px;
  border-right:2px solid var(--border2);color:var(--navy-900);
}
.crono-bar{
  position:absolute;inset-y:3px;border-radius:4px;
  display:flex;align-items:center;padding:0 6px;
  font-size:10px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis;cursor:pointer;transition:filter .15s;
  box-shadow:0 1px 3px rgba(15,39,68,.15);
}
.crono-bar:hover{filter:brightness(1.1)}
.crono-bar.activo{background:linear-gradient(90deg,#1d4ed8,#3b82f6)}
.crono-bar.reservado{background:linear-gradient(90deg,#92400e,#d97706)}
.crono-bar.pendiente_recogida{background:linear-gradient(90deg,#9a3412,#ea580c)}

/* ── IMPORT MODAL ── */
.import-zone{
  border:2px dashed var(--border2);border-radius:var(--radius);
  padding:32px;text-align:center;cursor:pointer;transition:all .2s;
  background:var(--bg3);
}
.import-zone:hover,.import-zone.drag-over{
  border-color:var(--navy-500);background:var(--navy-50);
}
.import-preview{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius2);
  overflow-x:auto;max-height:300px;overflow-y:auto;margin-top:12px;
}
.import-preview table{min-width:400px;font-size:12px}
.import-preview th{background:var(--bg3);font-size:10px}
.import-preview td{padding:7px 10px}
.import-err{color:var(--red);font-size:12px;padding:8px 12px;background:var(--red-soft);border:1px solid #F5BBC3;border-radius:6px;margin-top:8px}
.import-ok{color:var(--green);font-size:12px;padding:8px 12px;background:var(--green-bg);border:1px solid #B8E1CA;border-radius:6px;margin-top:8px}

/* ═══ FASE 3 — RENTABILIDAD / MANTENIMIENTO / PORTAL ═══ */
.rent-marg-pos{color:var(--green);font-weight:700}
.rent-marg-neg{color:var(--red);font-weight:700}
.rent-util-bar{display:inline-block;height:8px;border-radius:4px;background:linear-gradient(90deg,var(--green-dim),var(--green));vertical-align:middle;margin-right:6px}
.pill-mant-realizado{background:var(--green-bg);color:var(--green);border:1px solid #B8E1CA}
.pill-mant-programado{background:var(--blue-bg);color:var(--blue);border:1px solid #C7DAF0}
.pill-mant-en_curso{background:var(--yellow-bg);color:var(--yellow);border:1px solid #F6D89A}
.mant-alerta{background:var(--yellow-bg);border:1px solid #F6D89A;border-left:3px solid var(--yellow);border-radius:var(--radius2);padding:12px 14px;display:flex;align-items:center;gap:12px;margin-bottom:8px}
.mant-alerta.vencida{background:var(--red-soft);border-color:#F5BBC3;border-left-color:var(--red)}
.portal-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:14px;box-shadow:var(--shadow)}
.portal-card-head{background:var(--bg3);padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.token-chip{font-family:'SF Mono',ui-monospace,Menlo,Monaco,Consolas,monospace;font-size:11px;background:var(--bg4);border:1px solid var(--border);padding:3px 8px;border-radius:4px;color:var(--txt2)}
.hv-tab{border:0;background:transparent;color:var(--txt3);padding:10px 14px;font-family:'Inter',sans-serif;font-size:13px;font-weight:600;letter-spacing:.1px;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}
.hv-tab:hover{color:var(--navy-900)}.hv-tab.active{color:var(--red);border-bottom-color:var(--red)}

#printReembolso{display:none}
.pill-rechazada{background:var(--red-soft);color:var(--red);border:1px solid #F5BBC3}
.pill-en_revision{background:var(--purple-bg);color:var(--purple);border:1px solid #D7C4F0}
.pill-pendiente{background:var(--yellow-bg);color:var(--yellow);border:1px solid #F6D89A}
.pill-en_cotizacion{background:var(--blue-bg);color:var(--blue);border:1px solid #C7DAF0}
.pill-cerrada{background:var(--green-bg);color:var(--green);border:1px solid #B8E1CA}

/* ═══ FASE 1 — SEGUIMIENTOS ═══ */
.seg-item{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius2);
  padding:12px 14px;display:flex;flex-direction:column;gap:6px;
  border-left:3px solid var(--border2);
  box-shadow:var(--shadow);
}
.seg-item.tipo-comentario{border-left-color:var(--blue)}
.seg-item.tipo-tarea{border-left-color:var(--yellow)}
.seg-item.tipo-alerta{border-left-color:var(--red)}
.seg-item.completado{opacity:.55}
.seg-item-header{display:flex;align-items:center;justify-content:space-between;gap:8px}
.seg-tipo-badge{font-size:10px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;padding:2px 8px;border-radius:4px}
.seg-tipo-badge.comentario{background:var(--blue-bg);color:var(--blue)}
.seg-tipo-badge.tarea{background:var(--yellow-bg);color:var(--yellow)}
.seg-tipo-badge.alerta{background:var(--red-soft);color:var(--red)}
.seg-texto{font-size:13px;color:var(--txt);line-height:1.5}
.seg-meta{font-size:11px;color:var(--txt3)}
.seg-empty{text-align:center;padding:32px;color:var(--txt3);font-size:13px}

#printReembolso{display:none}

/* Print area styles */
.pr-wrap{font-family:'Inter','Segoe UI',Arial,sans-serif;font-size:9pt;color:#000;max-width:1100px;margin:0 auto}
.pr-title{text-align:center;font-size:14pt;font-weight:bold;border:2px solid #0F2744;padding:6px;margin-bottom:0;background:#0F2744;color:#fff;letter-spacing:.5px}
.pr-empresa{text-align:center;font-size:11pt;font-weight:bold;border:1px solid #0F2744;border-top:0;padding:4px;background:#EBF2FA;color:#0F2744}
.pr-hdr-grid{display:grid;grid-template-columns:1fr 1fr 1fr;border:1px solid #0F2744;border-top:0}
.pr-hdr-cell{padding:5px 8px;border-right:1px solid #ccc;font-size:9pt}
.pr-hdr-cell:last-child{border-right:0}
.pr-hdr-cell label{font-size:8pt;font-weight:bold;display:block;color:#0F2744;text-transform:uppercase}
.pr-hdr-cell span{font-weight:bold;font-size:10pt;color:#1a1a1a}
.pr-hdr2{display:grid;grid-template-columns:1fr 1fr 1fr;border:1px solid #0F2744;border-top:0;margin-bottom:8px}
.pr-pagos{display:grid;grid-template-columns:1fr auto;border:1px solid #0F2744;border-top:0;margin-bottom:0}
.pr-pagos-l{padding:5px 8px;border-right:1px solid #ccc}
.pr-pagos-r{padding:5px 12px;min-width:200px}
.pr-table{width:100%;border-collapse:collapse;font-size:8pt;margin-top:0}
.pr-table th{background:#0F2744;color:#fff;font-weight:bold;padding:4px 5px;border:1px solid #0F2744;text-align:center;font-size:7.5pt;letter-spacing:.3px;text-transform:uppercase}
.pr-table td{padding:3px 5px;border:1px solid #c8c8c8;vertical-align:middle;color:#1a1a1a}
.pr-table tr:nth-child(even){background:#F5F9FD}
.pr-table .num{text-align:right;font-family:monospace}
.pr-totals{display:grid;grid-template-columns:1fr 1fr;border:1px solid #0F2744;border-top:0;margin-top:0}
.pr-totals-l{border-right:1px solid #ccc;padding:6px 10px}
.pr-totals-r{padding:6px 10px}
.pr-totals strong{color:#0F2744}
.pr-firma{display:grid;grid-template-columns:1fr 1fr 1fr;gap:32px;margin-top:32px;padding-top:16px}
.pr-firma-item{border-top:1px solid #333;padding-top:4px;text-align:center;font-size:8pt;color:#333;font-weight:600}

/* ── MODO EDICIÓN EQUIPOS ── */
.maq-edit-panel{
  border-top:2px solid var(--red);
  background:#FFFAFB;
  padding:12px 14px 14px;
  display:grid;gap:10px;
  animation:maq-edit-in .15s ease;
}
@keyframes maq-edit-in{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.maq-edit-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:8px;
}
.maq-edit-field{display:flex;flex-direction:column;gap:3px}
.maq-edit-lbl{font-size:9.5px;text-transform:uppercase;letter-spacing:1px;color:var(--txt3);font-weight:700}
.maq-edit-input{
  padding:7px 9px;background:#fff;
  border:1px solid var(--border2);border-radius:6px;
  color:var(--txt);font-size:12.5px;width:100%;
  transition:border-color .15s;
}
.maq-edit-input:focus{outline:none;border-color:var(--navy-500);box-shadow:0 0 0 2px rgba(74,127,181,.12)}
.maq-edit-foot{display:flex;align-items:center;gap:10px;padding-top:4px}
.maq-editmode-banner{
  background:var(--red-soft);border:1px solid #F5BBC3;
  border-radius:8px;padding:8px 14px;font-size:12.5px;color:var(--red);
  font-weight:600;margin-bottom:10px;display:none;
}

/* ── Modal Equipo — Fase 1 ── */
#modalMaquina .modal{ max-width:780px; width:96vw; }
.maq-form-tabs{ display:flex; gap:2px; border-bottom:1px solid var(--border); margin-bottom:18px; }
.maq-ftab{
  background:transparent; border:0; color:var(--txt3); padding:10px 14px;
  font-family:'Inter',sans-serif; font-size:12.5px; font-weight:600;
  letter-spacing:.1px; cursor:pointer;
  border-bottom:2px solid transparent; transition:all .15s; white-space:nowrap;
}
.maq-ftab.active{ color:var(--red); border-bottom-color:var(--red); }
.maq-ftab:hover:not(.active){ color:var(--navy-900); }
.maq-fsec{ display:none; }
.maq-fsec.active{ display:block; }
.maq-sec-label{
  font-family:'Inter',sans-serif; font-size:11px; font-weight:700;
  letter-spacing:.8px; text-transform:uppercase; color:var(--txt3);
  border-bottom:1px solid var(--border); padding-bottom:6px; margin-bottom:14px;
}
.maq-type-grid{
  display:grid; grid-template-columns:repeat(auto-fill,minmax(120px,1fr)); gap:8px; margin-bottom:18px;
}
.maq-type-btn{
  background:#fff; border:1px solid var(--border); border-radius:var(--radius2);
  padding:10px 8px; cursor:pointer; text-align:center; transition:all .15s;
  display:flex; flex-direction:column; align-items:center; gap:4px;
}
.maq-type-btn:hover{ border-color:var(--border2); background:var(--bg3); }
.maq-type-btn.selected{ border-color:var(--navy-500); background:var(--navy-50); box-shadow:0 0 0 2px rgba(74,127,181,.12);}
.maq-type-icon{ font-size:22px; line-height:1; }
.maq-type-lbl{ font-size:10.5px; color:var(--txt2); font-family:'Inter',sans-serif; letter-spacing:.1px; font-weight:600;}
.maq-specs-grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
@media(max-width:540px){
  .maq-type-grid{ grid-template-columns:repeat(3,1fr); }
  .maq-specs-grid{ grid-template-columns:1fr; }
}

.btn-stop{background:var(--red);color:#fff;border:0;border-radius:6px;padding:5px 11px;font-size:11px;font-weight:700;cursor:pointer;letter-spacing:.2px;font-family:'Inter',sans-serif;transition:filter .15s}
.btn-stop:hover{filter:brightness(.92)}
.varada-abierta{border-left:3px solid var(--red)!important;background:#FFF5F5}
.hv-stat-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:16px;text-align:center;box-shadow:var(--shadow)}
.hv-stat-val{font-size:26px;font-weight:800;font-family:'Inter',sans-serif;line-height:1.1;color:var(--navy-900);letter-spacing:-.3px}
.hv-stat-lbl{font-size:10.5px;color:var(--txt3);text-transform:uppercase;letter-spacing:1px;margin-top:6px;font-weight:600}
.hv-tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.hv-tbl th{padding:9px 8px;color:var(--txt3);text-align:left;border-bottom:1px solid var(--border);font-size:11px;text-transform:uppercase;letter-spacing:.5px;background:var(--bg3);font-weight:700}
.hv-tbl td{padding:9px 8px;border-bottom:1px solid var(--border);color:var(--txt2)}

/* =========================================================
   ALCON OPS — SIDEBAR LAYOUT
   ========================================================= */
:root{
  --sidebar-w: 220px;
  --topbar-h:  56px;
}
body{
  overflow:hidden;
}
#app-shell{
  display:flex;
  height:100vh;
  width:100%;
}

/* ════════════════════════════════════════════════════
   SIDEBAR (navy)
   ════════════════════════════════════════════════════ */
#sidebar{
  width:var(--sidebar-w);
  min-width:var(--sidebar-w);
  height:100vh;
  background:var(--navy-900);
  border-right:1px solid var(--navy-800);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  flex-shrink:0;
  position:relative;
  z-index:100;
}

/* ── Brand ── */
.sb-brand{
  display:flex;
  align-items:center;
  gap:10px;
  padding:16px 16px 14px;
  border-bottom:1px solid rgba(255,255,255,.06);
  flex-shrink:0;
}
.sb-brand .hdr-logo{
  height:28px;
  flex-shrink:0;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.2));
}
.sb-brand-info{
  min-width:0;
  overflow:hidden;
}
.sb-brand .hdr-title{
  font-size:14px;
  font-weight:800;
  letter-spacing:.5px;
  color:#fff;
}
.sb-brand .hdr-sub{
  font-size:9px;
  color:rgba(255,255,255,.45);
  letter-spacing:1.3px;
  font-weight:600;
  text-transform:uppercase;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:160px;
}

/* ── Nav container ── */
.sb-nav{
  flex:1;
  overflow-y:auto;
  overflow-x:hidden;
  padding:6px 0;
  background:transparent;
  border:none;
}

/* Etiqueta de sección */
.sb-section-label{
  font-family:'Inter',sans-serif;
  font-size:9.5px;
  font-weight:700;
  letter-spacing:1.4px;
  text-transform:uppercase;
  color:rgba(255,255,255,.4);
  padding:14px 16px 6px;
  user-select:none;
}
.sb-collapsible{cursor:pointer;display:flex;align-items:center;justify-content:space-between}
.sb-arr{font-size:8px;transition:transform .2s;display:inline-block}
.sb-collapsible.open .sb-arr{transform:rotate(90deg)}
.sb-collapse-group{overflow:hidden;max-height:0;transition:max-height .25s ease}
.sb-collapse-group.open{max-height:300px}
.sb-nav .sb-section-label:first-child{
  padding-top:10px;
}

/* ── Botones nav dentro del sidebar ── */
#sidebar .nav-btn{
  width:100%;
  padding:9px 14px;
  font-family:'Inter',sans-serif;
  font-size:13px;
  font-weight:500;
  letter-spacing:.1px;
  text-transform:none;
  border-bottom:none;
  border-left:3px solid transparent;
  border-radius:0;
  justify-content:flex-start;
  text-align:left;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  color:rgba(255,255,255,.72);
  background:transparent;
  display:flex;
  align-items:center;
  gap:10px;
  transition:all .15s;
}
#sidebar .nav-btn:hover{
  background:rgba(255,255,255,.05);
  color:#fff;
}
#sidebar .nav-btn.active{
  background:linear-gradient(90deg,rgba(200,16,46,.18),rgba(200,16,46,.02));
  color:#fff;
  font-weight:600;
  border-left-color:var(--red);
  border-bottom-color:transparent;
}
#sidebar .nav-btn .nb{
  background:var(--red);
  color:#fff;
  margin-left:auto;
}

/* ── Topbar ── */
#main-wrap{
  flex:1;
  display:flex;
  flex-direction:column;
  min-width:0;
  height:100vh;
  overflow:hidden;
}
#topbar{
  height:var(--topbar-h);
  background:#fff;
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  padding:0 24px;
  flex-shrink:0;
  gap:14px;
}
main#main-content{
  flex:1;
  overflow-y:auto;
  overflow-x:hidden;
  padding:24px 28px 40px;
  max-width:none;
}

/* ── Sidebar footer ── */
.sb-footer{
  padding:12px 16px;
  border-top:1px solid rgba(255,255,255,.06);
  font-size:11px;
  color:rgba(255,255,255,.4);
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-shrink:0;
}
.sb-footer strong{color:rgba(255,255,255,.65);font-weight:600}

/* ── Responsive sidebar (mobile) ── */
@media(max-width:900px){
  body{overflow:auto}
  #app-shell{flex-direction:column;height:auto}
  #app-shell{flex-direction:row}
  #sidebar{
    width:160px;min-width:160px;height:100vh;
    flex-direction:column;overflow-x:hidden;overflow-y:auto;
    border-right:1px solid var(--navy-800);border-bottom:none;
  }
  .sb-brand{padding:12px 12px}
  .sb-nav{display:flex;flex-direction:column;padding:8px 0;overflow-y:auto;overflow-x:hidden}
  #sidebar .nav-btn{
    width:100%;font-size:12px;
    padding:9px 12px;flex-shrink:0;
  }
  #main-wrap{height:auto;overflow:visible}
  #topbar{height:auto;min-height:var(--topbar-h);flex-wrap:wrap;padding:8px 14px}
  main#main-content{overflow:visible;padding:14px 12px}
}

#app-shell {
  display: flex;
}

#sidebar {
  width: 240px;
  flex-shrink: 0;
}

#main-wrap {
  flex: 1;
  overflow-x: hidden;
}

#main-content {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 24px;
  box-sizing: border-box;
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}
#sidebar {
  width: 240px;
  flex-shrink: 0;
}

#main-wrap {
  flex: 1;
  overflow-x: hidden;
}

#main-content {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 24px;
  box-sizing: border-box;
}

/* === ICONOS CORPORATIVOS SVG (LIMPIO) === */

svg {
width: 18px;
height: 18px;
stroke-width: 1.4;
}

/* sidebar */
#sidebar svg {
color: rgba(255,255,255,.7);
transition: all .15s ease;
}

/* hover */
#sidebar .nav-btn:hover svg {
color: #ffffff;
}

/* activo */
#sidebar .nav-btn.active svg {
color: #C8102E;
}

/* topbar */
#topbar svg {
color: var(--txt3);
}

/* botones */
button svg {
transition: transform .15s ease, color .15s ease;
}

button:hover svg {
transform: scale(1.05);
}
/* ===== FIX VISUAL GLOBAL (NO TOCAR MÁS NADA) ===== */

/* Tamaño de texto normal */
html, body {
  font-size: 16px !important;
}

/* Títulos */
h1 { font-size: 28px !important; }
h2 { font-size: 24px !important; }
h3 { font-size: 20px !important; }

/* Texto general */
p, span, table, th, td, button {
  font-size: 15px !important;
}

/* Quitar caja que encierra el módulo comercial */
#main-content {
  max-width: 100% !important;
  width: 100% !important;
  margin: 0 !important;
}

/* Asegurar ancho completo */
#main-wrap {
  width: 100% !important;
}

/* ══════════════════════════════════════════════════════
   MÓDULO SUBARRIENDO
══════════════════════════════════════════════════════ */
.sub-card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: box-shadow .15s;
}
.sub-card:hover { box-shadow: 0 4px 18px rgba(0,0,0,.12); }
.sub-card-head  { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.sub-card-title { font-size: 14px; font-weight: 700; color: var(--txt); }
.sub-card-sub   { font-size: 11px; color: var(--txt3); margin-top: 2px; }

.sub-stats {
  display: flex;
  gap: 16px;
  background: rgba(255,255,255,.03);
  border-radius: 8px;
  padding: 10px 14px;
}
.sub-stat       { display: flex; flex-direction: column; align-items: center; gap: 2px; }
.sub-stat-val   { font-size: 18px; font-weight: 800; color: var(--txt); }
.sub-stat-label { font-size: 10px; color: var(--txt3); text-transform: uppercase; letter-spacing: .5px; }

.sub-uso-row {
  display: grid;
  grid-template-columns: 90px 50px 1fr 80px;
  gap: 8px;
  font-size: 12px;
  padding: 5px 0;
  border-bottom: 1px solid var(--border);
  color: var(--txt2);
}
.sub-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  font-size: 13px;
  background: rgba(255,255,255,.03);
  border-radius: 8px;
  padding: 10px;
}


.maq-card{ display:flex; flex-direction:column; }
.maq-card-body{ flex:1; }
.maq-card .maq-card-foot{ margin-top:auto; }

/* ═══ RESPONSIVE COLUMNAS TABLA ALQUILERES ═══ */
@media (max-width: 1280px) {
  .col-modalidad, .col-devolucion { display: none; }
}
@media (max-width: 1100px) {
  .col-inicio, .col-total { display: none; }
}

/* ═══ ANCHOS FIJOS TABLA ALQUILERES ═══ */
.alq-nro   { width:90px; white-space:nowrap }
.col-cliente{ max-width:220px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap }
.col-equipo { max-width:150px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap }

/* ═══ MÓDULO REPORTES / BI ═══ */
.rep-header{display:flex;align-items:center;gap:12px;padding:20px 0 12px;border-bottom:1px solid var(--border);margin-bottom:20px;flex-wrap:wrap}
.rep-subtitle{font-size:13px;color:var(--txt3);margin-top:2px}
.rep-select{height:32px;padding:0 10px;border:1px solid var(--border2);border-radius:6px;background:#fff;color:var(--txt2);font-family:'Inter',sans-serif;font-size:12px;font-weight:600;cursor:pointer}
.rep-subnav{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.rep-subtab{display:none}
.rep-subtab.active{display:block}
.rep-soon-card{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:10px;padding:32px 16px;border:1px dashed var(--border2);border-radius:10px;background:var(--bg3)}
.rep-soon-icon{color:var(--txt3)}
.rep-soon-text{font-size:14px;font-weight:700;color:var(--txt2)}
.rep-soon-badge{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--navy-800);background:var(--navy-100);padding:4px 10px;border-radius:999px}
.rep-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.rep-card{border:0.5px solid var(--border);border-radius:12px;padding:16px;background:var(--bg1)}
.rep-card-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--txt3);margin-bottom:6px}
.rep-card-value{font-size:24px;font-weight:700;color:var(--txt);line-height:1.2;margin-bottom:4px}
.rep-card-sub{font-size:12px;color:var(--txt3)}
.rep-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.rep-section{border:0.5px solid var(--border);border-radius:12px;padding:16px;background:var(--bg1)}
.rep-section-title{font-size:13px;font-weight:700;color:var(--txt);margin-bottom:14px;text-transform:uppercase;letter-spacing:.4px}
.rep-legend{display:flex;flex-direction:column;gap:8px}
.rep-legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--txt2)}
.rep-legend-item strong{margin-left:auto;font-weight:700;color:var(--txt)}
.rep-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.rep-util-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:16px}
.rep-util-card{text-align:center;padding:10px;background:var(--bg3);border-radius:8px}
.rep-util-val{font-size:20px;font-weight:700}
.rep-util-label{font-size:11px;color:var(--txt3);margin-top:2px}
.rep-pipe-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.rep-pipe-label{font-size:12px;color:var(--txt2);min-width:90px;text-transform:capitalize}
.rep-pipe-bar-wrap{flex:1;height:8px;background:var(--bg3);border-radius:4px;overflow:hidden}
.rep-pipe-bar{height:100%;background:#378ADD;border-radius:4px;transition:width .4s}
.rep-pipe-val{font-size:12px;color:var(--txt3);min-width:120px;text-align:right}
.rep-table-wrap{overflow-x:auto}
.rep-table{width:100%;border-collapse:collapse;font-size:13px}
.rep-table th{padding:8px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--txt3);border-bottom:1px solid var(--border)}
.rep-table td{padding:8px;border-bottom:1px solid var(--border);color:var(--txt2)}
.rep-table tr:last-child td{border-bottom:none}
@media(max-width:768px){
  .rep-kpis{grid-template-columns:repeat(2,1fr)}
  .rep-grid-2{grid-template-columns:1fr}
}
