/* ============================================================================
   Júbilo — Capa de componentes (reskin 2026)
   ----------------------------------------------------------------------------
   Reimplementa los componentes que el puente de tokens (jubilo-tokens.css) no
   logra solo recoloreando Bootstrap. Nombres tomados de design-system.html
   (verificado: ninguno colisiona con base.css). Las primitivas base
   (.btn .card .alert .form-control .table) se dejan a Bootstrap recoloreado;
   acá solo van los componentes net-new.

   Se carga DESPUÉS de jubilo-tokens.css. Se llena por fases (catálogo en el lab).
   Índice:
     A.0 Neutralizar tema legacy de base.css (variables de componente Bootstrap)
     A.1 Primitivas net-new — badge soft, role-badge, estado-badge, avatar,
         empty-state, kpi-card, table-wrap/toolbar, section-nav
   ========================================================================== */

/* ============================================================
   A.0 — NEUTRALIZAR TEMA LEGACY de base.css
   base.css scopea las variables de componente de Bootstrap con el
   tema viejo (.btn-primary{--bs-btn-bg:#010d27}, .text-bg-* con RGBA
   hardcodeado + !important). El puente de --bs-primary global no llega
   a esas vars locales. Acá las re-apuntamos a los tokens Júbilo.
   Carga última + misma especificidad → gana. (Los text-bg llevan
   !important porque base.css lo usa.)
   ============================================================ */

/* — Botones sólidos — */
.btn-primary {
  --bs-btn-bg: var(--brand-primary); --bs-btn-border-color: var(--brand-primary);
  --bs-btn-hover-bg: var(--brand-primary-hover); --bs-btn-hover-border-color: var(--brand-primary-hover);
  --bs-btn-active-bg: var(--brand-primary-hover); --bs-btn-active-border-color: var(--brand-primary-hover);
  --bs-btn-disabled-bg: var(--brand-primary); --bs-btn-disabled-border-color: var(--brand-primary);
  --bs-btn-color:#fff; --bs-btn-hover-color:#fff; --bs-btn-active-color:#fff; --bs-btn-disabled-color:#fff;
}
.btn-secondary {
  --bs-btn-bg: var(--brand-secondary); --bs-btn-border-color: var(--brand-secondary);
  --bs-btn-hover-bg: var(--brand-secondary-hover); --bs-btn-hover-border-color: var(--brand-secondary-hover);
  --bs-btn-active-bg: var(--brand-secondary-hover); --bs-btn-active-border-color: var(--brand-secondary-hover);
  --bs-btn-disabled-bg: var(--brand-secondary); --bs-btn-disabled-border-color: var(--brand-secondary);
  --bs-btn-color:#fff; --bs-btn-hover-color:#fff; --bs-btn-active-color:#fff; --bs-btn-disabled-color:#fff;
}
.btn-success {
  --bs-btn-bg: var(--status-success); --bs-btn-border-color: var(--status-success);
  --bs-btn-hover-bg: var(--status-success-dark); --bs-btn-hover-border-color: var(--status-success-dark);
  --bs-btn-active-bg: var(--status-success-dark); --bs-btn-active-border-color: var(--status-success-dark);
  --bs-btn-disabled-bg: var(--status-success); --bs-btn-disabled-border-color: var(--status-success);
  --bs-btn-color:#fff; --bs-btn-hover-color:#fff; --bs-btn-active-color:#fff; --bs-btn-disabled-color:#fff;
}
.btn-danger {
  --bs-btn-bg: var(--status-danger); --bs-btn-border-color: var(--status-danger);
  --bs-btn-hover-bg: var(--status-danger-dark); --bs-btn-hover-border-color: var(--status-danger-dark);
  --bs-btn-active-bg: var(--status-danger-dark); --bs-btn-active-border-color: var(--status-danger-dark);
  --bs-btn-disabled-bg: var(--status-danger); --bs-btn-disabled-border-color: var(--status-danger);
  --bs-btn-color:#fff; --bs-btn-hover-color:#fff; --bs-btn-active-color:#fff; --bs-btn-disabled-color:#fff;
}
.btn-warning {
  --bs-btn-bg: var(--status-warning); --bs-btn-border-color: var(--status-warning);
  --bs-btn-hover-bg: var(--status-warning-hover); --bs-btn-hover-border-color: var(--status-warning-hover);
  --bs-btn-active-bg: var(--status-warning-hover); --bs-btn-active-border-color: var(--status-warning-hover);
  --bs-btn-disabled-bg: var(--status-warning); --bs-btn-disabled-border-color: var(--status-warning);
  --bs-btn-color:#fff; --bs-btn-hover-color:#fff; --bs-btn-active-color:#fff; --bs-btn-disabled-color:#fff;
}
.btn-info {
  --bs-btn-bg: var(--status-info); --bs-btn-border-color: var(--status-info);
  --bs-btn-hover-bg: var(--brand-accent-hover); --bs-btn-hover-border-color: var(--brand-accent-hover);
  --bs-btn-active-bg: var(--brand-accent-hover); --bs-btn-active-border-color: var(--brand-accent-hover);
  --bs-btn-disabled-bg: var(--status-info); --bs-btn-disabled-border-color: var(--status-info);
  --bs-btn-color:#fff; --bs-btn-hover-color:#fff; --bs-btn-active-color:#fff; --bs-btn-disabled-color:#fff;
}

/* — Botones outline — */
.btn-outline-primary {
  --bs-btn-color: var(--brand-primary); --bs-btn-border-color: var(--brand-primary);
  --bs-btn-hover-bg: var(--brand-primary); --bs-btn-hover-border-color: var(--brand-primary);
  --bs-btn-active-bg: var(--brand-primary); --bs-btn-active-border-color: var(--brand-primary);
  --bs-btn-hover-color:#fff; --bs-btn-active-color:#fff;
}
.btn-outline-secondary {
  --bs-btn-color: var(--text-secondary); --bs-btn-border-color: var(--border-default);
  --bs-btn-hover-bg: var(--surface-hover); --bs-btn-hover-border-color: var(--border-strong);
  --bs-btn-hover-color: var(--brand-primary); --bs-btn-active-bg: var(--surface-hover);
  --bs-btn-active-color: var(--brand-primary); --bs-btn-active-border-color: var(--border-strong);
}
.btn-outline-danger {
  --bs-btn-color: var(--status-danger); --bs-btn-border-color: var(--status-danger);
  --bs-btn-hover-bg: var(--status-danger); --bs-btn-hover-border-color: var(--status-danger);
  --bs-btn-active-bg: var(--status-danger); --bs-btn-active-border-color: var(--status-danger);
  --bs-btn-hover-color:#fff; --bs-btn-active-color:#fff;
}

