/**
 * Condominio Manager — Design System
 * UI/UX de calidad mundial. Sin cambios de lógica, solo apariencia.
 */

@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,300;0,400;0,500;0,700;1,400&display=swap');

:root {
    --cm-font: 'Roboto', -apple-system, BlinkMacSystemFont, sans-serif;
    --cm-primary: #0d9488;
    --cm-primary-dark: #0f766e;
    --cm-primary-light: #ccfbf1;
    --cm-accent: #f59e0b;
    --cm-accent-light: #fef3c7;
    --cm-surface: #ffffff;
    --cm-bg: #f1f5f9;
    --cm-bg-subtle: #f8fafc;
    --cm-text: #1e293b;
    --cm-text-muted: #64748b;
    --cm-border: #e2e8f0;
    --cm-success: #059669;
    --cm-success-bg: #d1fae5;
    --cm-danger: #dc2626;
    --cm-danger-bg: #fee2e2;
    --cm-warning: #d97706;
    --cm-warning-bg: #fef3c7;
    --cm-info: #0d9488;
    --cm-info-bg: #e0f2fe;
    --cm-nav: #0f172a;
    --cm-nav-text: rgba(255,255,255,0.9);
    --cm-nav-hover: #fff;
    --cm-shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.05);
    --cm-shadow: 0 4px 6px -1px rgba(15, 23, 42, 0.07), 0 2px 4px -2px rgba(15, 23, 42, 0.05);
    --cm-shadow-lg: 0 10px 15px -3px rgba(15, 23, 42, 0.08), 0 4px 6px -4px rgba(15, 23, 42, 0.05);
    --cm-radius: 12px;
    --cm-radius-lg: 16px;
    --cm-radius-xl: 20px;
    --cm-ease: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --cm-ease-out: cubic-bezier(0.22, 1, 0.36, 1);
    --cm-duration: 0.25s;
    --cm-duration-fast: 0.15s;
}

/* --- Animaciones y transiciones --- */
@keyframes cm-fade-in {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes cm-slide-down {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* --- Alertas flash globales (animadas) --- */
.cm-flash-stack .cm-flash-alert-animated {
    animation: cm-slide-down 0.45s var(--cm-ease-out) both;
}
.cm-flash-stack .alert {
    border-radius: var(--cm-radius);
}

@keyframes cm-scale-in {
    from { opacity: 0; transform: scale(0.97); }
    to { opacity: 1; transform: scale(1); }
}

.main-content {
    animation: cm-fade-in var(--cm-duration) var(--cm-ease-out) both;
}

.page-header {
    animation: cm-fade-in 0.3s var(--cm-ease-out) 0.05s both;
}

.filter-card,
.card:not(.stat-card) {
    animation: cm-fade-in 0.35s var(--cm-ease-out) 0.08s both;
}

/* --- Base --- */
body {
    font-family: var(--cm-font) !important;
    background: var(--cm-bg) !important;
    color: var(--cm-text) !important;
    -webkit-font-smoothing: antialiased;
    margin: 0;
    padding: 0;
}

/* Header y footer a ancho completo; solo el cuerpo (main) tiene 20px a los lados */
.main-content {
    max-width: 100%;
    margin: 0 auto;
    padding: 1.75rem 20px 2.5rem;
    box-sizing: border-box;
}

/* Que el contenido use todo el ancho disponible (sin límite de .container de Bootstrap) */
.main-content .container {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

footer .container {
    padding-left: 20px !important;
    padding-right: 20px !important;
    max-width: 100%;
}

/* --- Page headers (títulos de pantalla) --- */
.page-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 1.75rem;
}
.page-header h1,
.page-header h2 {
    font-weight: 700 !important;
    color: var(--cm-text) !important;
    margin: 0 !important;
    font-size: 1.65rem !important;
    letter-spacing: -0.02em;
}
.page-header .subtitle {
    color: var(--cm-text-muted);
    font-size: 0.95rem;
    margin-top: 0.25rem;
}
.page-header .page-actions .btn {
    font-weight: 600;
    border-radius: 10px;
    padding: 0.5rem 1rem;
}

/* --- Cards (tarjetas modernas) --- */
.card-modern,
.card.shadow-sm.border-0,
.card {
    background: var(--cm-surface) !important;
    border-radius: var(--cm-radius-lg) !important;
    border: 1px solid var(--cm-border) !important;
    box-shadow: var(--cm-shadow) !important;
    overflow: hidden;
    transition: box-shadow var(--cm-duration) var(--cm-ease), transform var(--cm-duration) var(--cm-ease);
}
.card:hover {
    transform: translateY(-2px);
    box-shadow: var(--cm-shadow-lg) !important;
}
.card-modern:hover,
.card.shadow-sm.border-0:hover {
    box-shadow: var(--cm-shadow-lg) !important;
}
.card-header.bg-light,
.card-header.bg-white {
    background: var(--cm-bg-subtle) !important;
    border-bottom: 1px solid var(--cm-border) !important;
    padding: 1rem 1.25rem !important;
    font-weight: 600;
    color: var(--cm-text) !important;
    font-size: 0.95rem;
}
.card-header h5,
.card-header h6 {
    margin: 0 !important;
    font-weight: 700 !important;
    color: var(--cm-text) !important;
}
.card-body {
    padding: 1.25rem !important;
}

/* --- Stats cards (dashboard) --- */
.stat-card {
    background: var(--cm-surface) !important;
    border-radius: var(--cm-radius-lg) !important;
    border: 1px solid var(--cm-border) !important;
    box-shadow: var(--cm-shadow) !important;
    padding: 1.35rem !important;
    height: 100%;
    position: relative;
    overflow: hidden;
    transition: box-shadow var(--cm-duration) var(--cm-ease), transform var(--cm-duration) var(--cm-ease);
}
.stat-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--cm-shadow-lg) !important;
}
.stat-card .stat-icon {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
}
.stat-card .stat-label {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--cm-text-muted) !important;
}
.stat-card .stat-value {
    font-weight: 800 !important;
    font-size: 1.5rem !important;
    letter-spacing: -0.02em;
    margin-top: 0.25rem;
}

