/* ═══════════════════════════════════════
   Variables — Paleta Avanzar Soluciones
   ═══════════════════════════════════════ */
:root {
  --azul:      #002855;
  --azul-dk:   #001A38;
  --azul-lt:   #E6ECF4;
  --azul-md:   #B8C6DC;
  --rojo:      #D2232A;
  --rojo-lt:   #FCE7E8;
  --rojo-dk:   #A81A1F;
  --cian:      #0891B2;
  --cian-lt:   #E0F7FA;

  --bg:        #F3F6FB;
  --surface:   #FFFFFF;
  --surface-2: #EEF2FA;
  --borde:     #E2E8F4;
  --borde-md:  #C8D3EC;

  --txt-1:     #0F1B35;
  --txt-2:     #4B5563;
  --txt-3:     #8896B0;

  --ok:        #059669;  --ok-bg:   #ECFDF5;
  --warn:      #D97706;  --warn-bg: #FFFBEB;
  --danger:    #DC2626;  --dan-bg:  #FEF2F2;

  --grad-corp:  linear-gradient(135deg, #002855 0%, #D2232A 100%);
  --s-corp:     0 4px 16px rgba(210,35,42,.30);
  --s-corp-hv:  0 6px 20px rgba(210,35,42,.45), 0 2px 8px rgba(0,40,85,.30);

  --s1:  0 1px 4px rgba(15,27,53,.06);
  --s2:  0 4px 16px rgba(15,27,53,.09);
  --s3:  0 8px 32px rgba(15,27,53,.13);
  --s-azul: 0 4px 20px rgba(26,58,107,.22);

  --r-sm: 8px; --r-md: 12px; --r-lg: 18px; --r-xl: 22px; --r-pill: 999px;
  --ease: cubic-bezier(.4,0,.2,1);
  --fast: .14s var(--ease); --mid: .24s var(--ease);

  --logo-filter: none;
}

[data-theme="dark"] {
  --bg:        #0C1220;
  --surface:   #141D30;
  --surface-2: #1A2540;
  --borde:     rgba(255,255,255,.07);
  --borde-md:  rgba(255,255,255,.13);

  --txt-1:     #EAF0FF;
  --txt-2:     #8892B0;
  --txt-3:     #4A5278;

  --azul-lt:   rgba(26,58,107,.20);
  --azul-md:   rgba(26,58,107,.35);
  --rojo-lt:   rgba(214,28,46,.15);
  --cian-lt:   rgba(8,145,178,.13);

  --ok-bg:     rgba(5,150,105,.15);
  --warn-bg:   rgba(217,119,6,.15);
  --dan-bg:    rgba(220,38,38,.15);

  --s1:  0 1px 6px rgba(0,0,0,.35);
  --s2:  0 4px 20px rgba(0,0,0,.42);
  --s3:  0 8px 36px rgba(0,0,0,.52);
  --s-azul: 0 4px 20px rgba(26,58,107,.4);

  --logo-filter: brightness(0) invert(1);
}

/* ═══════════════════════════════════════
   Reset + Base
   ═══════════════════════════════════════ */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; -webkit-font-smoothing:antialiased; scroll-behavior:smooth; }
body {
  font-family:'Plus Jakarta Sans',-apple-system,sans-serif;
  background:var(--bg); color:var(--txt-1);
  min-height:100vh; line-height:1.6;
  transition:background var(--mid), color var(--mid);
}
button { font-family:inherit; cursor:pointer; }
a { color:inherit; }
input { font-family:inherit; }

/* ═══════════════════════════════════════
   Barra de progreso
   ═══════════════════════════════════════ */
#barraProgreso {
  position:fixed; top:0; left:0; height:2px; width:0%;
  background:linear-gradient(90deg, var(--rojo), var(--azul));
  z-index:9999; opacity:0;
  transition:width .4s var(--ease), opacity .3s var(--ease);
}
#barraProgreso.activa { opacity:1; }

/* ═══════════════════════════════════════
   Header
   ═══════════════════════════════════════ */