/* — Badges sólidos de Bootstrap (text-bg-*) — base.css usa !important — */
.text-bg-primary   { background-color: var(--brand-primary) !important; color:#fff !important; }
.text-bg-secondary { background-color: var(--brand-secondary) !important; color:#fff !important; }
.text-bg-success   { background-color: var(--status-success) !important; color:#fff !important; }
.text-bg-danger    { background-color: var(--status-danger) !important; color:#fff !important; }
.text-bg-warning   { background-color: var(--status-warning) !important; color:#fff !important; }
.text-bg-info      { background-color: var(--status-info) !important; color:#fff !important; }

/* ============================================================
   BADGE soft (con dot) — firma visual del design system.
   Se llama jb-badge para no chocar con el .badge de Bootstrap.
   ============================================================ */
.jb-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: var(--font-size-xs); font-weight: var(--font-weight-bold);
  padding: 3px 9px; border-radius: var(--radius-full); line-height: 1.4;
  white-space: nowrap;
}
.jb-badge::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: currentColor; opacity: .9; }
.jb-badge--success   { background: var(--status-success-soft); color: var(--status-success); }
.jb-badge--danger    { background: var(--status-danger-soft);  color: var(--status-danger); }
.jb-badge--primary   { background: var(--brand-primary-soft);  color: var(--brand-primary); }
.jb-badge--warning   { background: var(--status-warning-soft); color: var(--status-warning); }
.jb-badge--secondary { background: var(--palette-neu-100);     color: var(--text-secondary); }
.jb-badge--info      { background: var(--brand-primary-soft);  color: var(--brand-primary-hover); }

/* ============================================================
   ESTADO de paciente — A(ctivo) / I(nactivo) / S(uspendido) / E(gresado)
   ============================================================ */
.estado-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: var(--font-size-xs); font-weight: var(--font-weight-bold);
  padding: 3px 9px; border-radius: var(--radius-full); line-height: 1.4; white-space: nowrap;
}
.estado-badge::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.estado-badge--A { background: var(--status-success-soft); color: var(--status-success); }
.estado-badge--I { background: var(--palette-neu-100);     color: var(--text-secondary); }
.estado-badge--S { background: var(--status-warning-soft); color: var(--status-warning); }
.estado-badge--E { background: var(--status-danger-soft);  color: var(--status-danger); }

/* ============================================================
   ROLE BADGE — los 5 roles del sistema
   ============================================================ */
.role-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: var(--font-size-xs); font-weight: var(--font-weight-bold);
  padding: 2px 9px; border-radius: var(--radius-full);
}
.role-badge--admin  { background: var(--role-admin-bg);  color: var(--role-admin-text); }
.role-badge--gen    { background: var(--role-gen-bg);    color: var(--role-gen-text); }
.role-badge--ger    { background: var(--role-ger-bg);    color: var(--role-ger-text); }
.role-badge--medico { background: var(--role-medico-bg); color: var(--role-medico-text); }
.role-badge--gero   { background: var(--role-gero-bg);   color: var(--role-gero-text); }

/* ============================================================
   AVATAR (.av) — iniciales, 4 tamaños, 6 colores
   ============================================================ */
.av {
  border-radius: var(--radius-full); display: inline-flex; align-items: center;
  justify-content: center; font-weight: var(--font-weight-bold); flex-shrink: 0;
}
.av-xs { width: 24px; height: 24px; font-size: 9px; }
.av-sm { width: 30px; height: 30px; font-size: 10px; }
.av-md { width: 38px; height: 38px; font-size: 13px; }
.av-lg { width: 50px; height: 50px; font-size: 17px; }
.av-teal { background: var(--palette-teal-100);     color: var(--brand-primary); }
.av-sage { background: var(--status-success-soft);  color: var(--status-success); }
.av-rose { background: var(--status-danger-soft);   color: var(--status-danger); }
.av-dk   { background: var(--brand-primary-hover);  color: var(--text-on-dark); }
.av-neu  { background: var(--palette-teal-100);      color: var(--brand-primary-hover); }
.av-warn { background: var(--status-warning-soft);  color: var(--status-warning); }

/* ============================================================
   EMPTY STATE — icono + título + texto + acción
   ============================================================ */
.empty-state {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: var(--space-16) var(--space-8); text-align: center;
}
.empty-state__icon {
  width: 72px; height: 72px; border-radius: var(--radius-xl);
  background: var(--brand-primary-soft); display: flex; align-items: center;
  justify-content: center; font-size: 30px; color: var(--brand-accent); margin-bottom: var(--space-5);
}
.empty-state__title {
  font-size: var(--font-size-lg); font-weight: var(--font-weight-bold);
  color: var(--text-primary); margin-bottom: var(--space-2);
}
.empty-state__text {
  font-size: var(--font-size-sm); color: var(--text-secondary);
  max-width: 340px; line-height: 1.6; margin-bottom: var(--space-6);
}

/* ============================================================
   KPI CARD — stat card con icono, valor grande, delta
   ============================================================ */
.kpi-card {
  background: var(--surface-card); border-radius: var(--radius-lg);
  border: 1px solid var(--border-default); padding: var(--space-6);
  box-shadow: var(--shadow-sm); position: relative; overflow: hidden;
}
.kpi-card__label {
  font-size: var(--font-size-xs); font-weight: var(--font-weight-bold);
  text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-secondary);
}
.kpi-card__value {
  font-size: var(--font-size-3xl); font-weight: var(--font-weight-bold);
  letter-spacing: -0.03em; color: var(--text-primary); line-height: 1; margin-top: var(--space-2);
}
.kpi-card__delta {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: var(--font-size-xs); font-weight: var(--font-weight-medium);
  margin-top: var(--space-2); padding: 2px 8px; border-radius: var(--radius-full);
}
.kpi-card__delta--up      { background: var(--status-success-soft); color: var(--status-success); }
.kpi-card__delta--down    { background: var(--status-danger-soft);  color: var(--status-danger); }
.kpi-card__delta--neutral { background: var(--brand-primary-soft);  color: var(--brand-primary); }
.kpi-card__icon {
  position: absolute; right: var(--space-5); top: var(--space-5);
  width: 44px; height: 44px; border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center; font-size: 20px;
}
.kpi-card__icon--primary { background: var(--brand-primary-soft);  color: var(--brand-primary); }
.kpi-card__icon--success { background: var(--status-success-soft); color: var(--status-success); }
.kpi-card__icon--danger  { background: var(--status-danger-soft);  color: var(--status-danger); }
.kpi-card__icon--warning { background: var(--status-warning-soft); color: var(--status-warning); }

/* ============================================================
   TABLE WRAP + TOOLBAR — contenedor de tablas con barra de filtros
   (la <table> interna usa Bootstrap recoloreado)
   ============================================================ */
.table-wrap {
  border-radius: var(--radius-lg); border: 1px solid var(--border-default);
  overflow: hidden; background: var(--surface-card); box-shadow: var(--shadow-sm);
}
.table-wrap > .table { margin-bottom: 0; }
/* Gate de carga de tablas AJAX: spinner mientras DataTables trae los datos; al
   terminar (init.dt) se saca .dt-loading y la grilla aparece ya completa. */
.table-wrap > * { transition: opacity .25s ease; }
.table-wrap.dt-loading { position: relative; min-height: 240px; }
.table-wrap.dt-loading > * { opacity: 0; pointer-events: none; }
.table-wrap.dt-loading::after {
  content: ""; position: absolute; top: 50%; left: 50%;
  width: 34px; height: 34px; margin: -17px 0 0 -17px;
  border: 3px solid var(--border-default); border-top-color: var(--brand-primary);
  border-radius: 50%; animation: jb-spin .7s linear infinite;
}
@keyframes jb-spin { to { transform: rotate(360deg); } }
.table-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-4) var(--space-5); border-bottom: 1px solid var(--border-default);
  gap: var(--space-3); flex-wrap: wrap;
}

