/* ============================================================
   THINK BIG ACADÉMICO — DESIGN SYSTEM
   Dark Enterprise SaaS Premium
   ============================================================
   Este archivo centraliza:
   - Variables (colores, spacing, sombras, radios, tipografía)
   - Clases base reutilizables (.btn, .card, .input, .badge, etc.)

   Reglas:
   - Todos los HTML del proyecto cargan este archivo PRIMERO.
   - Los estilos específicos de cada vista van DESPUÉS.
   - Para overrides, usar las variables (no hardcodear colores).
   ============================================================ */

/* =========== TOKENS / VARIABLES =========== */
:root {
  /* === Colores - Fondo === */
  --ds-bg:           #0d1117;           /* Fondo principal */
  --ds-bg-2:         #161b22;           /* Fondo secundario (cards en fondo) */
  --ds-bg-3:         #21262d;           /* Fondo terciario (inputs, hovers) */
  --ds-surface:      #1c2128;           /* Cards/paneles */
  --ds-surface-2:    #131c31;           /* Cards alternativos (azulado) */
  --ds-surface-glow: rgba(28,33,40,.95); /* Cards con sutil transparencia */
  --ds-overlay:      rgba(0,0,0,0.65);  /* Overlay de modales */

  /* === Colores - Bordes === */
  --ds-border:       #30363d;
  --ds-border-soft:  rgba(255,255,255,.06);
  --ds-border-hover: #58a6ff;

  /* === Colores - Texto === */
  --ds-text:         #e6edf3;
  --ds-text-soft:    #cbd5e1;
  --ds-text-muted:   #7d8590;
  --ds-text-mute-2:  #94a3b8;
  --ds-text-dim:     #526070;

  /* === Colores - Acentos === */
  --ds-primary:      #58a6ff;           /* Azul (info, primario) */
  --ds-primary-soft: rgba(88,166,255,.12);
  --ds-success:      #39d353;           /* Verde (éxito, OK, activo) */
  --ds-success-soft: rgba(57,211,83,.12);
  --ds-warning:      #d29922;           /* Ámbar (advertencias) */
  --ds-warning-soft: rgba(210,153,34,.12);
  --ds-danger:       #f85149;           /* Rojo (error, vencido, eliminar) */
  --ds-danger-soft:  rgba(248,81,73,.12);
  --ds-info:         #bc8cff;           /* Púrpura (decorativo) */
  --ds-info-soft:    rgba(188,140,255,.12);
  --ds-orange:       #f0883e;
  --ds-orange-soft:  rgba(240,136,62,.12);

  /* === Spacing === */
  --ds-s-1:  4px;
  --ds-s-2:  8px;
  --ds-s-3:  12px;
  --ds-s-4:  16px;
  --ds-s-5:  20px;
  --ds-s-6:  24px;
  --ds-s-7:  32px;
  --ds-s-8:  40px;
  --ds-s-10: 48px;

  /* === Border radius === */
  --ds-r-sm:  6px;
  --ds-r-md:  10px;
  --ds-r-lg:  14px;
  --ds-r-xl:  18px;
  --ds-r-2xl: 22px;
  --ds-r-full: 999px;

  /* === Sombras === */
  --ds-shadow-sm:  0 2px 6px rgba(0,0,0,.2);
  --ds-shadow-md:  0 8px 24px rgba(0,0,0,.3);
  --ds-shadow-lg:  0 14px 40px rgba(0,0,0,.4);
  --ds-shadow-glow:0 0 0 3px rgba(88,166,255,.18);
  --ds-shadow-card:0 10px 30px rgba(0,0,0,.25);

  /* === Tipografía === */
  --ds-font-sans:    'Inter','Segoe UI','Roboto',sans-serif;
  --ds-font-mono:    'SF Mono','Consolas',monospace;
  --ds-fs-xs:   10px;
  --ds-fs-sm:   11px;
  --ds-fs-base: 13px;
  --ds-fs-md:   14px;
  --ds-fs-lg:   16px;
  --ds-fs-xl:   20px;
  --ds-fs-2xl:  26px;
  --ds-fs-3xl:  34px;
  --ds-fw-regular: 400;
  --ds-fw-medium:  500;
  --ds-fw-semi:    600;
  --ds-fw-bold:    700;
  --ds-fw-extra:   800;

  /* === Transiciones === */
  --ds-tr-fast:   .12s ease;
  --ds-tr-normal: .2s ease;
  --ds-tr-slow:   .35s ease;
}

/* =========== CLASES BASE REUTILIZABLES =========== */

/* --- Botones --- */
.ds-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--ds-s-2);
  padding: var(--ds-s-2) var(--ds-s-4);
  border-radius: var(--ds-r-md);
  border: 1px solid var(--ds-border);
  background: transparent;
  color: var(--ds-text);
  font-family: var(--ds-font-sans);
  font-size: var(--ds-fs-base);
  font-weight: var(--ds-fw-semi);
  cursor: pointer;
  transition: var(--ds-tr-fast);
  white-space: nowrap;
  user-select: none;
}
.ds-btn:hover { background: var(--ds-bg-3); }
.ds-btn:disabled { opacity: .4; cursor: not-allowed; }
.ds-btn:focus-visible { box-shadow: var(--ds-shadow-glow); outline: none; }

.ds-btn-sm { padding: 4px 10px; font-size: var(--ds-fs-sm); }
.ds-btn-lg { padding: 12px 22px; font-size: var(--ds-fs-md); }

.ds-btn-primary {
  background: var(--ds-primary);
  border-color: var(--ds-primary);
  color: #fff;
}
.ds-btn-primary:hover { filter: brightness(1.1); }

.ds-btn-success {
  background: #2ea043;
  border-color: #2ea043;
  color: #fff;
}
.ds-btn-success:hover { background: #3fb950; }

.ds-btn-danger {
  background: transparent;
  border-color: var(--ds-danger);
  color: var(--ds-danger);
}
.ds-btn-danger:hover { background: var(--ds-danger-soft); }

.ds-btn-ghost {
  background: rgba(255,255,255,.04);
  border-color: var(--ds-border-soft);
}

.ds-btn-icon {
  width: 38px;
  height: 38px;
  padding: 0;
  border-radius: var(--ds-r-md);
}

/* --- Cards --- */
.ds-card {
  background: linear-gradient(180deg, var(--ds-surface-glow), rgba(13,17,23,.95));
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-xl);
  padding: var(--ds-s-5);
  box-shadow: var(--ds-shadow-card);
}
.ds-card-flat {
  background: var(--ds-surface);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-lg);
  padding: var(--ds-s-4);
}
.ds-card-section-title {
  font-size: var(--ds-fs-sm);
  font-weight: var(--ds-fw-semi);
  color: var(--ds-text-muted);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: var(--ds-s-3);
}

/* --- Inputs --- */
.ds-input,
.ds-select,
.ds-textarea {
  width: 100%;
  background: var(--ds-bg-3);
  border: 1px solid var(--ds-border);
  color: var(--ds-text);
  padding: var(--ds-s-2) var(--ds-s-3);
  border-radius: var(--ds-r-md);
  font-family: var(--ds-font-sans);
  font-size: var(--ds-fs-base);
  outline: none;
  transition: var(--ds-tr-fast);
}
.ds-input:focus,
.ds-select:focus,
.ds-textarea:focus {
  border-color: var(--ds-primary);
  box-shadow: var(--ds-shadow-glow);
}
.ds-input:disabled { opacity: .55; }
.ds-textarea { resize: vertical; min-height: 70px; }

.ds-label {
  display: block;
  font-size: var(--ds-fs-sm);
  font-weight: var(--ds-fw-semi);
  color: var(--ds-text-muted);
  margin-bottom: var(--ds-s-1);
}
.ds-label-required::after {
  content: " *";
  color: var(--ds-danger);
}

/* --- Badges & Pills --- */
.ds-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--ds-r-sm);
  font-size: var(--ds-fs-xs);
  font-weight: var(--ds-fw-bold);
  background: var(--ds-bg-3);
  color: var(--ds-text);
}
.ds-pill {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--ds-r-full);
  font-size: var(--ds-fs-xs);
  font-weight: var(--ds-fw-semi);
}
.ds-pill-success { background: var(--ds-success-soft); color: var(--ds-success); }
.ds-pill-primary { background: var(--ds-primary-soft); color: var(--ds-primary); }
.ds-pill-warning { background: var(--ds-warning-soft); color: var(--ds-warning); }
.ds-pill-danger  { background: var(--ds-danger-soft);  color: var(--ds-danger); }
.ds-pill-info    { background: var(--ds-info-soft);    color: var(--ds-info); }
.ds-pill-muted   { background: rgba(125,133,144,.15);  color: var(--ds-text-muted); }

