/*
 * saphiro-pro-chrome: en layout propietario (todas las URLs del módulo).
 * Paleta fondos unificada (referencia panel Deudas):
 *   void #050a14 | lienzo #0b121b | paneles #162230 | campos/tablas #1e293b
 */
body.saphiro-pro-dark-main {
  --saphiro-bg-void: #050a14;
  --saphiro-bg-canvas: #0b121b;
  --saphiro-bg-panel: #162230;
  --saphiro-bg-field: #1e293b;
}

body.saphiro-pro-chrome .back-color-header,
body.saphiro-pro-chrome .back-color-header-admin {
  background: linear-gradient(180deg, var(--saphiro-bg-void) 0%, var(--saphiro-bg-canvas) 100%) !important;
  border-bottom: 1px solid #334155;
}

body.saphiro-pro-chrome .header-area .main-header-area.sticky {
  background: var(--saphiro-bg-canvas) !important;
  color: #e2e8f0 !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35) !important;
}

body.saphiro-pro-chrome .header-area .main-header-area.sticky ul li a,
body.saphiro-pro-chrome .header-area .main-header-area.sticky ul li a:hover {
  color: #d4c4a8 !important;
}

body.saphiro-pro-chrome .header-option {
  color: #d4c4a8 !important;
}

body.saphiro-pro-chrome .header-area .main-header-area .main-menu ul li a:hover {
  color: #f8fafc !important;
}

body.saphiro-pro-chrome .header-area .main-header-area .main-menu ul li .submenu {
  background: var(--saphiro-bg-panel) !important;
  border: 1px solid #334155;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.45);
}

body.saphiro-pro-chrome .header-area .main-header-area .main-menu ul li .submenu li a {
  color: #e2e8f0 !important;
}

body.saphiro-pro-chrome .header-area .main-header-area .main-menu ul li .submenu li:hover a {
  color: #fff !important;
  background: rgba(59, 130, 246, 0.12);
}

body.saphiro-pro-chrome .sub-option-admin {
  background-color: var(--saphiro-bg-panel) !important;
}

body.saphiro-pro-chrome .header_toggle {
  color: #e2e8f0 !important;
}

body.saphiro-pro-chrome .btn-conf-movil .bx-cog {
  color: #e2e8f0 !important;
}

body.saphiro-pro-chrome .btn-conf-movil .bx-cog:hover {
  color: #93c5fd !important;
}

body.saphiro-pro-chrome .menu_peque .dropdown-menu {
  background: var(--saphiro-bg-panel) !important;
  border: 1px solid #334155 !important;
}

body.saphiro-pro-chrome .menu_peque .dropdown-item.sub-option-menu-mobile {
  color: #e2e8f0 !important;
  background: transparent !important;
}

body.saphiro-pro-chrome .menu_peque .dropdown-item.sub-option-menu-mobile:hover {
  background: rgba(59, 130, 246, 0.15) !important;
  color: #fff !important;
}

body.saphiro-pro-chrome .div-frame-top,
body.saphiro-pro-chrome .div-frame-top-admin {
  background-color: var(--saphiro-bg-panel) !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25);
  border: 1px solid #334155;
}

body.saphiro-pro-chrome .div-frame-top-admin .title-text {
  color: #e2e8f0 !important;
}

/* Panel admin: style-admin.css define .div-frame-top { background-color: white } — forzar tema */
body.saphiro-pro-dark-main.adm-body #body-pd .div-frame-top,
body.saphiro-pro-dark-main.adm-body #body-pd .div-frame-top-admin {
  background-color: var(--saphiro-bg-panel) !important;
  border: 1px solid var(--saphiro-border-subtle, #334155);
}

body.saphiro-pro-dark-main.adm-body #body-pd .div-frame-top .title-text {
  color: #e2e8f0 !important;
}

/* Cabecera superior: .back-color-header en style-admin es blanco por defecto */
body.saphiro-pro-dark-main.adm-body .header-area.back-color-header,
body.saphiro-pro-dark-main.adm-body .back-color-header {
  background: linear-gradient(180deg, var(--saphiro-bg-void) 0%, var(--saphiro-bg-canvas) 100%) !important;
}