/* ============================================================
   SECTION NAV — tabs con subrayado (navegación dentro de página)
   ============================================================ */
.section-nav {
  display: flex; gap: var(--space-2); flex-wrap: wrap;
  border-bottom: 2px solid var(--border-default); margin-bottom: var(--space-6);
}
.section-nav__item {
  padding: var(--space-3) var(--space-5); font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium); color: var(--text-secondary);
  cursor: pointer; border: none; background: none; text-decoration: none;
  border-bottom: 2px solid transparent; margin-bottom: -2px;
  transition: all var(--transition); border-radius: var(--radius-sm) var(--radius-sm) 0 0;
}
.section-nav__item:hover { color: var(--brand-primary); background: var(--surface-hover); }
.section-nav__item.active { color: var(--brand-primary); border-bottom-color: var(--brand-primary); }

/* ============================================================================
   A.2 — SHELL (navbar + sidebar branded) + COMPUESTOS
   ============================================================================ */

/* ── NAVBAR (topbar oscura fija) ── */
.ds-navbar {
  position: fixed; top: 0; left: var(--sidebar-width); right: 0; z-index: 1000;
  height: var(--navbar-height); background: var(--surface-navbar);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 var(--space-6); box-shadow: 0 2px 8px rgba(0,0,0,0.18);
}
.ds-navbar__brand {
  display: flex; align-items: center; gap: var(--space-3);
  color: var(--text-on-dark); font-weight: var(--font-weight-bold);
  font-size: var(--font-size-lg); letter-spacing: -0.02em; text-decoration: none;
}
.ds-navbar__brand span { opacity: 0.55; font-weight: 400; font-size: var(--font-size-sm); }
.ds-navbar__actions { display: flex; align-items: center; gap: var(--space-3); }
.ds-navbar__icon-btn {
  width: 36px; height: 36px; border-radius: var(--radius-full);
  border: none; background: rgba(255,255,255,0.1); color: #fff; cursor: pointer;
  display: flex; align-items: center; justify-content: center; font-size: 14px;
  transition: background var(--transition); position: relative; text-decoration: none;
}
.ds-navbar__icon-btn:hover { background: rgba(255,255,255,0.2); color: #fff; }
.ds-navbar__badge {
  position: absolute; top: 4px; right: 4px; width: 8px; height: 8px; border-radius: 50%;
  background: var(--status-danger-icon); border: 2px solid var(--surface-navbar);
}
.ds-navbar__avatar {
  width: 34px; height: 34px; border-radius: var(--radius-full);
  background: var(--brand-accent); color: #fff; display: flex; align-items: center;
  justify-content: center; font-size: 13px; font-weight: var(--font-weight-bold);
  cursor: pointer; border: 2px solid rgba(255,255,255,0.25);
}
.ds-navbar__user { color: #fff; margin-right: var(--space-2); text-align: right; line-height: 1.25; }
.ds-navbar__user-name { font-size: var(--font-size-sm); font-weight: var(--font-weight-medium); }
.ds-navbar__user-role { font-size: var(--font-size-xs); opacity: 0.55; }
.ds-navbar__menu-btn { display: none; background: none; border: none; color: #fff;
  font-size: 20px; cursor: pointer; padding: var(--space-2); }

/* ── SIDEBAR (lateral oscuro fijo) ── */
.ds-sidebar {
  position: fixed; top: 0; left: 0; bottom: 0; z-index: 1001; width: var(--sidebar-width);
  background: var(--surface-sidebar); display: flex; flex-direction: column;
  overflow-y: auto; overflow-x: hidden;
}
.ds-sidebar::-webkit-scrollbar { width: 4px; }
.ds-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 4px; }
.ds-sidebar__logo {
  display: flex; align-items: center; gap: 11px;
  min-height: var(--navbar-height); padding: var(--space-3) var(--space-5);
  border-bottom: 1px solid rgba(255,255,255,0.08); flex-shrink: 0;
}
.ds-sidebar__logo-name { font-size: var(--font-size-xl); font-weight: var(--font-weight-bold);
  color: #fff; letter-spacing: -0.02em; line-height: 1.1; }
.ds-sidebar__logo-tagline { font-size: var(--font-size-xs); color: rgba(255,255,255,0.45);
  margin-top: var(--space-1); letter-spacing: 0.02em; text-transform: uppercase; }
.ds-sidebar__section-label { padding: var(--space-5) var(--space-5) var(--space-2);
  font-size: 10px; font-weight: var(--font-weight-bold); color: rgba(255,255,255,0.3);
  letter-spacing: 0.1em; text-transform: uppercase; }
.ds-sidebar__nav { flex: 1; padding: var(--space-2) 0; }
.ds-sidebar__item {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3) var(--space-5); color: rgba(255,255,255,0.6);
  font-size: var(--font-size-sm); font-weight: var(--font-weight-medium); cursor: pointer;
  transition: all var(--transition); margin: 1px var(--space-2); border-radius: var(--radius-md);
  border: none; background: none; width: calc(100% - 16px); text-align: left; text-decoration: none;
}
.ds-sidebar__item:hover,
.ds-sidebar__item:focus { background: rgba(255,255,255,0.08); color: #fff; text-decoration: none; }
.ds-sidebar__item.active { background: rgba(255,255,255,0.14); color: #fff; }
/* Sin subrayado al hover en ningún link del shell (base.css lo agrega por defecto). */
.ds-sidebar a:hover, .ds-sidebar a:focus,
.ds-navbar a:hover, .ds-navbar a:focus { text-decoration: none; }
.ds-sidebar__item-icon { width: 20px; text-align: center; font-size: 14px; opacity: 0.85; flex-shrink: 0; }
.ds-sidebar__footer { padding: var(--space-4) var(--space-5); border-top: 1px solid rgba(255,255,255,0.08); }
.ds-sidebar__footer-user { font-size: var(--font-size-xs); color: rgba(255,255,255,0.4); line-height: 1.5; }
.ds-sidebar__footer-email { color: rgba(255,255,255,0.65); font-weight: var(--font-weight-medium); }
.ds-sidebar__footer-badge { display: inline-block; margin-top: var(--space-2); background: var(--brand-accent);
  color: #fff; font-size: 10px; padding: 2px 8px; border-radius: var(--radius-full); }

/* ── MAIN content area ── */
.ds-main { margin-left: var(--sidebar-width); margin-top: var(--navbar-height);
  min-height: calc(100vh - var(--navbar-height)); padding: var(--space-8); }

/* ── Transición entre páginas (este sistema es multi-página: cada click al menú
   recarga el documento). View Transitions hace un cross-fade suave del contenido
   y mantiene el shell (navbar/sidebar) persistente, sin el flash del full-reload.
   Progressive enhancement: navegadores sin soporte navegan normal. ── */
@view-transition { navigation: auto; }
.ds-navbar  { view-transition-name: jb-navbar; }
.ds-sidebar { view-transition-name: jb-sidebar; }
::view-transition-group(root) { animation-duration: .2s; }
@media (prefers-reduced-motion: reduce) {
  ::view-transition-group(*), ::view-transition-old(*), ::view-transition-new(*) { animation: none !important; }
}

/* ── PAGE HEADER ── */
.ds-page-header { margin-bottom: var(--space-8); }
.ds-page-header--list { padding-top: var(--space-3); margin-bottom: var(--space-3); }
.ds-page-header__row { display: flex; justify-content: space-between; align-items: flex-start;
  gap: var(--space-4); flex-wrap: wrap; }
.ds-page-header__title { font-size: var(--font-size-2xl); font-weight: var(--font-weight-bold);
  color: var(--text-primary); letter-spacing: -0.02em; line-height: 1.2; }
.ds-page-header__subtitle { color: var(--text-secondary); margin-top: var(--space-1); font-size: var(--font-size-md); }
.ds-page-header__actions { display: flex; gap: var(--space-3); align-items: center; }

/* ── PATIENT CARD ── */
.patient-card {
  background: var(--surface-card); border-radius: var(--radius-lg);
  border: 1px solid var(--border-default); padding: var(--space-5); box-shadow: var(--shadow-sm);
  display: flex; gap: var(--space-4); align-items: flex-start;
  transition: box-shadow var(--transition), border-color var(--transition);
}
.patient-card:hover { box-shadow: var(--shadow-md); border-color: var(--border-strong); }
.patient-card__avatar {
  width: 44px; height: 44px; border-radius: var(--radius-full);
  background: var(--palette-teal-100); color: var(--brand-primary); display: flex;
  align-items: center; justify-content: center; font-weight: var(--font-weight-bold);
  font-size: var(--font-size-md); flex-shrink: 0;
}
.patient-card__name { font-weight: var(--font-weight-bold); color: var(--text-primary); }
.patient-card__doc { font-size: var(--font-size-xs); color: var(--text-muted); margin-top: 2px; }
.patient-card__meta { display: flex; gap: var(--space-3); margin-top: var(--space-2); flex-wrap: wrap; }

/* ── NOTIFICATION CARD + comment thread ── */
.notif-card { background: var(--surface-card); border-radius: var(--radius-lg);
  border: 1px solid var(--border-default); overflow: hidden; box-shadow: var(--shadow-sm);
  margin-bottom: var(--space-4); }
.notif-card--active { border-left: 4px solid var(--status-danger-icon); }
.notif-card--closed { border-left: 4px solid var(--border-default); }
.notif-card__header { padding: var(--space-4) var(--space-5); background: var(--surface-card-alt);
  display: flex; justify-content: space-between; align-items: center;
  border-bottom: 1px solid var(--border-default); }
.notif-card__body { padding: var(--space-4) var(--space-5); }
.comment-thread { background: var(--palette-teal-50); border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4); margin-bottom: var(--space-3); }
.comment-thread__title { font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--text-secondary); margin-bottom: 6px; }
.comment-item { font-size: 12px; color: var(--text-primary); padding: 3px 0;
  border-bottom: 1px solid rgba(var(--bs-primary-rgb), .18); }
.comment-item:last-child { border-bottom: none; }
.comment-item strong { color: var(--brand-primary-hover); }
.comment-item .cmt-time { color: var(--text-muted); }

/* ── FILTER PANEL (gráficos) ── */
.filter-panel { background: var(--surface-card); border-radius: var(--radius-lg);
  border: 1px solid var(--border-default); box-shadow: var(--shadow-sm);
  position: sticky; top: calc(var(--navbar-height) + var(--space-6)); }
.filter-panel__header { padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border-default); font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold); color: var(--text-primary);
  display: flex; align-items: center; gap: var(--space-2); }