/* --- Modal Premium --- */
.ds-overlay {
  position: fixed;
  inset: 0;
  background: var(--ds-overlay);
  backdrop-filter: blur(6px);
  z-index: 200;
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--ds-s-4);
  animation: ds-fade-in var(--ds-tr-normal);
}
.ds-overlay.on { display: flex; }
.ds-modal {
  background: var(--ds-surface);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-xl);
  padding: var(--ds-s-6);
  width: 100%;
  max-width: 520px;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: var(--ds-shadow-lg);
  animation: ds-zoom-in var(--ds-tr-normal);
}
.ds-modal-title {
  font-size: var(--ds-fs-md);
  font-weight: var(--ds-fw-bold);
  color: var(--ds-primary);
  margin-bottom: var(--ds-s-4);
}
.ds-modal-footer {
  display: flex;
  gap: var(--ds-s-2);
  justify-content: flex-end;
  margin-top: var(--ds-s-4);
  padding-top: var(--ds-s-4);
  border-top: 1px solid var(--ds-border-soft);
}

/* --- Tablas --- */
.ds-table {
  width: 100%;
  border-collapse: collapse;
}
.ds-table th {
  text-align: left;
  padding: var(--ds-s-3) var(--ds-s-4);
  font-size: var(--ds-fs-xs);
  font-weight: var(--ds-fw-semi);
  color: var(--ds-text-muted);
  text-transform: uppercase;
  letter-spacing: .5px;
  border-bottom: 1px solid var(--ds-border-soft);
  background: var(--ds-bg-3);
}
.ds-table td {
  padding: var(--ds-s-3) var(--ds-s-4);
  font-size: var(--ds-fs-base);
  border-bottom: 1px solid var(--ds-border-soft);
  vertical-align: middle;
}
.ds-table tr { transition: background var(--ds-tr-fast); }
.ds-table tr:hover { background: rgba(255,255,255,.02); }
.ds-table tr:last-child td { border-bottom: none; }
.ds-table-empty {
  text-align: center;
  color: var(--ds-text-muted);
  padding: var(--ds-s-6);
  font-style: italic;
}

/* --- Alertas --- */
.ds-alert {
  display: flex;
  align-items: flex-start;
  gap: var(--ds-s-3);
  padding: var(--ds-s-3) var(--ds-s-4);
  border-radius: var(--ds-r-md);
  border: 1px solid var(--ds-border-soft);
  font-size: var(--ds-fs-base);
  margin-bottom: var(--ds-s-3);
}
.ds-alert-info    { background: var(--ds-primary-soft); border-color: rgba(88,166,255,.3); color: var(--ds-text); }
.ds-alert-success { background: var(--ds-success-soft); border-color: rgba(57,211,83,.3);  color: var(--ds-text); }
.ds-alert-warning { background: var(--ds-warning-soft); border-color: rgba(210,153,34,.3); color: var(--ds-text); }
.ds-alert-danger  { background: var(--ds-danger-soft);  border-color: rgba(248,81,73,.3);  color: var(--ds-text); }

/* --- Helpers de layout --- */
.ds-stack-1  { display: flex; flex-direction: column; gap: var(--ds-s-1); }
.ds-stack-2  { display: flex; flex-direction: column; gap: var(--ds-s-2); }
.ds-stack-3  { display: flex; flex-direction: column; gap: var(--ds-s-3); }
.ds-stack-4  { display: flex; flex-direction: column; gap: var(--ds-s-4); }
.ds-row-1    { display: flex; gap: var(--ds-s-1); align-items: center; }
.ds-row-2    { display: flex; gap: var(--ds-s-2); align-items: center; }
.ds-row-3    { display: flex; gap: var(--ds-s-3); align-items: center; }
.ds-row-4    { display: flex; gap: var(--ds-s-4); align-items: center; }
.ds-grid-2   { display: grid; grid-template-columns: 1fr 1fr; gap: var(--ds-s-3); }
.ds-grid-3   { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--ds-s-3); }
.ds-grid-4   { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--ds-s-3); }
.ds-spacer   { flex: 1; }

/* --- Helpers de texto --- */
.ds-text-muted   { color: var(--ds-text-muted); }
.ds-text-sm      { font-size: var(--ds-fs-sm); }
.ds-text-xs      { font-size: var(--ds-fs-xs); }
.ds-text-bold    { font-weight: var(--ds-fw-bold); }
.ds-text-success { color: var(--ds-success); }
.ds-text-danger  { color: var(--ds-danger); }
.ds-text-warning { color: var(--ds-warning); }
.ds-text-primary { color: var(--ds-primary); }