/* Configuración / condominio: columnas y #base sin parche claro */
body.saphiro-pro-dark-main.adm-body #body-pd #base,
body.saphiro-pro-dark-main.adm-body #body-pd #base > .row,
body.saphiro-pro-dark-main.adm-body #body-pd #conf_menu,
body.saphiro-pro-dark-main.adm-body #body-pd #Condominio {
  background-color: transparent !important;
}

/* Portería: tasas del día sobre fondo oscuro */
body.saphiro-pro-dark-main .division-tasa-text,
body.saphiro-pro-dark-main .subtitle-text.division-tasa-text {
  color: #cbd5e1 !important;
}

body.saphiro-pro-dark-main .div-tasa-border {
  border-color: rgba(51, 65, 85, 0.85) !important;
}

body.saphiro-pro-chrome .title-text {
  color: #e2e8f0 !important;
}

/* Cerrar sesión junto a Inicio / Categoría / … en el header */
body.saphiro-pro-chrome .header-option.saphiro-pro-nav-logout {
  color: #fca5a5 !important;
}

body.saphiro-pro-chrome .header-area .main-header-area.sticky ul li a.saphiro-pro-nav-logout {
  color: #fca5a5 !important;
}

body.saphiro-pro-chrome .menu_peque .dropdown-item.saphiro-pro-nav-logout {
  color: #fca5a5 !important;
}

/* Catálogos públicos: tarjetas más claras, imagen con zoom y acciones visibles. */
body.saphiro-pro-dark-main .saphiro-public-card {
  height: 100%;
  border: 1px solid rgba(51, 65, 85, 0.55);
  border-radius: 1rem;
  background: #fff;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

body.saphiro-pro-dark-main .saphiro-public-thumb {
  height: 230px;
  overflow: hidden;
  border-radius: 0.85rem 0.85rem 0 0;
}

body.saphiro-pro-dark-main .saphiro-img-button {
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: zoom-in;
}

body.saphiro-pro-dark-main .saphiro-img-button img,
body.saphiro-pro-dark-main .saphiro-public-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  transition: transform 0.2s ease;
}

body.saphiro-pro-dark-main .saphiro-img-button:hover img {
  transform: scale(1.04);
}

body.saphiro-pro-dark-main .saphiro-public-noimage {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  background: #e2e8f0;
  color: #475569;
  font-weight: 700;
}

body.saphiro-pro-dark-main .saphiro-public-type {
  display: inline-block;
  margin: 0.9rem 1rem 0;
  padding: 0.25rem 0.55rem;
  border-radius: 999px;
  background: rgba(245, 158, 11, 0.15);
  color: #92400e;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

body.saphiro-pro-dark-main .saphiro-public-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  padding: 0 1rem 1rem;
}

body.saphiro-pro-dark-main .saphiro-public-actions .btn-inicio,
body.saphiro-pro-dark-main .saphiro-public-actions a.btn-inicio {
  width: auto;
  min-width: 96px;
  text-align: center;
  text-decoration: none;
}

body.saphiro-pro-dark-main .saphiro-whatsapp {
  background: #16a34a !important;
  border-color: #16a34a !important;
}

body.saphiro-pro-dark-main .saphiro-reservar {
  background: #2563eb !important;
  border-color: #2563eb !important;
}

body.saphiro-pro-dark-main .saphiro-public-zoom-img {
  display: block;
  width: 100%;
  max-height: 82vh;
  object-fit: contain;
  background: #020617;
}

/*
 * Sin menú lateral: quitar sangría que reserva la barra (#nav-bar).
 * Con barra (admin): NO anular padding — si no, el contenido queda bajo .l-navbar y se recorta el texto.
 */
@media screen and (min-width: 768px) {
  body.saphiro-pro-chrome.adm-body:not(.saphiro-admin-has-sidebar):not(.saphiro-propietario-has-sidebar) {
    padding-left: 0 !important;
  }

  body.saphiro-pro-chrome.adm-body:not(.saphiro-admin-has-sidebar):not(.saphiro-propietario-has-sidebar) #body-pd {
    padding-left: 0 !important;
  }

  body.saphiro-pro-chrome:not(.saphiro-propietario-has-sidebar) .left-media {
    left: 1rem !important;
  }
}

body.saphiro-pro-chrome .header_toggle {
  display: none !important;
}