.filter-panel__body { padding: var(--space-4) var(--space-5); }
.metric-row { display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-2) 0; font-size: var(--font-size-sm); }
.metric-row__dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-right: var(--space-2); }

/* ============================================================================
   A.3 — NÚCLEO CLÍNICO: form-check custom, toggle, turno-card, medicion-item,
   eva-scale. De estos 6 patrones salen las 11 mediciones por composición.
   ============================================================================ */

/* ── Input con icono ── */
.input-icon-wrap { position: relative; }
.input-icon-wrap .form-control, .input-icon-wrap .form-select { padding-left: 38px; }
.input-icon-wrap .input-icon { position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  color: var(--text-muted); font-size: 14px; pointer-events: none; z-index: 4; }

/* ── Checkbox & Radio custom (pisa el de Bootstrap, carga última) ── */
.form-check { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-2); }
.form-check-input {
  width: 17px; height: 17px; border: 1.5px solid var(--border-default);
  border-radius: var(--radius-sm); cursor: pointer; appearance: none; -webkit-appearance: none;
  background: #fff; flex-shrink: 0; transition: all var(--transition); position: relative; margin: 0;
}
.form-check-input[type="radio"] { border-radius: 50%; }
.form-check-input:checked { background: var(--brand-primary); border-color: var(--brand-primary); }
.form-check-input:checked::after {
  content: ''; position: absolute; inset: 0; background: #fff; border-radius: inherit;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='white' stroke-width='2' d='M3 8l3 3 7-7'/%3E%3C/svg%3E") center/12px no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='white' stroke-width='2' d='M3 8l3 3 7-7'/%3E%3C/svg%3E") center/12px no-repeat;
}
.form-check-input[type="radio"]:checked::after {
  -webkit-mask: none; mask: none; background: #fff; width: 6px; height: 6px; border-radius: 50%;
  top: 50%; left: 50%; transform: translate(-50%, -50%); inset: auto;
}
.form-check-input:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(var(--bs-primary-rgb), .25); }
.form-check-label { font-size: var(--font-size-sm); color: var(--text-primary); cursor: pointer; }