.header {
  background:var(--surface);
  border-bottom:1px solid var(--borde);
  position:sticky; top:0; z-index:200;
  box-shadow:var(--s1);
}
.header__inner {
  max-width:1280px; margin:0 auto; padding:12px 28px;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.header__izq { display:flex; align-items:center; gap:14px; }
.header__logo { height:28px; width:auto; filter:var(--logo-filter); flex-shrink:0; }
.header__sep  { width:1px; height:20px; background:var(--borde); flex-shrink:0; }
.header__titulo { font-size:.88rem; font-weight:700; color:var(--txt-1); letter-spacing:-.01em; }
.header__sub    { font-size:.68rem; color:var(--txt-3); font-weight:500; margin-top:1px; }
.header__der    { display:flex; align-items:center; gap:10px; }

.modo-chip {
  display:inline-flex; align-items:center; gap:5px;
  padding:5px 11px; border-radius:var(--r-pill);
  font-size:.69rem; font-weight:600; letter-spacing:.01em; white-space:nowrap;
}
.modo-chip--consulta { background:var(--azul-lt); color:var(--azul); border:1px solid var(--azul-md); }
.modo-chip--activo   { background:var(--ok-bg);   color:var(--ok);   border:1px solid rgba(5,150,105,.25); }
.modo-chip--error    { background:var(--dan-bg);  color:var(--danger); border:1px solid rgba(220,38,38,.25); }

.btn-tema {
  width:34px; height:34px; border-radius:var(--r-sm);
  background:var(--surface-2); border:1px solid var(--borde);
  display:flex; align-items:center; justify-content:center;
  color:var(--txt-2);
  transition:background var(--fast), border-color var(--fast), transform var(--fast);
}
.btn-tema:hover { background:var(--borde); transform:scale(1.06); }
.btn-tema .tema-luna { display:none; }
[data-theme="dark"] .btn-tema .tema-sol  { display:none; }
[data-theme="dark"] .btn-tema .tema-luna { display:inline-flex; }

/* ═══════════════════════════════════════
   Main Nav
   ═══════════════════════════════════════ */
.main-nav {
  background:var(--surface);
  border-bottom:1px solid var(--borde);
  position:sticky; top:53px; z-index:100;
}
.main-nav__inner {
  max-width:1280px; margin:0 auto; padding:0 28px;
  display:flex; gap:0;
}
.nav-tab {
  display:inline-flex; align-items:center; gap:7px;
  padding:12px 20px;
  background:transparent; border:none;
  border-bottom:2px solid transparent;
  color:var(--txt-3); font-size:.82rem; font-weight:600;
  transition:color var(--fast), border-color var(--fast), background var(--fast);
  white-space:nowrap;
}
.nav-tab:hover { color:var(--txt-1); background:var(--surface-2); }
.nav-tab--activa { color:var(--azul); border-bottom-color:var(--azul); }

/* ═══════════════════════════════════════
   Main layout
   ═══════════════════════════════════════ */
.main { max-width:1280px; margin:0 auto; padding:28px 28px 120px; }
.panel-grupo { animation:rise .22s var(--ease) both; }
@keyframes rise { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }

/* ═══════════════════════════════════════
   Grupo info strip
   ═══════════════════════════════════════ */
.grupo-info {
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; flex-wrap:wrap;
  background:var(--surface); border:1px solid var(--borde);
  border-radius:var(--r-lg); padding:14px 20px;
  margin-bottom:16px; box-shadow:var(--s1);
}
.grupo-info__izq { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.grupo-info__der {
  display:flex; align-items:center; gap:6px;
  font-size:.78rem; font-weight:600; color:var(--txt-2);
}
.grupo-badge {
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px; border-radius:var(--r-pill);
  font-size:.76rem; font-weight:700; white-space:nowrap;
}
.grupo-badge--a { background:var(--azul-lt); color:var(--azul); border:1px solid var(--azul-md); }
.grupo-badge--b { background:var(--cian-lt); color:var(--cian); border:1px solid rgba(8,145,178,.25); }
.grupo-miembros { font-size:.78rem; color:var(--txt-3); font-weight:500; }

/* ═══════════════════════════════════════
   Etapas grid + cards
   ═══════════════════════════════════════ */
.etapas-grid {
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:12px;
  margin-bottom:20px;
}
@media (max-width:900px)  { .etapas-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:500px)  { .etapas-grid { grid-template-columns:1fr; } }

.etapa-card {
  position:relative; overflow:hidden;
  background:var(--surface);
  border:1.5px solid var(--borde);
  border-radius:var(--r-lg);
  padding:22px 18px 18px;
  text-align:left;
  box-shadow:var(--s1);
  transition:border-color var(--mid), box-shadow var(--mid), background var(--mid), transform var(--fast);
}
.etapa-card:hover {
  border-color:var(--azul-md);
  box-shadow:var(--s2);
  transform:translateY(-2px);
}
.etapa-card.activa {
  border-color:var(--azul);
  background:var(--azul-lt);
  box-shadow:var(--s-azul);
}

/* Icono gigante de fondo */
.etapa-card__bg {
  position:absolute; right:-12px; bottom:-12px;
  width:88px; height:88px;
  color:var(--azul); opacity:.06;
  pointer-events:none;
}
.etapa-card__bg svg { width:100%; height:100%; stroke-width:1.5; }
.etapa-card.activa .etapa-card__bg { opacity:.10; }

.etapa-card__body { position:relative; z-index:1; }
.etapa-card__nombre {
  display:block; font-size:.86rem; font-weight:700;
  color:var(--txt-1); line-height:1.3; margin-bottom:6px;
}
.etapa-card.activa .etapa-card__nombre { color:var(--azul); }
.etapa-card__cnt {
  display:block; font-size:.7rem; font-weight:500; color:var(--txt-3);
}
.etapa-card.activa .etapa-card__cnt { color:var(--azul); opacity:.8; }

/* Número de orden de la etapa (esquina superior derecha) */
.etapa-card__orden {
  position:absolute; top:10px; right:12px; z-index:2;
  display:flex; align-items:center; justify-content:center;
  min-width:22px; height:22px; padding:0 6px; border-radius:var(--r-pill);
  background:var(--surface-2); border:1px solid var(--borde);
  font-size:.68rem; font-weight:800; color:var(--txt-3);
}
.etapa-card.activa .etapa-card__orden { background:var(--azul); border-color:var(--azul); color:#fff; }

/* Aviso de etapas de ejemplo (ocupa toda la fila de la cuadrícula) */
.etapas-aviso {
  grid-column:1 / -1;
  display:flex; align-items:flex-start; gap:9px;
  background:var(--azul-lt); border:1px solid var(--azul-md);
  border-radius:var(--r-md); padding:11px 15px;
  font-size:.8rem; color:var(--azul); line-height:1.5;
}
.etapas-aviso svg { width:17px; height:17px; flex-shrink:0; margin-top:1px; }
.etapas-aviso code { background:var(--surface); border:1px solid var(--borde-md); border-radius:4px; padding:1px 5px; font-size:.92em; }

/* ═══════════════════════════════════════
   Loader
   ═══════════════════════════════════════ */
.loader-area {
  display:flex; align-items:center; gap:12px;
  padding:28px 0; color:var(--txt-3); font-size:.84rem;
}
.loader-area[hidden] { display:none; }
.loader-ring {
  width:20px; height:20px; flex-shrink:0;
  border:2px solid var(--borde); border-top-color:var(--azul);
  border-radius:50%; animation:spin .7s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* ═══════════════════════════════════════
   Resultados — métricas compactas
   ═══════════════════════════════════════ */
.metricas-strip {
  display:flex; align-items:center; gap:20px; flex-wrap:wrap;
  background:var(--surface); border:1px solid var(--borde);
  border-radius:var(--r-lg); padding:12px 18px;
  margin-bottom:14px; box-shadow:var(--s1);
}
.m-dato { display:flex; flex-direction:column; }
.m-dato__num {
  font-size:1.3rem; font-weight:800; letter-spacing:-.04em; line-height:1;
  color:var(--txt-1);
}
.m-dato__num--rojo  { color:var(--rojo); }
.m-dato__num--azul  { color:var(--azul); }
.m-dato__txt { font-size:.85rem; font-weight:700; color:var(--txt-1); line-height:1.2; }
.m-dato__lbl { font-size:.63rem; font-weight:600; color:var(--txt-3); text-transform:uppercase; letter-spacing:.07em; margin-top:2px; }
.m-sep { width:1px; height:32px; background:var(--borde); flex-shrink:0; }
.m-spacer { flex:1; }

.btn-sel-todos {
  padding:7px 14px; border-radius:var(--r-pill);
  background:var(--surface-2); border:1px solid var(--borde-md);
  color:var(--txt-2); font-size:.75rem; font-weight:600;
  transition:all var(--fast);
}
.btn-sel-todos:hover { background:var(--azul-lt); border-color:var(--azul-md); color:var(--azul); }

/* ═══════════════════════════════════════
   Acordeón
   ═══════════════════════════════════════ */
.acordeon { margin-bottom:10px; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--borde); }

.acordeon-hd-row { display:flex; align-items:center; }
.acordeon-hd-row .acordeon-hd { flex:1; width:auto; }
.acordeon-hd-row > .acordeon-sel-todos { margin-right:14px; }

.acordeon-hd {
  width:100%; display:flex; align-items:center; gap:10px;
  padding:13px 18px;
  background:var(--surface); border:none; text-align:left;
  transition:background var(--fast);
}
.acordeon-hd:hover { background:var(--surface-2); }
.acordeon-hd.expandido { background:var(--surface-2); }

.acordeon-chevron {
  color:var(--txt-3); flex-shrink:0;
  transition:transform var(--fast);
}
.acordeon-hd.expandido .acordeon-chevron { transform:rotate(180deg); }

.acordeon-tipo {
  font-size:.84rem; font-weight:700; color:var(--txt-1); flex:1;
}
.acordeon-cnt {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:22px; height:22px; padding:0 7px;
  border-radius:var(--r-pill);
  font-size:.7rem; font-weight:700;
}
.acordeon-cnt--warn   { background:var(--warn-bg);  color:var(--warn); }
.acordeon-cnt--danger { background:var(--rojo-lt);  color:var(--rojo); }
.acordeon-cnt--ok     { background:var(--ok-bg);    color:var(--ok); }

.acordeon-sel-todos {
  margin-left:auto; display:flex; align-items:center; gap:6px;
  font-size:.73rem; font-weight:600; color:var(--txt-2);
  padding:4px 10px; border-radius:var(--r-pill);
  background:transparent; border:1px solid var(--borde);
  transition:all var(--fast); white-space:nowrap;
  flex-shrink:0;
}
.acordeon-sel-todos:hover { background:var(--azul-lt); border-color:var(--azul-md); color:var(--azul); }
.acordeon-sel-todos input[type="checkbox"] { accent-color:var(--azul); }

.acordeon-body {
  display:none; border-top:1px solid var(--borde);
  background:var(--surface);
}
.acordeon-body.abierto { display:block; animation:abrirse .18s var(--ease) both; }
@keyframes abrirse { from{opacity:0;transform:translateY(-4px)} to{opacity:1;transform:translateY(0)} }

/* ═══════════════════════════════════════
   Lista de leads (dentro del acordeón)
   ═══════════════════════════════════════ */
.leads-list {
  width:100%; border-collapse:collapse;
}
.leads-list thead { background:var(--surface-2); }
.leads-list thead th {
  padding:8px 14px; text-align:left;
  font-size:.61rem; font-weight:700;
  color:var(--txt-3); letter-spacing:.08em; text-transform:uppercase;
  white-space:nowrap; border-bottom:1px solid var(--borde);
}
.leads-list tbody tr { border-bottom:1px solid var(--borde); transition:background var(--fast); }
.leads-list tbody tr:last-child { border-bottom:none; }
.leads-list tbody tr:hover { background:var(--surface-2); }
.leads-list tbody tr.fila-sel { background:var(--azul-lt); }
.leads-list tbody tr.fila-ok  { opacity:.55; }
.leads-list td { padding:11px 14px; vertical-align:middle; }

.td-chk { width:36px; }
.td-chk input[type="checkbox"] { accent-color:var(--azul); width:15px; height:15px; cursor:pointer; }

.deal-id {
  font-size:.74rem; font-weight:700; color:var(--azul);
  text-decoration:none; background:var(--azul-lt);
  padding:2px 8px; border-radius:5px;
  transition:background var(--fast); white-space:nowrap;
}
.deal-id:hover { background:var(--azul-md); }

.deal-nombre { font-weight:600; color:var(--txt-1); font-size:.83rem; max-width:180px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.deal-persona { font-size:.79rem; color:var(--txt-2); }

.badge-dias {
  display:inline-flex; align-items:center;
  padding:3px 9px; border-radius:var(--r-pill);
  font-size:.7rem; font-weight:700; white-space:nowrap;
}
.badge-dias--na    { background:var(--warn-bg);  color:var(--warn); }
.badge-dias--venc  { background:var(--rojo-lt);  color:var(--rojo); }
.badge-dias--ok    { background:var(--ok-bg);    color:var(--ok); }

.accion-dest {
  font-size:.74rem; font-weight:600; color:var(--azul);
  white-space:nowrap;
}

/* Sin resultados dentro de acordeón */
.acordeon-vacio {
  padding:28px; text-align:center;
  color:var(--txt-3); font-size:.82rem;
}

/* ═══════════════════════════════════════
   Paginación
   ═══════════════════════════════════════ */
.paginacion {
  display:flex; align-items:center; gap:6px; flex-wrap:wrap;
  padding:14px 4px; margin-top:4px;
}
.pag-btn {
  height:32px; min-width:32px; padding:0 10px;
  border-radius:var(--r-sm);
  background:var(--surface); border:1px solid var(--borde);
  color:var(--txt-2); font-size:.78rem; font-weight:600;
  transition:all var(--fast); cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
}
.pag-btn:hover:not(:disabled) { background:var(--azul-lt); border-color:var(--azul-md); color:var(--azul); }
.pag-btn:disabled { opacity:.35; cursor:default; }
.pag-btn--nav { padding:0 14px; }
.pag-num--activa { background:var(--azul); border-color:var(--azul); color:#fff; }
.pag-num--activa:hover { background:var(--azul); color:#fff; }
.pag-numeros { display:flex; align-items:center; gap:4px; }
.pag-ellipsis {
  width:24px; text-align:center;
  color:var(--txt-3); font-size:.78rem;
}
.pag-total {
  margin-left:auto;
  font-size:.72rem; font-weight:600; color:var(--txt-3);
  white-space:nowrap;
}

/* ═══════════════════════════════════════
   Estado vacío genérico
   ═══════════════════════════════════════ */
.estado-vacio {
  display:flex; align-items:center; gap:10px;
  padding:36px 20px;
  color:var(--txt-3); font-size:.84rem; font-weight:500;
}

/* ═══════════════════════════════════════
   Barra de selección masiva (fija abajo)
   ═══════════════════════════════════════ */
.sel-bar {
  position:fixed; bottom:0; left:0; right:0; z-index:300;
  display:flex; align-items:center; gap:14px;
  padding:14px 32px;
  background:var(--azul-dk);
  border-top:1px solid rgba(255,255,255,.08);
  transform:translateY(100%);
  transition:transform var(--mid);
  box-shadow:0 -4px 24px rgba(0,0,0,.3);
}
.sel-bar.visible { transform:translateY(0); }
.sel-bar__ico { color:rgba(255,255,255,.6); flex-shrink:0; width:20px; height:20px; }
.sel-bar__txt { color:rgba(255,255,255,.85); font-size:.84rem; font-weight:600; flex:1; }

.btn-autorizar {
  display:inline-flex; align-items:center; gap:7px;
  padding:10px 22px; border-radius:var(--r-pill);
  background:var(--grad-corp); border:none; color:#fff;
  font-size:.82rem; font-weight:700;
  box-shadow:var(--s-corp);
  transition:box-shadow var(--fast), transform var(--fast), filter var(--fast);
  white-space:nowrap;
  cursor:pointer;
}
.btn-autorizar:hover  { box-shadow:var(--s-corp-hv); transform:translateY(-2px); filter:brightness(1.05); }
.btn-autorizar:active { transform:translateY(0); filter:brightness(.98); }

.btn-icon-ghost {
  background:none; border:none;
  color:rgba(255,255,255,.5); padding:6px;
  border-radius:var(--r-sm);
  display:flex; align-items:center; justify-content:center;
  transition:color var(--fast), background var(--fast);
}
.btn-icon-ghost:hover { color:#fff; background:rgba(255,255,255,.1); }

/* ═══════════════════════════════════════
   Modal
   ═══════════════════════════════════════ */
.modal-overlay {
  position:fixed; inset:0; z-index:400;
  background:rgba(10,20,40,.6);
  display:none; align-items:center; justify-content:center; padding:20px;
}
.modal-overlay.abierto { display:flex; animation:fadeIn .18s var(--ease) both; }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }

.modal {
  background:var(--surface); border-radius:var(--r-xl);
  box-shadow:var(--s3); max-width:460px; width:100%;
  animation:modalUp .22s var(--ease) both;
  overflow:hidden;
}
@keyframes modalUp { from{opacity:0;transform:translateY(16px) scale(.97)} to{opacity:1;transform:translateY(0) scale(1)} }

.modal__hd {
  display:flex; align-items:center; gap:12px;
  padding:20px 24px 16px;
  border-bottom:1px solid var(--borde);
}
.modal__ico { color:var(--rojo); flex-shrink:0; width:20px; height:20px; }
.modal__titulo { font-size:.96rem; font-weight:700; color:var(--txt-1); }

.modal__body { padding:18px 24px; }
.modal__body p { font-size:.87rem; color:var(--txt-2); line-height:1.6; margin-bottom:14px; }

.modal__detalle {
  background:var(--surface-2); border:1px solid var(--borde);
  border-radius:var(--r-md); padding:14px 16px;
  font-size:.82rem; color:var(--txt-1);
}
.modal__detalle p { margin-bottom:6px; font-size:.82rem; }
.modal__detalle p:last-child { margin-bottom:0; }
.modal__detalle strong { color:var(--azul); }

.modal__pie {
  display:flex; justify-content:flex-end; gap:10px;
  padding:14px 24px;
  border-top:1px solid var(--borde); background:var(--surface-2);
}

/* Campos del modal de creación (plantilla / fecha / periodicidad) */
.modal { max-width:520px; }
.modal__body { max-height:72vh; overflow-y:auto; }
.modal .adm-label { display:block; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--txt-3); margin:13px 0 5px; }
.modal .adm-input { width:100%; font:inherit; font-size:.88rem; color:var(--txt-1); background:var(--surface-2); border:1.5px solid var(--borde-md); border-radius:var(--r-md); padding:9px 12px; outline:none; transition:border-color var(--fast); }
.modal .adm-input:focus { border-color:var(--azul); background:var(--surface); box-shadow:0 0 0 3px var(--azul-lt); }
.modal-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.modal-tpl-prev { background:var(--surface-2); border:1px solid var(--borde); border-radius:var(--r-md); padding:11px 13px; margin:8px 0 2px; }
.modal-tpl-prev__a { font-weight:700; font-size:.84rem; color:var(--azul); margin-bottom:4px; }
.modal-tpl-prev__d { font-size:.8rem; color:var(--txt-2); line-height:1.5; white-space:pre-wrap; }

.btn-sec {
  padding:8px 18px; border-radius:var(--r-pill);
  background:transparent; border:1.5px solid var(--borde-md);
  color:var(--txt-2); font-size:.82rem; font-weight:600;
  transition:all var(--fast);
}
.btn-sec:hover { background:var(--surface-2); border-color:var(--borde-md); color:var(--txt-1); }

.btn-prim {
  display:inline-flex; align-items:center; gap:6px;
  padding:9px 22px; border-radius:var(--r-pill);
  background:var(--grad-corp); border:none; color:#fff;
  font-size:.82rem; font-weight:700;
  box-shadow:var(--s-corp);
  cursor:pointer;
  transition:box-shadow var(--fast), transform var(--fast), filter var(--fast);
}
.btn-prim:hover  { box-shadow:var(--s-corp-hv); transform:translateY(-2px); filter:brightness(1.05); }
.btn-prim:active { transform:translateY(0); filter:brightness(.98); }

/* ═══════════════════════════════════════
   Toast
   ═══════════════════════════════════════ */
.toast {
  position:fixed; bottom:80px; right:24px; z-index:500;
  background:var(--txt-1); color:#fff;
  border-radius:var(--r-lg); padding:12px 16px;
  font-size:.82rem; font-weight:500; max-width:360px;
  box-shadow:var(--s3);
  display:flex; align-items:center; gap:10px;
  transform:translateY(12px); opacity:0;
  transition:transform var(--mid), opacity var(--mid);
  pointer-events:none;
}
.toast.visible { transform:translateY(0); opacity:1; pointer-events:auto; }
.toast .btn-icon-ghost { color:rgba(255,255,255,.5); margin-left:4px; }
.toast .btn-icon-ghost:hover { color:#fff; }

/* ═══════════════════════════════════════
   Panel buscar
   ═══════════════════════════════════════ */
.buscar-panel {
  background:var(--surface); border:1px solid var(--borde);
  border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--s2);
}
.buscar-campo {
  display:flex; align-items:center; gap:10px;
  padding:14px 18px; border-bottom:1px solid var(--borde);
  background:var(--surface-2);
}
.buscar-ico { color:var(--txt-3); flex-shrink:0; width:16px; height:16px; }
.buscar-input {
  flex:1; border:none; background:transparent;
  font-size:.88rem; font-weight:500; color:var(--txt-1);
  outline:none;
}
.buscar-input::placeholder { color:var(--txt-3); }
#buscarResultados { padding:8px 0; min-height:120px; }
.buscar-resultado-fila {
  display:flex; align-items:center; gap:12px;
  padding:10px 18px; border-bottom:1px solid var(--borde);
  transition:background var(--fast);
}
.buscar-resultado-fila:last-child { border-bottom:none; }
.buscar-resultado-fila:hover { background:var(--surface-2); }

/* ═══════════════════════════════════════
   Iconos SVG helpers
   ═══════════════════════════════════════ */
.ico-xs  { width:14px; height:14px; flex-shrink:0; }
.ico-sm  { width:16px; height:16px; flex-shrink:0; }
.ico-md  { width:20px; height:20px; flex-shrink:0; }
.nav-ico { width:16px; height:16px; flex-shrink:0; }

/* ═══════════════════════════════════════
   Resultado: progress / estado final
   ═══════════════════════════════════════ */
.resultado-banner {
  display:flex; align-items:center; gap:12px;
  padding:14px 18px; border-radius:var(--r-lg);
  margin-bottom:16px; font-size:.84rem; font-weight:600;
  border:1px solid transparent;
}
.resultado-banner--ok    { background:var(--ok-bg);  border-color:rgba(5,150,105,.25); color:#064E3B; }
.resultado-banner--error { background:var(--dan-bg); border-color:rgba(220,38,38,.25); color:#991B1B; }

/* ═══════════════════════════════════════
   Footer
   ═══════════════════════════════════════ */
.footer {
  background:#fff;
  border-top:1px solid var(--borde);
  padding:26px 28px;
  margin-top:auto;
  text-align:center;
  font-size:.82rem;
  color:var(--txt-3);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
}
[data-theme="dark"] .footer { background:var(--surface); }
.footer__cliente { color:var(--txt-3); }
.footer__sep { color:var(--borde-md); user-select:none; }
.footer__by { color:var(--txt-2); font-weight:500; }
.footer__brand {
  margin-left:4px;
  font-weight:800;
  text-decoration:none;
  background:var(--grad-corp);
  background-clip:text;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
  letter-spacing:-.01em;
  transition:filter var(--fast);
}
.footer__brand:hover { filter:brightness(1.15); }

/* ═══════════════════════════════════════
   Guía / Panel Inicio
   ═══════════════════════════════════════ */

/* Hero */
.guia-hero {
  display:flex; align-items:center; gap:24px;
  background:linear-gradient(135deg, var(--azul-dk) 0%, var(--azul) 100%);
  border-radius:var(--r-xl); padding:28px 32px;
  margin-bottom:20px; color:#fff; box-shadow:var(--s3);
}
.guia-hero__svg { width:54px; height:54px; flex-shrink:0; opacity:.85; }
.guia-hero__titulo { font-size:1.2rem; font-weight:800; letter-spacing:-.02em; line-height:1.2; }
.guia-hero__sub { font-size:.76rem; opacity:.6; font-weight:600; letter-spacing:.04em; text-transform:uppercase; margin-bottom:6px; }
.guia-hero__desc { font-size:.84rem; opacity:.82; line-height:1.6; max-width:640px; margin-top:6px; }

/* Sections */
.guia-section {
  background:var(--surface); border:1px solid var(--borde);
  border-radius:var(--r-xl); padding:24px 28px;
  margin-bottom:14px; box-shadow:var(--s1);
}
.guia-h2 { font-size:.95rem; font-weight:800; color:var(--txt-1); margin-bottom:6px; letter-spacing:-.01em; }
.guia-desc { font-size:.83rem; color:var(--txt-2); line-height:1.6; margin-bottom:16px; }
.guia-code {
  display:inline; background:var(--surface-2); border:1px solid var(--borde-md);
  border-radius:4px; padding:1px 6px; font-family:monospace; font-size:.79rem; color:var(--azul);
}
.guia-nota {
  display:flex; align-items:flex-start; gap:8px;
  background:var(--azul-lt); border:1px solid var(--azul-md);
  border-radius:var(--r-md); padding:12px 16px;
  font-size:.8rem; color:var(--azul); line-height:1.55; margin-top:16px;
}
.guia-nota svg { flex-shrink:0; margin-top:1px; }

/* ¿Cómo funciona? — 3 pasos */
.guia-flujo { display:flex; align-items:flex-start; gap:0; margin-top:18px; }
.guia-paso {
  flex:1; background:var(--surface-2); border:1px solid var(--borde);
  border-radius:var(--r-lg); padding:20px 16px; text-align:center;
}
.guia-paso__ico {
  width:46px; height:46px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; margin:0 auto 10px;
}
.guia-paso__ico--1 { background:var(--azul-lt); color:var(--azul); }
.guia-paso__ico--2 { background:var(--warn-bg); color:var(--warn); }
.guia-paso__ico--3 { background:var(--ok-bg); color:var(--ok); }
.guia-paso__num { font-size:.63rem; font-weight:800; color:var(--txt-3); letter-spacing:.1em; text-transform:uppercase; margin-bottom:4px; }
.guia-paso__titulo { font-size:.88rem; font-weight:700; color:var(--txt-1); margin-bottom:6px; }
.guia-paso__desc { font-size:.76rem; color:var(--txt-2); line-height:1.55; }
.guia-flujo__conector {
  display:flex; align-items:center; padding:0 8px;
  color:var(--txt-3); flex-shrink:0; margin-top:44px;
}

/* Grupos A / B */
.guia-grupos { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:16px; }
.guia-grupo { border-radius:var(--r-lg); border:1.5px solid; padding:20px; }
.guia-grupo--a { border-color:var(--azul-md); background:var(--azul-lt); }
.guia-grupo--b { border-color:rgba(8,145,178,.3); background:var(--cian-lt); }
.guia-grupo__header {
  display:flex; align-items:center; gap:8px;
  font-weight:800; font-size:.9rem; margin-bottom:14px;
}
.guia-grupo--a .guia-grupo__header { color:var(--azul); }
.guia-grupo--b .guia-grupo__header { color:var(--cian); }
.guia-grupo__miembros { display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.guia-miembro { display:flex; align-items:center; gap:7px; font-size:.81rem; color:var(--txt-2); }
.guia-miembro svg { color:var(--ok); flex-shrink:0; }
.guia-grupo__sep {
  display:flex; align-items:center; gap:6px;
  font-size:.69rem; color:var(--txt-3); font-weight:700;
  text-transform:uppercase; letter-spacing:.06em;
  border-top:1px solid var(--borde); padding-top:12px; margin-bottom:10px;
}
.guia-grupo__destino { display:flex; flex-direction:column; gap:6px; }
.guia-dest-nombre, .guia-dest-etapa {
  display:flex; align-items:center; gap:6px;
  font-size:.82rem; font-weight:700; color:var(--txt-1);
}

/* Árbol de evaluación */
.eval-flujo { display:flex; flex-direction:column; align-items:stretch; margin-top:16px; gap:0; }
.eval-inicio {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--surface-2); border:1px solid var(--borde-md);
  border-radius:var(--r-pill); padding:8px 18px;
  font-size:.82rem; font-weight:700; color:var(--txt-2); align-self:center;
}
.eval-connector-v { width:2px; height:22px; background:var(--borde-md); align-self:center; }
.eval-step {
  border:1.5px solid var(--borde); border-radius:var(--r-lg);
  padding:18px 20px; background:var(--surface);
  display:flex; gap:16px; align-items:flex-start;
}
.eval-step__badge {
  width:36px; height:36px; min-width:36px; border-radius:50%;
  background:var(--azul); color:#fff;
  font-size:.7rem; font-weight:800; letter-spacing:.03em;
  display:flex; align-items:center; justify-content:center;
}
.eval-step__cuerpo { flex:1; min-width:0; }
.eval-pregunta { font-size:.86rem; font-weight:700; color:var(--txt-1); margin-bottom:12px; line-height:1.45; }
.eval-opciones { display:flex; flex-direction:column; gap:6px; }
.eval-opcion {
  display:flex; align-items:center; gap:10px;
  padding:8px 12px; border-radius:var(--r-md);
}
.eval-opcion--aplica  { background:var(--rojo-lt); }
.eval-opcion--ok      { background:var(--ok-bg); }
.eval-opcion--continua { background:var(--surface-2); }
.eval-opcion__tag {
  font-size:.67rem; font-weight:800; letter-spacing:.05em;
  padding:2px 7px; border-radius:4px; flex-shrink:0; min-width:30px; text-align:center;
}
.eval-opcion--aplica .eval-opcion__tag  { background:var(--rojo); color:#fff; }
.eval-opcion--ok .eval-opcion__tag      { background:var(--ok); color:#fff; }
.eval-opcion--continua .eval-opcion__tag { background:var(--txt-3); color:#fff; }
.eval-opcion__resultado { display:flex; align-items:center; gap:8px; flex-wrap:wrap; font-size:.8rem; color:var(--txt-2); }
.eval-pill {
  display:inline-flex; align-items:center;
  padding:2px 10px; border-radius:var(--r-pill);
  font-size:.67rem; font-weight:800; letter-spacing:.04em; white-space:nowrap;
}
.eval-pill--aplica { background:var(--rojo); color:#fff; }
.eval-pill--ok     { background:var(--ok);   color:#fff; }
.eval-continua { font-size:.79rem; color:var(--txt-3); font-style:italic; }

/* Detalle expandido de condición */
.eval-detalle {
  margin:10px 0 4px;
  border:1px solid var(--borde); border-radius:var(--r-md);
  overflow:hidden;
}
.eval-detalle__hd {
  display:flex; align-items:center; gap:7px;
  padding:8px 12px; background:var(--surface-2);
  font-size:.71rem; font-weight:800; color:var(--txt-3);
  text-transform:uppercase; letter-spacing:.07em;
  border-bottom:1px solid var(--borde);
}
.eval-detalle__body { padding:12px 14px; }

/* Tipos de actividad */
.eval-act-tipos { display:flex; flex-wrap:wrap; gap:7px; margin-bottom:12px; }
.eval-act-tipo {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--surface); border:1px solid var(--borde-md);
  border-radius:var(--r-pill); padding:5px 12px;
  font-size:.76rem; font-weight:600; color:var(--txt-2);
}
.eval-act-tipo svg { color:var(--azul); flex-shrink:0; }

/* Lo que NO cuenta */
.eval-no-titulo {
  display:flex; align-items:center; gap:5px;
  font-size:.71rem; font-weight:800; color:var(--txt-3);
  text-transform:uppercase; letter-spacing:.07em; margin-bottom:8px;
}
.eval-no-lista { display:flex; flex-direction:column; gap:5px; }
.eval-no-item {
  display:flex; align-items:flex-start; gap:7px;
  font-size:.78rem; color:var(--txt-2); line-height:1.45;
}
.eval-no-item svg { flex-shrink:0; margin-top:1px; }
.eval-no-item--si  svg { color:var(--ok); }
.eval-no-item--no  svg { color:var(--rojo); }

/* Etapas monitoreadas */
.guia-etapas { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-top:14px; }
.guia-etapa {
  text-align:center; padding:16px 10px;
  background:var(--surface-2); border:1px solid var(--borde);
  border-radius:var(--r-lg);
}
.guia-etapa__ico { color:var(--azul); display:flex; justify-content:center; margin-bottom:8px; }
.guia-etapa__nombre { font-size:.79rem; font-weight:700; color:var(--txt-1); line-height:1.3; }

/* Leyenda de indicadores */
.guia-badges { display:flex; flex-direction:column; gap:8px; margin-top:14px; }
.guia-badge-item {
  display:flex; align-items:center; gap:14px;
  padding:10px 14px; background:var(--surface-2);
  border:1px solid var(--borde); border-radius:var(--r-md);
}
.guia-badge-desc { font-size:.81rem; color:var(--txt-2); line-height:1.4; }

/* Pasos de uso */
.guia-pasos-uso { display:flex; flex-direction:column; margin-top:14px; }
.guia-uso-paso {
  display:flex; align-items:flex-start; gap:16px;
  padding:14px 0; border-bottom:1px solid var(--borde);
}
.guia-uso-paso:first-child { padding-top:0; }
.guia-uso-paso:last-child  { border-bottom:none; padding-bottom:0; }
.guia-uso-num {
  width:30px; height:30px; min-width:30px; border-radius:50%;
  background:var(--azul); color:#fff;
  font-size:.8rem; font-weight:800;
  display:flex; align-items:center; justify-content:center;
}
.guia-uso-titulo { font-size:.86rem; font-weight:700; color:var(--txt-1); margin-bottom:3px; }
.guia-uso-desc { font-size:.8rem; color:var(--txt-2); line-height:1.5; }

/* Parámetros del sistema */
.guia-limites { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:14px; }
.guia-limite {
  text-align:center; padding:20px 14px;
  background:var(--surface-2); border:1px solid var(--borde);
  border-radius:var(--r-lg);
}
.guia-limite__val { font-size:2.2rem; font-weight:900; color:var(--azul); letter-spacing:-.04em; line-height:1; margin-bottom:6px; }
.guia-limite__lbl { font-size:.76rem; font-weight:700; color:var(--txt-1); margin-bottom:6px; line-height:1.3; }
.guia-limite__desc { font-size:.74rem; color:var(--txt-3); line-height:1.45; }

/* ═══════════════════════════════════════
   Responsive
   ═══════════════════════════════════════ */
@media (max-width:900px) {
  .guia-grupos  { grid-template-columns:1fr; }
  .guia-etapas  { grid-template-columns:repeat(2,1fr); }
  .guia-limites { grid-template-columns:repeat(2,1fr); }
  .guia-flujo   { flex-direction:column; }
  .guia-flujo__conector { transform:rotate(90deg); padding:6px 0; margin-top:0; align-self:center; }
}
@media (max-width:640px) {
  .header__inner, .main-nav__inner, .main { padding-left:16px; padding-right:16px; }
  .grupo-info { flex-direction:column; align-items:flex-start; gap:8px; }
  .metricas-strip { gap:12px; }
  .sel-bar { padding:12px 16px; gap:10px; }
  .footer { gap:6px; padding:20px 16px; font-size:.76rem; }
  .footer__sep { display:none; }
  .footer__cliente, .footer__by { width:100%; }
  .guia-hero { flex-direction:column; text-align:center; padding:20px; gap:14px; }
  .guia-section { padding:18px 16px; }
  .guia-limites { grid-template-columns:1fr; }
}

/* ═══════════════════════════════════════════════════════════════
   Menú de usuario (header del dashboard)
   ═══════════════════════════════════════════════════════════════ */
.user-menu { position: relative; }

.user-chip {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 10px 6px 6px;
  border-radius: var(--r-pill);
  background: var(--surface-2);
  border: 1px solid var(--borde);
  cursor: pointer;
  font-family: inherit;
  color: var(--txt-1);
  transition: background var(--fast), border-color var(--fast), transform var(--fast);
}
.user-chip:hover { background: var(--azul-lt); border-color: var(--azul-md); }
.user-chip[aria-expanded="true"] { background: var(--azul-lt); border-color: var(--azul); }

.user-avatar {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--azul) 0%, var(--cian) 100%);
  color: #fff;
  font-weight: 800;
  font-size: .72rem;
  display: grid; place-items: center;
  letter-spacing: .03em;
  flex-shrink: 0;
}

.user-info { display: flex; flex-direction: column; line-height: 1.1; text-align: left; }
.user-nombre { font-size: .82rem; font-weight: 700; }
.user-rol {
  font-size: .62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--txt-3);
}
.user-rol--superadmin    { color: var(--rojo); }
.user-rol--administrador { color: var(--azul); }
.user-rol--admingrupoA   { color: var(--cian); }
.user-rol--admingrupoB   { color: var(--warn); }

.user-drop {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 240px;
  background: var(--surface);
  border: 1px solid var(--borde);
  border-radius: var(--r-md);
  box-shadow: var(--s3);
  overflow: hidden;
  z-index: 80;
  animation: drop-in .18s var(--ease);
}
@keyframes drop-in {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.user-drop__hd {
  padding: 12px 14px;
  border-bottom: 1px solid var(--borde);
  background: var(--surface-2);
}
.user-drop__email {
  font-size: .78rem;
  color: var(--txt-2);
  font-weight: 500;
  word-break: break-all;
}

.user-drop__item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  font-size: .85rem;
  color: var(--txt-1);
  text-decoration: none;
  background: transparent;
  border: none;
  cursor: pointer;
  width: 100%;
  font-family: inherit;
  transition: background var(--fast), color var(--fast);
}
.user-drop__item:hover { background: var(--azul-lt); color: var(--azul); }
.user-drop__item--danger { color: var(--rojo); }
.user-drop__item--danger:hover { background: var(--rojo-lt); color: var(--rojo); }

@media (max-width: 720px) {
  .user-info { display: none; }
  .user-chip { padding: 4px; }
}

.user-rol--analista { color: var(--cian); }
.user-rol--consulta { color: var(--txt-3); }

/* ═══════════════════════════════════════════════════════════════
   Layout con Sidebar lateral
   ═══════════════════════════════════════════════════════════════ */
.layout { display:flex; min-height:100vh; align-items:stretch; }

.sidebar {
  width:252px; flex-shrink:0;
  background:var(--surface);
  border-right:1px solid var(--borde);
  position:sticky; top:0; height:100vh;
  display:flex; flex-direction:column;
  z-index:200;
}
.sidebar__top {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 18px; border-bottom:1px solid var(--borde); min-height:57px;
}
.sidebar__brand { display:flex; align-items:center; }
.sidebar__logo { height:26px; width:auto; filter:var(--logo-filter); }
.sidebar__close {
  display:none; width:34px; height:34px; border-radius:var(--r-sm);
  background:transparent; border:none; color:var(--txt-2); align-items:center; justify-content:center;
}

.snav { flex:1; overflow-y:auto; padding:10px 12px; display:flex; flex-direction:column; gap:2px; }
.snav__grupo-lbl {
  font-size:.62rem; text-transform:uppercase; letter-spacing:.09em;
  color:var(--txt-3); font-weight:800; padding:14px 12px 6px;
}
.snav__item {
  display:flex; align-items:center; gap:11px;
  padding:9px 12px; border-radius:var(--r-sm);
  color:var(--txt-2); font-size:.82rem; font-weight:600; text-decoration:none;
  transition:background var(--fast), color var(--fast);
}
.snav__item:hover { background:var(--surface-2); color:var(--txt-1); }
.snav__item--activo { background:var(--azul-lt); color:var(--azul); }
.snav__item--activo .snav__ico { color:var(--azul); }
.snav__ico { width:18px; height:18px; flex-shrink:0; }

.sidebar__pie { border-top:1px solid var(--borde); padding:10px 12px 14px; display:flex; flex-direction:column; gap:8px; }
.snav__tema {
  display:flex; align-items:center; gap:11px;
  padding:9px 12px; border-radius:var(--r-sm);
  background:transparent; border:none; color:var(--txt-2);
  font-size:.8rem; font-weight:600; width:100%; text-align:left;
  transition:background var(--fast);
}
.snav__tema:hover { background:var(--surface-2); color:var(--txt-1); }
.snav__tema .tema-luna { display:none; }
[data-theme="dark"] .snav__tema .tema-sol  { display:none; }
[data-theme="dark"] .snav__tema .tema-luna { display:inline-flex; }

.sidebar__user { display:flex; align-items:center; gap:10px; padding:8px; border-radius:var(--r-md); background:var(--surface-2); }
.sidebar__user-info { flex:1; min-width:0; display:flex; flex-direction:column; gap:1px; }
.sidebar__user-nombre { font-size:.78rem; font-weight:700; color:var(--txt-1); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sidebar__salir { color:var(--txt-3); display:flex; padding:6px; border-radius:var(--r-sm); }
.sidebar__salir:hover { color:var(--danger); background:var(--dan-bg); }

.contenido { flex:1; min-width:0; display:flex; flex-direction:column; }
.contenido > main { flex:1 0 auto; }

.topbar {
  display:flex; align-items:center; gap:14px;
  padding:13px 28px; background:var(--surface);
  border-bottom:1px solid var(--borde);
  position:sticky; top:0; z-index:100;
}
.topbar__hamb {
  display:none; width:36px; height:36px; border-radius:var(--r-sm);
  background:var(--surface-2); border:1px solid var(--borde); color:var(--txt-2);
  align-items:center; justify-content:center; flex-shrink:0;
}
.topbar__hamb svg { width:18px; height:18px; }
.topbar__tit { flex:1; min-width:0; }
.topbar__titulo { font-size:1rem; font-weight:800; color:var(--txt-1); letter-spacing:-.01em; }
.topbar__sub { font-size:.7rem; color:var(--txt-3); font-weight:500; }

.contenido .main { max-width:none; width:100%; margin:0; padding:24px 28px 120px; }

.sidebar-backdrop { display:none; }

/* ═══════════════════════════════════════════════════════════════
   Dashboard / Resumen
   ═══════════════════════════════════════════════════════════════ */
.dash-hd { margin-bottom:22px; }
.dash-hd__titulo { font-size:1.45rem; font-weight:800; color:var(--txt-1); letter-spacing:-.02em; }
.dash-hd__sub { font-size:.85rem; color:var(--txt-2); margin-top:4px; }

.dash-cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); gap:16px; margin-bottom:28px; }
.dash-card {
  background:var(--surface); border:1px solid var(--borde);
  border-radius:var(--r-lg); padding:18px 20px; box-shadow:var(--s1);
  display:flex; flex-direction:column; gap:8px;
  transition:box-shadow var(--fast), transform var(--fast);
}
.dash-card:hover { box-shadow:var(--s2); transform:translateY(-2px); }
.dash-card__ico {
  width:40px; height:40px; border-radius:11px;
  display:flex; align-items:center; justify-content:center;
  background:var(--azul-lt); color:var(--azul); margin-bottom:2px;
}
.dash-card__ico svg { width:20px; height:20px; }
.dash-card__ico--rojo { background:var(--dan-bg); color:var(--danger); }
.dash-card__ico--ok   { background:var(--ok-bg);  color:var(--ok); }
.dash-card__ico--cian { background:var(--cian-lt); color:var(--cian); }
.dash-card__num { font-size:1.9rem; font-weight:800; line-height:1; color:var(--txt-1); letter-spacing:-.02em; }
.dash-card__num--texto { font-size:1.15rem; line-height:1.25; letter-spacing:-.01em; }
.dash-card__lbl { font-size:.8rem; color:var(--txt-2); font-weight:600; }
.dash-card__hint { font-size:.7rem; color:var(--txt-3); }

.dash-seccion-lbl { font-size:1rem; font-weight:800; color:var(--txt-1); margin:6px 0 14px; }
.dash-acciones { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:14px; }
.dash-accion {
  display:flex; align-items:center; gap:14px; text-decoration:none;
  background:var(--surface); border:1px solid var(--borde);
  border-radius:var(--r-md); padding:16px 18px;
  transition:border-color var(--fast), transform var(--fast), box-shadow var(--fast);
}
.dash-accion:hover { border-color:var(--azul-md); transform:translateY(-2px); box-shadow:var(--s2); }
.dash-accion__ico {
  width:42px; height:42px; border-radius:12px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  background:var(--grad-corp); color:#fff;
}
.dash-accion__ico svg { width:20px; height:20px; }
.dash-accion__tit { font-size:.9rem; font-weight:700; color:var(--txt-1); }
.dash-accion__desc { font-size:.76rem; color:var(--txt-3); line-height:1.4; }

/* ═══════════════════════════════════════════════════════════════
   Historial
   ═══════════════════════════════════════════════════════════════ */
.hist-wrap { background:var(--surface); border:1px solid var(--borde); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--s1); }
.hist-tabla { width:100%; border-collapse:collapse; }
.hist-tabla th {
  text-align:left; font-size:.7rem; text-transform:uppercase; letter-spacing:.04em;
  color:var(--txt-3); font-weight:700; padding:12px 16px; border-bottom:1px solid var(--borde); background:var(--surface-2);
}
.hist-tabla td { padding:12px 16px; font-size:.82rem; color:var(--txt-1); border-bottom:1px solid var(--borde); }
.hist-tabla tr:last-child td { border-bottom:none; }
.hist-vacio { text-align:center; padding:48px 20px; color:var(--txt-3); font-size:.85rem; }

/* ═══════════════════════════════════════════════════════════════
   Responsive — sidebar off-canvas
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:880px) {
  .sidebar {
    position:fixed; left:0; top:0; height:100vh;
    transform:translateX(-100%); transition:transform .26s var(--ease);
    box-shadow:var(--s3);
  }
  .sidebar--abierto { transform:translateX(0); }
  .sidebar__close { display:flex; }
  .topbar__hamb { display:flex; }
  .sidebar-backdrop {
    position:fixed; inset:0; background:rgba(8,12,20,.45);
    z-index:150; opacity:0; pointer-events:none; transition:opacity .26s var(--ease);
  }
  .sidebar-backdrop.visible { display:block; opacity:1; pointer-events:auto; }
  .contenido .main { padding:18px 16px 120px; }
  .topbar { padding:12px 16px; }
}

/* ═══════════════════════════════════════════════════════════════
   MEJORAS UBICACIÓN DE CLIENTES (10)
   ═══════════════════════════════════════════════════════════════ */

/* (1) Búsqueda global en topbar ─────────────────────────────── */
.topsearch {
  display:flex; align-items:center; gap:9px;
  flex:1; max-width:420px;
  background:var(--surface-2); border:1.5px solid var(--borde);
  border-radius:var(--r-pill); padding:8px 14px;
  transition:border-color var(--fast), box-shadow var(--fast), background var(--fast);
}
.topsearch:focus-within { border-color:var(--azul); background:var(--surface); box-shadow:0 0 0 4px var(--azul-lt); }
.topsearch__ico { width:16px; height:16px; flex-shrink:0; color:var(--txt-3); }
.topsearch:focus-within .topsearch__ico { color:var(--azul); }
.topsearch__input {
  flex:1; border:none; background:transparent; outline:none;
  font-size:.84rem; font-weight:500; color:var(--txt-1); min-width:0;
}
.topsearch__input::placeholder { color:var(--txt-3); }
.topsearch__kbd {
  font-size:.62rem; font-weight:700; color:var(--txt-3);
  background:var(--surface); border:1px solid var(--borde-md);
  border-radius:5px; padding:2px 6px; flex-shrink:0; line-height:1;
}
.topsearch:focus-within .topsearch__kbd { display:none; }

/* (2) Resaltado de coincidencias ────────────────────────────── */
mark.hl {
  background:linear-gradient(transparent 55%, #FDE68A 55%);
  color:inherit; font-weight:800; border-radius:2px; padding:0 1px;
}
[data-theme="dark"] mark.hl { background:linear-gradient(transparent 55%, rgba(217,119,6,.55) 55%); color:#fff; }

/* (3) Barra de filtros dentro de la etapa ───────────────────── */
.filtros-bar {
  display:flex; align-items:center; gap:12px; flex-wrap:wrap;
  background:var(--surface); border:1px solid var(--borde);
  border-radius:var(--r-lg); padding:12px 16px; margin-bottom:14px;
  box-shadow:var(--s1);
}
.filtro-campo {
  display:flex; align-items:center; gap:8px;
  background:var(--surface-2); border:1.5px solid var(--borde);
  border-radius:var(--r-pill); padding:7px 14px; flex:1; min-width:220px;
  transition:border-color var(--fast), box-shadow var(--fast);
}
.filtro-campo:focus-within { border-color:var(--azul); box-shadow:0 0 0 3px var(--azul-lt); }
.filtro-campo svg { width:15px; height:15px; color:var(--txt-3); flex-shrink:0; }
.filtro-input { flex:1; border:none; background:transparent; outline:none; font-size:.83rem; color:var(--txt-1); min-width:0; }
.filtro-input::placeholder { color:var(--txt-3); }
.filtros-info { font-size:.74rem; font-weight:700; color:var(--txt-3); white-space:nowrap; }
.filtros-info b { color:var(--azul); }

/* (3b) Chips de responsable ──────────────────────────────────── */
.filtro-chips { display:flex; align-items:center; gap:7px; flex-wrap:wrap; width:100%; }
.chip-resp {
  display:inline-flex; align-items:center; gap:7px;
  padding:4px 11px 4px 4px; border-radius:var(--r-pill);
  background:var(--surface-2); border:1.5px solid var(--borde);
  color:var(--txt-2); font-size:.76rem; font-weight:600;
  transition:all var(--fast); cursor:pointer; white-space:nowrap;
}
.chip-resp:hover { border-color:var(--azul-md); color:var(--txt-1); }
.chip-resp.activo { background:var(--azul-lt); border-color:var(--azul); color:var(--azul); }
.chip-resp__cnt {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:18px; height:18px; padding:0 5px; border-radius:var(--r-pill);
  background:var(--surface); border:1px solid var(--borde);
  font-size:.66rem; font-weight:800; color:var(--txt-3);
}
.chip-resp.activo .chip-resp__cnt { background:var(--azul); color:#fff; border-color:var(--azul); }

/* (4) Avatar de responsable con color determinístico ────────── */
.resp-cell { display:flex; align-items:center; gap:9px; }
.avatar-resp {
  width:26px; height:26px; min-width:26px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:.66rem; font-weight:800; letter-spacing:.02em; color:#fff;
  background:hsl(var(--h,210) 48% 46%);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.18);
}
.chip-resp .avatar-resp { width:22px; height:22px; min-width:22px; font-size:.6rem; }

/* (5) Medidor de urgencia (barra térmica) ───────────────────── */
.heat {
  display:block; height:5px; width:88px; max-width:100%;
  margin-top:6px; border-radius:var(--r-pill);
  background:var(--surface-2); overflow:hidden;
}
.heat__fill {
  display:block; height:100%; border-radius:var(--r-pill);
  background:linear-gradient(90deg, var(--warn), var(--rojo));
}
.heat--max .heat__fill { background:repeating-linear-gradient(45deg, var(--rojo) 0 4px, var(--rojo-dk) 4px 8px); width:100% !important; }

/* (6) Botón copiar al portapapeles ──────────────────────────── */
.cliente-cell { display:flex; align-items:center; gap:6px; }
.btn-copy {
  width:22px; height:22px; border-radius:6px; flex-shrink:0;
  display:inline-flex; align-items:center; justify-content:center;
  background:transparent; border:1px solid transparent; color:var(--txt-3);
  opacity:0; transition:all var(--fast);
}
.btn-copy svg { width:13px; height:13px; }
.leads-list tbody tr:hover .btn-copy,
.buscar-resultado-fila:hover .btn-copy { opacity:1; }
.btn-copy:hover { background:var(--azul-lt); border-color:var(--azul-md); color:var(--azul); }
.btn-copy.copiado { opacity:1; background:var(--ok-bg); border-color:rgba(5,150,105,.3); color:var(--ok); }

/* (7) Encabezados ordenables ────────────────────────────────── */
.leads-list th.sortable { cursor:pointer; user-select:none; transition:color var(--fast); }
.leads-list th.sortable:hover { color:var(--azul); }
.leads-list th.sortable::after {
  content:'↕'; font-size:.85em; opacity:.35; margin-left:5px; font-weight:400;
}
.leads-list th.sort-asc::after  { content:'↑'; opacity:1; color:var(--azul); }
.leads-list th.sort-desc::after { content:'↓'; opacity:1; color:var(--azul); }

/* (8) Botón flotante "ir arriba" ────────────────────────────── */
.fab-top {
  position:fixed; right:24px; bottom:96px; z-index:280;
  width:46px; height:46px; border-radius:50%;
  background:var(--grad-corp); color:#fff; border:none;
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--s-corp);
  opacity:0; transform:translateY(14px) scale(.85); pointer-events:none;
  transition:opacity var(--mid), transform var(--mid), box-shadow var(--fast);
}
.fab-top svg { width:20px; height:20px; }
.fab-top.visible { opacity:1; transform:translateY(0) scale(1); pointer-events:auto; }
.fab-top:hover { box-shadow:var(--s-corp-hv); transform:translateY(-3px) scale(1.05); }

/* (9) Skeleton shimmer de carga ─────────────────────────────── */
.skel { position:relative; overflow:hidden; background:var(--surface-2); border-radius:6px; }
.skel::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.45), transparent);
  transform:translateX(-100%); animation:shimmer 1.3s infinite;
}
[data-theme="dark"] .skel::after { background:linear-gradient(90deg, transparent, rgba(255,255,255,.07), transparent); }
@keyframes shimmer { 100% { transform:translateX(100%); } }
.skel-line { height:12px; margin:6px 0; }
.skel-card { background:var(--surface); border:1.5px solid var(--borde); border-radius:var(--r-lg); padding:22px 18px; }
.skel-rows { background:var(--surface); border:1px solid var(--borde); border-radius:var(--r-lg); overflow:hidden; }
.skel-rows .skel-fila { display:flex; align-items:center; gap:16px; padding:14px 18px; border-bottom:1px solid var(--borde); }
.skel-rows .skel-fila:last-child { border-bottom:none; }

/* Responsive ─────────────────────────────────────────────────── */
@media (max-width:720px) {
  .topsearch { max-width:none; }
  .topsearch__kbd { display:none; }
}
@media (max-width:560px) {
  .topsearch { display:none; }
}

/* ═══════════════════════════════════════════════════════════════
   NAVBAR SUPERIOR (reemplaza el sidebar lateral)
   ═══════════════════════════════════════════════════════════════ */
.layout { flex-direction:column; }          /* apila navbar + contenido */

.navbar {
  position:sticky; top:0; z-index:200;
  background:var(--surface);
  border-bottom:1px solid var(--borde);
  box-shadow:var(--s1);
}
.navbar__inner {
  display:flex; align-items:center; gap:16px;
  height:56px; padding:0 24px;
}
.navbar__hamb {
  display:none; width:38px; height:38px; border-radius:var(--r-sm);
  background:var(--surface-2); border:1px solid var(--borde); color:var(--txt-2);
  align-items:center; justify-content:center; flex-shrink:0;
}
.navbar__hamb svg { width:18px; height:18px; }
.navbar__brand { display:flex; align-items:center; flex-shrink:0; }
.navbar__logo { height:34px; width:auto; filter:var(--logo-filter); }

.navbar__nav {
  display:flex; align-items:center; gap:2px;
  flex:1; min-width:0; overflow-x:auto;
  scrollbar-width:none;
}
.navbar__nav::-webkit-scrollbar { display:none; }

.nav-link {
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 13px; border-radius:var(--r-sm);
  color:var(--txt-2); font-size:.83rem; font-weight:600;
  text-decoration:none; white-space:nowrap;
  transition:background var(--fast), color var(--fast);
}
.nav-link:hover { background:var(--surface-2); color:var(--txt-1); }
.nav-link--activo { background:var(--azul-lt); color:var(--azul); }
.nav-link .snav__ico { width:17px; height:17px; flex-shrink:0; }
.nav-link--activo .snav__ico { color:var(--azul); }

.navbar__sep { width:1px; height:24px; background:var(--borde); margin:0 6px; flex-shrink:0; }

/* Divisor uniforme entre TODOS los módulos del navbar (línea vertical entre ítems) */
.navbar__nav > .nav-link,
.navbar__nav > .nav-drop { position:relative; }
.navbar__nav > .nav-link + .nav-link::before,
.navbar__nav > .nav-link + .nav-drop::before,
.navbar__nav > .nav-drop + .nav-link::before,
.navbar__nav > .nav-drop + .nav-drop::before {
  content:""; position:absolute; left:-1px; top:50%;
  transform:translateY(-50%);
  width:1px; height:22px; background:var(--borde);
  pointer-events:none;
}

.navbar__der { display:flex; align-items:center; gap:10px; flex-shrink:0; margin-left:auto; }

.btn-tema-nav {
  width:36px; height:36px; border-radius:var(--r-sm);
  background:var(--surface-2); border:1px solid var(--borde); color:var(--txt-2);
  display:flex; align-items:center; justify-content:center;
  transition:background var(--fast), transform var(--fast);
}
.btn-tema-nav:hover { background:var(--borde); transform:scale(1.05); }
.btn-tema-nav--activo { background:var(--azul-lt); border-color:var(--azul-md); color:var(--azul); }
.btn-tema-nav .snav__ico { width:18px; height:18px; }
.btn-tema-nav .tema-luna { display:none; }
[data-theme="dark"] .btn-tema-nav .tema-sol  { display:none; }
[data-theme="dark"] .btn-tema-nav .tema-luna { display:inline-flex; }

/* Menú de usuario (chip + dropdown) en la navbar */
.user-chevron { width:14px; height:14px; color:var(--txt-3); flex-shrink:0; transition:transform var(--fast); }
.user-chip[aria-expanded="true"] .user-chevron { transform:rotate(180deg); }
.user-drop__nombre { font-size:.84rem; font-weight:700; color:var(--txt-1); }
.user-drop__item .snav__ico { width:16px; height:16px; }

/* La topbar (título + búsqueda) queda como subcabecera bajo la navbar */
.topbar { top:56px; }
.topbar__hamb { display:none !important; }   /* el menú móvil lo maneja la navbar */

/* ═══════════════════════════════════════════════════════════════
   Buscar (resultados reales de Bitrix24) + Historial dinámico
   ═══════════════════════════════════════════════════════════════ */
.buscar-cab {
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:10px 18px; font-size:.74rem; font-weight:700; color:var(--txt-3);
  text-transform:uppercase; letter-spacing:.05em; border-bottom:1px solid var(--borde);
}
.dir-sello {
  display:inline-flex; align-items:center; gap:5px;
  font-family:'Plus Jakarta Sans',-apple-system,sans-serif;
  text-transform:none; letter-spacing:0; font-weight:700;
  padding:2px 9px; border-radius:var(--r-pill);
  background:var(--surface-2); border:1px solid var(--borde); color:var(--txt-2);
}
.dir-sello svg { width:13px; height:13px; flex-shrink:0; }
.dir-sello--vivo { background:var(--ok-bg); border-color:rgba(5,150,105,.25); color:var(--ok); }
.buscar-etapa {
  font-size:.71rem; font-weight:700; color:var(--azul);
  background:var(--azul-lt); border:1px solid var(--azul-md);
  border-radius:var(--r-pill); padding:3px 10px; white-space:nowrap;
  max-width:180px; overflow:hidden; text-overflow:ellipsis;
}
.buscar-resultado-fila .resp-cell { min-width:0; max-width:200px; }
.buscar-resultado-fila .deal-persona { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

.hist-hd {
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:16px; flex-wrap:wrap; margin-bottom:16px;
}
.btn-refrescar {
  display:inline-flex; align-items:center; gap:7px;
  padding:8px 16px; border-radius:var(--r-pill);
  background:var(--surface-2); border:1px solid var(--borde-md);
  color:var(--txt-2); font-size:.79rem; font-weight:600;
  transition:all var(--fast);
}
.btn-refrescar:hover { background:var(--azul-lt); border-color:var(--azul-md); color:var(--azul); }
.btn-refrescar svg { width:15px; height:15px; }

.hist-toolbar {
  display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:14px;
}
.hist-tabla .deal-nombre { margin-left:6px; }

/* Gráficos del Dashboard (SVG, sin librerías) */
.dash-graficos {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
  gap:14px; margin-bottom:8px;
}
.grafico-card {
  background:var(--surface); border:1px solid var(--borde);
  border-radius:var(--r-lg); box-shadow:var(--s1); padding:14px 16px;
  display:flex; flex-direction:column;
}
.grafico-card__tit {
  display:flex; align-items:center; gap:8px;
  font-size:.82rem; font-weight:700; color:var(--txt-1); margin-bottom:12px;
}
.grafico-card__tit svg { color:var(--azul); }
.grafico-card__body { flex:1; display:flex; align-items:center; justify-content:center; min-height:200px; width:100%; min-width:0; }

/* Barras horizontales — el SVG se acota para no agrandarse en pantallas anchas */
.g-svg { width:100%; max-width:420px; height:auto; display:block; margin:0 auto; }
.g-lbl   { font-size:11.5px; font-weight:600; fill:var(--txt-2); }
.g-val   { font-size:11.5px; font-weight:800; fill:var(--azul); }
.g-track { fill:var(--surface-2); }
.g-donut-num { font-size:22px; font-weight:800; fill:var(--txt-1); letter-spacing:-.5px; }
.g-donut-lbl { font-size:8.5px; font-weight:700; fill:var(--txt-3); text-transform:uppercase; letter-spacing:.5px; }
[data-theme="dark"] .g-val { fill:#4BA3D3; }

/* Donut + leyenda — anillo de tamaño fijo y leyenda acotada */
.g-torta-wrap { display:flex; align-items:center; gap:20px; flex-wrap:wrap; width:100%; justify-content:center; }
.g-pie { width:150px; height:150px; flex:0 0 auto; }
.g-pie path { transition:opacity var(--fast); }
.g-pie path:hover { opacity:.82; }
.g-legend { display:flex; flex-direction:column; gap:7px; min-width:140px; max-width:220px; flex:0 1 auto; }
.g-leg { display:flex; align-items:center; gap:8px; font-size:.78rem; color:var(--txt-2); }
.g-leg__lbl { flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.g-leg b { color:var(--txt-1); font-variant-numeric:tabular-nums; margin-left:auto; }
.g-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }

/* Top responsables (Dashboard) */
.topresp-fila {
  display:flex; align-items:center; gap:12px;
  padding:9px 6px; border-bottom:1px solid var(--borde);
}
.topresp-fila:last-child { border-bottom:none; }
.topresp-pos {
  width:20px; text-align:center; flex-shrink:0;
  font-size:.78rem; font-weight:800; color:var(--txt-3);
}
.topresp-nombre {
  flex:1; min-width:0; font-size:.84rem; font-weight:600; color:var(--txt-1);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.topresp-bar {
  width:34%; min-width:80px; height:8px; flex-shrink:0;
  background:var(--surface-2); border-radius:var(--r-pill); overflow:hidden;
}
.topresp-bar__fill { display:block; height:100%; border-radius:var(--r-pill); background:var(--grad-corp); }
.topresp-cnt {
  min-width:36px; text-align:right; flex-shrink:0;
  font-size:.9rem; font-weight:800; color:var(--azul); letter-spacing:-.02em;
}
@media (max-width:560px) { .topresp-bar { display:none; } }

/* Módulo Seguimiento (tareas vencidas + clientes sin tarea reciente) */
.buscar-campo .btn-refrescar { padding:7px 9px; flex-shrink:0; }

/* Paleta de severidad (criterio jurídico) */
:root {
  --sev-critico:#B91C1C; --sev-critico-bg:#FEE2E2;
  --sev-alto:#EA580C;    --sev-alto-bg:#FFEDD5;
  --sev-medio:#CA8A04;   --sev-medio-bg:#FEF9C3;
}
[data-theme="dark"] {
  --sev-critico-bg:rgba(185,28,28,.20); --sev-alto-bg:rgba(234,88,12,.18); --sev-medio-bg:rgba(202,138,4,.18);
}

/* KPIs (cuadro de totales / información activa) */
.seg-kpis { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:12px; margin-bottom:14px; }
.seg-kpi {
  display:flex; align-items:center; gap:13px;
  background:var(--surface); border:1px solid var(--borde); border-left:3px solid var(--azul);
  border-radius:var(--r-md); padding:14px 16px; box-shadow:var(--s1);
}
.seg-kpi--rojo { border-left-color:var(--rojo); }
.seg-kpi--warn { border-left-color:var(--warn); }
.seg-kpi--mal  { border-left-color:var(--rojo); }
.seg-kpi--medio{ border-left-color:var(--warn); }
.seg-kpi--bien { border-left-color:var(--ok); }
.seg-kpi__ico { width:40px; height:40px; border-radius:11px; flex-shrink:0; display:grid; place-items:center; background:var(--azul-lt); color:var(--azul); }
.seg-kpi__ico svg { width:20px; height:20px; }
.seg-kpi__ico--rojo { background:var(--dan-bg); color:var(--rojo); }
.seg-kpi__ico--warn { background:var(--warn-bg); color:var(--warn); }
.seg-kpi__num { font-size:1.7rem; font-weight:800; color:var(--txt-1); letter-spacing:-.03em; line-height:1; }
.seg-kpi--rojo .seg-kpi__num { color:var(--rojo); }
.seg-kpi--warn .seg-kpi__num { color:var(--warn); }
.seg-kpi__lbl { font-size:.72rem; font-weight:700; color:var(--txt-3); margin-top:5px; text-transform:uppercase; letter-spacing:.03em; }
.seg-kpi__sub { font-size:.68rem; color:var(--txt-3); margin-top:2px; }
/* Anillo de % (conic-gradient) */
.seg-anillo {
  --c:var(--cian); position:relative; width:48px; height:48px; flex-shrink:0; border-radius:50%;
  background:conic-gradient(var(--c) calc(var(--pct,0)*1%), var(--surface-2) 0);
  display:grid; place-items:center;
}
.seg-anillo::before { content:''; position:absolute; width:34px; height:34px; border-radius:50%; background:var(--surface); }
.seg-anillo span { position:relative; font-size:.72rem; font-weight:800; color:var(--txt-1); }
.seg-anillo--mal { --c:var(--rojo); } .seg-anillo--medio { --c:var(--warn); } .seg-anillo--bien { --c:var(--ok); }

/* Triaje por severidad */
.seg-triaje { background:var(--surface); border:1px solid var(--borde); border-radius:var(--r-md); padding:12px 14px; margin-bottom:14px; box-shadow:var(--s1); }
.seg-triaje__bar { display:flex; height:10px; border-radius:var(--r-pill); overflow:hidden; background:var(--surface-2); margin-bottom:11px; }
.sev-fill { display:block; height:100%; }
.sev-fill.sev-critico { background:var(--sev-critico); }
.sev-fill.sev-alto { background:var(--sev-alto); }
.sev-fill.sev-medio { background:var(--sev-medio); }
.seg-chips { display:flex; flex-wrap:wrap; gap:8px; }
.sev-chip {
  display:inline-flex; align-items:center; gap:7px; padding:5px 12px; border-radius:var(--r-pill);
  background:var(--surface-2); border:1.5px solid var(--borde); color:var(--txt-2);
  font-size:.76rem; font-weight:700; cursor:pointer; transition:all var(--fast);
}
.sev-chip:hover { border-color:var(--borde-md); }
.sev-chip.activo { color:#fff; }
.sev-chip--all.activo { background:var(--azul); border-color:var(--azul); }
.sev-chip--critico.activo { background:var(--sev-critico); border-color:var(--sev-critico); }
.sev-chip--alto.activo { background:var(--sev-alto); border-color:var(--sev-alto); }
.sev-chip--medio.activo { background:var(--sev-medio); border-color:var(--sev-medio); }
.sev-chip--critico b { color:var(--sev-critico); } .sev-chip--critico.activo b { color:#fff; }
.sev-chip--alto b { color:var(--sev-alto); } .sev-chip--alto.activo b { color:#fff; }
.sev-chip--medio b { color:var(--sev-medio); } .sev-chip--medio.activo b { color:#fff; }

/* Badges / heat / dots de severidad en filas */
.sev-badge { display:inline-flex; align-items:center; padding:2px 9px; border-radius:var(--r-pill); font-size:.68rem; font-weight:800; }
.sev-badge.sev-critico { background:var(--sev-critico-bg); color:var(--sev-critico); }
.sev-badge.sev-alto { background:var(--sev-alto-bg); color:var(--sev-alto); }
.sev-badge.sev-medio { background:var(--sev-medio-bg); color:var(--sev-medio); }
.seg-venc-cell { display:flex; align-items:center; gap:8px; white-space:nowrap; }
.seg-heat { width:54px; height:6px; border-radius:var(--r-pill); background:var(--surface-2); overflow:hidden; flex-shrink:0; }
.seg-heat span { display:block; height:100%; border-radius:var(--r-pill); }
.seg-heat.sev-critico span { background:var(--sev-critico); }
.seg-heat.sev-alto span { background:var(--sev-alto); }
.seg-heat.sev-medio span { background:var(--sev-medio); }
.seg-dias { font-size:.74rem; font-weight:800; color:var(--txt-2); font-variant-numeric:tabular-nums; min-width:36px; }
.seg-asunto { font-size:.8rem; color:var(--txt-2); max-width:220px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.seg-tabla th:last-child { width:170px; }

/* Mini-barra y dots de severidad en cabecera de responsable */
.sev-mini { display:flex; width:80px; height:7px; border-radius:var(--r-pill); overflow:hidden; background:var(--surface-2); margin-left:auto; flex-shrink:0; }
.sev-mini__seg.sev-critico { background:var(--sev-critico); }
.sev-mini__seg.sev-alto { background:var(--sev-alto); }
.sev-mini__seg.sev-medio { background:var(--sev-medio); }
.sev-dots { display:flex; gap:5px; flex-shrink:0; }
.sev-dot { display:inline-flex; align-items:center; justify-content:center; min-width:22px; height:20px; padding:0 6px; border-radius:var(--r-pill); font-size:.7rem; font-weight:800; color:#fff; }
.sev-dot.sev-critico { background:var(--sev-critico); }
.sev-dot.sev-alto { background:var(--sev-alto); }
.sev-dot.sev-medio { background:var(--sev-medio); }

/* Selector de mes */
.seg-mes { display:flex; align-items:center; gap:10px; margin-bottom:14px; flex-wrap:wrap; }
.seg-mes label { font-size:.78rem; font-weight:700; color:var(--txt-2); }
.seg-mes__sel { width:auto; min-width:200px; padding:8px 12px; }
.seg-mes .dir-sello { margin-left:auto; }

/* Macro-acordeones anidados */
.seg-macros { display:flex; flex-direction:column; gap:12px; }
.acordeon--macro { border:1.5px solid var(--borde-md); border-radius:var(--r-lg); overflow:hidden; }
.acordeon--macro > .acordeon-hd-row > .acordeon-hd { padding:14px 18px; font-size:.9rem; }
.acordeon--macro > .acordeon-hd-row > .acordeon-hd svg:not(.acordeon-chevron) { width:17px; height:17px; }
.acordeon--macro-rojo > .acordeon-hd-row { background:var(--dan-bg); }
.acordeon--macro-rojo .acordeon-tipo { color:var(--rojo); }
.acordeon--macro-warn > .acordeon-hd-row { background:var(--warn-bg); }
.acordeon--macro-warn .acordeon-tipo { color:var(--warn); }
.acordeon--macro > .acordeon-body { background:var(--surface-2); padding:10px; }
.acordeon--macro .acordeon { background:var(--surface); border:1px solid var(--borde); border-radius:var(--r-md); margin-bottom:8px; overflow:hidden; }
.acordeon--macro .acordeon:last-child { margin-bottom:0; }
.acordeon--macro .acordeon-body { background:var(--surface); }
.acordeon--macro .acordeon-hd { gap:10px; }
.seg-sub {
  display:flex; align-items:center; gap:7px;
  padding:10px 16px 8px; font-size:.74rem; font-weight:800;
  text-transform:uppercase; letter-spacing:.05em;
}
.seg-sub svg { width:15px; height:15px; }
.seg-sub--venc { color:var(--rojo); }
.seg-sub--sin  { color:var(--warn); }
.seg-fecha { font-size:.8rem; color:var(--txt-2); white-space:nowrap; font-variant-numeric:tabular-nums; }
.seg-pill {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:20px; height:18px; padding:0 6px; border-radius:var(--r-pill);
  font-size:.72rem; font-weight:800; color:#fff; vertical-align:middle;
}
.seg-pill--venc { background:var(--rojo); }
.seg-pill--sin  { background:var(--warn); }
#buscarResultados .seg-sub + .leads-list { margin-bottom:6px; }
.acordeon-cnt--neutral { background:var(--azul-lt); color:var(--azul); }
.dir-cargando {
  display:inline-flex; align-items:center; gap:6px; margin-left:10px;
  font-weight:600; color:var(--txt-3); text-transform:none; letter-spacing:0;
}
#buscarResultados .acordeon { border:none; border-bottom:1px solid var(--borde); border-radius:0; margin-bottom:0; }
#buscarResultados .acordeon:last-child { border-bottom:none; }
#buscarResultados .acordeon-hd .avatar-resp { margin-right:2px; }
.td-neg-id { width:96px; }
.td-neg-copy { width:42px; text-align:right; }
#buscarResultados .leads-list td { padding:9px 14px; }

/* ─── Navbar responsive: menú colapsable ─── */
@media (max-width:880px) {
  .navbar__hamb { display:flex; }
  .navbar__nav {
    position:absolute; top:56px; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:3px;
    background:var(--surface); border-bottom:1px solid var(--borde);
    box-shadow:var(--s3); padding:12px; overflow:visible;
    transform:translateY(-14px); opacity:0; pointer-events:none;
    transition:transform .2s var(--ease), opacity .2s var(--ease);
    max-height:calc(100vh - 56px); overflow-y:auto;
  }
  .navbar--abierto .navbar__nav { transform:translateY(0); opacity:1; pointer-events:auto; }
  .nav-link { padding:11px 14px; }
  .navbar__sep { display:none; }
  /* En el menú vertical (móvil) no se muestran los divisores verticales */
  .navbar__nav > .nav-link::before, .navbar__nav > .nav-drop::before { display:none; }
}

/* ═══════════════════════════════════════════════════════════════
   Navbar · menú desplegable (dropdown) — componente nuevo y aditivo.
   No altera el estilo de los ítems existentes del navbar.
   ═══════════════════════════════════════════════════════════════ */
.nav-drop { position:relative; display:inline-flex; flex-shrink:0; }
.nav-drop__btn { cursor:pointer; background:transparent; border:none; }
.nav-drop__chevron { width:14px; height:14px; margin-left:-2px; transition:transform var(--fast); }
.nav-drop.abierto .nav-drop__chevron { transform:rotate(180deg); }

/* position:fixed → el menú escapa del recorte de overflow del .navbar__nav.
   Sus coordenadas (left/top) las fija el JS al abrir, ancladas al botón. */
.nav-drop__menu {
  position:fixed; z-index:300;
  min-width:236px; padding:6px;
  background:var(--surface); border:1px solid var(--borde);
  border-radius:var(--r-md); box-shadow:var(--s3);
  display:none; flex-direction:column; gap:2px;
}
.nav-drop.abierto .nav-drop__menu { display:flex; }

.nav-drop__item {
  display:flex; align-items:center; gap:10px;
  padding:9px 11px; border-radius:var(--r-sm);
  color:var(--txt-2); font-size:.82rem; font-weight:600;
  text-decoration:none; white-space:nowrap;
  transition:background var(--fast), color var(--fast);
}
.nav-drop__item:hover { background:var(--surface-2); color:var(--txt-1); }
.nav-drop__item--activo { background:var(--azul-lt); color:var(--azul); }
.nav-drop__item .snav__ico { width:17px; height:17px; flex-shrink:0; }
.nav-drop__item--activo .snav__ico { color:var(--azul); }

/* En el menú móvil el dropdown se muestra en línea (no flotante). */
@media (max-width:880px) {
  .nav-drop { display:block; width:100%; }
  .nav-drop__btn { width:100%; justify-content:flex-start; }
  .nav-drop__menu {
    position:static; top:auto; left:auto;
    box-shadow:none; border:none; min-width:0;
    padding:2px 0 2px 30px; background:transparent;
  }
  .nav-drop__chevron { margin-left:auto; }
}