/* Barra lateral copropietario: mostrar hamburguesa y alinear cabecera con style-admin */
body.saphiro-pro-chrome.saphiro-propietario-has-sidebar .header_toggle {
  display: block !important;
}

@media screen and (min-width: 768px) {
  body.saphiro-pro-chrome.saphiro-propietario-has-sidebar .left-media {
    left: 5.5rem !important;
    width: 150px !important;
  }
}

/* Sin franja gris entre cabecera y contenido oscuro */
body.saphiro-pro-chrome.saphiro-pro-dark-main.adm-body {
  background: var(--saphiro-bg-void);
}

/* Activo solo con class en body: templates inicio + pagos copropietario (contenido principal). */

body.saphiro-pro-dark-main .blog_area.section-padding {
  background: linear-gradient(180deg, var(--saphiro-bg-void) 0%, var(--saphiro-bg-canvas) 55%, var(--saphiro-bg-canvas) 100%) !important;
}

/* Evita franja #F5F5F5 de .back-color (style-admin) y huecos entre header y contenido */
body.saphiro-pro-dark-main.adm-body #contenedor_general,
body.saphiro-pro-dark-main.adm-body #body-pd {
  background-color: var(--saphiro-bg-void);
}

body.saphiro-pro-dark-main.adm-body .l-navbar {
  background: var(--saphiro-bg-void) !important;
}

body.saphiro-pro-chrome.saphiro-propietario-has-sidebar .nav_link {
  min-height: 52px;
  gap: 0.85rem;
}

body.saphiro-pro-chrome.saphiro-propietario-has-sidebar .nav_link i,
body.saphiro-pro-chrome.saphiro-propietario-has-sidebar .nav_icon,
body.saphiro-pro-chrome.saphiro-propietario-has-sidebar .nav_logo-icon {
  font-size: 1.45rem !important;
}

body.saphiro-pro-chrome.saphiro-propietario-has-sidebar .nav_name {
  font-size: 0.92rem;
  font-weight: 700;
}

body.saphiro-pro-chrome .saphiro-owner-chip {
  margin: 0.45rem 0.85rem 0.9rem;
  padding: 0.65rem 0.7rem;
  border: 1px solid rgba(245, 158, 11, 0.35);
  border-radius: 0.85rem;
  background: rgba(245, 158, 11, 0.09);
  color: #e2e8f0;
}

body.saphiro-pro-chrome .saphiro-owner-chip span {
  display: block;
  font-size: 0.62rem;
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #fbbf24;
}

body.saphiro-pro-chrome .saphiro-owner-chip strong {
  display: block;
  margin-top: 0.3rem;
  font-size: 0.85rem;
  line-height: 1.2;
  color: #fff;
}

body.saphiro-pro-dark-main.adm-body .blog_area.back-color {
  background: linear-gradient(180deg, var(--saphiro-bg-void) 0%, var(--saphiro-bg-canvas) 55%, var(--saphiro-bg-canvas) 100%) !important;
}

body.saphiro-layout-propietario.saphiro-pro-dark-main #body-pd .container .center-area,
body.saphiro-layout-propietario.saphiro-pro-dark-main #body-pd .normal-font {
  color: #cbd5e1;
}

body.saphiro-pro-dark-main .divider {
  border-color: rgba(51, 65, 85, 0.8) !important;
}

/* Perfil expandible (misma página inicio) */
body.saphiro-pro-dark-main #ViewUserProfile {
  background: var(--saphiro-bg-panel) !important;
  border-color: #334155 !important;
  color: #e2e8f0;
}

body.saphiro-pro-dark-main #ViewUserProfile .text-dark,
body.saphiro-pro-dark-main #ViewUserProfile .normal-font {
  color: #e2e8f0 !important;
}

body.saphiro-pro-dark-main #ViewUserProfile .divider {
  border-color: #334155 !important;
}

/* Modal método de pago (pantalla pagos) — solo paneles con adm-body (no sitio público) */
body.saphiro-pro-dark-main.adm-body .modal-content {
  background: var(--saphiro-bg-panel);
  color: #e2e8f0;
  border: 1px solid #334155;
}

body.saphiro-pro-dark-main.adm-body .modal-header,
body.saphiro-pro-dark-main.adm-body .modal-footer {
  border-color: #334155;
}