/* ── Toggle switch ── */
.toggle { position: relative; display: inline-flex; align-items: center; gap: var(--space-3); cursor: pointer; }
.toggle__input { position: absolute; opacity: 0; width: 0; height: 0; }
.toggle__track { width: 40px; height: 22px; border-radius: 11px; background: var(--border-default);
  transition: background var(--transition); flex-shrink: 0; position: relative; }
.toggle__thumb { position: absolute; left: 3px; top: 3px; width: 16px; height: 16px; border-radius: 50%;
  background: #fff; box-shadow: 0 1px 4px rgba(0,0,0,0.25); transition: transform var(--transition); }
.toggle__input:checked + .toggle__track { background: var(--brand-primary); }
.toggle__input:checked + .toggle__track .toggle__thumb { transform: translateX(18px); }
.toggle__label { font-size: var(--font-size-sm); color: var(--text-primary); }

/* ── Turno card (mañana/tarde/noche) ── */
.turno-card { background: var(--surface-card); border-radius: var(--radius-lg); border: 1px solid var(--border-default);
  box-shadow: var(--shadow-sm); overflow: hidden; margin-bottom: var(--space-5); }
.turno-card__head { padding: var(--space-4) var(--space-6); display: flex; align-items: center; gap: var(--space-3); }
.turno-card__head--manana { background: linear-gradient(135deg, var(--turno-manana-bg-start), var(--turno-manana-bg-end)); border-bottom: 1px solid var(--turno-manana-border); }
.turno-card__head--tarde  { background: linear-gradient(135deg, var(--turno-tarde-bg-start), var(--turno-tarde-bg-end)); border-bottom: 1px solid var(--turno-tarde-border); }
.turno-card__head--noche  { background: linear-gradient(135deg, var(--turno-noche-bg-start), var(--turno-noche-bg-end)); border-bottom: 1px solid rgba(255,255,255,.08); }
.turno-card__head--noche .turno-card__title { color: var(--text-on-dark); }
.turno-card__head--noche .turno-card__subtitle { color: var(--text-on-dark-muted); }
.turno-card__icon { width: 34px; height: 34px; border-radius: var(--radius-md); display: flex;
  align-items: center; justify-content: center; font-size: 15px; flex-shrink: 0; }
.turno-card__icon--manana { background: rgba(255,193,50,.18); color: var(--status-warning); }
.turno-card__icon--tarde  { background: var(--palette-teal-100); color: var(--brand-primary); }
.turno-card__icon--noche  { background: rgba(255,255,255,.1); color: rgba(255,255,255,.8); }
.turno-card__title    { font-weight: var(--font-weight-bold); font-size: var(--font-size-base); color: var(--text-primary); }
.turno-card__subtitle { font-size: var(--font-size-xs); color: var(--text-secondary); }
.turno-card__body { padding: var(--space-5) var(--space-6); }

/* ── Medición item (bloque de cada medición dentro de un turno) ── */
.medicion-item { background: var(--surface-card-alt); border-radius: var(--radius-md);
  border: 1px solid var(--border-default); padding: var(--space-4) var(--space-5); margin-bottom: var(--space-4); }
.medicion-item.full-width { grid-column: 1 / -1; }
.medicion-item__title { font-size: var(--font-size-xs); font-weight: var(--font-weight-bold);
  color: var(--text-primary); margin-bottom: var(--space-3); display: flex; align-items: center; gap: 6px;
  text-transform: uppercase; letter-spacing: .04em; }
.medicion-item__title i { color: var(--brand-primary); font-size: 11px; }
.medicion-item__new-badge { font-size: 9px; background: var(--status-success-soft); color: var(--status-success);
  padding: 2px 6px; border-radius: var(--radius-full); margin-left: 5px; font-weight: var(--font-weight-bold); }

/* ── EVA Pain scale (dolor 0-10) ── */
.eva-scale { display: flex; gap: 3px; flex-wrap: nowrap; }
.eva-step { flex: 1; min-width: 24px; height: 32px; border-radius: var(--radius-sm); display: flex;
  align-items: center; justify-content: center; font-size: 10px; font-weight: var(--font-weight-bold);
  cursor: pointer; transition: var(--transition); border: 2px solid transparent; color: var(--text-on-dark); margin: 0; }
.eva-step:hover, .eva-step.selected, .eva-step:has(input:checked) { transform: scale(1.12); border-color: rgba(255,255,255,.7); box-shadow: 0 0 0 2px rgba(0,0,0,.18); }
.eva-step:focus-within { outline: none; border-color: #fff; box-shadow: 0 0 0 3px rgba(73,140,134,.45); }
.eva-step--0 { background: var(--eva-0); } .eva-step--1 { background: var(--eva-1); }
.eva-step--2 { background: var(--eva-2); } .eva-step--3 { background: var(--eva-3); }
.eva-step--4 { background: var(--eva-4); } .eva-step--5 { background: var(--eva-5); }
.eva-step--6 { background: var(--eva-6); color: var(--text-primary); } .eva-step--7 { background: var(--eva-7); color: var(--text-primary); }
.eva-step--8 { background: var(--eva-8); } .eva-step--9 { background: var(--eva-9); }
.eva-step--10 { background: var(--eva-10); }

/* ── Repetidor de filas (medicación) ── */
.repeater__row { display: grid; grid-template-columns: 2fr 1fr 1fr auto; gap: var(--space-3);
  align-items: end; padding: var(--space-3); background: var(--surface-card); border: 1px solid var(--border-default);
  border-radius: var(--radius-md); margin-bottom: var(--space-3); }
.repeater__remove { background: var(--status-danger-soft); color: var(--status-danger); border: none;
  width: 38px; height: 38px; border-radius: var(--radius-md); cursor: pointer; flex-shrink: 0; }
.repeater__remove:hover { background: var(--status-danger-mid); }

/* ============================================================================
   A.4 — PANTALLAS NUEVAS (sin preview): calendario, login, archivos
   ============================================================================ */

/* ── Login ── */
.jb-login { min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--brand-secondary), var(--brand-primary)); padding: var(--space-5); }
.jb-login__card { width: 100%; max-width: 400px; background: var(--surface-card);
  border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); padding: var(--space-10) var(--space-8); }
