/* ── Badges de Nivel ──────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--text-xs);
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 99px;
  letter-spacing: .03em;
  white-space: nowrap;
  line-height: 1.4;
}
.badge-inicio    { background: var(--slate-100); color: var(--slate-600); }
.badge-activo    { background: var(--blue-100);  color: var(--blue-800); }
.badge-preferente{ background: var(--teal-100);  color: var(--teal-700); }
.badge-elite     { background: var(--indigo-100);color: var(--indigo-600); }
.badge-embajador {
  background: linear-gradient(135deg, var(--gold-100), #fef9ee);
  color: var(--gold-600);
  border: 1px solid var(--gold-300);
}
.badge-registrado { background: var(--slate-100); color: var(--slate-600); }
.badge-contactado { background: var(--blue-50); color: var(--blue-700); }
.badge-agendado   { background: var(--gold-100); color: var(--gold-600); }
.badge-asistio    { background: var(--green-100); color: var(--green-600); }
.badge-no-asistio,
.badge-cancelado  { background: var(--rose-100); color: var(--rose-600); }

/* Tipo de paciente */
.tipo-badge {
  display: inline-block;
  font-size: .69rem;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 99px;
  letter-spacing: .02em;
}
.tipo-badge.particular   { background: var(--blue-100);  color: var(--blue-800); }
.tipo-badge.prepagada    { background: var(--teal-100);  color: var(--teal-700); }
.tipo-badge.poliza       { background: var(--indigo-100);color: var(--indigo-600); }
.tipo-badge.eps          { background: var(--slate-100); color: var(--slate-600); }
.tipo-badge.tipo-particular { background: var(--blue-100); color: var(--blue-800); }
.tipo-badge.tipo-prepagada  { background: var(--teal-100); color: var(--teal-700); }
.tipo-badge.tipo-poliza     { background: var(--indigo-100); color: var(--indigo-600); }
.tipo-badge.tipo-eps        { background: var(--slate-100); color: var(--slate-600); }
.tipo-badge.tipo-otro       { background: var(--slate-100); color: var(--slate-600); }

/* Estado referido / remisión */
.estado-badge {
  display: inline-flex;
  align-items: center;
  font-size: var(--text-xs);
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 99px;
  line-height: 1.4;
  white-space: nowrap;
}
.estado-registrado   { background: var(--slate-100); color: var(--slate-700); }
.estado-contactado   { background: var(--blue-100);  color: var(--blue-800); }
.estado-agendado     { background: var(--amber-100); color: var(--amber-600); }
.estado-asistio      { background: var(--green-100); color: var(--green-600); }
.estado-noasistio    { background: var(--rose-100);  color: var(--rose-600); }
.estado-cancelado    { background: var(--slate-100); color: var(--slate-500); }
.estado-novalida     { background: #fff1f2;           color: #9f1239; }
.estado-reprogramada { background: #eff6ff;           color: #1d4ed8; }
.badge-no-valida     { background: #fff1f2;           color: #9f1239; }
.badge-vencido       { background: #fff7ed;           color: #c2410c; }
.badge-pendiente-medico { background: #f0f9ff;        color: #0369a1; }

/* Pts badge */
.pts-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: .72rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 99px;
}
.pts-badge:not(.pts-badge-zero) {
  background: var(--gold-100);
  color: var(--gold-600);
}
.pts-badge-zero { background: var(--slate-100); color: var(--slate-500); }

/* ── Toolbar / Search ─────────────────────────────────────── */
.toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.search-box {
  display: flex;
  align-items: center;
  background: var(--white);
  border: 1.5px solid var(--slate-200);
  border-radius: var(--radius);
  padding: 6px 12px;
  gap: 7px;
  flex: 1;
  min-width: 200px;
  transition: border-color var(--transition);
}
.search-box:focus-within { border-color: var(--blue-400); }
.search-box input {
  border: none;
  outline: none;
  font-size: .85rem;
  background: transparent;
  color: var(--slate-800);
  width: 100%;
}
.search-box input::placeholder { color: var(--slate-400); }
.search-box span { color: var(--slate-400); font-size: .9rem; }

.filter-group {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.filter-group select {
  padding: 7px 10px;
  border: 1.5px solid var(--slate-200);
  border-radius: var(--radius);
  font-size: .82rem;
  background: var(--white);
  color: var(--slate-700);
  outline: none;
  cursor: pointer;
  transition: border-color var(--transition);
}
.filter-group select:focus { border-color: var(--blue-400); }

/* ── Data Table ───────────────────────────────────────────── */
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-base);
}
.data-table th {
  padding: 10px 14px;
  text-align: left;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--cead-medium);
  background: linear-gradient(to bottom, #f8fafc, var(--slate-50));
  border-bottom: 2px solid var(--slate-200);
  white-space: nowrap;
}
.data-table td {
  padding: 11px 14px;
  border-bottom: 1px solid var(--slate-100);
  color: var(--slate-700);
  vertical-align: middle;
}
.data-table tbody tr { transition: background var(--transition); }
.data-table tbody tr:hover { background: var(--blue-50); }
.data-table tbody tr:last-child td { border-bottom: none; }

.pac-link {
  background: none;
  border: none;
  color: var(--blue-600);
  font-weight: 600;
  font-size: .84rem;
  cursor: pointer;
  padding: 0;
  text-align: left;
  font-family: var(--font-body);
}
.pac-link:hover { text-decoration: underline; }

/* Mini progress en tabla */
.mini-progress-wrap { display: flex; align-items: center; gap: 7px; min-width: 100px; }
.mini-progress-track {
  flex: 1;
  height: 5px;
  background: var(--slate-100);
  border-radius: 99px;
  overflow: hidden;
}
.mini-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--blue-600), var(--teal-500));
  border-radius: 99px;
  transition: width .4s ease;
}
.mini-progress-pct {
  font-size: .7rem;
  font-weight: 600;
  color: var(--slate-500);
  min-width: 28px;
  text-align: right;
}