body.saphiro-pro-dark-main.adm-body .modal-header .close {
  color: #e2e8f0;
  text-shadow: none;
  opacity: 0.85;
}

/*
  Modales admin: bootstrap.min.css fuerza .modal-dialog { background:#fff } y .tabla-reportes
  con display:grid + tbody fijo (55rem), lo que rompe tablas y contraste en tema oscuro.
*/
body.saphiro-pro-dark-main.adm-body .modal-dialog {
  background: transparent !important;
  max-width: min(96vw, 1140px);
}

body.saphiro-pro-dark-main.adm-body .modal .modal-title {
  color: var(--saphiro-text, #f3f4f6);
}

body.saphiro-pro-dark-main.adm-body .modal .table-responsive.saphiro-modal-table-wrap,
body.saphiro-pro-dark-main.adm-body .modal .saphiro-modal-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
}

body.saphiro-pro-dark-main.adm-body .modal .table.tabla-reportes,
body.saphiro-pro-dark-main.adm-body .modal #tabla-reportes {
  display: table !important;
  width: 100% !important;
  margin-left: 0 !important;
  border-collapse: collapse !important;
  table-layout: auto;
}

body.saphiro-pro-dark-main.adm-body .modal .tabla-reportes thead,
body.saphiro-pro-dark-main.adm-body .modal #tabla-reportes thead {
  display: table-header-group !important;
}

body.saphiro-pro-dark-main.adm-body .modal .tabla-reportes tbody,
body.saphiro-pro-dark-main.adm-body .modal #tabla-reportes tbody {
  display: table-row-group !important;
  width: auto !important;
  max-width: none !important;
  background-color: transparent !important;
  white-space: normal !important;
}

body.saphiro-pro-dark-main.adm-body .modal .tabla-reportes tr,
body.saphiro-pro-dark-main.adm-body .modal #tabla-reportes tr {
  display: table-row !important;
}

body.saphiro-pro-dark-main.adm-body .modal .tabla-reportes th,
body.saphiro-pro-dark-main.adm-body .modal #tabla-reportes th {
  background: rgba(55, 65, 81, 0.95) !important;
  color: #f3f4f6 !important;
  padding: 0.5rem 0.65rem !important;
  border: 1px solid #4b5563 !important;
  border-radius: 0 !important;
  font-weight: 600;
}

body.saphiro-pro-dark-main.adm-body .modal .tabla-reportes td,
body.saphiro-pro-dark-main.adm-body .modal #tabla-reportes td {
  color: #e5e7eb !important;
  background: rgba(15, 23, 42, 0.35) !important;
  border: 1px solid #4b5563 !important;
  padding: 0.45rem 0.6rem !important;
  vertical-align: middle;
}

/* Tablas genéricas en modales (no solo #tabla-reportes / .tabla-reportes) */
body.saphiro-pro-dark-main.adm-body .modal .modal-body .table {
  color: #e5e7eb;
}

body.saphiro-pro-dark-main.adm-body .modal .modal-body .table thead th {
  color: #f3f4f6;
  border-color: #4b5563;
}

body.saphiro-pro-dark-main.adm-body .modal .modal-body .table td {
  border-color: #4b5563;
}