/* --- Animaciones base --- */
@keyframes ds-fade-in  { from { opacity: 0; } to { opacity: 1; } }
@keyframes ds-zoom-in  { from { opacity: 0; transform: scale(.96); } to { opacity: 1; transform: scale(1); } }
@keyframes ds-slide-up { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.ds-anim-fade  { animation: ds-fade-in  var(--ds-tr-normal); }
.ds-anim-zoom  { animation: ds-zoom-in  var(--ds-tr-normal); }
.ds-anim-slide { animation: ds-slide-up var(--ds-tr-slow); }

/* --- Microinteracciones (hover suave global) --- */
.ds-hover-lift { transition: transform var(--ds-tr-fast), box-shadow var(--ds-tr-fast); }
.ds-hover-lift:hover { transform: translateY(-2px); box-shadow: var(--ds-shadow-md); }

/* --- Scrollbar fino --- */
.ds-scrollable::-webkit-scrollbar { width: 6px; height: 6px; }
.ds-scrollable::-webkit-scrollbar-thumb { background: var(--ds-border); border-radius: var(--ds-r-full); }
.ds-scrollable::-webkit-scrollbar-thumb:hover { background: var(--ds-text-muted); }

/* --- Glass effect (sutil, profesional) --- */
.ds-glass {
  background: rgba(28,33,40,.7);
  backdrop-filter: blur(14px);
  border: 1px solid var(--ds-border-soft);
}

/* ============================================================
   COMPATIBILIDAD LEGACY (mejora clases existentes sin romper)
   Aplica el look del Design System sobre las clases viejas
   que ya usa la app. NO cambia el HTML — solo eleva el estilo.
   ============================================================ */

/* === PILLS (badges en tablas) === */
.pill {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: var(--ds-r-full);
  font-size: var(--ds-fs-xs);
  font-weight: var(--ds-fw-bold);
  letter-spacing: .3px;
  line-height: 1.4;
  border: 1px solid transparent;
}
.pill.green   { background: var(--ds-success-soft); color: var(--ds-success); border-color: rgba(57,211,83,.25); }
.pill.blue    { background: var(--ds-primary-soft); color: var(--ds-primary); border-color: rgba(88,166,255,.25); }
.pill.purple  { background: var(--ds-info-soft);    color: var(--ds-info);    border-color: rgba(188,140,255,.25); }
.pill.yellow  { background: var(--ds-warning-soft); color: var(--ds-warning); border-color: rgba(210,153,34,.25); }
.pill.red     { background: var(--ds-danger-soft);  color: var(--ds-danger);  border-color: rgba(248,81,73,.25); }
.pill.orange  { background: var(--ds-orange-soft);  color: var(--ds-orange);  border-color: rgba(240,136,62,.25); }

/* === BADGES de tabs (números rojos en sidebar/topbar) === */
.badge,
.sb-bg {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  background: var(--ds-danger);
  color: #fff;
  font-size: var(--ds-fs-xs);
  font-weight: var(--ds-fw-bold);
  border-radius: var(--ds-r-full);
  line-height: 1;
  box-shadow: 0 0 0 2px var(--ds-bg-2);
}

/* === FASES (PA1, PA2, etc.) — refinados visualmente === */
.fase {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: var(--ds-r-full);
  font-size: var(--ds-fs-xs);
  font-weight: var(--ds-fw-bold);
  letter-spacing: .3px;
  line-height: 1.4;
  border: 1px solid transparent;
}
.fase.fPA1 { background: var(--ds-success-soft); color: var(--ds-success); border-color: rgba(57,211,83,.25); }
.fase.fPA2 { background: var(--ds-primary-soft); color: var(--ds-primary); border-color: rgba(88,166,255,.25); }
.fase.fPA3 { background: var(--ds-warning-soft); color: var(--ds-warning); border-color: rgba(210,153,34,.25); }
.fase.fPA4 { background: var(--ds-info-soft);    color: var(--ds-info);    border-color: rgba(188,140,255,.25); }
.fase.fPA5 { background: rgba(236,72,153,.15);   color: #ec4899;          border-color: rgba(236,72,153,.25); }
.fase.fLEV { background: var(--ds-orange-soft);  color: var(--ds-orange);  border-color: rgba(240,136,62,.25); }
.fase.fBE  { background: rgba(16,185,129,.15);   color: #10b981;          border-color: rgba(16,185,129,.25); }

/* === Estados de pago (CERRADO, ACTIVO, CONGELADO) === */
/* Solo aplico a span.ep (no a [class*="ep-"]) para evitar conflictos con otras clases */
span.ep {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: var(--ds-r-full);
  font-size: var(--ds-fs-xs);
  font-weight: var(--ds-fw-bold);
  letter-spacing: .3px;
  border: 1px solid transparent;
}
/* CERRADO = rojo vivo solido (badge fuerte para avisar "cerrado") */
span.ep.ep-CERRADO   { background: #e74c3c; color: #fff; border-color: #c0392b; box-shadow: 0 0 8px rgba(231,76,60,.35); }
/* ACTIVO = verde (coincide con el boton @ ACTIVOS) */
span.ep.ep-ACTIVO    { background: rgba(63,185,80,.18); color: #3fb950; border-color: rgba(63,185,80,.35); }
/* CONGELADO = gris-azulado tenue (este badge ya no se ve en Pagos, va a Observados) */
span.ep.ep-CONGELADO { background: rgba(127,154,192,.15);  color: #7f9ac0;          border-color: rgba(127,154,192,.3); }

/* ============================================================
   BOTONES — Fase 1B-2 Design System
   Unificamos look de todas las clases de botón existentes.
   Uso transitions específicas (no "all") para evitar parpadeos.
   ============================================================ */

/* === Base .btn === */
button.btn,
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 6px 14px;
  font-family: var(--ds-font-sans);
  font-size: var(--ds-fs-sm);
  font-weight: var(--ds-fw-semi);
  letter-spacing: .2px;
  line-height: 1.4;
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-md);
  background: transparent;
  color: var(--ds-text);
  cursor: pointer;
  white-space: nowrap;
  user-select: none;
  transition: background-color var(--ds-tr-fast),
              border-color var(--ds-tr-fast),
              color var(--ds-tr-fast),
              transform var(--ds-tr-fast),
              box-shadow var(--ds-tr-fast);
}
button.btn:hover,
.btn:hover {
  background: var(--ds-bg-3);
  border-color: var(--ds-text-muted);
  transform: translateY(-1px);
}
button.btn:active,
.btn:active {
  transform: translateY(0);
}
button.btn:focus-visible,
.btn:focus-visible {
  outline: none;
  box-shadow: var(--ds-shadow-glow);
}
button.btn:disabled,
.btn:disabled {
  opacity: .45;
  cursor: not-allowed;
  transform: none !important;
}

/* === Variante verde (.btn.bg) — éxito, guardar, agregar === */
button.btn.bg,
.btn.bg {
  background: linear-gradient(180deg, #2ea043, #238636);
  border-color: #2ea043;
  color: #fff !important;
}
button.btn.bg:hover,
.btn.bg:hover {
  background: linear-gradient(180deg, #3fb950, #2ea043);
  border-color: #3fb950;
  box-shadow: 0 4px 14px rgba(57,211,83,.25);
}

/* === Variante azul (.btn.bb) — info, descargar === */
button.btn.bb,
.btn.bb {
  background: linear-gradient(180deg, #2188ff, #1f6fcf);
  border-color: #2188ff;
  color: #fff !important;
}
button.btn.bb:hover,
.btn.bb:hover {
  background: linear-gradient(180deg, #58a6ff, #2188ff);
  border-color: #58a6ff;
  box-shadow: 0 4px 14px rgba(88,166,255,.25);
}

/* === Variante roja (.btn.br) — eliminar, quitar === */
button.btn.br,
.btn.br {
  background: transparent;
  border-color: var(--ds-danger);
  color: var(--ds-danger) !important;
}
button.btn.br:hover,
.btn.br:hover {
  background: var(--ds-danger-soft);
  border-color: var(--ds-danger);
  box-shadow: 0 4px 14px rgba(248,81,73,.18);
}

/* === Variante ámbar (.btn.ba) — advertencias, mover === */
button.btn.ba,
.btn.ba {
  background: rgba(210,153,34,.12);
  border-color: var(--ds-warning);
  color: var(--ds-warning) !important;
}
button.btn.ba:hover,
.btn.ba:hover {
  background: rgba(210,153,34,.22);
  box-shadow: 0 4px 14px rgba(210,153,34,.18);
}

/* === Variante púrpura (.btn.bpu) — Gestión === */
button.btn.bpu,
.btn.bpu {
  background: rgba(188,140,255,.12);
  border-color: var(--ds-info);
  color: var(--ds-info) !important;
}
button.btn.bpu:hover,
.btn.bpu:hover {
  background: rgba(188,140,255,.22);
  box-shadow: 0 4px 14px rgba(188,140,255,.18);
}

/* === Botón de Login (.lbtn) === */
.lbtn {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 18px;
  font-family: var(--ds-font-sans);
  font-size: var(--ds-fs-md);
  font-weight: var(--ds-fw-bold);
  letter-spacing: .3px;
  border: none;
  border-radius: var(--ds-r-md);
  background: linear-gradient(180deg, #3b82f6, #2563eb);
  color: #fff;
  cursor: pointer;
  transition: background var(--ds-tr-fast), transform var(--ds-tr-fast), box-shadow var(--ds-tr-fast);
  box-shadow: 0 4px 14px rgba(59,130,246,.25);
}
.lbtn:hover {
  background: linear-gradient(180deg, #58a6ff, #3b82f6);
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(59,130,246,.35);
}
.lbtn:active { transform: translateY(0); }
.lbtn:disabled {
  opacity: .55;
  cursor: not-allowed;
  transform: none !important;
}

/* === Botones de filtro (.fbtn) — años, "Activos", "Cerrados" === */
.fbtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 5px 12px;
  font-family: var(--ds-font-sans);
  font-size: var(--ds-fs-sm);
  font-weight: var(--ds-fw-semi);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-md);
  background: transparent;
  color: var(--ds-text-muted);
  cursor: pointer;
  white-space: nowrap;
  transition: background-color var(--ds-tr-fast),
              color var(--ds-tr-fast),
              border-color var(--ds-tr-fast);
}
.fbtn:hover {
  color: var(--ds-text);
  border-color: var(--ds-text-muted);
  background: var(--ds-bg-3);
}
.fbtn.on {
  background: var(--ds-primary-soft);
  border-color: var(--ds-primary);
  color: var(--ds-primary);
}

/* === Botones de mes (.mbtn) — flechas ◀ ▶ === */
.mbtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  padding: 0;
  font-size: var(--ds-fs-base);
  font-weight: var(--ds-fw-bold);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-md);
  background: var(--ds-bg-3);
  color: var(--ds-text);
  cursor: pointer;
  transition: background-color var(--ds-tr-fast), border-color var(--ds-tr-fast);
}
.mbtn:hover {
  background: var(--ds-surface);
  border-color: var(--ds-primary);
  color: var(--ds-primary);
}

/* === Sidebar quick buttons (.sb-q-btn) === */
.sb-q-btn {
  transition: background-color var(--ds-tr-fast),
              border-color var(--ds-tr-fast),
              transform var(--ds-tr-fast);
}
.sb-q-btn:hover {
  border-color: var(--ds-text-muted);
  transform: translateX(2px);
}

/* === Topbar icon buttons (.at-burger, .at-bell, .icon-btn) === */
.at-burger, .at-bell, .icon-btn {
  transition: background-color var(--ds-tr-fast), border-color var(--ds-tr-fast);
}
.at-burger:hover, .at-bell:hover, .icon-btn:hover {
  background: rgba(255,255,255,.08);
  border-color: var(--ds-text-muted);
}

/* === Botones de navegación de tabs (.tab) === */
.tab {
  transition: background-color var(--ds-tr-fast), color var(--ds-tr-fast);
}

/* ============================================================
   CARDS — Fase 1B-3 Design System
   Unificamos look de las cards (KPI, dashboard, generales).
   ============================================================ */

/* === Cards genéricas (.card) en todo el panel === */
.card {
  background: linear-gradient(180deg, var(--ds-surface-glow), rgba(13,17,23,.92));
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-xl);
  padding: var(--ds-s-5);
  box-shadow: var(--ds-shadow-card);
  transition: border-color var(--ds-tr-fast), box-shadow var(--ds-tr-fast);
}
.card:hover {
  border-color: rgba(88,166,255,.18);
}
/* Header consistente de card */
.card .ct {
  font-size: var(--ds-fs-sm);
  font-weight: var(--ds-fw-bold);
  color: var(--ds-text-muted);
  text-transform: uppercase;
  letter-spacing: .6px;
  margin-bottom: var(--ds-s-3);
}

/* === KPI cards del dashboard (los 5 grandes con números) === */
#pg-dash .kpi {
  position: relative;
  background: linear-gradient(180deg, var(--ds-surface-glow), rgba(13,17,23,.95));
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-xl);
  padding: var(--ds-s-5) var(--ds-s-5) var(--ds-s-4);
  overflow: hidden;
  transition: transform var(--ds-tr-normal),
              border-color var(--ds-tr-normal),
              box-shadow var(--ds-tr-normal);
  animation: ds-slide-up var(--ds-tr-slow) backwards;
}
#pg-dash .kpi:nth-child(1) { animation-delay: 0ms;   border-top: 2px solid rgba(248,81,73,.6);  }
#pg-dash .kpi:nth-child(2) { animation-delay: 60ms;  border-top: 2px solid rgba(88,166,255,.6); }
#pg-dash .kpi:nth-child(3) { animation-delay: 120ms; border-top: 2px solid rgba(57,211,83,.6);  }
#pg-dash .kpi:nth-child(4) { animation-delay: 180ms; border-top: 2px solid rgba(188,140,255,.6); }
#pg-dash .kpi:nth-child(5) { animation-delay: 240ms; border-top: 2px solid rgba(210,153,34,.6); }

#pg-dash .kpi:hover {
  transform: translateY(-3px);
  border-color: rgba(88,166,255,.3);
  box-shadow: var(--ds-shadow-md);
}

/* Iconos de los KPIs con halo */
#pg-dash .kpi-icon {
  position: relative;
  width: 48px;
  height: 48px;
  border-radius: var(--ds-r-lg);
  font-size: 18px;
  flex-shrink: 0;
}
#pg-dash .kpi-icon::before {
  content: '';
  position: absolute;
  inset: -6px;
  border-radius: var(--ds-r-lg);
  background: inherit;
  filter: blur(14px);
  opacity: .35;
  z-index: -1;
}

