@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;700;800&display=swap');

body,
html {
  font-family: 'Montserrat', 'Source Sans Pro', Arial, sans-serif;
  font-weight: 400;
  font-size: 12.5px;
  background-color: #f5f7fa;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: 700;
}

p, input, button, label, select, textarea {
  font-weight: 400;
}

.wrapper > section {
  background-color: #f5f7fa;
}

.wrapper > .aside {
  background-color: #fff;
}

.btn__dashboard {
  width: 2.5rem;
}

.text-white {
  color: #fff !important;
}

.widget-description {
  color: rgba(255, 255, 255, 0.8);
  font-size: 0.9em;
}

.bg-govco-purple { background-color: #4B286D; }
.bg-govco-red { background-color: #A80521; }
.bg-govco-orange { background-color: #FF6E00; }
.bg-govco-yellow { background-color: #FFD200; }
.bg-govco-green { background-color: #069169; }
.bg-govco-purple-dark { background-color: #3A1F55; }
.bg-govco-red-dark { background-color: #86041A; }
.bg-govco-orange-dark { background-color: #CC5800; }
.bg-govco-yellow-dark { background-color: #CCA800; }
.bg-govco-green-dark { background-color: #057354; }

.bg-govco-yellow,
.bg-govco-yellow-dark {
  color: #000 !important;
}

.bg-govco-yellow .widget-description,
.text-dark .widget-description {
  color: rgba(0, 0, 0, 0.7) !important;
}

.text-dark,
.text-dark.text-white,
.text-dark .text-white,
.text-dark .fa {
  color: #000 !important;
}

.gd-public-theme-toggle {
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 50;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(26,54,93,.16);
  border-radius: 12px;
  background: rgba(255,255,255,.86);
  color: #1A365D;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 24px rgba(26,54,93,.12);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s, transform .12s;
}

.gd-public-theme-toggle:hover {
  background: #fff;
  color: #22456e;
  transform: translateY(-1px);
}

.gd-public-theme-toggle i {
  font-size: 1rem;
}

[data-theme="dark"] .gd-public-theme-toggle {
  background: rgba(22,32,50,.88);
  border-color: #2D3748;
  color: #E2E8F0;
  box-shadow: 0 8px 24px rgba(0,0,0,.28);
}

[data-theme="dark"] .gd-public-theme-toggle:hover {
  background: #1E2D47;
  color: #fff;
}

[data-theme="dark"] .gdl,
[data-theme="dark"] .gdr,
[data-theme="dark"] .gd-recover,
[data-theme="dark"] .gd-reset,
[data-theme="dark"] .gd-verify {
  background-color: #131B2E !important;
  background-image: radial-gradient(circle, rgba(99, 179, 237, .14) 1px, transparent 1px) !important;
}

[data-theme="dark"] .gdl__body,
[data-theme="dark"] .gdr__card,
[data-theme="dark"] .gd-recover__card,
[data-theme="dark"] .gd-reset__card,
[data-theme="dark"] .gd-verify__card {
  background: #1E2D47 !important;
  color: #E2E8F0 !important;
  border-color: #2D3748 !important;
}

[data-theme="dark"] .gdl__logo,
[data-theme="dark"] .gdr__logo,
[data-theme="dark"] .gd-recover__logo,
[data-theme="dark"] .gd-reset__logo,
[data-theme="dark"] .gd-verify__logo {
  filter: brightness(0) invert(1);
}

[data-theme="dark"] .gdl__lbl,
[data-theme="dark"] .gdr__lbl,
[data-theme="dark"] .gd-recover__label,
[data-theme="dark"] .gd-reset__label {
  color: #A0AEC0 !important;
}

[data-theme="dark"] .gdl__inp,
[data-theme="dark"] .gdr__inp,
[data-theme="dark"] .gd-recover__input,
[data-theme="dark"] .gd-reset__input,
[data-theme="dark"] .gdr__select .ui-select-bootstrap > .ui-select-match > .btn {
  background: #162032 !important;
  border-color: #2D3748 !important;
  color: #E2E8F0 !important;
}

[data-theme="dark"] .gdl__inp::placeholder,
[data-theme="dark"] .gdr__inp::placeholder,
[data-theme="dark"] .gd-recover__input::placeholder,
[data-theme="dark"] .gd-reset__input::placeholder,
[data-theme="dark"] .gdr__select .ui-select-placeholder {
  color: #718096 !important;
}

[data-theme="dark"] .gdr__select .ui-select-match-text {
  color: #E2E8F0 !important;
}

[data-theme="dark"] .gdr__select .ui-select-choices,
[data-theme="dark"] .gdr__select .dropdown-menu {
  background: #162032 !important;
  border-color: #2D3748 !important;
  box-shadow: 0 18px 36px rgba(0, 0, 0, .32) !important;
}

[data-theme="dark"] .gdr__select .ui-select-choices-row > a {
  color: #E2E8F0 !important;
}

[data-theme="dark"] .gdr__select .ui-select-choices-row.active > a,
[data-theme="dark"] .gdr__select .ui-select-choices-row > a:hover {
  background: #22456e !important;
  color: #fff !important;
}

[data-theme="dark"] .gdl__icon,
[data-theme="dark"] .gdr__icon,
[data-theme="dark"] .gd-recover__input-icon,
[data-theme="dark"] .gd-reset__input-icon,
[data-theme="dark"] .gd-reset__eye {
  color: #8EA4C8 !important;
}

[data-theme="dark"] .gdl__footer,
[data-theme="dark"] .gdr__footer,
[data-theme="dark"] .gd-recover__footer,
[data-theme="dark"] .gd-reset__footer,
[data-theme="dark"] .gd-verify__footer,
[data-theme="dark"] .gd-recover__desc,
[data-theme="dark"] .gd-reset__desc,
[data-theme="dark"] .gd-verify__desc,
[data-theme="dark"] .gd-reset__back {
  color: #A0AEC0 !important;
}

[data-theme="dark"] .gd-recover__heading,
[data-theme="dark"] .gd-reset__heading,
[data-theme="dark"] .gd-verify__status {
  color: #F7FAFC !important;
}

/* =======================================================
   GESDOC — Sistema de diseño global
   Aplica a todas las vistas de listado (.admin-panel)
   ======================================================= */

/* ── Layout con topbar fija ── */
.topnavbar-wrapper {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 1050;
    height: 52px;
}
.aside {
    top: 52px !important;
    height: calc(100vh - 52px) !important;
}
.aside-inner {
    height: 100% !important;
}
section {
    padding-top: 52px;
}

/* --- Variables de diseño --- */
:root {
  --gd-primary:         #1A365D;
  --gd-primary-dark:    #152D4E;
  --gd-primary-hover:   #1e3f6d;
  --gd-primary-light:   #EBF4FF;
  --gd-primary-border:  #BEE3F8;
  --gd-success:         #2E7D32;
  --gd-success-hover:   #276529;
  --gd-danger:          #C62828;
  --gd-danger-bg:       #FFF5F5;
  --gd-warning:         #D97706;
  --gd-text:            #1A202C;
  --gd-text-secondary:  #4A5568;
  --gd-text-muted:      #718096;
  --gd-border:          #E2E8F0;
  --gd-bg:              #F7FAFC;
  --gd-bg-row-alt:      #FAFBFD;
  --gd-white:           #FFFFFF;
  --gd-radius:          8px;
  --gd-radius-sm:       4px;
  --gd-shadow-sm:       0 1px 3px rgba(0,0,0,0.08);
  --gd-shadow:          0 2px 8px rgba(0,0,0,0.07);
  --gd-font-sm:         0.875rem;
  --gd-font-base:       0.95rem;
  --gd-font-md:         1rem;
}

/* -------------------------------------------------------
   Panel contenedor principal
   ------------------------------------------------------- */
.admin-panel {
  padding: 1.25rem 1.5rem;
  color: var(--gd-text);
  box-sizing: border-box;
}

/* -------------------------------------------------------
   Encabezado de sección
   ------------------------------------------------------- */
.title-header {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 1.25rem;
  padding-bottom: 0.85rem;
  border-bottom: 2px solid var(--gd-primary-light);
}
.title-header img {
  width: 26px;
  height: 26px;
  object-fit: contain;
  flex-shrink: 0;
}
.title-text {
  margin: 0;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--gd-primary);
  letter-spacing: -0.01em;
  line-height: 1.2;
}

/* Badge opcional junto al título: total de registros, etc. */
.title-badge {
  margin-left: auto;
  background: var(--gd-primary-light);
  color: var(--gd-primary);
  font-size: 0.72rem;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 12px;
  border: 1px solid var(--gd-primary-border);
  white-space: nowrap;
}

/* -------------------------------------------------------
   Barra de búsqueda / acciones
   ------------------------------------------------------- */
.search-form {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
  align-items: center;
}
.search-input {
  flex: 1 1 220px;
  height: 36px;
  padding: 0 0.75rem;
  border: 1.5px solid var(--gd-border);
  border-radius: var(--gd-radius-sm);
  font-size: var(--gd-font-base);
  color: var(--gd-text);
  background: var(--gd-white);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.search-input:focus {
  outline: none;
  border-color: var(--gd-primary);
  box-shadow: 0 0 0 3px rgba(26,54,93,0.12);
}
.search-input::placeholder { color: var(--gd-text-muted); }

/* -------------------------------------------------------
   Botones
   ------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  height: 36px;
  padding: 0 1rem;
  border-radius: var(--gd-radius-sm);
  border: none;
  font-size: var(--gd-font-base);
  font-weight: 500;
  cursor: pointer;
  transition: background 0.2s;
  white-space: nowrap;
  user-select: none;
  text-decoration: none;
}
.btn-primary  { background: var(--gd-primary);  color: #fff; }
.btn-primary:hover  { background: var(--gd-primary-dark); color: #fff; }
.btn-success  { background: var(--gd-success);  color: #fff; }
.btn-success:hover  { background: var(--gd-success-hover); color: #fff; }
.btn-danger   { background: var(--gd-danger);   color: #fff; }
.btn-danger:hover   { background: #a82020; color: #fff; }
.btn-warning  { background: var(--gd-warning);  color: #fff; }
.btn-warning:hover  { background: #b86005; color: #fff; }
.btn-default, .btn-secondary {
  background: var(--gd-white);
  color: var(--gd-text);
  border: 1.5px solid var(--gd-border);
}
.btn-default:hover, .btn-secondary:hover {
  background: var(--gd-bg);
  border-color: #cbd5e0;
}
.btn-sm {
  height: 30px;
  padding: 0 0.7rem;
  font-size: var(--gd-font-sm);
}

/* -------------------------------------------------------
   Tabla — contenedor
   ------------------------------------------------------- */
.table-wrapper {
  width: 100%;
  overflow-x: auto;
  border-radius: var(--gd-radius);
  border: 1px solid var(--gd-border);
  background: var(--gd-white);
  box-shadow: var(--gd-shadow-sm);
}

/* -------------------------------------------------------
   Tabla de datos
   ------------------------------------------------------- */
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--gd-font-base);
}

/* Encabezado */
.data-table thead tr {
  background: var(--gd-primary);
}
.data-table thead th {
  padding: 0.65rem 1rem;
  text-align: left;
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.95);
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
  border: none;
  position: relative;
}
.data-table thead th:hover {
  background: rgba(255,255,255,0.08);
}
/* Ícono de orden en encabezados */
.data-table thead th .fa {
  opacity: 0.6;
  margin-left: 4px;
  font-size: 0.75rem;
}
.data-table thead th .fa-caret-down,
.data-table thead th .fa-caret-up,
.data-table thead th .fa-sort-desc,
.data-table thead th .fa-sort-asc {
  opacity: 1;
  color: #fff;
}

/* Filas */
.data-table tbody tr {
  border-bottom: 1px solid var(--gd-border);
  transition: background 0.12s;
}
.data-table tbody tr:last-child { border-bottom: none; }
.data-table tbody tr:nth-child(even) { background: var(--gd-bg-row-alt); }
.data-table tbody tr:hover { background: var(--gd-primary-light) !important; }

/* Celdas */
.data-table tbody td {
  padding: 0.7rem 1rem;
  vertical-align: middle;
  color: var(--gd-text);
}

/* -------------------------------------------------------
   Columna de acciones
   ------------------------------------------------------- */
.actions-col { width: 1%; white-space: nowrap; text-align: center !important; }
.actions {
  display: flex;
  justify-content: center;
  gap: 0.25rem;
}
.icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: var(--gd-radius-sm);
  border: none;
  background: var(--gd-bg);
  color: var(--gd-text-secondary);
  font-size: 0.85rem;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.icon-btn:hover { background: var(--gd-primary); color: #fff; }
.icon-btn.delete { background: var(--gd-danger-bg); color: var(--gd-danger); }
.icon-btn.delete:hover { background: var(--gd-danger); color: #fff; }
.icon-btn.view { background: #EBF4FF; color: var(--gd-primary); }
.icon-btn.view:hover { background: var(--gd-primary); color: #fff; }
.icon-btn.toggle-active { background: #E8F5E9; color: #2E7D32; }
.icon-btn.toggle-active:hover { background: #2E7D32; color: #fff; }
.icon-btn.toggle-inactive { background: #FFEBEE; color: #C62828; }
.icon-btn.toggle-inactive:hover { background: #C62828; color: #fff; }
tr.row-inactive td { opacity: 0.55; }

/* -------------------------------------------------------
   Matriz de permisos por rol
-------------------------------------------------------- */
.permisos-table { table-layout: fixed; }
.permisos-table .perm-col-module { width: auto; }
.permisos-table .perm-col { width: 72px; }
.permisos-table .perm-group-header td {
  background: var(--gd-primary-light);
  color: var(--gd-primary);
  font-weight: 600;
  font-size: var(--gd-font-sm);
  padding: 0.45rem 1rem;
}
.permisos-table .perm-group-header .perm-toggle-group {
  float: right;
  font-size: 0.75rem;
  color: var(--gd-primary);
  background: none;
  border: 1px solid var(--gd-primary);
  border-radius: 4px;
  padding: 1px 8px;
  cursor: pointer;
  line-height: 1.4;
}
.permisos-table .perm-group-header .perm-toggle-group:hover { background: var(--gd-primary); color: #fff; }
.permisos-table .perm-indent { padding-left: 1.8rem !important; }
.perm-check { width: 16px; height: 16px; cursor: pointer; accent-color: var(--gd-primary); }
.perm-loading { text-align: center; padding: 2.5rem; color: var(--gd-text-secondary); }

/* -------------------------------------------------------
   Fila vacía
   ------------------------------------------------------- */
.empty-row td {
  text-align: center !important;
  padding: 2.5rem 1rem !important;
  color: var(--gd-text-muted);
  font-size: var(--gd-font-base);
}
.empty-row .fa {
  display: block;
  font-size: 1.8rem;
  margin-bottom: 0.5rem;
  opacity: 0.3;
}

/* -------------------------------------------------------
   Footer / Paginación
   ------------------------------------------------------- */
.panel-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.65rem 1rem;
  background: var(--gd-bg);
  border-top: 1px solid var(--gd-border);
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-top: 0;
}
.panel-footer-info {
  font-size: var(--gd-font-sm);
  color: var(--gd-text-muted);
}
.panel-footer-info strong { color: var(--gd-text-secondary); }
.panel-footer-right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* Paginación */
.panel-footer ul.pagination-sm {
  display: flex !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  gap: 2px;
}
.panel-footer ul.pagination-sm li a,
.panel-footer ul.pagination-sm li span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 30px;
  height: 30px;
  padding: 0 6px !important;
  font-size: var(--gd-font-sm) !important;
  color: var(--gd-primary) !important;
  text-decoration: none !important;
  border: 1px solid var(--gd-border) !important;
  border-radius: var(--gd-radius-sm) !important;
  transition: background 0.15s, color 0.15s !important;
  cursor: pointer !important;
  background: var(--gd-white) !important;
}
.panel-footer ul.pagination-sm li.active a,
.panel-footer ul.pagination-sm li.active span {
  background: var(--gd-primary) !important;
  color: #fff !important;
  border-color: var(--gd-primary) !important;
}
.panel-footer ul.pagination-sm li a:hover {
  background: var(--gd-primary) !important;
  color: #fff !important;
  border-color: var(--gd-primary) !important;
}
.panel-footer ul.pagination-sm li.disabled a,
.panel-footer ul.pagination-sm li.disabled span {
  color: var(--gd-text-muted) !important;
  cursor: default !important;
  pointer-events: none !important;
}

/* Botón refrescar */
.btn-refresh {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 30px;
  height: 30px;
  background: var(--gd-white) !important;
  border: 1px solid var(--gd-border) !important;
  border-radius: var(--gd-radius-sm) !important;
  font-size: 0.85rem !important;
  color: var(--gd-text-secondary) !important;
  cursor: pointer !important;
  transition: background 0.2s, color 0.2s !important;
}
.btn-refresh:hover {
  background: var(--gd-primary) !important;
  color: #fff !important;
  border-color: var(--gd-primary) !important;
}

/* -------------------------------------------------------
   Componentes de celda reutilizables
   ------------------------------------------------------- */

/* Nombre + subinfo apilados */
.gd-stack        { display: flex; flex-direction: column; gap: 1px; }
.gd-stack-main   { font-weight: 500; color: var(--gd-text); }
.gd-stack-sub    { font-size: 0.75rem; color: var(--gd-text-secondary); }

/* Código / NIT monospace */
.gd-code {
  display: inline-block;
  font-family: monospace;
  font-size: 0.78rem;
  background: #EEF2F7;
  border-radius: 3px;
  padding: 2px 7px;
  color: var(--gd-primary);
  border: 1px solid #D1DCF0;
  letter-spacing: 0.02em;
}

/* Enlace */
.gd-link { color: var(--gd-primary); text-decoration: none; }
.gd-link:hover { text-decoration: underline; color: var(--gd-primary-dark); }

/* Texto secundario / vacío */
.gd-muted { color: var(--gd-text-muted); }
.gd-text-secondary { color: var(--gd-text-secondary); }

/* Badge de estado */
.gd-badge {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.gd-badge-success { background: #E8F5E9; color: #2E7D32; }
.gd-badge-danger  { background: #FFEBEE; color: #C62828; }
.gd-badge-info    { background: var(--gd-primary-light); color: var(--gd-primary); }
.gd-badge-warning { background: #FFF8E1; color: #B45309; }
.gd-badge-neutral { background: var(--gd-bg); color: var(--gd-text-secondary); border: 1px solid var(--gd-border); }

/* -------------------------------------------------------
   select.form-control dentro de search-form
   ------------------------------------------------------- */
.search-form select.form-control {
  height: 36px;
  padding: 0 0.75rem;
  border: 1.5px solid var(--gd-border);
  border-radius: var(--gd-radius-sm);
  font-size: var(--gd-font-base);
  background: var(--gd-white);
  color: var(--gd-text);
  box-shadow: none;
  transition: border-color 0.2s;
  appearance: none;
}
.search-form select.form-control:focus {
  outline: none;
  border-color: var(--gd-primary);
  box-shadow: 0 0 0 3px rgba(26,54,93,0.12);
}

/* -------------------------------------------------------
   Modales — diseño centrado unificado
   ------------------------------------------------------- */

/* Animación de entrada */
@keyframes gd-modal-in {
  from { opacity: 0; transform: scale(0.96) translateY(-8px); }
  to   { opacity: 1; transform: scale(1)   translateY(0); }
}

/* Centrado vertical del dialog */
.modal-dialog {
  display: flex;
  align-items: center;
  min-height: calc(100% - 60px);
  margin: 30px auto;
}

/* Contenido principal */
.modal-content {
  border: none !important;
  border-radius: var(--gd-radius) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.18) !important;
  overflow: hidden;
  animation: gd-modal-in 0.2s ease;
  width: 100%;
}

/* Cabecera Bootstrap estándar */
.modal-header {
  background: var(--gd-primary) !important;
  border-bottom: none !important;
  padding: 1rem 1.25rem !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}
.modal-header .modal-title {
  color: #fff !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  margin: 0 !important;
}
.modal-header .close {
  color: rgba(255,255,255,0.8) !important;
  opacity: 1 !important;
  font-size: 1.4rem !important;
  text-shadow: none !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1 !important;
}
.modal-header .close:hover { color: #fff !important; }

/* Cuerpo Bootstrap estándar */
.modal-body {
  padding: 1.25rem 1.5rem !important;
  background: var(--gd-white);
  font-size: var(--gd-font-base);
  color: var(--gd-text);
  max-height: calc(100vh - 220px);
  overflow-y: auto;
}

/* Pie Bootstrap estándar */
.modal-footer {
  background: var(--gd-bg) !important;
  border-top: 1px solid var(--gd-border) !important;
  padding: 0.75rem 1.25rem !important;
  display: flex !important;
  justify-content: flex-end !important;
  gap: 0.5rem !important;
}

/* ----- Estructura personalizada (.modal-right-panel-container) -----
   Ahora centrada dentro del modal estándar de Bootstrap            */
.modal-right-panel-container {
  display: flex;
  flex-direction: column;
  background: var(--gd-white);
  max-height: calc(100vh - 120px);
  overflow: hidden;
  position: relative;
}

.custom-close-btn {
  position: absolute;
  top: 14px;
  right: 16px;
  background: none;
  border: none;
  font-size: 1.1rem;
  color: rgba(255,255,255,0.75);
  cursor: pointer;
  z-index: 10;
  line-height: 1;
  padding: 0;
}
.custom-close-btn:hover { color: #fff; }

.custom-header {
  padding: 1rem 1.25rem;
  flex-shrink: 0;
  border-bottom: 1px solid var(--gd-border);
  background: var(--gd-primary);
}
.custom-header h2,
.custom-header .modal-title {
  font-size: 1rem;
  margin: 0;
  font-weight: 600;
  color: #fff;
}
.custom-subtitle { font-size: 0.82rem; color: rgba(255,255,255,0.7); margin-top: 3px; }

.custom-modal-body {
  padding: 1.25rem 1.5rem;
  flex: 1;
  overflow-y: auto;
  background: var(--gd-white);
  font-size: var(--gd-font-base);
  color: var(--gd-text);
}

.custom-footer {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  padding: 0.75rem 1.25rem;
  border-top: 1px solid var(--gd-border);
  background: var(--gd-bg);
  flex-shrink: 0;
}

/* Fondo semitransparente del modal */
.modal-backdrop { opacity: 0.5 !important; }

/* -------------------------------------------------------
   Fixes de layout sidebar / topbar / loading-bar
   ------------------------------------------------------- */
.wrapper > .aside             { overflow: hidden !important; }
.wrapper > .aside > .aside-inner {
  padding-top: 0 !important;
  overflow: hidden !important;
}
.wrapper > section            { margin-top: 0 !important; }
.sidebar:not(.show-scrollbar) {
  margin-right: 0 !important;
  overflow: hidden !important;
}
#loading-bar {
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  top: 0 !important;
  z-index: 99999 !important;
}
#loading-bar-spinner { position: fixed !important; }

/* -------------------------------------------------------
   Preloader — override completo del estilo gulp/PNG
   ------------------------------------------------------- */
.preloader {
  position: fixed !important;
  top: 0 !important; left: 0 !important;
  width: 100% !important; height: 100% !important;
  background: #F7FAFC !important;
  background-image: none !important;
  z-index: 99999 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  transition: opacity .45s ease !important;
}

/* Logo giratorio */
.gd-pl-body {
  display: flex;
  align-items: center;
  justify-content: center;
}
.gd-pl-logo {
  height: 64px;
  width: auto;
  object-fit: contain;
  animation: gd-pl-spin 1.4s ease-in-out infinite;
  transform-origin: center center;
}
@keyframes gd-pl-spin {
  0%   { transform: rotate(0deg)   scale(1);    opacity: 1;   }
  45%  { transform: rotate(170deg) scale(1.08); opacity: .85; }
  50%  { transform: rotate(180deg) scale(1.08); opacity: .85; }
  95%  { transform: rotate(350deg) scale(1);    opacity: 1;   }
  100% { transform: rotate(360deg) scale(1);    opacity: 1;   }
}

/* Ocultar barra de progreso del gulp */
.preloader-progress,
.preloader-progress-bar { display: none !important; }

/* Estados oculto/transición */
.preloader-hidden          { opacity: 0 !important; pointer-events: none !important; display: block !important; }
.preloader-hidden-add      { opacity: 1 !important; display: block !important; }
.preloader-hidden-add-active { opacity: 0 !important; }

/* Modo oscuro */
[data-theme="dark"] .preloader  { background: #131B2E !important; }
[data-theme="dark"] .gd-pl-logo { filter: brightness(0) invert(1); opacity: .9; }

/* -------------------------------------------------------
   Vista de detalle en modal
   ------------------------------------------------------- */
.gd-detail-section {
  margin-bottom: 1.25rem;
}
.gd-detail-section:last-child { margin-bottom: 0; }

.gd-detail-section-title {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--gd-text-muted);
  margin-bottom: 0.65rem;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--gd-border);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.gd-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem 1.5rem;
}

.gd-detail-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.gd-detail-item--full {
  grid-column: 1 / -1;
}

.gd-detail-label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--gd-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.gd-detail-value {
  font-size: var(--gd-font-base);
  color: var(--gd-text);
  font-weight: 400;
}

/* -------------------------------------------------------
   Texto helper
   ------------------------------------------------------- */
.text-thin { font-weight: 400; }

/* -------------------------------------------------------
   Formularios complejos de búsqueda (radicados / gestión)
   ------------------------------------------------------- */
.gestiondoc-form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.65rem;
  margin-bottom: 0.75rem;
}
.gestiondoc-form-search {
  grid-template-columns: 200px 1fr auto;
  align-items: center;
}
.gestiondoc-select-clear {
  display: flex;
  align-items: center;
  gap: 0.3rem;
}
.gestiondoc-select-clear select.form-control { flex: 1; }
.gestiondoc-btn-icon {
  background: var(--gd-primary-light);
  color: var(--gd-primary);
  border: none;
  border-radius: var(--gd-radius-sm);
  padding: 0.3rem 0.55rem;
  font-size: 0.9rem;
  cursor: pointer;
  transition: background 0.2s;
}
.gestiondoc-btn-icon:hover { background: var(--gd-primary-border); }
.gestiondoc-select-small .ui-select-bootstrap { font-size: 0.9rem; }
.gestiondoc-search-input,
.gestiondoc-search-input .input-group { width: 100%; }
.gestiondoc-btns { display: flex; align-items: center; gap: 0.4rem; }
.gestiondoc-form-row .ui-select-bootstrap,
.gestiondoc-form-row select.form-control {
  border-radius: var(--gd-radius-sm);
  font-size: var(--gd-font-base);
  width: 100%;
}
.ui-select-bootstrap .ui-select-match-text { color: var(--gd-text); font-weight: 400; }
.ui-select-placeholder { color: var(--gd-text-muted) !important; }
@media (max-width: 768px) {
  .gestiondoc-form-row,
  .gestiondoc-form-search { grid-template-columns: 1fr; }
}

/* -------------------------------------------------------
   Indicadores tipo radicado
   ------------------------------------------------------- */
.fa.orange { color: #D97706; }
.fa.green  { color: #2E7D32; }
.fa.blue   { color: var(--gd-primary); }
.fa.red    { color: var(--gd-danger); }

/* Botón de acciones (campanita) en tablas */
.btn-alarm {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: none;
  background: var(--gd-primary-light);
  color: var(--gd-primary);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  transition: background 0.2s, color 0.2s;
}
.btn-alarm:hover,
.btn-alarm:focus {
  background: var(--gd-primary);
  color: #fff;
  outline: none;
}

/* Indicador circular de estado */
.circle {
  display: inline-block;
  border-radius: 50%;
}
.circle-lg { width: 10px; height: 10px; }
.icon-container { display: inline-flex; align-items: center; gap: 4px; }

/* -------------------------------------------------------
   Flatpickr — campo Fecha Límite Respuesta
   ------------------------------------------------------- */
.flatpickr-input {
  background: #fff !important;
  cursor: pointer !important;
}
.flatpickr-input[readonly] {
  background: #fff !important;
}

/* Colores del calendario en tema del sistema */
.flatpickr-day.selected,
.flatpickr-day.selected:hover {
  background: var(--gd-primary) !important;
  border-color: var(--gd-primary) !important;
}
.flatpickr-day:hover {
  background: var(--gd-primary-light) !important;
}
.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover {
  color: #ccc !important;
  background: transparent !important;
  cursor: not-allowed !important;
  text-decoration: line-through;
}
/* Indicador visual en el campo: ícono calendario */
.gd-fecha-limite {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%231A365D' stroke-width='2'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 10px center !important;
  padding-right: 32px !important;
}

/* =======================================================
   TEMA OSCURO — Se activa con data-theme="dark" en <html>
   ======================================================= */

/* --- Variables globales gd-* --- */
[data-theme="dark"] {
  --gd-primary:        #4A90D9;
  --gd-primary-dark:   #3A7BC8;
  --gd-primary-hover:  #5599E0;
  --gd-primary-light:  #162032;
  --gd-primary-border: #2D4A6E;
  --gd-success:        #48BB78;
  --gd-success-hover:  #38A169;
  --gd-danger:         #FC8181;
  --gd-danger-bg:      #2D1B1B;
  --gd-warning:        #F6AD55;
  --gd-text:           #E2E8F0;
  --gd-text-secondary: #A0AEC0;
  --gd-text-muted:     #718096;
  --gd-border:         #2D3748;
  --gd-bg:             #131B2E;
  --gd-bg-row-alt:     #1A2540;
  --gd-white:          #1E2D47;
  --gd-shadow-sm:      0 1px 3px rgba(0,0,0,0.4);
  --gd-shadow:         0 2px 8px rgba(0,0,0,0.35);
}

/* --- Body y área de contenido --- */
[data-theme="dark"] body,
[data-theme="dark"] .wrapper > section,
[data-theme="dark"] .content-wrapper { background-color: #131B2E !important; color: #E2E8F0; }

/* -------------------------------------------------------
   Sidebar custom (.sidebar y .sb-*)
   ------------------------------------------------------- */
[data-theme="dark"] .wrapper > .aside,
[data-theme="dark"] .aside-inner                           { background-color: #0D1526 !important; }
[data-theme="dark"] .sidebar                               { background: #0D1526 !important; box-shadow: 2px 0 12px rgba(0,0,0,.4) !important; }
[data-theme="dark"] .sb-head                               { border-bottom-color: #2D3748 !important; }
[data-theme="dark"] .sb-toggle                             { background: #1A2540 !important; color: #A0AEC0 !important; }
[data-theme="dark"] .sb-toggle:hover                       { background: #2D3748 !important; }
[data-theme="dark"] .sidebar .nav > li > a                 { color: #A0AEC0 !important; }
[data-theme="dark"] .sidebar .nav > li > a:hover           { background: #1A2540 !important; color: #E2E8F0 !important; }
[data-theme="dark"] .sidebar .nav > li.active > a          { background: #162032 !important; color: #E2E8F0 !important; }
[data-theme="dark"] .sidebar .nav > li.active              { border-left-color: #4A90D9 !important; }
[data-theme="dark"] .sidebar-subnav                        { background: #0D1526 !important; }
[data-theme="dark"] .sidebar-subnav-header                 { color: #718096 !important; }
[data-theme="dark"] .sidebar-subnav > li > a               { color: #A0AEC0 !important; }
[data-theme="dark"] .sidebar-subnav > li > a:hover         { background: #1A2540 !important; color: #E2E8F0 !important; }
[data-theme="dark"] .sidebar-subnav > li.active > a        { background: #162032 !important; color: #E2E8F0 !important; }
[data-theme="dark"] .sb-logout                             { border-top-color: #2D3748 !important; }
[data-theme="dark"] .sb-logout button                      { color: #A0AEC0 !important; }
[data-theme="dark"] .sb-logout button:hover                { background: rgba(255,255,255,.08) !important; color: #E2E8F0 !important; }
[data-theme="dark"] .sb-theme button                       { color: #A0AEC0 !important; }
[data-theme="dark"] .sb-theme button:hover                 { background: rgba(255,255,255,.08) !important; color: #E2E8F0 !important; }

/* -------------------------------------------------------
   Dashboard (.gd-dash) — override variables locales
   ------------------------------------------------------- */
[data-theme="dark"] .gd-dash {
  --pr:  #4A90D9;
  --bl:  #63B3ED;
  --bg:  #131B2E;
  --card:#1E2D47;
  --txt: #E2E8F0;
  --mut: #A0AEC0;
  --bdr: #2D3748;
  background: #131B2E;
  color: #E2E8F0;
}
[data-theme="dark"] .gd-period                             { background: #1E2D47 !important; border-color: #2D3748 !important; }
[data-theme="dark"] .gd-period:hover                       { border-color: #4A90D9 !important; }
[data-theme="dark"] .gd-card                               { background: #1E2D47 !important; box-shadow: 0 2px 8px rgba(0,0,0,.3) !important; }
[data-theme="dark"] .gd-table td                           { border-bottom-color: #2D3748 !important; color: #E2E8F0 !important; }
[data-theme="dark"] .gd-table tr:hover td                  { background: rgba(74,144,217,.08) !important; }
[data-theme="dark"] .gd-badge--warning                     { background: #3D2C00 !important; color: #F6AD55 !important; }
[data-theme="dark"] .gd-badge--danger                      { background: #2D1B1B !important; color: #FC8181 !important; }
[data-theme="dark"] .gd-badge--normal                      { background: #1A2540 !important; color: #63B3ED !important; }
[data-theme="dark"] .bg-govco-white                        { background: #1E2D47 !important; color: #E2E8F0 !important; border-color: #2D3748 !important; }
[data-theme="dark"] .gd-empty                              { color: #718096; }

/* -------------------------------------------------------
   Formularios radicación (.rad-*)
   ------------------------------------------------------- */
[data-theme="dark"] .rad-header-text h1                    { color: #E2E8F0 !important; }
[data-theme="dark"] .rad-header-text p                     { color: #A0AEC0 !important; }
[data-theme="dark"] .rad-section                           { background: #1E2D47 !important; box-shadow: 0 1px 3px rgba(0,0,0,.3) !important; }
[data-theme="dark"] .rad-section-header                    { background: #162032 !important; border-bottom-color: #2D3748 !important; color: #CBD5E0 !important; }
[data-theme="dark"] .rad-section-header i                  { color: #4A90D9 !important; }
[data-theme="dark"] .rad-field > label                     { color: #CBD5E0 !important; }
[data-theme="dark"] .rad-auto-check span                   { color: #A0AEC0 !important; }
[data-theme="dark"] .rad-select-name                       { color: #E2E8F0 !important; }
[data-theme="dark"] .rad-select-detail                     { color: #A0AEC0 !important; }
[data-theme="dark"] .rad-btn-add                           { background: #162032 !important; border-color: #2D3748 !important; color: #A0AEC0 !important; }
[data-theme="dark"] .rad-btn-add:hover                     { background: #1A2540 !important; color: #E2E8F0 !important; }

/* -------------------------------------------------------
   Panels Bootstrap
   ------------------------------------------------------- */
[data-theme="dark"] .panel,
[data-theme="dark"] .panel-default                         { background-color: #1E2D47 !important; border-color: #2D3748 !important; }
[data-theme="dark"] .panel-heading,
[data-theme="dark"] .panel-default > .panel-heading        { background-color: #162032 !important; border-color: #2D3748 !important; color: #E2E8F0 !important; }
[data-theme="dark"] .panel-body                            { background-color: #1E2D47; color: #E2E8F0; }
[data-theme="dark"] .panel-footer                          { background-color: #162032 !important; border-top-color: #2D3748 !important; color: #A0AEC0; }

/* -------------------------------------------------------
   Formularios Bootstrap
   ------------------------------------------------------- */
[data-theme="dark"] .form-control,
[data-theme="dark"] input.form-control,
[data-theme="dark"] select.form-control,
[data-theme="dark"] textarea.form-control {
  background-color: #162032 !important;
  border-color: #2D3748 !important;
  color: #E2E8F0 !important;
}
[data-theme="dark"] .form-control:focus                    { border-color: #4A90D9 !important; box-shadow: 0 0 0 3px rgba(74,144,217,0.2) !important; }
[data-theme="dark"] .form-control::placeholder             { color: #718096 !important; }
[data-theme="dark"] .form-control[disabled],
[data-theme="dark"] .form-control[readonly]                { background-color: #0D1526 !important; color: #718096 !important; }
[data-theme="dark"] label,
[data-theme="dark"] .control-label                         { color: #CBD5E0; }
[data-theme="dark"] .input-group-addon                     { background-color: #162032 !important; border-color: #2D3748 !important; color: #A0AEC0 !important; }
[data-theme="dark"] .has-error .form-control               { border-color: #FC8181 !important; }
[data-theme="dark"] .form-group                            { color: #E2E8F0; }

/* -------------------------------------------------------
   Tablas Bootstrap
   ------------------------------------------------------- */
[data-theme="dark"] .table                                 { color: #E2E8F0; }
[data-theme="dark"] .table > thead > tr > th,
[data-theme="dark"] .table > tfoot > tr > th               { background-color: #162032; border-color: #2D3748 !important; color: #CBD5E0; }
[data-theme="dark"] .table > tbody > tr > td,
[data-theme="dark"] .table > tbody > tr > th               { border-color: #2D3748 !important; color: #E2E8F0; background-color: #1E2D47; }
[data-theme="dark"] .table-striped > tbody > tr:nth-of-type(odd) > td { background-color: #1A2540; }
[data-theme="dark"] .table-hover > tbody > tr:hover > td   { background-color: #162032 !important; }
[data-theme="dark"] .table-bordered                        { border-color: #2D3748 !important; }
[data-theme="dark"] .table-bordered > * > tr > *           { border-color: #2D3748 !important; }

/* -------------------------------------------------------
   Modales
   ------------------------------------------------------- */
[data-theme="dark"] .modal-content                         { background-color: #1E2D47 !important; border-color: #2D3748 !important; }
[data-theme="dark"] .modal-body                            { background-color: #1E2D47 !important; color: #E2E8F0 !important; }
[data-theme="dark"] .modal-footer                          { background-color: #162032 !important; border-top-color: #2D3748 !important; }
[data-theme="dark"] .modal-header                          { border-bottom-color: #2D3748; }
[data-theme="dark"] .custom-modal-body                     { background-color: #1E2D47 !important; color: #E2E8F0 !important; }
[data-theme="dark"] .custom-footer                         { background-color: #162032 !important; border-top-color: #2D3748 !important; }

/* -------------------------------------------------------
   Dropdowns
   ------------------------------------------------------- */
[data-theme="dark"] .dropdown-menu                         { background-color: #1E2D47 !important; border-color: #2D3748 !important; box-shadow: 0 4px 16px rgba(0,0,0,0.4) !important; }
[data-theme="dark"] .dropdown-menu > li > a                { color: #E2E8F0 !important; }
[data-theme="dark"] .dropdown-menu > li > a:hover,
[data-theme="dark"] .dropdown-menu > li > a:focus          { background-color: #162032 !important; color: #fff !important; }
[data-theme="dark"] .dropdown-menu .divider                { background-color: #2D3748; }

/* -------------------------------------------------------
   UI-Select
   ------------------------------------------------------- */
[data-theme="dark"] .ui-select-bootstrap .ui-select-choices { background-color: #1E2D47 !important; border-color: #2D3748 !important; }
/* Bootstrap theme renders <span class="ui-select-choices-row-inner">, not <a> */
[data-theme="dark"] .ui-select-bootstrap .ui-select-choices-row > a,
[data-theme="dark"] .ui-select-bootstrap .ui-select-choices-row > span,
[data-theme="dark"] .ui-select-bootstrap .ui-select-choices-row-inner { color: #E2E8F0 !important; }
[data-theme="dark"] .ui-select-bootstrap .ui-select-choices-row-inner div,
[data-theme="dark"] .ui-select-bootstrap .ui-select-choices-row-inner small { color: inherit !important; }
[data-theme="dark"] .ui-select-bootstrap .ui-select-choices-row > a:hover,
[data-theme="dark"] .ui-select-bootstrap .ui-select-choices-row > span:hover,
[data-theme="dark"] .ui-select-bootstrap .ui-select-choices-row.active > a,
[data-theme="dark"] .ui-select-bootstrap .ui-select-choices-row.active > span { background-color: #162032 !important; color: #fff !important; }
[data-theme="dark"] .ui-select-bootstrap > .ui-select-match.btn,
[data-theme="dark"] .ui-select-bootstrap > .ui-select-match.btn-default { background-color: #162032 !important; border-color: #2D3748 !important; color: #E2E8F0 !important; }
[data-theme="dark"] .ui-select-placeholder                 { color: #718096 !important; }
[data-theme="dark"] .ui-select-match-text                  { color: #E2E8F0 !important; }

/* -------------------------------------------------------
   Flatpickr
   ------------------------------------------------------- */
[data-theme="dark"] .flatpickr-calendar                    { background: #1E2D47 !important; border-color: #2D3748 !important; box-shadow: 0 6px 20px rgba(0,0,0,0.5) !important; }
[data-theme="dark"] .flatpickr-months,
[data-theme="dark"] .flatpickr-month                       { background: #162032 !important; color: #E2E8F0 !important; fill: #E2E8F0 !important; }
[data-theme="dark"] .flatpickr-weekdays,
[data-theme="dark"] span.flatpickr-weekday                 { background: #162032 !important; color: #718096 !important; }
[data-theme="dark"] .flatpickr-day                         { color: #E2E8F0 !important; }
[data-theme="dark"] .flatpickr-day:hover                   { background: #162032 !important; border-color: #2D3748 !important; }
[data-theme="dark"] .flatpickr-day.selected,
[data-theme="dark"] .flatpickr-day.selected:hover          { background: #4A90D9 !important; border-color: #4A90D9 !important; color: #fff !important; }
[data-theme="dark"] .flatpickr-day.flatpickr-disabled,
[data-theme="dark"] .flatpickr-day.flatpickr-disabled:hover { color: #2D3748 !important; }
[data-theme="dark"] .flatpickr-day.today                   { border-color: #4A90D9 !important; }
[data-theme="dark"] .flatpickr-current-month .flatpickr-monthDropdown-months,
[data-theme="dark"] .flatpickr-current-month input.cur-year { color: #E2E8F0 !important; background: transparent !important; }
[data-theme="dark"] .flatpickr-input,
[data-theme="dark"] .flatpickr-input[readonly]             { background-color: #162032 !important; color: #E2E8F0 !important; }
[data-theme="dark"] .numInputWrapper:hover                  { background: #162032 !important; }
[data-theme="dark"] .flatpickr-prev-month svg,
[data-theme="dark"] .flatpickr-next-month svg              { fill: #A0AEC0 !important; }

/* -------------------------------------------------------
   Paginación
   ------------------------------------------------------- */
[data-theme="dark"] .pagination > li > a,
[data-theme="dark"] .pagination > li > span               { background-color: #1E2D47; border-color: #2D3748; color: #A0AEC0; }
[data-theme="dark"] .pagination > li > a:hover             { background-color: #162032; color: #E2E8F0; }
[data-theme="dark"] .pagination > .active > a,
[data-theme="dark"] .pagination > .active > span           { background-color: #4A90D9; border-color: #4A90D9; color: #fff; }
[data-theme="dark"] .pagination > .disabled > a            { background-color: #0D1526; border-color: #2D3748; color: #4A5568; }

/* -------------------------------------------------------
   Nav tabs
   ------------------------------------------------------- */
[data-theme="dark"] .nav-tabs                              { border-bottom-color: #2D3748; }
[data-theme="dark"] .nav-tabs > li > a                     { color: #A0AEC0; background-color: #162032; border-color: #2D3748; }
[data-theme="dark"] .nav-tabs > li > a:hover               { color: #E2E8F0; border-color: #2D3748; }
[data-theme="dark"] .nav-tabs > li.active > a,
[data-theme="dark"] .nav-tabs > li.active > a:hover        { color: #E2E8F0; background-color: #1E2D47; border-bottom-color: #1E2D47; }

/* -------------------------------------------------------
   Texto, headings, badges, alertas
   ------------------------------------------------------- */
[data-theme="dark"] h1,[data-theme="dark"] h2,[data-theme="dark"] h3,
[data-theme="dark"] h4,[data-theme="dark"] h5,[data-theme="dark"] h6 { color: #E2E8F0; }
[data-theme="dark"] p                                      { color: #CBD5E0; }
[data-theme="dark"] .text-muted                            { color: #718096 !important; }
[data-theme="dark"] hr                                     { border-color: #2D3748; }
[data-theme="dark"] a                                      { color: #63B3ED; }
[data-theme="dark"] a:hover                                { color: #90CDF4; }
[data-theme="dark"] small, [data-theme="dark"] .small      { color: #A0AEC0; }
[data-theme="dark"] .badge                                 { background-color: #162032; color: #E2E8F0; }
[data-theme="dark"] .alert                                 { border-color: #2D3748; }
[data-theme="dark"] .alert-default                         { background-color: #1E2D47; color: #E2E8F0; }

/* -------------------------------------------------------
   Scrollbar (webkit)
   ------------------------------------------------------- */
[data-theme="dark"] ::-webkit-scrollbar                    { width: 6px; height: 6px; }
[data-theme="dark"] ::-webkit-scrollbar-track              { background: #0D1526; }
[data-theme="dark"] ::-webkit-scrollbar-thumb              { background: #2D3748; border-radius: 3px; }
[data-theme="dark"] ::-webkit-scrollbar-thumb:hover        { background: #4A5568; }


/* Modal detalle búsqueda avanzada */
.modal-detalle-rad .modal-dialog { max-width: 1050px; width: 95%; }

/* -------------------------------------------------------
   Dark mode coverage for custom views
   ------------------------------------------------------- */
[data-theme="dark"] .admin-panel,
[data-theme="dark"] .gd-detail-shell,
[data-theme="dark"] .gd-tab-page,
[data-theme="dark"] .gd-doc-view,
[data-theme="dark"] .gd-report-page {
  background: #131B2E !important;
  color: #E2E8F0 !important;
}

[data-theme="dark"] .title-header { border-bottom-color: #2D3748 !important; }

[data-theme="dark"] .title-text,
[data-theme="dark"] .smtp-title,
[data-theme="dark"] .smtp-host,
[data-theme="dark"] .gd-report-title h3,
[data-theme="dark"] .gd-doc-head h3,
[data-theme="dark"] .gd-section h4,
[data-theme="dark"] .gd-info-item strong,
[data-theme="dark"] .gd-section b,
[data-theme="dark"] .gd-record-strip strong,
[data-theme="dark"] .gd-panel-head h4,
[data-theme="dark"] .gd-person-info strong,
[data-theme="dark"] .gd-assigned-card strong,
[data-theme="dark"] .gd-event-meta strong,
[data-theme="dark"] .gd-field-head label,
[data-theme="dark"] .gd-action-form label,
[data-theme="dark"] .gd-mode-alert strong,
[data-theme="dark"] .gd-subject-card p {
  color: #E2E8F0 !important;
}

[data-theme="dark"] .smtp-subtitle,
[data-theme="dark"] .smtp-muted,
[data-theme="dark"] .smtp-field label,
[data-theme="dark"] .gd-report-title p,
[data-theme="dark"] .gd-field > span,
[data-theme="dark"] .gd-eyebrow,
[data-theme="dark"] .gd-section p,
[data-theme="dark"] .gd-info-item label,
[data-theme="dark"] .gd-record-strip span,
[data-theme="dark"] .gd-subject-card label,
[data-theme="dark"] .gd-panel-head span,
[data-theme="dark"] .gd-person-info span,
[data-theme="dark"] .gd-assigned-card span,
[data-theme="dark"] .gd-assign-meta,
[data-theme="dark"] .gd-mode-alert span,
[data-theme="dark"] .gd-field-head span,
[data-theme="dark"] .gd-event-meta span,
[data-theme="dark"] .gd-event-body label,
[data-theme="dark"] .gd-event-body p,
[data-theme="dark"] .gd-event-extra,
[data-theme="dark"] .gd-empty-mini,
[data-theme="dark"] .gd-empty-state,
[data-theme="dark"] .prt-size-label,
[data-theme="dark"] .prt-preview-label,
[data-theme="dark"] .prt-position-label,
[data-theme="dark"] .upd-rad-label,
[data-theme="dark"] .upd-drop-subtext,
[data-theme="dark"] .upd-drop-hint,
[data-theme="dark"] .upd-file-size {
  color: #A0AEC0 !important;
}

[data-theme="dark"] .smtp-card,
[data-theme="dark"] .gd-report-filters,
[data-theme="dark"] .gd-report-table,
[data-theme="dark"] .gd-detail-tabs,
[data-theme="dark"] .gd-record-strip,
[data-theme="dark"] .gd-subject-card,
[data-theme="dark"] .gd-panel,
[data-theme="dark"] .gd-work-panel,
[data-theme="dark"] .gd-doc-summary,
[data-theme="dark"] .gd-pdf-panel,
[data-theme="dark"] .gd-info-item,
[data-theme="dark"] .gd-section,
[data-theme="dark"] .gd-file-chip,
[data-theme="dark"] .gd-action-card,
[data-theme="dark"] .gd-mode-alert,
[data-theme="dark"] .gd-chip-input,
[data-theme="dark"] .gd-mail-chip,
[data-theme="dark"] .gd-upload-box,
[data-theme="dark"] .gd-event-card,
[data-theme="dark"] .gd-event-body,
[data-theme="dark"] .gd-person-card,
[data-theme="dark"] .gd-assigned-card,
[data-theme="dark"] .upd-modal,
[data-theme="dark"] .upd-content,
[data-theme="dark"] .upd-info-box,
[data-theme="dark"] .upd-drop-zone,
[data-theme="dark"] .upd-file-card,
[data-theme="dark"] .prt-modal,
[data-theme="dark"] .prt-content,
[data-theme="dark"] .prt-size-btn,
[data-theme="dark"] .prt-position-item {
  background: #1E2D47 !important;
  border-color: #2D3748 !important;
  color: #E2E8F0 !important;
  box-shadow: none !important;
}

[data-theme="dark"] .smtp-card-header,
[data-theme="dark"] .gd-panel-head,
[data-theme="dark"] .gd-doc-head,
[data-theme="dark"] .gd-action-grid,
[data-theme="dark"] .gd-form-actions,
[data-theme="dark"] .gd-report-footer,
[data-theme="dark"] .prt-footer,
[data-theme="dark"] .upd-footer {
  background: #162032 !important;
  border-color: #2D3748 !important;
}

[data-theme="dark"] .smtp-field input,
[data-theme="dark"] .smtp-field select,
[data-theme="dark"] .gd-field .form-control,
[data-theme="dark"] .gd-field .ui-select-bootstrap > .ui-select-match > .btn,
[data-theme="dark"] .gd-search input,
[data-theme="dark"] .gd-chip-input input,
[data-theme="dark"] .upd-field .form-control,
[data-theme="dark"] .upd-field select,
[data-theme="dark"] .upd-field textarea {
  background: #162032 !important;
  border-color: #2D3748 !important;
  color: #E2E8F0 !important;
}

[data-theme="dark"] .smtp-field input::placeholder,
[data-theme="dark"] .gd-field .form-control::placeholder,
[data-theme="dark"] .gd-chip-input input::placeholder,
[data-theme="dark"] .upd-field .form-control::placeholder {
  color: #718096 !important;
}

[data-theme="dark"] .gd-detail-tabs a,
[data-theme="dark"] .gd-action-card,
[data-theme="dark"] .prt-size-btn,
[data-theme="dark"] .prt-position-item label,
[data-theme="dark"] .gd-icon-btn,
[data-theme="dark"] .gd-btn-light {
  color: #A0AEC0 !important;
}

[data-theme="dark"] .gd-detail-tabs a:hover,
[data-theme="dark"] .gd-action-card:hover:not(.disabled),
[data-theme="dark"] .prt-size-btn:hover,
[data-theme="dark"] .prt-position-item:hover,
[data-theme="dark"] .gd-icon-btn:hover,
[data-theme="dark"] .gd-btn-light:hover {
  background: #22324F !important;
  color: #E2E8F0 !important;
}

[data-theme="dark"] .gd-detail-tabs a.active,
[data-theme="dark"] .prt-size-btn.active,
[data-theme="dark"] .prt-position-item.active {
  background: #0F2942 !important;
  border-color: #4A90D9 !important;
  color: #E2E8F0 !important;
}

[data-theme="dark"] .prt-position-item.active label { color: #E2E8F0 !important; }

[data-theme="dark"] .gd-btn-primary,
[data-theme="dark"] .prt-btn-print,
[data-theme="dark"] .upd-btn-upload,
[data-theme="dark"] .upd-btn-select {
  background: #2B6CB0 !important;
  border-color: #2B6CB0 !important;
  color: #fff !important;
}

[data-theme="dark"] .gd-btn-dark {
  background: #0D1526 !important;
  border-color: #2D3748 !important;
  color: #fff !important;
}

[data-theme="dark"] .gd-btn-soft {
  background: #2D1B1B !important;
  border-color: #4A2525 !important;
  color: #FC8181 !important;
}

[data-theme="dark"] .gd-btn-warning {
  background: #1B4332 !important;
  border-color: #276749 !important;
  color: #B7F5D1 !important;
}

[data-theme="dark"] .smtp-status-active {
  background: #1B4332 !important;
  color: #B7F5D1 !important;
}

[data-theme="dark"] .smtp-status-inactive {
  background: #162032 !important;
  color: #A0AEC0 !important;
}

[data-theme="dark"] .gd-report-icon,
[data-theme="dark"] .gd-type-pill,
[data-theme="dark"] .gd-file-chip,
[data-theme="dark"] .gd-avatar {
  background: #162032 !important;
  color: #63B3ED !important;
}

[data-theme="dark"] .gd-report-table .data-table th {
  background: #0D1526 !important;
  color: #CBD5E0 !important;
}

[data-theme="dark"] .gd-report-table .data-table td,
[data-theme="dark"] .data-table td {
  background: #1E2D47 !important;
  border-color: #2D3748 !important;
  color: #E2E8F0 !important;
}

[data-theme="dark"] .data-table tbody tr:hover td { background: #22324F !important; }

[data-theme="dark"] #pdf-container { background: #0D1526 !important; }

[data-theme="dark"] #conten_documents canvas {
  box-shadow: 0 0 0 1px #2D3748, 0 8px 24px rgba(0,0,0,.45);
}

[data-theme="dark"] .gd-pdf-controls,
[data-theme="dark"] #pdf-controls {
  background: #162032 !important;
  border-color: #2D3748 !important;
  color: #E2E8F0 !important;
}

[data-theme="dark"] .gd-pdf-controls button,
[data-theme="dark"] #pdf-controls button {
  background: #1E2D47 !important;
  border-color: #2D3748 !important;
  color: #A0AEC0 !important;
}

[data-theme="dark"] .gd-mode-respuesta {
  background: #123524 !important;
  border-color: #276749 !important;
}

[data-theme="dark"] .gd-mode-devolucion {
  background: #3D1F1F !important;
  border-color: #742A2A !important;
}

[data-theme="dark"] .gd-mode-prorroga {
  background: #3D2C00 !important;
  border-color: #744210 !important;
}

[data-theme="dark"] .gd-action-card strong,
[data-theme="dark"] .gd-action-card i,
[data-theme="dark"] .gd-event-body label,
[data-theme="dark"] .upd-drop-text,
[data-theme="dark"] .upd-rad-value,
[data-theme="dark"] .upd-file-name,
[data-theme="dark"] .gd-radicado,
[data-theme="dark"] .gd-link-btn {
  color: #63B3ED !important;
}

[data-theme="dark"] .upd-drop-zone-active {
  background: #0F2942 !important;
  border-color: #4A90D9 !important;
}

[data-theme="dark"] .prt-paper-container {
  background: #0D1526 !important;
  border-color: #2D3748 !important;
}

[data-theme="dark"] .prt-paper,
[data-theme="dark"] #tbRadicado,
[data-theme="dark"] .sticker-qr,
[data-theme="dark"] .sticker-info {
  background: #fff !important;
  color: #000 !important;
}

[data-theme="dark"] #tbRadicado *,
[data-theme="dark"] .sticker-info .si-line {
  color: #000 !important;
}

[data-theme="dark"] .gd-follow-page .gd-events-panel {
  background: #1E2D47 !important;
  border-color: #2D3748 !important;
}

[data-theme="dark"] .gd-follow-page .gd-event-list {
  background: #1E2D47 !important;
}

[data-theme="dark"] .gd-follow-page .gd-event-card {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

[data-theme="dark"] .gd-follow-page .gd-event-card:before {
  background: #3B4A63 !important;
}

[data-theme="dark"] .gd-follow-page .gd-event-body {
  background: #162032 !important;
  border-color: #2D3748 !important;
  box-shadow: 0 8px 20px rgba(0,0,0,.22) !important;
}

[data-theme="dark"] .gd-follow-page .gd-event-meta strong {
  color: #E2E8F0 !important;
}

[data-theme="dark"] .gd-follow-page .gd-event-meta span {
  color: #8FA3C3 !important;
}

[data-theme="dark"] .gd-follow-page .gd-event-body label {
  color: #63B3ED !important;
}

[data-theme="dark"] .gd-follow-page .gd-event-body p {
  color: #CBD5E0 !important;
}

[data-theme="dark"] .gd-follow-page .gd-event-extra,
[data-theme="dark"] .gd-follow-page .gd-event-extra strong {
  color: #AFC0D8 !important;
}

[data-theme="dark"] .gd-follow-page .gd-event-dot {
  background: #E8F2FF !important;
  color: #1F4F82 !important;
  box-shadow: 0 0 0 4px #1E2D47;
}

[data-theme="dark"] .gd-follow-page .gd-event-success .gd-event-dot {
  background: #DDFBEA !important;
  color: #166534 !important;
}

[data-theme="dark"] .gd-follow-page .gd-event-danger .gd-event-dot {
  background: #FFE1E1 !important;
  color: #B91C1C !important;
}

[data-theme="dark"] .gd-follow-page .gd-event-warning .gd-event-dot {
  background: #FFF2C2 !important;
  color: #92400E !important;
}