body.saphiro-pro-dark-main.adm-body .modal.saphiro-admin-modal .modal-body label {
  color: var(--saphiro-text-muted, #9ca3af);
}

body.saphiro-pro-dark-main.adm-body .modal.saphiro-admin-modal .modal-body .form-control {
  background-color: var(--saphiro-bg-input, #1e293b) !important;
  border-color: var(--saphiro-border, #374151) !important;
  color: var(--saphiro-text, #f3f4f6) !important;
}

/* Modales en tema oscuro sin panel admin (p. ej. base-layout / reservaciones) */
body.saphiro-pro-dark-main:not(.adm-body) .modal-dialog {
  background: transparent !important;
  max-width: min(96vw, 800px);
}

body.saphiro-pro-dark-main:not(.adm-body) .modal-content {
  background: var(--saphiro-bg-panel, #1e293b);
  color: #e2e8f0;
  border: 1px solid #334155;
}

body.saphiro-pro-dark-main:not(.adm-body) .modal-header,
body.saphiro-pro-dark-main:not(.adm-body) .modal-footer {
  border-color: #334155;
}

body.saphiro-pro-dark-main:not(.adm-body) .modal-header .close {
  color: #e2e8f0;
  text-shadow: none;
  opacity: 0.85;
}

body.saphiro-pro-dark-main:not(.adm-body) .modal.saphiro-admin-modal .modal-body label {
  color: #9ca3af;
}

body.saphiro-pro-dark-main:not(.adm-body) .modal.saphiro-admin-modal .modal-body .form-control {
  background-color: #1e293b !important;
  border-color: #374151 !important;
  color: #f3f4f6 !important;
}

body.saphiro-pro-dark-main:not(.adm-body) .modal.saphiro-public-modal .modal-body strong {
  color: #f3f4f6;
}

/* Sitio público, superusuario: mismo degradado de fondo sin adm-body */
body.saphiro-pro-dark-main:not(.adm-body) {
  background: linear-gradient(180deg, var(--saphiro-bg-void) 0%, var(--saphiro-bg-canvas) 50%, var(--saphiro-bg-canvas) 100%) !important;
  min-height: 100vh;
}

/* Superusuario: contenido principal legible */
body.saphiro-pro-dark-main .saphiro-superuser-main {
  color: #e2e8f0;
}

/* =============================================================================
   Tema oscuro unificado — paneles administración / copropietario (#body-pd)
   Variables de fondo: heredan --saphiro-bg-* del body (paleta Deudas).
   ============================================================================= */
body.saphiro-pro-dark-main.adm-body {
  --saphiro-bg-deep: var(--saphiro-bg-void);
  --saphiro-bg-card: var(--saphiro-bg-panel);
  --saphiro-bg-input: var(--saphiro-bg-field);
  --saphiro-bg-muted-surface: var(--saphiro-bg-panel);
  --saphiro-border: #374151;
  --saphiro-border-subtle: #334155;
  --saphiro-text: #f3f4f6;
  --saphiro-text-muted: #9ca3af;
  --saphiro-accent: #2563eb;
  --saphiro-accent-soft: rgba(37, 99, 235, 0.2);
}

body.saphiro-pro-dark-main.adm-body #body-pd .modulo,
body.saphiro-pro-dark-main.adm-body #body-pd .container.modulo,
body.saphiro-pro-dark-main.adm-body #body-pd .container.rounded.modulo {
  background: var(--saphiro-bg-card) !important;
  border-color: var(--saphiro-border-subtle) !important;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4) !important;
  color: var(--saphiro-text);
}

body.saphiro-pro-dark-main.adm-body #body-pd .text-dark {
  color: var(--saphiro-text) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .col-form-label,
body.saphiro-pro-dark-main.adm-body #body-pd .col-form-label.text-dark {
  color: var(--saphiro-text-muted) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .form-control,
body.saphiro-pro-dark-main.adm-body #body-pd select.form-control,
body.saphiro-pro-dark-main.adm-body #body-pd textarea.form-control,
body.saphiro-pro-dark-main.adm-body #body-pd .custom-select,
body.saphiro-pro-dark-main.adm-body #body-pd select {
  background-color: var(--saphiro-bg-input) !important;
  border-color: var(--saphiro-border) !important;
  color: var(--saphiro-text) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .form-control:focus,
body.saphiro-pro-dark-main.adm-body #body-pd select:focus,
body.saphiro-pro-dark-main.adm-body #body-pd textarea:focus {
  background-color: var(--saphiro-bg-input) !important;
  color: var(--saphiro-text) !important;
  border-color: var(--saphiro-accent) !important;
  box-shadow: 0 0 0 0.2rem var(--saphiro-accent-soft);
}

body.saphiro-pro-dark-main.adm-body #body-pd .form-control::placeholder {
  color: #6b7280;
}

body.saphiro-pro-dark-main.adm-body #body-pd .input-group-text {
  background: var(--saphiro-bg-field) !important;
  border-color: var(--saphiro-border) !important;
  color: var(--saphiro-text-muted) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .custom-file-label {
  background: var(--saphiro-bg-input) !important;
  border-color: var(--saphiro-border) !important;
  color: var(--saphiro-text-muted) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd option {
  background: var(--saphiro-bg-input);
  color: var(--saphiro-text);
}

body.saphiro-pro-dark-main.adm-body #body-pd .btn-option {
  background-color: rgba(22, 34, 48, 0.95) !important;
  border: 1px solid #b45309 !important;
  color: #fdba74 !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .btn-option:hover {
  background-color: var(--saphiro-accent-soft) !important;
  border-color: var(--saphiro-accent) !important;
  color: #fff !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .button-table {
  background-color: var(--saphiro-bg-input) !important;
  border-color: #b45309 !important;
  color: #fdba74 !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .button-table:hover {
  background-color: var(--saphiro-accent) !important;
  border-color: var(--saphiro-accent) !important;
  color: #fff !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .table {
  color: var(--saphiro-text);
  background-color: transparent;
}

body.saphiro-pro-dark-main.adm-body #body-pd .table thead th,
body.saphiro-pro-dark-main.adm-body #body-pd .table-header {
  background: var(--saphiro-bg-field) !important;
  color: var(--saphiro-text) !important;
  border-color: var(--saphiro-border-subtle) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .table td,
body.saphiro-pro-dark-main.adm-body #body-pd .table th {
  border-color: var(--saphiro-border-subtle) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd tbody[style*="background-color: white"],
body.saphiro-pro-dark-main.adm-body #body-pd tbody[style*="background-color:white"] {
  background-color: transparent !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .card {
  background: var(--saphiro-bg-card);
  border-color: var(--saphiro-border-subtle);
  color: var(--saphiro-text);
}

body.saphiro-pro-dark-main.adm-body #body-pd .card-header {
  background: var(--saphiro-bg-panel);
  border-bottom-color: var(--saphiro-border-subtle);
  color: var(--saphiro-text);
}