/* Número del KPI más imponente */
#pg-dash .kpi-num {
  font-size: 32px;
  font-weight: var(--ds-fw-extra);
  letter-spacing: -1px;
  line-height: 1;
  color: var(--ds-text);
}

/* Subtítulo de KPI con mejor contraste */
#pg-dash .kpi small {
  display: inline-block;
  font-size: var(--ds-fs-sm);
  color: var(--ds-text-mute-2);
  margin-top: 4px;
}

/* === Cards del Dashboard (Rendimiento, Alertas, Actividad, etc.) === */
#pg-dash .dash-card {
  background: linear-gradient(180deg, var(--ds-surface-glow), rgba(13,17,23,.92));
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-xl);
  padding: var(--ds-s-5);
  box-shadow: var(--ds-shadow-card);
  transition: border-color var(--ds-tr-fast);
}
#pg-dash .dash-card:hover {
  border-color: rgba(88,166,255,.18);
}

/* Título de las cards del dashboard */
#pg-dash .dash-card h2 {
  font-size: var(--ds-fs-lg);
  font-weight: var(--ds-fw-bold);
  color: var(--ds-text);
  letter-spacing: -.3px;
  margin-bottom: var(--ds-s-4);
}

/* Header con título + acción ("Ver todas") */
#pg-dash .dash-card .head-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--ds-s-4);
}
#pg-dash .dash-card .head-row h2 {
  margin-bottom: 0;
}
#pg-dash .ver-todas {
  font-size: var(--ds-fs-sm);
  color: var(--ds-primary);
  cursor: pointer;
  font-weight: var(--ds-fw-semi);
  padding: 4px 10px;
  border-radius: var(--ds-r-sm);
  transition: background-color var(--ds-tr-fast);
}
#pg-dash .ver-todas:hover {
  background: var(--ds-primary-soft);
  text-decoration: none;
}

/* === Alert items (lista de alertas importantes) === */
#pg-dash .alert-item {
  display: flex;
  align-items: center;
  gap: var(--ds-s-3);
  padding: var(--ds-s-3) var(--ds-s-3);
  border-radius: var(--ds-r-md);
  background: rgba(255,255,255,.02);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background-color var(--ds-tr-fast), border-color var(--ds-tr-fast);
}
#pg-dash .alert-item:hover {
  background: rgba(255,255,255,.05);
  border-color: var(--ds-border-soft);
}
#pg-dash .alert-icon {
  width: 38px;
  height: 38px;
  border-radius: var(--ds-r-md);
  font-size: 14px;
  flex-shrink: 0;
}

/* === Activity items (lista de actividad reciente) === */
#pg-dash .activity-item {
  display: flex;
  gap: var(--ds-s-3);
  padding: var(--ds-s-2) 0;
}
#pg-dash .activity-time {
  display: inline-block;
  font-size: var(--ds-fs-xs);
  color: var(--ds-text-muted);
  font-weight: var(--ds-fw-semi);
  background: rgba(255,255,255,.04);
  padding: 2px 8px;
  border-radius: var(--ds-r-sm);
  margin-bottom: 4px;
  letter-spacing: .2px;
}

/* === Coordinator rows (carga por colaborador) === */
#pg-dash .coord-row {
  padding: var(--ds-s-2) 0;
  transition: opacity var(--ds-tr-fast);
}
#pg-dash .coord-av {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  font-size: var(--ds-fs-base);
  font-weight: var(--ds-fw-bold);
  letter-spacing: .3px;
  box-shadow: 0 4px 12px rgba(0,0,0,.25);
  flex-shrink: 0;
}
#pg-dash .bar {
  height: 8px;
  border-radius: var(--ds-r-full);
  background: rgba(255,255,255,.04);
  overflow: hidden;
}
#pg-dash .bar .fill {
  height: 100%;
  border-radius: var(--ds-r-full);
  transition: width var(--ds-tr-slow);
}

/* === Pequeñas mejoras al gráfico (Apex chart contenedor) === */
#pg-dash #d-chart {
  margin: var(--ds-s-1) 0 0;
}

/* === KPI delta (deltas tipo "+18% vs abr") === */
#pg-dash .kpi-delta.up,
#pg-dash .kpi-delta {
  font-size: var(--ds-fs-sm);
  font-weight: var(--ds-fw-semi);
}
#pg-dash .kpi-delta.up { color: var(--ds-success); }
#pg-dash .kpi-delta.down { color: var(--ds-danger); }
#pg-dash .kpi-delta-mu { color: var(--ds-text-muted); font-weight: var(--ds-fw-regular); }

/* === Animación de aparición suave para todas las cards del dashboard === */
#pg-dash .dash-card { animation: ds-slide-up var(--ds-tr-slow) backwards; }
#pg-dash .dash-grid > .dash-card:nth-child(1) { animation-delay: 300ms; }
#pg-dash .dash-grid > .dash-card:nth-child(2) { animation-delay: 350ms; }
#pg-dash .dash-lower > .dash-card:nth-child(1) { animation-delay: 400ms; }
#pg-dash .dash-lower > .dash-card:nth-child(2) { animation-delay: 450ms; }
#pg-dash .dash-lower > .dash-card:nth-child(3) { animation-delay: 500ms; }

/* === Cards de Reportes (en otros lugares también) === */
#pg-rep .card,
#pg-cfg .card {
  background: linear-gradient(180deg, var(--ds-surface-glow), rgba(13,17,23,.92));
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-xl);
  padding: var(--ds-s-5);
  box-shadow: var(--ds-shadow-card);
}

/* ============================================================
   INPUTS Y MODALES — Fase 1B-4 Design System
   Mejora visual de campos de formulario y ventanas emergentes.
   ============================================================ */

/* === Inputs unificados (.fi, .fs, .fta) === */
input.fi,
select.fs,
textarea.fta {
  width: 100%;
  background: var(--ds-bg-3);
  border: 1px solid var(--ds-border);
  color: var(--ds-text);
  padding: 9px 12px;
  border-radius: var(--ds-r-md);
  font-family: var(--ds-font-sans);
  font-size: var(--ds-fs-base);
  font-weight: var(--ds-fw-regular);
  outline: none;
  transition: border-color var(--ds-tr-fast),
              box-shadow var(--ds-tr-fast),
              background-color var(--ds-tr-fast);
}

input.fi:hover,
select.fs:hover,
textarea.fta:hover {
  border-color: var(--ds-text-muted);
}

input.fi:focus,
select.fs:focus,
textarea.fta:focus {
  border-color: var(--ds-primary);
  box-shadow: 0 0 0 3px rgba(88,166,255,.18);
  background: var(--ds-bg-2);
}

input.fi:disabled,
select.fs:disabled,
textarea.fta:disabled {
  opacity: .55;
  cursor: not-allowed;
}

input.fi::placeholder,
textarea.fta::placeholder {
  color: var(--ds-text-dim);
  opacity: .85;
}

/* Read-only inputs */
input.fi[readonly] {
  background: rgba(255,255,255,.02);
  cursor: default;
}

/* Textarea: resize vertical y altura mínima */
textarea.fta {
  resize: vertical;
  min-height: 72px;
  line-height: 1.5;
  font-family: var(--ds-font-sans);
}

/* Select: flecha custom (consistente entre navegadores) */
select.fs {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 36px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237d8590' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 12px;
  cursor: pointer;
}
select.fs:focus {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2358a6ff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
}

/* === Form Labels === */
.fl {
  display: block;
  font-size: var(--ds-fs-sm);
  font-weight: var(--ds-fw-semi);
  color: var(--ds-text-mute-2);
  margin-bottom: 6px;
  letter-spacing: .2px;
}

/* === Form Groups === */
.fg {
  margin-bottom: var(--ds-s-4);
}