.jb-login__brand { text-align: center; margin-bottom: var(--space-6); }
.jb-login__logo { width: 64px; height: 64px; border-radius: var(--radius-lg); margin-bottom: var(--space-3); }
.jb-login__title { font-size: var(--font-size-2xl); font-weight: var(--font-weight-bold);
  color: var(--text-primary); letter-spacing: -0.02em; }
.jb-login__tagline { font-size: var(--font-size-sm); color: var(--text-secondary); }

/* ── Calendario mensual de seguimiento ── */
.jb-cal { background: var(--surface-card); border-radius: var(--radius-lg);
  border: 1px solid var(--border-default); box-shadow: var(--shadow-sm); overflow: hidden; }
.jb-cal__head { display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-4) var(--space-5); border-bottom: 1px solid var(--border-default); }
.jb-cal__month { font-size: var(--font-size-lg); font-weight: var(--font-weight-bold);
  color: var(--text-primary); text-transform: capitalize; }
.jb-cal__nav { display: flex; gap: var(--space-2); }
.jb-cal__grid { display: grid; grid-template-columns: repeat(7, 1fr); }
.jb-cal__weekday { padding: var(--space-3); text-align: center; font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold); text-transform: uppercase; letter-spacing: .04em;
  color: var(--text-secondary); border-bottom: 1px solid var(--border-default); }
.jb-cal__day { min-height: 92px; padding: var(--space-2) var(--space-3); border-right: 1px solid var(--border-default);
  border-bottom: 1px solid var(--border-default); position: relative; transition: background var(--transition);
  cursor: pointer; display: flex; flex-direction: column; gap: var(--space-2);
  text-decoration: none; color: inherit; }
.jb-cal__day:focus-visible { outline: none; box-shadow: inset 0 0 0 2px var(--brand-primary); z-index: 1; }
.jb-cal__day:nth-child(7n) { border-right: none; }
.jb-cal__day:hover { background: var(--surface-hover); }
.jb-cal__day--out { background: var(--surface-card-alt); cursor: default; }
.jb-cal__day--out:hover { background: var(--surface-card-alt); }
.jb-cal__daynum { font-size: var(--font-size-sm); font-weight: var(--font-weight-medium); color: var(--text-primary); }
.jb-cal__day--out .jb-cal__daynum { color: var(--text-muted); }
.jb-cal__day--today .jb-cal__daynum { background: var(--brand-primary); color: #fff; width: 24px; height: 24px;
  border-radius: var(--radius-full); display: flex; align-items: center; justify-content: center; }
/* Estado de carga del día */
.jb-cal__state { font-size: 10px; font-weight: var(--font-weight-bold); padding: 2px 7px;
  border-radius: var(--radius-full); align-self: flex-start; display: inline-flex; align-items: center; gap: 4px; }
.jb-cal__state::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.jb-cal__state--complete { background: var(--status-success-soft); color: var(--status-success); }
.jb-cal__state--partial  { background: var(--status-warning-soft); color: var(--status-warning); }
.jb-cal__state--empty    { background: var(--palette-neu-100);     color: var(--text-muted); }
.jb-cal__legend { display: flex; gap: var(--space-4); padding: var(--space-3) var(--space-5);
  flex-wrap: wrap; border-top: 1px solid var(--border-default); }

/* ── Archivos: tabs + uploader (se completa en su lote) ── */
.jb-uploader { border: 2px dashed var(--border-strong); border-radius: var(--radius-lg);
  padding: var(--space-8); text-align: center; background: var(--surface-card-alt);
  transition: border-color var(--transition), background var(--transition); cursor: pointer; }
.jb-uploader:hover { border-color: var(--brand-primary); background: var(--brand-primary-soft); }
.jb-uploader__icon { font-size: 32px; color: var(--brand-accent); margin-bottom: var(--space-3); }

/* ============================================================================
   A.5 — PRIMITIVAS CHICAS + NEUTRALIZACIÓN EXTENDIDA + DataTables + Chart
   Todo token-driven: cambiar la paleta en jubilo-tokens.css recolorea esto.
   ============================================================================ */

/* ── Breadcrumb (Bootstrap, recolor) ── */
.breadcrumb { font-size: var(--font-size-sm); margin-bottom: var(--space-4); --bs-breadcrumb-divider-color: var(--text-muted); }
.breadcrumb-item a { color: var(--text-secondary); text-decoration: none; }
.breadcrumb-item a:hover { color: var(--brand-primary); }
.breadcrumb-item.active { color: var(--text-primary); font-weight: var(--font-weight-medium); }

/* ── Pagination (Bootstrap, neutraliza tema base.css) ── */
.pagination {
  --bs-pagination-color: var(--text-secondary);
  --bs-pagination-bg: var(--surface-card);
  --bs-pagination-border-color: var(--border-default);
  --bs-pagination-hover-color: var(--brand-primary);
  --bs-pagination-hover-bg: var(--surface-hover);
  --bs-pagination-hover-border-color: var(--border-strong);
  --bs-pagination-focus-color: var(--brand-primary);
  --bs-pagination-active-color: #fff;
  --bs-pagination-active-bg: var(--brand-primary);
  --bs-pagination-active-border-color: var(--brand-primary);
  --bs-pagination-border-radius: var(--radius-md);
  gap: var(--space-1);
}
.page-link { border-radius: var(--radius-md) !important; }

