/* ═══════════════════════════════════════
   Variables — Paleta Avanzar Soluciones
   ═══════════════════════════════════════ */
:root {
  --azul:      #1A3A6B;
  --azul-dk:   #0F2347;
  --azul-lt:   #EBF0FA;
  --azul-md:   #C5D3F0;
  --rojo:      #D61C2E;
  --rojo-lt:   #FEECEE;
  --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;

  --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; }

/* ═══════════════════════════════════════
   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:9px 20px; border-radius:var(--r-pill);
  background:var(--rojo); border:none; color:#fff;
  font-size:.82rem; font-weight:700;
  box-shadow:0 2px 12px rgba(214,28,46,.4);
  transition:background var(--fast), box-shadow var(--fast), transform var(--fast);
  white-space:nowrap;
}
.btn-autorizar:hover  { background:#b8172a; box-shadow:0 4px 16px rgba(214,28,46,.5); transform:translateY(-1px); }
.btn-autorizar:active { transform:translateY(0); }

.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);
}

.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:8px 20px; border-radius:var(--r-pill);
  background:var(--rojo); border:none; color:#fff;
  font-size:.82rem; font-weight:700;
  transition:background var(--fast), transform var(--fast);
}
.btn-prim:hover  { background:#b8172a; transform:translateY(-1px); }
.btn-prim:active { transform:translateY(0); }

/* ═══════════════════════════════════════
   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 {
  text-align:center; padding:24px;
  font-size:.71rem; color:var(--txt-3);
  border-top:1px solid var(--borde); margin-top:40px;
}

/* ═══════════════════════════════════════
   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; }
  .guia-hero { flex-direction:column; text-align:center; padding:20px; gap:14px; }
  .guia-section { padding:18px 16px; }
  .guia-limites { grid-template-columns:1fr; }
}