/* === Form Grids === */
.f2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ds-s-3);
  margin-bottom: var(--ds-s-4);
}
.f3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--ds-s-3);
  margin-bottom: var(--ds-s-4);
}

/* === Inputs de búsqueda (en topbar) === */
.at-search input {
  font-family: var(--ds-font-sans);
  font-size: var(--ds-fs-base);
}
.at-search input::placeholder {
  color: var(--ds-text-dim);
}

/* === Inputs del login === */
.lbox input[type="email"],
.lbox input[type="password"] {
  width: 100%;
  padding: 11px 14px;
  background: var(--ds-bg-3);
  border: 1px solid var(--ds-border);
  color: var(--ds-text);
  border-radius: var(--ds-r-md);
  font-size: var(--ds-fs-md);
  margin-bottom: var(--ds-s-2);
  outline: none;
  transition: border-color var(--ds-tr-fast), box-shadow var(--ds-tr-fast);
}
.lbox input:focus {
  border-color: var(--ds-primary);
  box-shadow: 0 0 0 3px rgba(88,166,255,.18);
}

/* ============================================================
   MODALES — Mejora visual con blur, animación, sombras
   ============================================================ */

/* === Overlay con efecto glass === */
.ov {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(8px) saturate(1.2);
  -webkit-backdrop-filter: blur(8px) saturate(1.2);
  z-index: 200;
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--ds-s-4);
}
.ov.on {
  display: flex;
  animation: ds-fade-in .18s ease;
}

/* === Modal box === */
.modal {
  background: linear-gradient(180deg, var(--ds-surface-glow), var(--ds-bg-2));
  border: 1px solid rgba(88,166,255,.12);
  border-radius: var(--ds-r-xl);
  padding: var(--ds-s-6);
  width: 100%;
  max-width: 540px;
  max-height: 92vh;
  overflow-y: auto;
  box-shadow:
    0 20px 60px rgba(0,0,0,.5),
    0 0 0 1px rgba(255,255,255,.04) inset;
  animation: ds-zoom-in .22s cubic-bezier(.2,.9,.3,1.1);
}

/* === Header de modal === */
.mh {
  font-size: var(--ds-fs-lg);
  font-weight: var(--ds-fw-bold);
  color: var(--ds-primary);
  letter-spacing: -.3px;
  margin-bottom: var(--ds-s-4);
  padding-bottom: var(--ds-s-3);
  border-bottom: 1px solid var(--ds-border-soft);
  display: flex;
  align-items: center;
  gap: var(--ds-s-2);
}

/* === Footer de modal (botones) === */
.mf {
  display: flex;
  gap: var(--ds-s-2);
  justify-content: flex-end;
  flex-wrap: wrap;
  margin-top: var(--ds-s-5);
  padding-top: var(--ds-s-4);
  border-top: 1px solid var(--ds-border-soft);
}

/* Scrollbar fino dentro de modales */
.modal::-webkit-scrollbar {
  width: 6px;
}
.modal::-webkit-scrollbar-thumb {
  background: var(--ds-border);
  border-radius: var(--ds-r-full);
}
.modal::-webkit-scrollbar-thumb:hover {
  background: var(--ds-text-muted);
}

/* ============================================================
   DASHBOARD V2 — Centro de comando operativo
   Estilo minimalista tipo Linear / Notion / Stripe.
   "Qué hacer hoy" en vez de "estadísticas".
   ============================================================ */

/* === Saludo === */
#pg-dash .dash-greeting {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding: 28px 4px 32px;
  flex-wrap: wrap;
  gap: 16px;
}
#pg-dash .dash-date {
  font-size: 11px;
  color: var(--ds-text-muted);
  text-transform: capitalize;
  margin-bottom: 6px;
  letter-spacing: .4px;
  font-weight: 500;
}
#pg-dash .dash-hello {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -.7px;
  line-height: 1.1;
  color: var(--ds-text);
}
#pg-dash .dash-hello .wave {
  display: inline-block;
  animation: ds-wave 1.6s ease-in-out;
  transform-origin: 70% 70%;
}
#pg-dash .dash-summary {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding: 12px 20px;
  background: linear-gradient(135deg, rgba(88,166,255,.08), rgba(188,140,255,.06));
  border: 1px solid rgba(88,166,255,.15);
  border-radius: 14px;
}
#pg-dash .dash-summary-num {
  font-size: 28px;
  font-weight: 800;
  color: var(--ds-primary);
  letter-spacing: -1px;
  line-height: 1;
}
#pg-dash .dash-summary-label {
  font-size: 11px;
  color: var(--ds-text-mute-2);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
}

/* === Bloques (Pipeline, Urgente, Esta semana) === */
#pg-dash .dash-block {
  margin-bottom: 28px;
}
#pg-dash .dash-block-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--ds-text-muted);
  text-transform: uppercase;
  letter-spacing: 1.4px;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
}
#pg-dash .urgente-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--ds-danger);
  box-shadow: 0 0 0 4px rgba(248,81,73,.15);
  animation: ds-pulse 2s ease-in-out infinite;
}

/* === Pipeline operativo === */
#pg-dash .pipeline {
  display: flex;
  align-items: stretch;
  gap: 0;
  background: linear-gradient(180deg, rgba(28,33,40,.6), rgba(13,17,23,.4));
  border: 1px solid var(--ds-border-soft);
  border-radius: 16px;
  padding: 8px;
}
#pg-dash .pipeline-stage {
  flex: 1;
  min-width: 0;
  text-align: center;
  cursor: pointer;
  padding: 18px 12px 16px;
  border-radius: 12px;
  position: relative;
  transition: background-color var(--ds-tr-fast);
}
#pg-dash .pipeline-stage:hover {
  background: rgba(255,255,255,.03);
}
#pg-dash .pipeline-num {
  font-size: 32px;
  font-weight: 800;
  color: var(--ds-text);
  letter-spacing: -1px;
  line-height: 1;
  margin-bottom: 8px;
}
#pg-dash .pipeline-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--ds-text-muted);
  text-transform: uppercase;
  letter-spacing: .8px;
  margin-bottom: 4px;
}
#pg-dash .pipeline-detail {
  font-size: 11px;
  color: var(--ds-text-mute-2);
  line-height: 1.3;
  font-weight: 500;
}
#pg-dash .pipeline-arrow {
  display: flex;
  align-items: center;
  font-size: 14px;
  color: var(--ds-border);
  flex: 0 0 16px;
  user-select: none;
}
/* Estado: con pendientes (acento sutil) */
#pg-dash .pipeline-stage.has-pending .pipeline-num {
  color: var(--ds-warning);
}
#pg-dash .pipeline-stage.has-pending::after {
  content: '';
  position: absolute;
  top: 12px;
  right: 12px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ds-warning);
  box-shadow: 0 0 0 3px rgba(210,153,34,.15);
}
#pg-dash .pipeline-stage.is-empty .pipeline-num {
  color: var(--ds-text-dim);
}

/* === Grid 2 col (Urgente + Esta semana) === */
#pg-dash .dash-grid-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

/* === Lista de acciones (Urgente, Esta semana) === */
#pg-dash .action-list {
  background: linear-gradient(180deg, rgba(28,33,40,.5), rgba(13,17,23,.3));
  border: 1px solid var(--ds-border-soft);
  border-radius: 14px;
  overflow: hidden;
}
#pg-dash .action-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  background: transparent;
  cursor: pointer;
  transition: background-color var(--ds-tr-fast);
  border-top: 1px solid var(--ds-border-soft);
}
#pg-dash .action-item:first-child { border-top: none; }
#pg-dash .action-item:hover { background: rgba(255,255,255,.025); }
#pg-dash .action-marker {
  width: 3px;
  align-self: stretch;
  border-radius: 2px;
  flex-shrink: 0;
}
#pg-dash .action-marker.danger  { background: var(--ds-danger); }
#pg-dash .action-marker.warning { background: var(--ds-warning); }
#pg-dash .action-marker.info    { background: var(--ds-primary); }
#pg-dash .action-marker.success { background: var(--ds-success); }
#pg-dash .action-body {
  flex: 1;
  min-width: 0;
}
#pg-dash .action-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--ds-text);
  letter-spacing: -.1px;
  margin-bottom: 3px;
}
#pg-dash .action-meta {
  font-size: 12px;
  color: var(--ds-text-mute-2);
  font-weight: 400;
  line-height: 1.4;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
#pg-dash .action-arrow {
  color: var(--ds-text-dim);
  font-size: 18px;
  font-weight: 600;
  margin-right: -2px;
}
#pg-dash .action-empty {
  padding: 26px;
  text-align: center;
  font-size: 12px;
  color: var(--ds-text-muted);
  font-weight: 500;
}

/* === Animaciones === */
@keyframes ds-pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(.85); opacity: .7; }
}
@keyframes ds-wave {
  0%, 100% { transform: rotate(0deg); }
  20% { transform: rotate(14deg); }
  40% { transform: rotate(-8deg); }
  60% { transform: rotate(14deg); }
  80% { transform: rotate(-4deg); }
}