/* --- Tables (jTable y tablas en general): legacy solo sin UI Tabler; con Tabler manda tabler-standard.css --- */
body:not(.cm-ui-kit-tabler) .table-responsive {
    border-radius: var(--cm-radius);
    overflow: hidden;
}
body:not(.cm-ui-kit-tabler) .table {
    margin-bottom: 0 !important;
    font-size: 0.9rem;
}
body:not(.cm-ui-kit-tabler) .table thead th {
    background: var(--cm-bg-subtle) !important;
    color: var(--cm-text-muted) !important;
    font-weight: 700 !important;
    font-size: 0.7rem !important;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.9rem 1rem !important;
    border: none !important;
    border-bottom: 2px solid var(--cm-border) !important;
}
body:not(.cm-ui-kit-tabler) .table tbody td {
    padding: 0.85rem 1rem !important;
    vertical-align: middle !important;
    border-color: var(--cm-border) !important;
}
body:not(.cm-ui-kit-tabler) .table tbody td.text-body {
    color: var(--cm-text) !important;
    font-size: inherit;
}
body:not(.cm-ui-kit-tabler) .table tbody tr {
    transition: background var(--cm-duration-fast) var(--cm-ease);
}
body:not(.cm-ui-kit-tabler) .table tbody tr:hover {
    background: var(--cm-bg-subtle) !important;
}
body:not(.cm-ui-kit-tabler) .table-hover tbody tr:hover {
    background: var(--cm-bg-subtle) !important;
}
body:not(.cm-ui-kit-tabler) .table-light thead th {
    background: var(--cm-bg-subtle) !important;
    color: var(--cm-text-muted) !important;
}