body.saphiro-pro-dark-main.adm-body #body-pd .graphic {
  background-color: var(--saphiro-bg-card) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .text-color-general {
  color: var(--saphiro-text) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd [style*="background-color: #e9ecef"],
body.saphiro-pro-dark-main.adm-body #body-pd [style*="background-color:#e9ecef"] {
  background-color: var(--saphiro-bg-muted-surface) !important;
  border-color: var(--saphiro-border-subtle) !important;
  color: var(--saphiro-text) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .dataTables_wrapper,
body.saphiro-pro-dark-main.adm-body #body-pd .dataTables_wrapper label,
body.saphiro-pro-dark-main.adm-body #body-pd .dataTables_info,
body.saphiro-pro-dark-main.adm-body #body-pd .dataTables_length,
body.saphiro-pro-dark-main.adm-body #body-pd .dataTables_filter {
  color: var(--saphiro-text-muted);
}

body.saphiro-pro-dark-main.adm-body #body-pd .dataTables_wrapper .form-control {
  background: var(--saphiro-bg-input) !important;
  color: var(--saphiro-text) !important;
  border-color: var(--saphiro-border) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .page-link {
  background: var(--saphiro-bg-input);
  border-color: var(--saphiro-border);
  color: var(--saphiro-text);
}

body.saphiro-pro-dark-main.adm-body #body-pd .page-item.active .page-link {
  background: var(--saphiro-accent);
  border-color: var(--saphiro-accent);
}

body.saphiro-pro-dark-main.adm-body #body-pd .alert-info {
  background: rgba(37, 99, 235, 0.18);
  border-color: rgba(59, 130, 246, 0.45);
  color: #bfdbfe;
}

body.saphiro-pro-dark-main.adm-body #body-pd .alert-success {
  background: rgba(16, 185, 129, 0.15);
  border-color: rgba(16, 185, 129, 0.4);
  color: #a7f3d0;
}

body.saphiro-pro-dark-main.adm-body #body-pd .alert-warning {
  background: rgba(245, 158, 11, 0.15);
  border-color: rgba(245, 158, 11, 0.4);
  color: #fde68a;
}

body.saphiro-pro-dark-main.adm-body #body-pd .alert-danger {
  background: rgba(248, 113, 113, 0.12);
  border-color: rgba(248, 113, 113, 0.45);
  color: #fecaca;
}

body.saphiro-pro-dark-main.adm-body #body-pd .list-group-item {
  background: var(--saphiro-bg-input);
  border-color: var(--saphiro-border-subtle);
  color: var(--saphiro-text);
}