/* ── Dropdown (Bootstrap, neutraliza tema) — usado en navbar user menu ── */
.dropdown-menu {
  --bs-dropdown-bg: var(--surface-card);
  --bs-dropdown-border-color: var(--border-default);
  --bs-dropdown-border-radius: var(--radius-md);
  --bs-dropdown-link-color: var(--text-primary);
  --bs-dropdown-link-hover-bg: var(--surface-hover);
  --bs-dropdown-link-hover-color: var(--brand-primary);
  --bs-dropdown-link-active-bg: var(--brand-primary);
  --bs-dropdown-link-active-color: #fff;
  box-shadow: var(--shadow-md); padding: var(--space-2);
}
.dropdown-item { border-radius: var(--radius-sm); font-size: var(--font-size-sm); }

/* ── Nav-tabs / nav-pills (neutraliza tema) ── */
.nav-tabs {
  --bs-nav-tabs-border-color: var(--border-default);
  --bs-nav-tabs-link-active-color: var(--brand-primary);
  --bs-nav-tabs-link-active-border-color: var(--border-default) var(--border-default) var(--surface-card);
}
.nav-tabs .nav-link { color: var(--text-secondary); }
.nav-tabs .nav-link:hover { color: var(--brand-primary); }
.nav-pills { --bs-nav-pills-link-active-bg: var(--brand-primary); --bs-nav-pills-border-radius: var(--radius-md); }
.nav-link { color: var(--brand-primary); }

/* ── Progress (upload, etc.) ── */
.progress { --bs-progress-bg: var(--palette-neu-100); --bs-progress-bar-bg: var(--brand-primary); --bs-progress-border-radius: var(--radius-full); height: 8px; }

/* ── Spinner / loading ── */
.spinner-border, .spinner-grow { color: var(--brand-primary); }
.jb-loading { display: inline-flex; align-items: center; gap: var(--space-2); color: var(--text-secondary); font-size: var(--font-size-sm); }

/* ── Tooltip / popover (neutraliza tema) — info de quimiotipo ── */
.tooltip { --bs-tooltip-bg: var(--brand-secondary); --bs-tooltip-color: #fff; --bs-tooltip-border-radius: var(--radius-sm); font-family: var(--font-family); }
.popover {
  --bs-popover-bg: var(--surface-card); --bs-popover-border-color: var(--border-default);
  --bs-popover-border-radius: var(--radius-md); --bs-popover-header-bg: var(--surface-card-alt);
  --bs-popover-header-color: var(--text-primary); --bs-popover-body-color: var(--text-secondary);
  box-shadow: var(--shadow-md); font-family: var(--font-family);
}
.jb-help { color: var(--brand-accent); cursor: help; font-size: 13px; }

/* ── Count badge (pill numérico en tab/sidebar) ── */
.jb-count { display: inline-flex; align-items: center; justify-content: center; min-width: 18px; height: 18px;
  padding: 0 5px; font-size: 10px; font-weight: var(--font-weight-bold); border-radius: var(--radius-full);
  background: var(--brand-primary-soft); color: var(--brand-primary); }

/* ── DataTables 2.x tematizado ──
   DT real = 2.2.2: emite .dt-container con filas .dt-layout-row (length+search
   arriba, info+paging abajo) y la tabla en .dt-layout-table. Las clases viejas
   DT1 (.dataTables_wrapper/.dataTables_filter/.paginate_button) NO se emiten →
   acá se tematiza la estructura DT2 real. */
.dt-container { font-size: var(--font-size-sm); color: var(--text-secondary); }

/* Filas de control: toolbar arriba (alt bg) + pie con info/paginación, con padding */
.dt-container .dt-layout-row:not(.dt-layout-table) {
  align-items: center; gap: var(--space-3);
  margin: 0; padding: var(--space-3) var(--space-5);
}
.dt-container > .dt-layout-row:first-child {
  background: var(--surface-card-alt); border-bottom: 1px solid var(--border-default);
}
.dt-container > .dt-layout-row:last-child { border-top: 1px solid var(--border-default); }
.dt-container .dt-layout-table { margin: 0; }
.dt-container .dt-layout-cell { padding: 0; }

/* Buscador estilo search-box con lupa (DT2 deja el label vacio via text:_INPUT_) */
.dt-container .dt-search { position: relative; display: inline-flex; align-items: center; margin: 0; }
.dt-container .dt-search::before {
  content: "\f002"; font-family: "Font Awesome 6 Free"; font-weight: 900;
  position: absolute; left: 0.75rem; top: 50%; transform: translateY(-50%);
  color: var(--text-muted); font-size: 13px; pointer-events: none; z-index: 2;
}
.dt-container .dt-search label { display: none; }
.dt-container .dt-input, .dt-container select.dt-input, .dt-container input.dt-input {
  border: 1.5px solid var(--border-default); border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-3); background: var(--surface-input);
  color: var(--text-primary); font-family: var(--font-family); font-size: var(--font-size-sm);
  outline: none; transition: border-color var(--transition), box-shadow var(--transition);
}
.dt-container .dt-search input.dt-input { min-width: 280px; padding-left: 2.1rem; }
.dt-container .dt-input:focus {
  border-color: var(--border-focus); box-shadow: 0 0 0 3px rgba(var(--bs-primary-rgb), .18);
}

/* Info "Mostrando registros del 1 al N" */
.dt-container .dt-info { color: var(--text-muted); font-size: var(--font-size-sm); margin: 0; padding: 0; }

/* Paginación teal */
.dt-container .dt-paging { margin: 0; }
.dt-container .dt-paging .dt-paging-button {
  border-radius: var(--radius-md) !important; border: 1px solid var(--border-default) !important;
  color: var(--text-secondary) !important; background: var(--surface-card) !important;
  margin: 0 2px !important; padding: var(--space-1) var(--space-3) !important; min-width: 0 !important;
}
.dt-container .dt-paging .dt-paging-button.current,
.dt-container .dt-paging .dt-paging-button.current:hover {
  background: var(--brand-primary) !important; border-color: var(--brand-primary) !important; color: #fff !important;
}
.dt-container .dt-paging .dt-paging-button:hover:not(.current):not(.disabled) {
  background: var(--surface-hover) !important; border-color: var(--border-strong) !important; color: var(--brand-primary) !important;
}
.dt-container .dt-paging .dt-paging-button.disabled { opacity: .45; }