/* --- Buttons --- */
.btn {
    font-weight: 600 !important;
    font-family: var(--cm-font) !important;
    border-radius: 10px !important;
    transition: background var(--cm-duration) var(--cm-ease), border-color var(--cm-duration) var(--cm-ease), color var(--cm-duration) var(--cm-ease), transform var(--cm-duration) var(--cm-ease), box-shadow var(--cm-duration) var(--cm-ease) !important;
}
.btn-primary {
    background: var(--cm-primary) !important;
    border-color: var(--cm-primary) !important;
    color: #fff !important;
}
.btn-primary:hover {
    background: var(--cm-primary-dark) !important;
    border-color: var(--cm-primary-dark) !important;
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(13, 148, 136, 0.35);
}
.btn-outline-primary {
    border-color: var(--cm-primary) !important;
    color: var(--cm-primary) !important;
}
.btn-outline-primary:hover {
    background: var(--cm-primary-light) !important;
    border-color: var(--cm-primary) !important;
    color: var(--cm-primary-dark) !important;
}
.btn-sm {
    padding: 0.35rem 0.75rem !important;
    font-size: 0.8rem !important;
}
.btn-success { background: var(--cm-success) !important; border-color: var(--cm-success) !important; }
.btn-danger { background: var(--cm-danger) !important; border-color: var(--cm-danger) !important; }
.btn-warning { background: var(--cm-warning) !important; border-color: var(--cm-warning) !important; color: #fff !important; }
.btn-info { background: var(--cm-info) !important; border-color: var(--cm-info) !important; }

/* --- Form controls --- */
.form-control,
.form-select {
    border-radius: 10px !important;
    border: 1px solid var(--cm-border) !important;
    padding: 0.55rem 0.85rem !important;
    font-family: var(--cm-font) !important;
    transition: border-color var(--cm-duration) var(--cm-ease), box-shadow var(--cm-duration) var(--cm-ease);
}
.form-control:focus,
.form-select:focus {
    border-color: var(--cm-primary) !important;
    box-shadow: 0 0 0 3px rgba(13, 148, 136, 0.15) !important;
}
.form-label {
    font-weight: 600 !important;
    color: var(--cm-text) !important;
    font-size: 0.85rem !important;
}
.form-control-sm, .form-select.form-select-sm {
    border-radius: 8px !important;
    padding: 0.4rem 0.65rem !important;
}

/* --- Filter cards --- */
.filter-card {
    background: var(--cm-surface) !important;
    border-radius: var(--cm-radius-lg) !important;
    border: 1px solid var(--cm-border) !important;
    box-shadow: var(--cm-shadow) !important;
    margin-bottom: 1.5rem;
}
.filter-card .card-header {
    background: linear-gradient(135deg, var(--cm-bg-subtle) 0%, #fff 100%) !important;
    border-bottom: 1px solid var(--cm-border) !important;
    padding: 0.85rem 1.25rem !important;
}
.filter-card .card-header h6 {
    font-weight: 700 !important;
    color: var(--cm-primary-dark) !important;
    font-size: 0.85rem !important;
}
.filter-card .card-body {
    padding: 1rem 1.25rem !important;
}

/* --- Pagination (jTable) --- */
.pagination {
    gap: 0.25rem;
}
.pagination .page-link {
    border-radius: 8px !important;
    font-weight: 600 !important;
    border: 1px solid var(--cm-border) !important;
    color: var(--cm-text) !important;
    padding: 0.4rem 0.7rem !important;
    transition: background var(--cm-duration-fast) var(--cm-ease), border-color var(--cm-duration-fast) var(--cm-ease), color var(--cm-duration-fast) var(--cm-ease);
}
.pagination .page-link:hover {
    background: var(--cm-primary-light) !important;
    border-color: var(--cm-primary) !important;
    color: var(--cm-primary-dark) !important;
}
.pagination .page-item.disabled .page-link {
    background: var(--cm-bg-subtle) !important;
    color: var(--cm-text-muted) !important;
}
.pagination .page-item.active .page-link {
    background: var(--cm-primary) !important;
    border-color: var(--cm-primary) !important;
}

/* --- Badges --- */
.badge {
    font-weight: 600 !important;
    font-size: 0.7rem !important;
    padding: 0.35em 0.65em !important;
    border-radius: 6px !important;
}
.bg-success { background: var(--cm-success) !important; }
.bg-danger { background: var(--cm-danger) !important; }
.bg-warning { background: var(--cm-warning) !important; color: #fff !important; }
.bg-info { background: var(--cm-info) !important; }
.bg-primary { background: var(--cm-primary) !important; }

/* --- Navbar --- */
.navbar {
    background: var(--cm-nav) !important;
    box-shadow: var(--cm-shadow-lg) !important;
    padding: 0.6rem 0 !important;
}
.navbar-container {
    padding-left: 20px !important;
    padding-right: 20px !important;
}
.navbar-brand {
    font-weight: 800 !important;
    letter-spacing: -0.02em !important;
}
.navbar-brand {
    transition: opacity var(--cm-duration-fast) var(--cm-ease);
}
.navbar-brand:hover {
    opacity: 0.92;
}
.navbar-logo {
    height: 69px;
    width: auto;
    max-width: 272px;
    object-fit: contain;
    display: block;
    vertical-align: middle;
    flex-shrink: 0;
    transition: transform var(--cm-duration) var(--cm-ease);
}
.navbar-brand:hover .navbar-logo {
    transform: scale(1.02);
}

.navbar-dark .navbar-brand-text {
    color: rgba(255, 255, 255, 0.95) !important;
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    white-space: nowrap;
}

@media (max-width: 991.98px) {
    .navbar-logo {
        height: 62px;
        max-width: 233px;
    }
    .navbar-dark .navbar-brand-text {
        font-size: 0.95rem;
    }
}

.footer-logo {
    height: 62px;
    width: auto;
    max-width: 233px;
    object-fit: contain;
    display: block;
    flex-shrink: 0;
    opacity: 0.92;
}
.navbar-dark .navbar-nav .nav-link {
    color: var(--cm-nav-text) !important;
    font-weight: 500 !important;
    border-radius: 8px;
    padding: 0.5rem 0.75rem !important;
    transition: color 0.2s ease, background 0.2s ease;
}
.navbar-dark .navbar-nav .nav-link:hover,
.navbar-dark .navbar-nav .nav-link.active {
    color: var(--cm-nav-hover) !important;
    background: rgba(255,255,255,0.08);
}
.navbar-dark .navbar-nav .nav-link.dropdown-toggle.text-warning {
    color: #fbbf24 !important;
}
.dropdown-menu {
    border: 1px solid var(--cm-border) !important;
    border-radius: var(--cm-radius) !important;
    box-shadow: var(--cm-shadow-lg) !important;
    padding: 0.5rem !important;
    transition: opacity var(--cm-duration-fast) var(--cm-ease);
}
.dropdown-item {
    transition: background var(--cm-duration-fast) var(--cm-ease), color var(--cm-duration-fast) var(--cm-ease);
}
.dropdown-item {
    border-radius: 8px !important;
    padding: 0.5rem 1rem !important;
    font-weight: 500 !important;
}
.dropdown-item:hover {
    background: var(--cm-primary-light) !important;
    color: var(--cm-primary-dark) !important;
}
.dropdown-header {
    font-size: 0.65rem !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--cm-text-muted) !important;
    padding: 0.4rem 1rem !important;
}
.user-avatar-circle {
    width: 40px;
    height: 40px;
    background: rgba(255,255,255,0.15) !important;
    font-size: 1.2rem;
    border-radius: 50%;
    transition: background 0.3s ease;
}
.nav-link:hover .user-avatar-circle {
    background: rgba(255,255,255,0.25) !important;
}

/* --- Alerts --- */
.alert {
    animation: cm-slide-down 0.35s var(--cm-ease-out) both;
    border-radius: var(--cm-radius) !important;
    transition: opacity var(--cm-duration) var(--cm-ease);
    border: none !important;
    font-weight: 500 !important;
}
.alert-success { background: var(--cm-success-bg) !important; color: var(--cm-success) !important; }
.alert-danger { background: var(--cm-danger-bg) !important; color: var(--cm-danger) !important; }
.alert-warning { background: var(--cm-warning-bg) !important; color: var(--cm-warning) !important; }
.alert-info { background: var(--cm-info-bg) !important; color: var(--cm-info) !important; }

/* --- Footer --- */
footer {
    background: var(--cm-nav) !important;
    color: rgba(255,255,255,0.8) !important;
    border-top: 3px solid var(--cm-primary) !important;
    font-size: 0.9rem !important;
}
footer a {
    color: rgba(255,255,255,0.7) !important;
    transition: color 0.2s ease;
}
footer a:hover {
    color: #fff !important;
}

/* --- Quick links / Accesos rápidos --- */
.quick-link-btn {
    border-radius: var(--cm-radius) !important;
    border: 2px solid var(--cm-border) !important;
    padding: 1rem 1.25rem !important;
    text-align: left !important;
    transition: border-color var(--cm-duration) var(--cm-ease), background var(--cm-duration) var(--cm-ease), transform var(--cm-duration) var(--cm-ease), box-shadow var(--cm-duration) var(--cm-ease) !important;
    background: #fff !important;
}
.quick-link-btn:hover {
    border-color: var(--cm-primary) !important;
    background: var(--cm-primary-light) !important;
    transform: translateY(-2px);
    box-shadow: var(--cm-shadow);
}

/* --- Empty states (tablas vacías) --- */
.table tbody td.text-muted .display-6,
.table tbody td.text-muted .ti {
    color: var(--cm-border) !important;
}

/* --- Override Bootstrap primary if used in JS --- */
.text-primary { color: var(--cm-primary) !important; }
.bg-primary { background: var(--cm-primary) !important; }
.border-primary { border-color: var(--cm-primary) !important; }

/* ========== TEMA OSCURO (referencia dashboard profesional) ========== */
[data-theme="dark"] {
    --cm-surface: #2d3748;
    --cm-bg: #1a202c;
    --cm-bg-subtle: #2d3748;
    --cm-text: #e2e8f0;
    --cm-text-muted: #a0aec0;
    --cm-border: #4a5568;
    --cm-primary: #14b8a6;
    --cm-primary-dark: #0d9488;
    --cm-primary-light: #0f766e;
    --cm-success: #34d399;
    --cm-success-bg: #064e3b;
    --cm-danger: #f87171;
    --cm-danger-bg: #7f1d1d;
    --cm-warning: #fbbf24;
    --cm-warning-bg: #78350f;
    --cm-info: #0d9488;
    --cm-info-bg: #0c4a6e;
    --cm-nav: #0f172a;
    --cm-nav-text: rgba(255,255,255,0.9);
    --cm-nav-hover: #fff;
    --cm-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.2);
    --cm-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.25), 0 2px 4px -2px rgba(0, 0, 0, 0.2);
    --cm-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.3), 0 4px 6px -4px rgba(0, 0, 0, 0.2);
}