body.saphiro-pro-dark-main.adm-body #body-pd .modulo h1,
body.saphiro-pro-dark-main.adm-body #body-pd .modulo h2,
body.saphiro-pro-dark-main.adm-body #body-pd .modulo h3,
body.saphiro-pro-dark-main.adm-body #body-pd .modulo h4,
body.saphiro-pro-dark-main.adm-body #body-pd .modulo h5 {
  color: var(--saphiro-text);
}

body.saphiro-pro-dark-main.adm-body #body-pd .modulo .text-muted {
  color: var(--saphiro-text-muted) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .border-secondary {
  border-color: var(--saphiro-border-subtle) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .subtitle-text,
body.saphiro-pro-dark-main.adm-body #body-pd .normal-font,
body.saphiro-pro-dark-main.adm-body #body-pd .sub-option {
  color: var(--saphiro-text-muted) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .text-tasa-value {
  color: #93c5fd !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .alert .close {
  color: inherit;
  opacity: 0.85;
  text-shadow: none;
}

body.saphiro-pro-dark-main.adm-body #body-pd .dropdown-menu {
  background: var(--saphiro-bg-panel);
  border-color: var(--saphiro-border-subtle);
}

body.saphiro-pro-dark-main.adm-body #body-pd .dropdown-item {
  color: var(--saphiro-text);
}

body.saphiro-pro-dark-main.adm-body #body-pd .dropdown-item:hover {
  background: rgba(37, 99, 235, 0.2);
  color: #fff;
}

/* ---------------------------------------------------------------------------
   Formularios form-style-10 / 12 (style-admin.css usa #FFF y #F8F8F8)
   Configuración, propietarios, bancos, etc.
   --------------------------------------------------------------------------- */
body.saphiro-pro-dark-main.adm-body #body-pd .form-style-10,
body.saphiro-pro-dark-main.adm-body #body-pd .form-style-12 {
  background: var(--saphiro-bg-panel) !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .form-style-10 .inner-wrap,
body.saphiro-pro-dark-main.adm-body #body-pd .form-style-12 .inner-wrap {
  background: rgba(30, 41, 59, 0.55) !important;
  border: 1px solid var(--saphiro-border-subtle);
}

body.saphiro-pro-dark-main.adm-body #body-pd .form-style-10 label,
body.saphiro-pro-dark-main.adm-body #body-pd .form-style-12 label {
  color: var(--saphiro-text-muted) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .form-style-10 .section span {
  border-color: var(--saphiro-bg-panel) !important;
}

/* ---------------------------------------------------------------------------
   Tablas Bootstrap / DataTables: celdas y franjas claras por defecto
   --------------------------------------------------------------------------- */