/* === Tira de KPIs de estado === */
#pg-dash .dash-status-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 22px;
}
#pg-dash .status-card {
  background: linear-gradient(180deg, rgba(28,33,40,.7), rgba(13,17,23,.5));
  border: 1px solid var(--ds-border-soft);
  border-radius: 14px;
  padding: 18px 18px 16px;
  cursor: pointer;
  transition: transform var(--ds-tr-fast), border-color var(--ds-tr-fast), background var(--ds-tr-fast);
  position: relative;
  overflow: hidden;
}
#pg-dash .status-card:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.12);
}
#pg-dash .status-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: var(--ds-text-dim);
}
#pg-dash .status-active::before    { background: #39d353; }
#pg-dash .status-closed::before    { background: #f85149; }
#pg-dash .status-frozen::before    { background: #7f9ac0; }
#pg-dash .status-overdue::before   { background: #d29922; }
#pg-dash .status-num {
  font-size: 28px;
  font-weight: 800;
  color: var(--ds-text);
  letter-spacing: -.5px;
  line-height: 1;
  margin-bottom: 6px;
}
#pg-dash .status-active .status-num    { color: #39d353; }
#pg-dash .status-closed .status-num    { color: #f85149; }
#pg-dash .status-frozen .status-num    { color: #7f9ac0; }
#pg-dash .status-overdue .status-num   { color: #d29922; }
#pg-dash .status-lbl {
  font-size: 11px;
  color: var(--ds-text-mute-2);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
}

/* === Página congelada (Archivados) — vibe de hielo === */
.pg-frozen {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(ellipse at top, rgba(127,154,192,.10), transparent 70%),
    radial-gradient(ellipse at bottom right, rgba(88,166,255,.06), transparent 60%);
  border-radius: 16px;
  padding: 22px;
  min-height: 60vh;
}
.pg-frozen::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(127,154,192,.05), transparent 40%);
  pointer-events: none;
}
.frozen-snowflakes {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
}
.frozen-snowflakes span {
  position: absolute;
  color: rgba(173,216,230,.25);
  font-size: 18px;
  animation: frozen-float 12s ease-in-out infinite;
  user-select: none;
}
.frozen-snowflakes span:nth-child(2n) { font-size: 14px; animation-delay: -3s; animation-duration: 16s; }
.frozen-snowflakes span:nth-child(3n) { font-size: 22px; animation-delay: -6s; animation-duration: 20s; color: rgba(173,216,230,.18); }
.frozen-snowflakes span:nth-child(5n) { font-size: 11px; animation-delay: -9s; color: rgba(206,225,238,.32); }
@keyframes frozen-float {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  25%      { transform: translate(8px, 6px) rotate(8deg); }
  50%      { transform: translate(-4px, 12px) rotate(-6deg); }
  75%      { transform: translate(-8px, 4px) rotate(4deg); }
}

/* Tablas de Archivados con tinte frio */
.pg-frozen .tw,
.pg-frozen #obs-ct > * {
  background: linear-gradient(180deg, rgba(28,42,58,.65), rgba(13,17,23,.55));
  border-color: rgba(127,154,192,.22);
}
.pg-frozen #obs-ct th {
  color: #cce4f5 !important;
}
.pg-frozen #obs-ct .pendiente,
.pg-frozen #obs-ct td[style*="color:#f59e0b"] {
  filter: hue-rotate(180deg) saturate(.8);
}

/* === Sidebar: Configuración (engranaje con menu desplegable) === */
.sb-cfg-wrap {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,.06);
  position: relative;
}
.sb-cfg-trigger {
  display: flex;
  align-items: center;
  gap: 11px;
  width: 100%;
  padding: 9px 12px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 9px;
  color: var(--ds-text-mute-2, #94a3b8);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color var(--ds-tr-fast), color var(--ds-tr-fast);
  text-align: left;
}
.sb-cfg-trigger i {
  font-size: 14px;
  width: 16px;
  text-align: center;
}
.sb-cfg-trigger:hover {
  background: rgba(255,255,255,.05);
  color: #fff;
}

/* Menu flotante estilo Claude (oscuro, sombras, popover) */
.sb-cfg-menu {
  display: none;
  position: absolute;
  left: 4px;
  bottom: calc(100% + 6px);
  width: 220px;
  background: #1f2532;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  padding: 6px;
  box-shadow: 0 12px 36px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.03);
  z-index: 200;
  flex-direction: column;
  gap: 2px;
}
.sb-cfg-menu.open { display: flex; }

.sb-cfg-menu .sb-cfg-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 12px;
  background: transparent;
  border: none;
  border-radius: 8px;
  color: #e6edf3;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color var(--ds-tr-fast);
  text-align: left;
  width: 100%;
}
.sb-cfg-menu .sb-cfg-item i {
  font-size: 14px;
  width: 18px;
  text-align: center;
  color: var(--ds-text-mute-2, #94a3b8);
}
.sb-cfg-menu .sb-cfg-item:hover {
  background: rgba(255,255,255,.06);
}
.sb-cfg-menu .sb-cfg-item:hover i { color: #fff; }

@media (max-width:1100px){
  .sb-cfg-trigger span { display: none; }
  .sb-cfg-trigger { justify-content: center; padding: 9px 0; }
  .sb-cfg-menu { width: 200px; left: calc(100% + 6px); bottom: 0; }
}

/* === Dashboard layout principal (izquierda gráficos + derecha avisos) === */
#pg-dash .dash-main {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 20px;
  align-items: start;
}
#pg-dash .dash-main-left { min-width: 0; }
#pg-dash .dash-main-right {
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: sticky;
  top: 14px;
}
@media (max-width: 1100px) {
  #pg-dash .dash-main { grid-template-columns: 1fr; }
  #pg-dash .dash-main-right { position: static; }
}

/* === Panel de avisos pendientes === */
#pg-dash .dash-avisos {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
#pg-dash .d-aviso {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.04);
  border-radius: 12px;
  cursor: pointer;
  transition: background-color var(--ds-tr-fast), border-color var(--ds-tr-fast), transform var(--ds-tr-fast);
}
#pg-dash .d-aviso:hover {
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.10);
  transform: translateX(-2px);
}
#pg-dash .d-aviso-empty {
  opacity: .45;
  cursor: default;
}
#pg-dash .d-aviso-empty:hover {
  background: rgba(255,255,255,.025);
  border-color: rgba(255,255,255,.04);
  transform: none;
}
#pg-dash .d-aviso-ic {
  width: 38px; height: 38px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
}
#pg-dash .d-aviso-body { flex: 1; min-width: 0; }
#pg-dash .d-aviso-count {
  font-size: 22px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -.5px;
  margin-bottom: 2px;
}
#pg-dash .d-aviso-lbl {
  font-size: 12px;
  color: var(--ds-text);
  font-weight: 600;
}
#pg-dash .d-aviso-sub {
  font-size: 10px;
  color: var(--ds-text-mute-2, #94a3b8);
  margin-top: 1px;
  font-weight: 500;
}

/* === Bloques del dashboard (cards genéricos) === */
#pg-dash .dash-block {
  background: linear-gradient(180deg, rgba(28,33,40,.6), rgba(13,17,23,.4));
  border: 1px solid var(--ds-border-soft);
  border-radius: 16px;
  padding: 20px 22px;
  margin-bottom: 20px;
}
#pg-dash .dash-block-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--ds-text);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
  letter-spacing: -.1px;
}
#pg-dash .dash-block-title i { font-size: 14px; }

/* === Lista de alertas (alert-list / alert-item) === */
#pg-dash .alert-list { display: flex; flex-direction: column; gap: 10px; }
#pg-dash .alert-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.04);
  border-radius: 12px;
  cursor: pointer;
  transition: background-color var(--ds-tr-fast), border-color var(--ds-tr-fast);
}
#pg-dash .alert-item:hover {
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.08);
}
#pg-dash .alert-icon {
  width: 38px; height: 38px;
  border-radius: 11px;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
}
#pg-dash .alert-text { flex: 1; min-width: 0; }
#pg-dash .alert-text h4 {
  font-size: 13px;
  font-weight: 700;
  color: var(--ds-text);
  margin: 0 0 3px 0;
  letter-spacing: -.1px;
}
#pg-dash .alert-text p {
  font-size: 12px;
  color: var(--ds-text-mute-2);
  margin: 0;
  font-weight: 500;
}
#pg-dash .alert-time {
  display: flex; align-items: center; gap: 8px;
  flex-shrink: 0;
}
#pg-dash .alert-time span {
  font-size: 11px;
  color: var(--ds-text-muted);
  white-space: nowrap;
}
#pg-dash .alert-arrow {
  font-size: 11px;
  color: var(--ds-text-dim);
}