[data-theme="dark"] body {
    background: var(--cm-bg) !important;
    color: var(--cm-text) !important;
}

[data-theme="dark"] .card {
    background: var(--cm-surface) !important;
    border-color: var(--cm-border) !important;
    color: var(--cm-text) !important;
}

[data-theme="dark"] .card-body {
    color: var(--cm-text) !important;
}

[data-theme="dark"] .filter-card .card-header {
    background: linear-gradient(135deg, #2d3748 0%, #1a202c 100%) !important;
}

[data-theme="dark"] .dropdown-menu {
    background: var(--cm-surface) !important;
    border-color: var(--cm-border) !important;
}

[data-theme="dark"] .dropdown-item {
    color: var(--cm-text) !important;
}

[data-theme="dark"] .dropdown-item:hover {
    background: rgba(20, 184, 166, 0.2) !important;
    color: var(--cm-primary) !important;
}

[data-theme="dark"] .dropdown-header {
    color: var(--cm-text-muted) !important;
}

[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
    background: var(--cm-bg) !important;
    border-color: var(--cm-border) !important;
    color: var(--cm-text) !important;
}

[data-theme="dark"] .form-control::placeholder {
    color: var(--cm-text-muted);
}

[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
    background: var(--cm-surface) !important;
    color: var(--cm-text) !important;
}

/* form-text: texto de ayuda en formularios — visible en modo claro y oscuro */
.form-text {
    color: var(--cm-text-muted) !important;
}
[data-theme="dark"] .form-text {
    color: var(--cm-text-muted) !important;
}
[data-theme="dark"] .form-text.text-danger {
    color: #f87171 !important;
}

[data-theme="dark"] .pagination .page-link {
    background: var(--cm-surface) !important;
    border-color: var(--cm-border) !important;
    color: var(--cm-text) !important;
}

[data-theme="dark"] .pagination .page-link:hover {
    background: var(--cm-primary-light) !important;
    color: #fff !important;
}

[data-theme="dark"] .pagination .page-item.disabled .page-link {
    background: var(--cm-bg) !important;
    color: var(--cm-text-muted) !important;
}

[data-theme="dark"] .alert-success { background: var(--cm-success-bg) !important; color: #6ee7b7 !important; }
[data-theme="dark"] .alert-danger { background: var(--cm-danger-bg) !important; color: #fca5a5 !important; }
[data-theme="dark"] .alert-warning { background: #422006 !important; color: #fcd34d !important; }
[data-theme="dark"] .alert-info { background: var(--cm-info-bg) !important; color: #7dd3fc !important; }

[data-theme="dark"] .table-secondary,
[data-theme="dark"] tr.table-secondary {
    background: #1a202c !important;
    color: var(--cm-text-muted) !important;
}

[data-theme="dark"] .text-muted {
    color: var(--cm-text-muted) !important;
}

[data-theme="dark"] .border,
[data-theme="dark"] .border-top,
[data-theme="dark"] .border-bottom {
    border-color: var(--cm-border) !important;
}

[data-theme="dark"] .bg-light {
    background: var(--cm-bg-subtle) !important;
}

[data-theme="dark"] .small.text-muted,
[data-theme="dark"] .text-white-50 {
    color: var(--cm-text-muted) !important;
}

/* Dashboard en modo oscuro: tarjetas, tabla y accesos rápidos */
[data-theme="dark"] .stat-card {
    background: var(--cm-surface) !important;
    border-color: var(--cm-border) !important;
}

[data-theme="dark"] .stat-card .stat-label {
    color: var(--cm-text-muted) !important;
}

[data-theme="dark"] .stat-card .stat-value {
    color: var(--cm-text) !important;
}

[data-theme="dark"] .stat-card .stat-value.text-success {
    color: #34d399 !important;
}

[data-theme="dark"] .stat-card .stat-value.text-danger {
    color: #f87171 !important;
}

[data-theme="dark"] .quick-link-btn {
    background: #374151 !important;
    border-color: #4b5563 !important;
    color: #e5e7eb !important;
}

[data-theme="dark"] .quick-link-btn .text-muted {
    color: #9ca3af !important;
}

[data-theme="dark"] .quick-link-btn:hover {
    background: var(--cm-primary-light) !important;
    border-color: var(--cm-primary) !important;
    color: #fff !important;
}

[data-theme="dark"] .quick-link-btn:hover .text-muted {
    color: rgba(255,255,255,0.85) !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table thead th,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table .table-light th {
    background: #1e293b !important;
    color: #f1f5f9 !important;
    border-bottom-color: var(--cm-border) !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table tbody td {
    color: var(--cm-text) !important;
    border-color: var(--cm-border) !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table tbody tr:hover {
    background: rgba(30, 41, 59, 0.6) !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table tbody tr:nth-child(even) {
    background: rgba(30, 41, 59, 0.3) !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table tbody tr:nth-child(even):hover {
    background: rgba(30, 41, 59, 0.6) !important;
}

/* Tablas dentro de tarjetas (no jTable): fondo y texto coherentes con el tema */
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .card .table:not(.table-jtable) > tbody > tr > td,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .card .table:not(.table-jtable) > tbody > tr > th {
    background-color: var(--cm-surface) !important;
    color: var(--cm-text) !important;
    border-color: var(--cm-border) !important;
}
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .card .table:not(.table-jtable) > tbody > tr.table-light > td,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .card .table:not(.table-jtable) > tbody > tr.table-light > th {
    background-color: rgba(51, 65, 85, 0.9) !important;
    color: #f8fafc !important;
    border-color: var(--cm-border) !important;
}
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .card .table:not(.table-jtable) > tbody > tr.table-secondary > td,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .card .table:not(.table-jtable) > tbody > tr.table-secondary > th,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .card .table:not(.table-jtable) > tfoot > tr.table-secondary > th,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .card .table:not(.table-jtable) > tfoot > tr.table-secondary > td {
    background-color: rgba(30, 41, 59, 0.95) !important;
    color: #e2e8f0 !important;
    border-color: var(--cm-border) !important;
}

/* Pestañas conciliación: coherentes con el tema (refuerzo si hiciera falta junto a data-bs-theme) */
[data-theme="dark"] .conciliacion-nav-tabs {
    border-bottom-color: var(--cm-border) !important;
}
[data-theme="dark"] .conciliacion-nav-tabs .nav-link {
    color: var(--cm-text-muted) !important;
    background: transparent !important;
    border-color: transparent transparent var(--cm-border) !important;
}
[data-theme="dark"] .conciliacion-nav-tabs .nav-link:hover {
    color: var(--cm-text) !important;
    border-color: var(--cm-border) var(--cm-border) transparent !important;
}
[data-theme="dark"] .conciliacion-nav-tabs .nav-link.active {
    color: var(--cm-text) !important;
    background: var(--cm-surface) !important;
    border-color: var(--cm-border) var(--cm-border) var(--cm-surface) !important;
}

[data-theme="dark"] .table .bg-light.px-2.py-1.rounded,
[data-theme="dark"] td .bg-light {
    background: #4b5563 !important;
    color: var(--cm-text) !important;
}

[data-theme="dark"] .btn-outline-primary {
    border-color: var(--cm-primary) !important;
    color: var(--cm-primary) !important;
}

[data-theme="dark"] .btn-outline-primary:hover {
    background: rgba(20, 184, 166, 0.2) !important;
    color: #5eead4 !important;
    border-color: var(--cm-primary) !important;
}

[data-theme="dark"] .page-header .subtitle {
    color: var(--cm-text-muted) !important;
}

[data-theme="dark"] .page-header .subtitle strong {
    color: var(--cm-text) !important;
}

[data-theme="dark"] .card-header.bg-light {
    background: #1e293b !important;
    border-bottom-color: var(--cm-border) !important;
    color: var(--cm-text) !important;
}

[data-theme="dark"] .card-header.bg-light h5,
[data-theme="dark"] .card-header.bg-light h6 {
    color: var(--cm-text) !important;
}

/* Badges y botones en modo oscuro (Super Admin / Admin UH / vistas listado) */
[data-theme="dark"] .badge.bg-light,
[data-theme="dark"] .badge.bg-light.text-dark {
    background: var(--cm-bg-subtle) !important;
    color: var(--cm-text) !important;
    border-color: var(--cm-border);
}
[data-theme="dark"] .btn-outline-dark {
    border-color: var(--cm-text-muted) !important;
    color: var(--cm-text) !important;
}
[data-theme="dark"] .btn-outline-dark:hover {
    background: var(--cm-bg-subtle) !important;
    border-color: var(--cm-text) !important;
    color: var(--cm-text) !important;
}
[data-theme="dark"] .text-secondary {
    color: var(--cm-text-muted) !important;
}

/* Vista Admin (Super Admin / Admin UH): mismo criterio que vista dueño */
.vista-admin .filter-card {
    border-color: var(--cm-border);
}
[data-theme="dark"] .vista-admin .filter-card {
    background: var(--cm-surface) !important;
    border-color: var(--cm-border) !important;
}
[data-theme="dark"] .vista-admin .filter-card .card-body {
    color: var(--cm-text);
}

/*
 * Piel legacy jTable / actividad (zebra + grises fijos). Con UI Tabler, el aspecto lo define tabler-standard.css.
 */
body:not(.cm-ui-kit-tabler) .table-actividad-reciente,
body:not(.cm-ui-kit-tabler) .table-jtable {
    font-size: 14px !important;
}

body:not(.cm-ui-kit-tabler) .table-actividad-reciente thead th,
body:not(.cm-ui-kit-tabler) .table-jtable thead th {
    background: #f1f5f9 !important;
    color: #1e293b !important;
    border-bottom-color: #e2e8f0 !important;
    font-size: 14px !important;
}

body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody td,
body:not(.cm-ui-kit-tabler) .table-jtable tbody td {
    color: #1e293b !important;
    background: #fff !important;
    border-color: #e2e8f0 !important;
}

body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody td.text-muted,
body:not(.cm-ui-kit-tabler) .table-jtable tbody td.text-muted {
    color: #475569 !important;
}

body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody tr:nth-child(even) td,
body:not(.cm-ui-kit-tabler) .table-jtable tbody tr:nth-child(even) td {
    background: #f8fafc !important;
}

body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody tr:hover td,
body:not(.cm-ui-kit-tabler) .table-jtable tbody tr:hover td {
    background: #f1f5f9 !important;
}

body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody tr:nth-child(even):hover td,
body:not(.cm-ui-kit-tabler) .table-jtable tbody tr:nth-child(even):hover td {
    background: #e2e8f0 !important;
}

body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody td.text-success,
body:not(.cm-ui-kit-tabler) .table-jtable tbody td.text-success {
    color: #0d6832 !important;
}

body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody td.text-danger,
body:not(.cm-ui-kit-tabler) .table-jtable tbody td.text-danger {
    color: #b91c1c !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-actividad-reciente thead th,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-jtable thead th {
    background: #1e293b !important;
    color: #f1f5f9 !important;
    border-bottom-color: var(--cm-border) !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody tr,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-jtable tbody tr {
    background: var(--cm-surface) !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody td,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-jtable tbody td {
    background: transparent !important;
    color: var(--cm-text) !important;
    border-color: var(--cm-border) !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody td.text-muted,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-jtable tbody td.text-muted {
    color: var(--cm-text-muted) !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody tr:nth-child(even),
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-jtable tbody tr:nth-child(even) {
    background: rgba(30, 41, 59, 0.5) !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody tr:nth-child(even) td,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-jtable tbody tr:nth-child(even) td {
    background: transparent !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody tr:hover,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-jtable tbody tr:hover {
    background: rgba(30, 41, 59, 0.85) !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody tr:hover td,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-jtable tbody tr:hover td {
    background: transparent !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody td.text-success,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-jtable tbody td.text-success {
    color: #34d399 !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody td.text-danger,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-jtable tbody td.text-danger {
    color: #f87171 !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-actividad-reciente tbody td.text-info,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-jtable tbody td.text-info {
    color: #5eead4 !important;
}

html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-jtable tfoot th,
html[data-theme="dark"] body:not(.cm-ui-kit-tabler) .table-jtable tfoot td {
    background: rgba(30, 41, 59, 0.75) !important;
    color: var(--cm-text) !important;
    border-color: var(--cm-border) !important;
}

/* ========== VISTA DUEÑO / PROPIETARIO (modo claro y oscuro) ========== */
.vista-vecino .vista-vecino-link {
    color: #1e293b;
}
.vista-vecino .vista-vecino-link:hover {
    color: var(--cm-primary);
}
.vista-vecino .table-vista-vecino thead th {
    background: #f1f5f9 !important;
    color: #1e293b !important;
    border-bottom-color: #e2e8f0 !important;
}
.vista-vecino .table-vista-vecino tbody td {
    background: #fff !important;
    color: #1e293b !important;
    border-color: #e2e8f0 !important;
}
.vista-vecino .table-vista-vecino tbody tr:nth-child(even) td {
    background: #f8fafc !important;
}
.vista-vecino .table-vista-vecino tbody tr:hover td {
    background: #f1f5f9 !important;
}
.vista-vecino .table-vista-vecino tbody td.text-muted {
    color: #475569 !important;
}
.vista-vecino .table-vista-vecino tbody td.text-success {
    color: #0d6832 !important;
}
.vista-vecino .table-vista-vecino tbody td.text-danger {
    color: #b91c1c !important;
}
.vista-vecino .vista-vecino-concepto {
    color: #1e293b;
}

[data-theme="dark"] .vista-vecino .vista-vecino-title,
[data-theme="dark"] .vista-vecino h4.text-secondary,
[data-theme="dark"] .vista-vecino h5.text-secondary {
    color: var(--cm-text-muted) !important;
}
[data-theme="dark"] .vista-vecino .vista-vecino-link {
    color: var(--cm-text) !important;
}
[data-theme="dark"] .vista-vecino .vista-vecino-link:hover {
    color: var(--cm-primary) !important;
}
[data-theme="dark"] .vista-vecino .card-header.vista-vecino-card-header,
[data-theme="dark"] .vista-vecino .card-header.bg-light {
    background: #1e293b !important;
    border-bottom-color: var(--cm-border) !important;
    color: var(--cm-text) !important;
}
[data-theme="dark"] .vista-vecino .badge.bg-light.text-dark,
[data-theme="dark"] .vista-vecino .vista-vecino-badge-tipo,
[data-theme="dark"] .vista-vecino .vista-vecino-badge-propiedad {
    background: var(--cm-bg-subtle) !important;
    color: var(--cm-text) !important;
    border-color: var(--cm-border) !important;
}
[data-theme="dark"] .vista-vecino .vista-vecino-concepto {
    color: var(--cm-text) !important;
}
[data-theme="dark"] .vista-vecino .table-vista-vecino thead th {
    background: #1e293b !important;
    color: #f1f5f9 !important;
    border-bottom-color: var(--cm-border) !important;
}
[data-theme="dark"] .vista-vecino .table-vista-vecino tbody tr {
    background: var(--cm-surface) !important;
}
[data-theme="dark"] .vista-vecino .table-vista-vecino tbody td {
    background: transparent !important;
    color: var(--cm-text) !important;
    border-color: var(--cm-border) !important;
}
[data-theme="dark"] .vista-vecino .table-vista-vecino tbody tr:nth-child(even) {
    background: rgba(30, 41, 59, 0.5) !important;
}
[data-theme="dark"] .vista-vecino .table-vista-vecino tbody tr:nth-child(even) td {
    background: transparent !important;
}
[data-theme="dark"] .vista-vecino .table-vista-vecino tbody tr:hover {
    background: rgba(30, 41, 59, 0.85) !important;
}
[data-theme="dark"] .vista-vecino .table-vista-vecino tbody tr:hover td {
    background: transparent !important;
}
[data-theme="dark"] .vista-vecino .table-vista-vecino tbody td.text-muted {
    color: var(--cm-text-muted) !important;
}
[data-theme="dark"] .vista-vecino .table-vista-vecino tbody td.text-success {
    color: #34d399 !important;
}
[data-theme="dark"] .vista-vecino .table-vista-vecino tbody td.text-danger {
    color: #f87171 !important;
}
[data-theme="dark"] .vista-vecino .table-vista-vecino tbody td.text-info {
    color: #5eead4 !important;
}
[data-theme="dark"] .vista-vecino .btn-outline-dark {
    border-color: var(--cm-text-muted) !important;
    color: var(--cm-text) !important;
}
[data-theme="dark"] .vista-vecino .btn-outline-dark:hover {
    background: var(--cm-bg-subtle) !important;
    border-color: var(--cm-text) !important;
    color: var(--cm-text) !important;
}
[data-theme="dark"] .vista-vecino .vista-vecino-badge-registros {
    background: var(--cm-bg-subtle) !important;
    color: var(--cm-text) !important;
    border: 1px solid var(--cm-border);
}

/* Vista vecino: Reglamento y documentos + Ver reglamento (Dueño/Propietario) */
[data-theme="dark"] .vista-vecino .filter-card,
[data-theme="dark"] .vista-vecino .vista-vecino-filter-card {
    background: var(--cm-surface) !important;
    border-color: var(--cm-border) !important;
}
[data-theme="dark"] .vista-vecino .filter-card .card-header,
[data-theme="dark"] .vista-vecino .vista-vecino-filter-card .card-header {
    background: #1e293b !important;
    border-bottom-color: var(--cm-border) !important;
    color: var(--cm-text) !important;
}
[data-theme="dark"] .vista-vecino .filter-card .card-body,
[data-theme="dark"] .vista-vecino .vista-vecino-filter-card .card-body {
    color: var(--cm-text);
}
[data-theme="dark"] .vista-vecino .vista-vecino-iframe-wrap {
    background: var(--cm-bg-subtle) !important;
    border-color: var(--cm-border) !important;
}
[data-theme="dark"] .vista-vecino h1,
[data-theme="dark"] .vista-vecino h2 {
    color: var(--cm-text) !important;
}
[data-theme="dark"] .vista-vecino .page-header .subtitle {
    color: var(--cm-text-muted) !important;
}

/*
 * Tabler core (beta) redefine .navbar-expand-lg .navbar-collapse (en ≥992px) como columna y
 * los .dropdown-menu como estáticos/sin fondo (patrón navbar vertical).
 * Solo corregimos en desktop: en móvil Tabler usa columna en el collapse y conviene no forzar fila.
 */
@media (min-width: 992px) {
    body.cm-ui-kit-tabler nav.navbar.cm-top-navbar.navbar-expand-lg .navbar-collapse {
        flex-direction: row !important;
        flex-wrap: wrap !important;
        align-items: center !important;
    }
    body.cm-ui-kit-tabler nav.navbar.cm-top-navbar.navbar-expand-lg .navbar-collapse .navbar-nav {
        flex-direction: row !important;
        flex-wrap: wrap !important;
        align-items: center !important;
    }
    body.cm-ui-kit-tabler nav.navbar.cm-top-navbar.navbar-expand-lg .navbar-collapse .dropdown-menu {
        position: absolute !important;
        z-index: 1000 !important;
        background-color: var(--cm-surface) !important;
        background-clip: padding-box !important;
        border: 1px solid var(--cm-border) !important;
        border-radius: var(--cm-radius) !important;
        box-shadow: var(--cm-shadow-lg) !important;
        color: var(--cm-text) !important;
        min-width: 12rem !important;
        padding: 0.5rem 0 !important;
        margin: 0.125rem 0 0 !important;
    }
    body.cm-ui-kit-tabler nav.navbar.cm-top-navbar.navbar-expand-lg .navbar-collapse .dropdown-item {
        color: var(--cm-text) !important;
        width: 100% !important;
    }
    body.cm-ui-kit-tabler nav.navbar.cm-top-navbar.navbar-expand-lg .navbar-collapse .dropdown-header {
        color: var(--cm-text-muted) !important;
    }
    body.cm-ui-kit-tabler nav.navbar.cm-top-navbar.navbar-expand-lg .navbar-collapse .dropdown-divider {
        border-top-color: var(--cm-border) !important;
    }
}

/* En el menú hamburguesa, Tabler deja los submenús sin fondo: restaurar legibilidad */
@media (max-width: 991.98px) {
    body.cm-ui-kit-tabler nav.navbar.cm-top-navbar .navbar-collapse.show .dropdown-menu,
    body.cm-ui-kit-tabler nav.navbar.cm-top-navbar .navbar-collapse.collapsing .dropdown-menu {
        background-color: var(--cm-surface) !important;
        border: 1px solid var(--cm-border) !important;
        border-radius: var(--cm-radius) !important;
        box-shadow: var(--cm-shadow) !important;
        margin-top: 0.25rem !important;
        padding: 0.35rem 0 !important;
    }
    body.cm-ui-kit-tabler nav.navbar.cm-top-navbar .navbar-collapse .dropdown-item {
        color: var(--cm-text) !important;
    }
}

/* Encabezados de tabla ordenables (clic = ASC/DESC vía jtSorting) */
.table-jtable thead th.cm-th-sortable {
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
}
.table-jtable thead th.cm-th-sortable:hover {
    background-color: rgba(13, 148, 136, 0.08);
}
[data-theme="dark"] .table-jtable thead th.cm-th-sortable:hover {
    background-color: rgba(255, 255, 255, 0.06);
}

/*
 * Catálogos Unidades / Inmuebles (.cm-page-table-fill)
 * No usar la clase global "page-header": Tabler la define como columna centrada.
 */
.cm-catalog-header {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    margin-bottom: 0.5rem;
    text-align: left;
}
.cm-catalog-header .cm-catalog-heading {
    text-align: left;
    flex: 1 1 auto;
    min-width: min(100%, 12rem);
}
.cm-catalog-header h1 {
    font-size: 1.35rem !important;
    font-weight: 700 !important;
    line-height: 1.25 !important;
    color: var(--cm-text) !important;
}
.cm-catalog-header .subtitle {
    color: var(--cm-text-muted);
    font-size: 0.8rem;
    margin-top: 0.15rem;
    line-height: 1.3;
}
.cm-catalog-header .cm-catalog-actions .btn {
    padding: 0.4rem 0.85rem;
    font-size: 0.875rem;
    font-weight: 600;
}

/* Ancho consistente del bloque de tabla con márgenes laterales fijos */
.cm-catalog-header,
.cm-filter-toolbar,
.cm-table-panel {
    width: auto !important;
    max-width: none !important;
    align-self: stretch;
    margin-left: 24px;
    margin-right: 24px;
}
.cm-page-table-fill {
    width: 100% !important;
    max-width: 100% !important;
}
@media (max-width: 767.98px) {
    .cm-catalog-header,
    .cm-filter-toolbar,
    .cm-table-panel {
        width: auto !important;
        margin-left: 12px;
        margin-right: 12px;
    }
}

/* Barra de filtros compacta (sin bloque header separado) */
.cm-filter-toolbar.filter-card .card-body {
    padding: 0.35rem 0.65rem !important;
}
.cm-filter-toolbar .cm-filter-toolbar-label {
    padding-bottom: 0.15rem;
    padding-right: 0.35rem;
    margin-right: 0.15rem;
    border-right: 1px solid var(--cm-border);
    line-height: 1.2;
    font-size: 0.72rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.cm-filter-toolbar .cm-filter-label {
    font-size: 0.72rem;
    font-weight: 600;
    margin-bottom: 0.12rem;
    color: var(--cm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

/* Tarjeta de tabla: más área útil, menos relleno */
.cm-table-panel > .card-body {
    padding: 0.55rem 0.75rem !important;
}
.cm-table-panel .cm-table-toolbar {
    margin-bottom: 0.35rem !important;
}
.cm-table-panel .table-responsive,
.card:has(.table-jtable) .table-responsive {
    max-height: 360px;
    min-height: 360px;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}
/* Sin “salto” al hover: la tabla ocupa casi toda la vista */
.cm-page-table-fill > .cm-table-panel.card:hover,
.cm-page-table-fill > .cm-filter-toolbar.card:hover {
    transform: none;
    box-shadow: var(--cm-shadow) !important;
}

body:has(.cm-page-table-fill) > nav.navbar {
    margin-bottom: 0.4rem !important;
}
body:has(.cm-page-table-fill) .navbar {
    padding: 0.32rem 0 !important;
}
body:has(.cm-page-table-fill) .navbar-logo {
    height: 46px;
    max-width: 190px;
}
@media (max-width: 991.98px) {
    body:has(.cm-page-table-fill) .navbar-logo {
        height: 42px;
        max-width: 170px;
    }
}
body:has(.cm-page-table-fill) .navbar-dark .navbar-brand-text {
    font-size: 0.92rem;
}
body:has(.cm-page-table-fill) > main.main-content {
    padding-top: 0.3rem;
    padding-bottom: 0.6rem;
}
body:has(.cm-page-table-fill) .cm-page-table-fill {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    text-align: left !important;
}
body:has(.cm-page-table-fill) .cm-page-table-fill > .cm-filter-toolbar {
    margin-bottom: 0.35rem !important;
}
body:has(.cm-page-table-fill) .cm-page-table-fill > .alert {
    flex-shrink: 0;
}

/*
 * Unidades / Inmuebles: en pantallas anchas el body no hace scroll vertical;
 * cabecera, filtros y pie fijos en el flujo flex; la grilla hace scroll interno.
 */
@media (min-width: 1200px) {
    body:has(.cm-page-table-fill) {
        height: 100vh;
        height: 100dvh;
        overflow: hidden;
        display: flex;
        flex-direction: column;
    }
    body:has(.cm-page-table-fill) > nav.navbar {
        flex-shrink: 0;
    }
    body:has(.cm-page-table-fill) > main.main-content {
        flex: 1 1 auto;
        width: 100%;
        min-height: 0;
        overflow: hidden;
        display: flex;
        flex-direction: column;
        padding-top: 0.2rem;
        padding-bottom: 0.35rem;
    }
    body:has(.cm-page-table-fill) > main.main-content > .cm-flash-stack {
        flex-shrink: 0;
    }
    body:has(.cm-page-table-fill) > footer {
        flex-shrink: 0;
    }
    body:has(.cm-page-table-fill) .cm-page-table-fill {
        flex: 1 1 auto;
        min-height: 0;
        display: flex;
        flex-direction: column;
        overflow: hidden;
    }
    body:has(.cm-page-table-fill) .cm-page-table-fill > .cm-catalog-header {
        flex-shrink: 0;
    }
    body:has(.cm-page-table-fill) .cm-page-table-fill > .cm-filter-toolbar {
        flex-shrink: 0;
    }
    body:has(.cm-page-table-fill) .cm-page-table-fill > .cm-table-panel {
        flex: 1 1 auto;
        min-height: 0;
        display: flex;
        flex-direction: column;
        overflow: hidden;
    }
    body:has(.cm-page-table-fill) .cm-page-table-fill > .cm-table-panel > .card-body {
        flex: 1 1 auto;
        min-height: 0;
        display: flex;
        flex-direction: column;
        overflow: hidden;
    }
    body:has(.cm-page-table-fill) .cm-page-table-fill > .cm-table-panel > .card-body > .cm-table-toolbar {
        flex-shrink: 0;
    }
    body:has(.cm-page-table-fill) .cm-page-table-fill .table-responsive {
        flex: 1 1 auto;
        min-height: 0;
        overflow: auto;
        -webkit-overflow-scrolling: touch;
    }
    /* Movimientos: toolbar + tabla dentro de #jtableContainer */
    body:has(.cm-page-table-fill) .cm-page-table-fill > .cm-table-panel > .card-body > .movimientos-jtable-wrap {
        flex: 1 1 auto;
        min-height: 0;
        display: flex;
        flex-direction: column;
        overflow: hidden;
    }
    body:has(.cm-page-table-fill) .cm-page-table-fill > .cm-table-panel .movimientos-jtable-wrap .cm-table-toolbar {
        flex-shrink: 0;
    }
    body:has(.cm-page-table-fill) .cm-page-table-fill > .cm-table-panel .movimientos-jtable-wrap .table-responsive {
        flex: 1 1 auto;
        min-height: 0;
        overflow: auto;
        -webkit-overflow-scrolling: touch;
    }
}