body.saphiro-pro-dark-main.adm-body #body-pd .table td,
body.saphiro-pro-dark-main.adm-body #body-pd .table tbody th {
  background-color: transparent !important;
  border-color: var(--saphiro-border-subtle) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .table thead th {
  border-color: var(--saphiro-border-subtle) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .table-bordered td,
body.saphiro-pro-dark-main.adm-body #body-pd .table-bordered th {
  border-color: var(--saphiro-border-subtle) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd thead.thead-light th {
  background-color: var(--saphiro-bg-field) !important;
  color: var(--saphiro-text) !important;
  border-color: var(--saphiro-border-subtle) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .table-striped tbody tr:nth-of-type(odd) {
  background-color: rgba(22, 34, 48, 0.45) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .table-hover tbody tr:hover {
  background-color: rgba(37, 99, 235, 0.14) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd table.dataTable tbody tr {
  background-color: transparent !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd table.dataTable.stripe tbody tr.odd,
body.saphiro-pro-dark-main.adm-body #body-pd table.dataTable.display tbody tr.odd {
  background-color: rgba(22, 34, 48, 0.4) !important;
}

/* Resaltado de búsqueda DataTables (<mark>): mismo color de texto, sin bloque amarillo/gris */
body.saphiro-pro-dark-main.adm-body #body-pd table.dataTable tbody td mark,
body.saphiro-pro-dark-main.adm-body #body-pd .table tbody td mark {
  background: transparent !important;
  color: inherit !important;
  padding: 0;
}

body.saphiro-pro-dark-main.adm-body #body-pd .dataTables_wrapper .dataTables_length,
body.saphiro-pro-dark-main.adm-body #body-pd .dataTables_wrapper .dataTables_filter,
body.saphiro-pro-dark-main.adm-body #body-pd .dataTables_wrapper .dataTables_info,
body.saphiro-pro-dark-main.adm-body #body-pd .dataTables_wrapper .dataTables_paginate {
  background: transparent !important;
}

/* Utilidades Bootstrap que aún inyectan blanco en plantillas */
body.saphiro-pro-dark-main.adm-body #body-pd .bg-white {
  background-color: var(--saphiro-bg-panel) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .bg-light {
  background-color: rgba(30, 41, 59, 0.45) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .jumbotron {
  background: var(--saphiro-bg-panel) !important;
  color: var(--saphiro-text);
}

body.saphiro-pro-dark-main.adm-body #body-pd .card-body {
  background-color: transparent !important;
  color: var(--saphiro-text);
}

/* ---------------------------------------------------------------------------
   Viewports: sin scroll horizontal; html oscuro (evita franja clara abajo)
   --------------------------------------------------------------------------- */
html {
  background-color: #050a14;
}

body.saphiro-pro-dark-main.adm-body {
  overflow-x: clip;
  background: var(--saphiro-bg-void) !important;
}

body.saphiro-pro-dark-main.adm-body #body-pd .blog_area.section-padding {
  padding-bottom: 2.5rem !important;
}

/* Panel con sidebar: menos hueco bajo la cabecera global */
body.saphiro-pro-dark-main.adm-body.saphiro-admin-has-sidebar #body-pd .blog_area.section-padding,
body.saphiro-pro-dark-main.adm-body.saphiro-propietario-has-sidebar #body-pd .blog_area.section-padding {
  padding-top: 0.35rem !important;
}

body.saphiro-pro-dark-main.adm-body footer.footer,
body.saphiro-pro-dark-main.adm-body .footer.copy-right_text,
body.saphiro-pro-dark-main.adm-body .copy-right_text {
  background: var(--saphiro-bg-void) !important;
}

body.saphiro-pro-dark-main.adm-body .footer .copy-right_text .footer_border {
  border-top: 1px solid rgba(51, 65, 85, 0.75) !important;
  padding-bottom: 1.25rem;
}

body.saphiro-pro-dark-main.adm-body .footer .copy_right {
  color: #94a3b8 !important;
}

/* Login / páginas públicas (base-layout): cabecera y tarjeta alineadas al tema */
body.saphiro-pro-dark-main:not(.adm-body) .header-area {
  background: linear-gradient(180deg, var(--saphiro-bg-void) 0%, var(--saphiro-bg-canvas) 100%) !important;
  border-bottom: 1px solid #334155;
}

body.saphiro-pro-dark-main:not(.adm-body) .header-area .main-header-area {
  background: transparent !important;
}

body.saphiro-pro-dark-main:not(.adm-body) .header-area .main-menu ul li a,
body.saphiro-pro-dark-main:not(.adm-body) .header-area #navigation li a {
  color: #d4c4a8 !important;
}

body.saphiro-pro-dark-main:not(.adm-body) .header-area .main-menu ul li a:hover {
  color: #f8fafc !important;
}

.saphiro-login-page-wrap {
  min-height: min(70vh, calc(100vh - 220px));
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.saphiro-public-login-card {
  background: var(--saphiro-bg-panel) !important;
  border: 1px solid #334155;
  color: #e2e8f0;
}

.saphiro-public-login-title {
  color: #f1f5f9 !important;
  font-size: 1.35rem;
}

.saphiro-public-login-card label {
  color: #94a3b8;
}

.saphiro-public-login-card .form-control {
  background: var(--saphiro-bg-field) !important;
  border-color: #475569 !important;
  color: #f1f5f9 !important;
}

.saphiro-public-login-card .form-control:focus {
  border-color: #2563eb !important;
  box-shadow: 0 0 0 0.15rem rgba(37, 99, 235, 0.25);
}

.saphiro-public-login-links a {
  color: #93c5fd !important;
}

body.saphiro-pro-dark-main:not(.adm-body) footer.footer {
  background: var(--saphiro-bg-void) !important;
}

body.saphiro-pro-dark-main:not(.adm-body) .footer .footer_top {
  background: transparent !important;
}