/* === Actividad reciente (timeline simple) === */
#pg-dash .activity { display: flex; flex-direction: column; gap: 16px; padding: 4px 4px; }
#pg-dash .activity-item {
  display: flex; gap: 14px;
  align-items: flex-start;
  position: relative;
}
#pg-dash .activity-item .dot {
  width: 11px; height: 11px;
  border-radius: 50%;
  margin-top: 4px;
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(13,17,23,.6);
}
#pg-dash .activity-item p {
  font-size: 13px;
  font-weight: 600;
  color: var(--ds-text);
  margin: 0;
  line-height: 1.3;
}
#pg-dash .activity-item span {
  font-size: 11px;
  color: var(--ds-text-mute-2);
}
#pg-dash .activity-time {
  display: block;
  font-size: 10px;
  color: var(--ds-text-muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .4px;
  margin-bottom: 1px;
}

/* === Carga por colaborador === */
#pg-dash .cobars-list { display: flex; flex-direction: column; gap: 14px; }
#pg-dash .coord-row {
  display: flex; gap: 12px;
  align-items: center;
}
#pg-dash .coord-av {
  width: 36px; height: 36px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
  font-size: 14px;
  color: #fff;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
}
#pg-dash .coord-info { flex: 1; min-width: 0; }
#pg-dash .coord-info-top {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 6px;
}
#pg-dash .coord-info-top b {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -.1px;
}
#pg-dash .coord-info-top span {
  font-size: 11px;
  color: var(--ds-text-mute-2);
  font-weight: 500;
}
#pg-dash .coord-row .bar {
  height: 6px;
  background: rgba(255,255,255,.05);
  border-radius: 999px;
  overflow: hidden;
}
#pg-dash .coord-row .bar .fill {
  height: 100%;
  border-radius: 999px;
  transition: width .4s ease;
}

/* === Leyenda del donut === */
#pg-dash .status-legend {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--ds-border-soft);
}
#pg-dash .leg-item {
  display: flex;
  align-items: center;
  gap: 10px;
}
#pg-dash .leg-dot {
  width: 10px; height: 10px; border-radius: 50%;
  flex-shrink: 0;
}
#pg-dash .leg-name {
  font-size: 12px;
  color: var(--ds-text);
  font-weight: 600;
  flex: 1;
}
#pg-dash .leg-val {
  font-size: 11px;
  color: var(--ds-text-mute-2);
  font-weight: 600;
}

/* === Indicadores === */
#pg-ind .ind-bloque {
  background: linear-gradient(180deg, rgba(28,33,40,.6), rgba(13,17,23,.4));
  border: 1px solid var(--ds-border-soft);
  border-radius: 14px;
  padding: 18px 22px 20px;
  margin-bottom: 18px;
}
#pg-ind .ind-bloque-h {
  font-size: 14px; font-weight: 800; color: #fff;
  margin: 0 0 14px;
  letter-spacing: -.1px;
  display: flex; align-items: center; gap: 10px;
}
#pg-ind .ind-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}
#pg-ind .ind-kpi {
  background: rgba(255,255,255,.025);
  padding: 14px 16px;
  border-radius: 10px;
}
#pg-ind .ind-kpi-lbl {
  font-size: 10px; font-weight: 700;
  color: var(--ds-text-mute-2, #94a3b8);
  text-transform: uppercase;
  letter-spacing: .5px;
}
#pg-ind .ind-kpi-val {
  font-size: 22px; font-weight: 800;
  margin-top: 4px;
  letter-spacing: -.5px;
}
#pg-ind .ind-kpi-sub {
  font-size: 11px; color: var(--ds-text-mute-2, #94a3b8);
  margin-top: 4px;
}
#pg-ind .ind-tabla table { width: 100%; border-collapse: collapse; }
#pg-ind .ind-tabla th {
  font-size: 10px; font-weight: 800; color: var(--ds-text-mute-2, #94a3b8);
  text-transform: uppercase; letter-spacing: .5px;
  padding: 10px; text-align: left;
  border-bottom: 1px solid var(--ds-border-soft);
}
#pg-ind .ind-tabla td {
  padding: 10px; font-size: 13px; color: #fff;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
#pg-ind .ind-tabla tr:last-child td { border-bottom: none; }
#pg-ind .ind-av {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  color: #fff; font-weight: 800; font-size: 12px;
  margin-right: 9px; vertical-align: middle;
}
#pg-ind .ind-vacio {
  padding: 14px; text-align: center;
  color: var(--ds-text-mute-2, #94a3b8);
  font-size: 12px;
  font-style: italic;
}
#pg-ind .ind-cnt {
  font-size: 10px; font-weight: 700;
  padding: 2px 9px; border-radius: var(--ds-r-full);
  background: rgba(255,255,255,.06); color: var(--ds-text-mute-2, #94a3b8);
}
.ind-sueldos {
  display: flex; flex-direction: column; gap: 8px;
}
.ind-sueldo-row {
  display: flex; align-items: center; gap: 14px;
  padding: 10px 12px;
  background: rgba(255,255,255,.025);
  border-radius: 8px;
  flex-wrap: wrap;
}
.ind-sueldo-row input:focus {
  border-color: #58a6ff; outline: none;
}
#pg-ind .ind-chip {
  display: inline-block;
  padding: 3px 9px;
  border-radius: var(--ds-r-full);
  font-size: 10px;
  font-weight: 700;
  border: 1px solid;
  margin: 1px 3px 1px 0;
}

/* === Modal info (custom, reemplaza alert nativo) === */
.ov-info {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.65);
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(4px);
}
.ov-info-box {
  background: linear-gradient(180deg, #1c2128, #0d1117);
  border: 1px solid var(--ds-border-soft);
  border-radius: 16px;
  padding: 22px 26px 18px;
  min-width: 320px;
  max-width: 480px;
  box-shadow: 0 20px 60px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.04);
}
.ov-info-header {
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--ds-border-soft);
  letter-spacing: -.1px;
}
.ov-info-body { margin-bottom: 18px; }
.ov-info-body .oi-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 7px 0;
  font-size: 13px;
}
.ov-info-body .oi-lbl {
  color: var(--ds-text-mute-2, #94a3b8);
  text-transform: uppercase;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .5px;
}
.ov-info-body .oi-val { color: #fff; font-weight: 600; }
.ov-info-body .oi-entregable {
  margin-top: 12px;
  padding: 14px 16px;
  background: rgba(63,185,80,.10);
  border: 1px solid rgba(63,185,80,.25);
  border-radius: 10px;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  text-align: center;
}
.ov-info-foot { text-align: right; }
.ov-info-foot .btn { padding: 8px 22px; font-weight: 700; }

/* === Carga & Gantt — tabla unificada === */
#pg-carga .carga-tabla tr.carga-grp td {
  height: 40px; box-sizing: border-box; /* matchea con .gdr en Gantt */
  border-left: 3px solid;
  border-color: inherit;
}
#pg-carga .carga-tabla tr.carga-tot td {
  height: 42px; box-sizing: border-box; /* matchea con .gtot en Gantt */
  padding: 10px;
}

/* === Seguimiento — bloques === */
#pg-seg .seg-bloque {
  background: linear-gradient(180deg, rgba(28,33,40,.6), rgba(13,17,23,.4));
  border: 1px solid var(--ds-border-soft);
  border-radius: 14px;
  padding: 16px 20px 18px;
  margin-bottom: 18px;
}
#pg-seg .seg-bloque-h {
  font-size: 14px; font-weight: 800; color: #fff;
  margin: 0 0 12px; padding-left: 10px;
  border-left: 3px solid #888;
  display: flex; align-items: center; gap: 10px;
  letter-spacing: -.1px;
}
#pg-seg .seg-cnt {
  font-size: 11px; font-weight: 700;
  padding: 2px 9px; border-radius: var(--ds-r-full);
  background: rgba(255,255,255,.06); color: var(--ds-text-mute-2);
}
#pg-seg .seg-vacio { font-size: 12px; color: var(--ds-text-mute-2); padding: 8px 4px; }
#pg-seg .seg-tabla table { width: 100%; border-collapse: collapse; }
#pg-seg .seg-tabla tr:hover td { background: rgba(255,255,255,.02); }
#pg-seg select option { background: var(--ds-bg-2, #161b22); color: #fff; }

/* === Seguimiento === */
#pg-seg .empty {
  background: linear-gradient(180deg, rgba(28,33,40,.5), rgba(13,17,23,.3));
  border: 1px solid var(--ds-border-soft);
  border-radius: 14px;
}
#pg-seg .tw {
  background: linear-gradient(180deg, rgba(28,33,40,.5), rgba(13,17,23,.3));
  border: 1px solid var(--ds-border-soft);
  border-radius: 14px;
  overflow: hidden;
}
#pg-seg table th {
  background: rgba(255,255,255,.03);
  border-bottom: 1px solid var(--ds-border-soft);
}
#pg-seg select option {
  background: var(--ds-bg-2, #161b22);
  color: #fff;
}