/* Tabla: header gris en mayúsculas + filas con padding generoso (look moderno) */
.table-wrap table.dataTable,
.table-wrap table.table { --bs-table-cell-padding-y: .85rem; --bs-table-cell-padding-x: var(--space-5); }
.table-wrap table.table > thead > tr > th { padding: var(--space-3) var(--space-5); }
.table-wrap table.table > tbody > tr > td,
.table-wrap table.table > tbody > tr > th { padding: .85rem var(--space-5); vertical-align: middle; }
table.dataTable thead th, .table-wrap table.table thead th {
  border-bottom: 1px solid var(--border-default); color: var(--text-secondary);
  font-size: var(--font-size-xs); text-transform: uppercase; letter-spacing: .04em;
  font-weight: var(--font-weight-bold);
}

/* ── Chart container ── */
.chart-box { background: var(--surface-card); border: 1px solid var(--border-default);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); padding: var(--space-5); }
.chart-box__title { font-size: var(--font-size-sm); font-weight: var(--font-weight-bold);
  color: var(--text-primary); margin-bottom: var(--space-4); }
.chart-canvas { position: relative; width: 100%; min-height: 260px; }

/* ── Modal / dialog (Bootstrap, neutraliza tema + look Júbilo) ── */
.modal-content {
  --bs-modal-bg: var(--surface-card);
  --bs-modal-border-color: var(--border-default);
  --bs-modal-border-radius: var(--radius-lg);
  --bs-modal-header-border-color: var(--border-default);
  --bs-modal-footer-border-color: var(--border-default);
  --bs-modal-color: var(--text-primary);
  box-shadow: var(--shadow-lg);
}
.modal-header { background: var(--surface-card-alt); }
.modal-title { font-weight: var(--font-weight-bold); color: var(--text-primary); letter-spacing: -0.01em; }
.modal-backdrop { --bs-backdrop-bg: var(--brand-secondary); --bs-backdrop-opacity: .55; }

/* ── SweetAlert tematizado (botones = .btn Bootstrap teal via mixin global en baseAdmin) ── */
.jb-swal.swal2-popup { border-radius: var(--radius-lg); font-family: var(--font-family); }
.jb-swal .swal2-title { color: var(--text-primary); font-weight: var(--font-weight-bold); }
.jb-swal .swal2-html-container { color: var(--text-secondary); }
.jb-swal .swal2-actions { gap: var(--space-3); }
.jb-swal .swal2-actions .btn { margin: 0; }

/* ── Tabla de archivos: fila con icono de tipo ── */
.jb-file-icon { width: 34px; height: 34px; border-radius: var(--radius-md); display: inline-flex;
  align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0;
  background: var(--brand-primary-soft); color: var(--brand-primary); }

/* ── Dual list (patologías: disponibles ↔ asignadas) ── */
.dual-list { display: grid; grid-template-columns: 1fr auto 1fr; gap: var(--space-4); align-items: stretch; }
.dual-list__col { border: 1px solid var(--border-default); border-radius: var(--radius-md);
  background: var(--surface-card); display: flex; flex-direction: column; min-height: 220px; overflow: hidden; }
.dual-list__head { padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--border-default);
  font-size: var(--font-size-xs); font-weight: var(--font-weight-bold); text-transform: uppercase;
  letter-spacing: .04em; color: var(--text-secondary); background: var(--surface-card-alt);
  display: flex; justify-content: space-between; align-items: center; }
.dual-list__body { padding: var(--space-2); overflow-y: auto; flex: 1; }
.dual-list__item { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm); font-size: var(--font-size-sm); color: var(--text-primary);
  cursor: grab; transition: background var(--transition); }
.dual-list__item:hover { background: var(--surface-hover); }
.dual-list__item i { color: var(--text-muted); font-size: 11px; }
.dual-list__mid { display: flex; flex-direction: column; justify-content: center; gap: var(--space-2); }

/* ============================================================================
   Shell B1: adopción de .ds-* en baseAdmin real. Va AL FINAL del archivo a
   propósito: el override mobile de .ds-main debe cargar DESPUÉS de la regla base
   `.ds-main { margin-left: var(--sidebar-width) }` para ganarle por orden de cascada.
   ============================================================================ */
.ds-navbar__brand { gap: var(--space-2); }
.ds-navbar__brand-link { color: var(--text-on-dark); text-decoration: none;
  font-weight: var(--font-weight-bold); font-size: var(--font-size-lg); letter-spacing: -0.02em; }
.ds-navbar__user-toggle { display: flex; align-items: center; gap: var(--space-2);
  text-decoration: none; cursor: pointer; }
.ds-navbar__user-name, .ds-navbar__user-role { display: block; }
/* Rol bajo el nombre en el menú de usuario (dropdown del topbar). */
.dropdown-user-details-role { font-size: var(--font-size-xs); color: var(--text-muted);
  text-transform: uppercase; letter-spacing: .04em; margin-top: 2px; line-height: 1.2; }

/* Menú de usuario del topbar: respiración interna (evita el look amontonado).
   El gap ícono↔texto del header lo da base.css vía el scope .dropdown-user. */
.ds-navbar .dropdown-menu { min-width: 240px; padding: var(--space-2); border-radius: var(--radius-lg); }
.ds-navbar .dropdown-header { padding: var(--space-3) var(--space-3) var(--space-2); }
.ds-navbar .dropdown-user-img { color: var(--brand-primary); font-size: 16px; }
.ds-navbar .dropdown-item { padding: var(--space-2) var(--space-3); border-radius: var(--radius-md); }
.ds-navbar .dropdown-item:hover, .ds-navbar .dropdown-item:focus { background: var(--surface-hover); color: var(--brand-primary); }
.ds-navbar .dropdown-divider { margin: var(--space-2) 0; }
.ds-sidebar__footer-copy { margin-top: var(--space-3); font-size: 10px; color: rgba(255,255,255,0.3); }

/* Off-canvas en mobile (≤991.98px). responsive-sidebar.js togglea .mobile-show sobre .ds-sidebar. */
@media (max-width: 991.98px) {
  .ds-navbar__menu-btn { display: inline-flex; align-items: center; justify-content: center; }
  /* En mobile el topbar vuelve a ancho completo (el sidebar pasa a off-canvas). */
  .ds-navbar { left: 0; }
  .ds-sidebar { transform: translateX(-100%); transition: transform var(--transition);
    box-shadow: 0 0 24px rgba(0,0,0,0.35); }
  .ds-sidebar.mobile-show { transform: translateX(0); }
  .ds-main { margin-left: 0; }
}