/* === Gestion: resumen card del header === */
#pg-gest .gest-resumen { display: flex; }
#pg-gest .gest-res-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  background: linear-gradient(180deg, rgba(28,33,40,.6), rgba(13,17,23,.4));
  border: 1px solid;
  border-radius: 12px;
}
#pg-gest .gest-res-num {
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -.5px;
  line-height: 1;
}
#pg-gest .gest-res-lbl {
  font-size: 10px;
  color: var(--ds-text-mute-2, #94a3b8);
  text-transform: uppercase;
  letter-spacing: .5px;
  font-weight: 700;
  line-height: 1.25;
}

/* === Gestion (nuevos / en progreso / post-servicio) === */
#pg-gest .gest-bloque {
  background: linear-gradient(180deg, rgba(28,33,40,.55), rgba(13,17,23,.35));
  border: 1px solid var(--ds-border-soft);
  border-radius: 14px;
  padding: 18px 22px 20px;
  margin-bottom: 16px;
  transition: border-color var(--ds-tr-fast);
}
#pg-gest .gest-bloque:hover { border-color: rgba(255,255,255,.10); }
#pg-gest .gest-bloque-h {
  font-size: 14px;
  font-weight: 800;
  color: #fff;
  margin: 0 0 14px;
  padding-left: 12px;
  border-left: 3px solid #888;
  display: flex;
  align-items: center;
  gap: 10px;
  letter-spacing: -.1px;
}
#pg-gest .gest-cnt {
  font-size: 11px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: var(--ds-r-full);
  background: rgba(255,255,255,.06);
  color: var(--ds-text-mute-2);
}
#pg-gest .gest-vacio {
  font-size: 12px;
  color: var(--ds-text-mute-2);
  padding: 14px 4px 6px;
  font-style: italic;
  text-align: center;
  opacity: .7;
}
#pg-gest .gest-tabla table {
  width: 100%;
  border-collapse: collapse;
}
#pg-gest .gest-tabla th {
  font-size: 10px;
  font-weight: 800;
  color: var(--ds-text-mute-2);
  text-transform: uppercase;
  letter-spacing: .5px;
  padding: 8px 10px;
  text-align: left;
  border-bottom: 1px solid var(--ds-border-soft);
}
#pg-gest .gest-tabla td {
  padding: 10px;
  font-size: 12px;
  color: var(--ds-text);
  border-bottom: 1px solid rgba(255,255,255,.04);
}
#pg-gest .gest-tabla tr:last-child td { border-bottom: none; }
#pg-gest .gest-tabla tr:hover td { background: rgba(255,255,255,.02); }
#pg-gest .gest-td-nro { color: var(--ds-text-mute-2); font-weight: 600; width: 56px; }
#pg-gest .gest-td-nom { font-weight: 700; }
#pg-gest .gest-td-car { color: var(--ds-text-mute-2); white-space: nowrap; }
#pg-gest .gest-td-ent { color: var(--ds-text-mute-2); }
#pg-gest .gest-td-asg { width: 200px; }
#pg-gest .gest-td-send { width: 140px; text-align: right; }
#pg-gest .gest-sel {
  background: var(--ds-bg-2,#161b22); color: #fff;
  border: 1px solid var(--ds-border-soft);
  padding: 7px 10px; border-radius: 6px; font-size: 12px;
  width: 100%; cursor: pointer; outline: none;
}
#pg-gest .gest-sel:focus { border-color: #58a6ff; }
#pg-gest .gest-btn-send {
  background: linear-gradient(180deg,#58a6ff,#3b82f6);
  color: #fff; border: none;
  padding: 7px 14px; border-radius: 6px; cursor: pointer;
  font-size: 11px; font-weight: 700; letter-spacing: .3px;
  display: inline-flex; align-items: center; gap: 6px;
  box-shadow: 0 2px 8px rgba(88,166,255,.25);
}
#pg-gest .gest-btn-send:hover { filter: brightness(1.1); }
#pg-gest .gest-btn-sent {
  background: rgba(63,185,80,.18); color: #3fb950;
  border: 1px solid rgba(63,185,80,.35);
  padding: 7px 14px; border-radius: 6px;
  font-size: 11px; font-weight: 800;
  cursor: default;
}

/* === Colaboradores === */
#pg-col .col-bloque {
  background: linear-gradient(180deg, rgba(28,33,40,.6), rgba(13,17,23,.4));
  border: 1px solid var(--ds-border-soft);
  border-radius: 14px;
  padding: 16px 20px 18px;
  margin-bottom: 18px;
}
#pg-col .col-bloque-h {
  font-size: 14px; font-weight: 800; color: #fff;
  margin: 0 0 12px; padding-left: 10px;
  border-left: 3px solid #888;
  display: flex; align-items: center; gap: 10px;
  letter-spacing: -.1px;
}
#pg-col .col-cnt {
  font-size: 11px; font-weight: 700;
  padding: 2px 9px; border-radius: var(--ds-r-full);
  background: rgba(255,255,255,.06); color: var(--ds-text-mute-2);
}
#pg-col .col-vacio { font-size: 12px; color: var(--ds-text-mute-2); padding: 8px 4px; font-style: italic; }
#pg-col .col-tabla table { width: 100%; border-collapse: collapse; }
#pg-col .col-tabla th {
  font-size: 10px; font-weight: 800; color: var(--ds-text-mute-2);
  text-transform: uppercase; letter-spacing: .5px;
  padding: 8px 10px; text-align: left;
  border-bottom: 1px solid var(--ds-border-soft);
}
#pg-col .col-tabla td {
  padding: 12px 10px; font-size: 13px; color: var(--ds-text);
  border-bottom: 1px solid rgba(255,255,255,.04);
}
#pg-col .col-tabla tr:last-child td { border-bottom: none; }
#pg-col .col-td-av { width: 50px; }
#pg-col .col-av {
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px; border-radius: 50%;
  color: #fff; font-weight: 800; font-size: 14px;
}
#pg-col .col-td-nom { font-weight: 700; }
#pg-col .col-td-sueldo { width: 170px; white-space: nowrap; }
#pg-col .col-td-costo  { width: 130px; font-size: 13px; }
#pg-col .col-td-act    { width: 130px; text-align: right; }
#pg-col .col-td-sueldo input:focus { border-color: #58a6ff; }
#pg-col .col-dir-badge {
  font-size: 9px; font-weight: 800; padding: 2px 7px;
  background: rgba(251,191,36,.18); color: #fbbf24;
  border-radius: var(--ds-r-full); margin-left: 6px;
}
#pg-col .col-inact-badge {
  font-size: 9px; font-weight: 800; padding: 2px 7px;
  background: rgba(255,255,255,.06); color: var(--ds-text-mute-2);
  border-radius: var(--ds-r-full); margin-left: 6px;
}

/* === Auditoría (timeline) === */
#pg-audit .audit-timeline {
  position: relative;
  padding-left: 24px;
  border-left: 2px solid var(--ds-border-soft);
  display: flex;
  flex-direction: column;
  gap: 14px;
}
#pg-audit .audit-row {
  position: relative;
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 14px;
  align-items: flex-start;
}
#pg-audit .audit-bullet {
  position: absolute;
  left: -32px;
  top: 18px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  box-shadow: 0 0 0 4px rgba(13,17,23,1);
}
#pg-audit .audit-time {
  font-size: 11px;
  color: var(--ds-text-mute-2);
  font-weight: 600;
  padding-top: 16px;
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: .3px;
}
#pg-audit .audit-card {
  background: linear-gradient(180deg, rgba(28,33,40,.5), rgba(13,17,23,.3));
  border: 1px solid var(--ds-border-soft);
  border-radius: 12px;
  padding: 12px 16px;
}
#pg-audit .audit-card-head {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
  font-size: 13px;
  margin-bottom: 4px;
}
#pg-audit .audit-ic { font-size: 14px; }
#pg-audit .audit-act { color: var(--ds-text); font-weight: 500; }
#pg-audit .audit-target {
  font-size: 12px;
  color: var(--ds-text-mute-2);
  margin-top: 4px;
}
#pg-audit .audit-detail {
  font-size: 11px;
  color: var(--ds-text-muted);
  margin-top: 2px;
}
@media (max-width: 700px) {
  #pg-audit .audit-row { grid-template-columns: 1fr; }
  #pg-audit .audit-time { padding-top: 0; }
}

/* === Responsive === */
@media (max-width: 900px) {
  #pg-dash .dash-grid-2col { grid-template-columns: 1fr; }
  #pg-dash .dash-status-strip { grid-template-columns: 1fr 1fr; }
  #pg-dash .pipeline {
    flex-direction: column;
    gap: 4px;
  }
  #pg-dash .pipeline-arrow {
    transform: rotate(90deg);
    align-self: center;
    padding: 4px 0;
  }
}
@media (max-width: 600px) {
  #pg-dash .dash-status-strip { grid-template-columns: 1fr; }
}
