/*
 * Tipografía global del proyecto (alineada con custom.css → body)
 * Pila: Roboto → Helvetica Neue → Arial → Droid Sans → sans-serif · 13px · line-height 1.471
 * (Roboto se carga desde Google Fonts en views/template.php)
 */
html {
    font-family: Roboto, "Helvetica Neue", Arial, "Droid Sans", sans-serif;
    font-size: 13px;
    line-height: 1.471;
}

:root {
    --app-bg-page: #f1f5f9;
    --app-border-soft: #e2e8f0;
    --app-text-muted: #64748b;
    --app-text-strong: #334155;
    --sidebar-width-expanded: 230px;
    --sidebar-width-collapsed: 70px;
    --sidebar-ease: cubic-bezier(0.4, 0, 0.2, 1);
    --sidebar-duration: 0.18s;
    --nav-top-offset: 68px;
    --layout-pad-x: 20px;
    --layout-pad-y: 10px;
    --app-footer-height: 46px;
}

/* El ul con la clase correo-list es el que contiene los correos */

.correo-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

/* el cursor pointer es para que el mouse se convierta en una mano cuando se pase por encima */
/* Agrega un sobreado en el elemento cuando se pase por encima */
.correo-list li:hover {
    cursor: pointer;
    background-color: #F2F5F7; /* Hover */
    /* Agrega una transición para que el cambio de color sea más suave */
    transition: background-color 0.2s ease;
    /* Letra en negrita */
    font-weight: bold;
}

/* Agrega un borde al elemento seleccionado */
.correo-list li.active {
    border-left: 5px solid #00abfa; /* Azul Claro para Elementos Activos */
}
/* Si el texto es muy largo, se corta y se agrega puntos suspensivos */
.correo-list li .correo-list-text {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ==============================
   Sidebar izquierda fija (layout)
   ============================== */

/* Sidebar fijo al hacer scroll (solo escritorio; en móvil usa drawer en @media abajo) */
@media (min-width: 992px) {
    .nav-md .container.body .col-md-3.left_col,
    .nav-sm .container.body .col-md-3.left_col {
        position: fixed !important;
        top: 0;
        bottom: 0;
        left: 0;
    }

    .nav-sm .container.body .col-md-3.left_col {
        z-index: 10050;
    }
}

/*
 * Scroll vertical solo en menú expandido. En nav-sm el flyout sale lateralmente:
 * si el ancestro tiene overflow:hidden (custom.css .left_col) el submenú queda recortado “dentro” del sidebar.
 */
.nav-md .left_col.scroll-view {
    height: 100vh;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
}

.nav-sm .container.body .col-md-3.left_col,
.nav-sm .left_col.scroll-view {
    overflow: visible !important;
}

.nav-sm .left_col.scroll-view {
    height: 100vh;
    -webkit-overflow-scrolling: touch;
}

/* ==============================
   Scrollbar minimalista (celeste)
   Solo para el sidebar izquierdo
   ============================== */

.left_col.scroll-view {
    /* Firefox */
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 171, 250, 0.55) transparent;
}

/* Chrome / Edge / Safari */
.left_col.scroll-view::-webkit-scrollbar {
    width: 8px;
}

.left_col.scroll-view::-webkit-scrollbar-track {
    background: transparent;
}

.left_col.scroll-view::-webkit-scrollbar-thumb {
    background-color: rgba(0, 171, 250, 0.55);
    border-radius: 999px;
    border: 2px solid transparent; /* deja aire (look minimal) */
    background-clip: content-box;
}

.left_col.scroll-view::-webkit-scrollbar-thumb:hover {
    background-color: rgba(0, 171, 250, 0.85);
}

/* Móvil: menú lateral drawer (misma lógica que dteapp) */
@media (max-width: 991px) {
    .nav-sm .main_container > .top_nav,
    .nav-md .main_container > .top_nav,
    .nav-sm .container.body .right_col,
    .nav-md .container.body .right_col,
    body.sidebar-state-applied.nav-sm .container.body .right_col,
    body.sidebar-state-applied.nav-md .container.body .right_col {
        margin-left: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .nav-sm .main_container > .top_nav,
    .nav-md .main_container > .top_nav,
    body.sidebar-state-applied.nav-sm .main_container > .top_nav,
    body.sidebar-state-applied.nav-md .main_container > .top_nav {
        margin-left: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: auto !important;
    }

    .right_col,
    body.sidebar-state-applied .container.body .right_col {
        margin-top: 0 !important;
        padding: var(--nav-top-offset) var(--layout-pad-x) var(--app-footer-height) !important;
        min-height: auto !important;
    }

    .nav-md .container.body .col-md-3.left_col,
    .nav-sm .container.body .col-md-3.left_col,
    body.sidebar-state-applied.nav-md .container.body .col-md-3.left_col,
    body.sidebar-state-applied.nav-sm .container.body .col-md-3.left_col {
        display: flex !important;
        position: fixed !important;
        top: 0 !important;
        left: -280px !important;
        bottom: 0 !important;
        width: 260px !important;
        max-width: 85vw !important;
        margin-left: 0 !important;
        z-index: 10050 !important;
        transition: left 0.25s ease !important;
    }

    body.mobile-menu-open.nav-md .container.body .col-md-3.left_col,
    body.mobile-menu-open.nav-sm .container.body .col-md-3.left_col,
    body.mobile-menu-open.sidebar-state-applied.nav-md .container.body .col-md-3.left_col,
    body.mobile-menu-open.sidebar-state-applied.nav-sm .container.body .col-md-3.left_col {
        left: 0 !important;
        box-shadow: 4px 0 24px rgba(0, 0, 0, 0.25);
    }

    body.mobile-menu-open {
        overflow: hidden;
    }

    body.mobile-menu-open::before {
        content: "";
        position: fixed;
        inset: 0;
        background: rgba(15, 23, 42, 0.45);
        z-index: 10040;
    }

    body.nav-sm .nav.side-menu li a span:not(.fa) {
        opacity: 1 !important;
    }

    .nav-sm .nav.side-menu li a {
        font-size: 13px !important;
        text-align: left !important;
        padding: 12px 14px !important;
    }
}

/* Iconos barra principal (nav-sm), más legibles y alineados al diseño */
.nav-sm #sidebar-menu ul.nav.side-menu > li > a i {
    font-size: 24px !important;
    line-height: 1 !important;
}

/* Nav-sm: solo ícono + tooltip al hover */
.nav-sm #sidebar-menu ul.nav.side-menu > li {
    position: relative;
}

/* Pincho hacia la barra (solo primer nivel): enlaza visualmente el flyout con el ícono */
.nav-sm #sidebar-menu ul.nav.side-menu > li:has(> ul.child_menu)::before {
    content: "";
    position: absolute;
    left: 100%;
    margin-left: -7px;
    top: 22px;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 8px 9px 8px 0;
    border-color: transparent #0d2868 transparent transparent;
    z-index: 10062;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.12s ease;
}

.nav-sm #sidebar-menu ul.nav.side-menu > li:has(> ul.child_menu):hover::before,
.nav-sm #sidebar-menu ul.nav.side-menu > li:has(> ul.child_menu):focus-within::before,
.nav-sm #sidebar-menu ul.nav.side-menu > li:has(> ul.child_menu).active-sm::before {
    opacity: 1;
}

/* Puente invisible para mantener :hover al pasar del icono al panel (sin pointer-events:none) */
.nav-sm #sidebar-menu ul.nav.side-menu > li:has(> ul.child_menu)::after,
.nav-sm #sidebar-menu ul.nav.child_menu > li:has(> ul.child_menu)::after {
    content: "";
    position: absolute;
    left: 100%;
    top: 0;
    bottom: 0;
    width: 22px;
    z-index: 10059;
}


.nav-sm #sidebar-menu ul.nav.side-menu > li > a {
    text-align: center !important;
    font-size: 0 !important; /* oculta texto plano (text nodes) */
}

.nav-sm #sidebar-menu ul.nav.side-menu > li > a i {
    float: none !important;
    margin-right: 0 !important;
    width: 100% !important;
    text-align: center !important;
    font-size: 24px !important;
}

/* Ocultar texto (dejar solo ícono) */
.nav-sm #sidebar-menu ul.nav.side-menu > li > a span:not(.fa) {
    display: none !important;
}

/*
 * Menú encogido: NO usar display:none !important en el estado base: jQuery (fadeIn/show)
 * no puede anular !important; el clic en nav-sm quedaría sin efecto.
 * Hover/focus-within sí pueden usar !important para ganar a custom.min.css.
 */
.nav-sm #sidebar-menu li > ul.nav.child_menu {
    display: none;
}

.nav-sm #sidebar-menu li:hover > ul.nav.child_menu,
.nav-sm #sidebar-menu li:focus-within > ul.nav.child_menu {
    display: block !important;
}

/* Submenú flotante (nav-sm): misma familia cromática que el lateral (#082064) + acento #00abfa */
.nav-sm #sidebar-menu li > ul.nav.child_menu {
    position: absolute !important;
    left: 100% !important;
    margin-left: -14px !important;
    top: 0 !important;
    min-width: 176px;
    z-index: 10060;
    padding: 6px 0;
    border-radius: 0 8px 8px 8px;
    overflow: hidden;
    background: linear-gradient(165deg, #0d2868 0%, #082064 50%, #061845 100%) !important;
    box-shadow: 6px 16px 32px rgba(5, 20, 62, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-left: 3px solid #00abfa;
}

.nav-sm #sidebar-menu ul.nav.side-menu > li:has(> ul.child_menu):hover > a,
.nav-sm #sidebar-menu ul.nav.side-menu > li:has(> ul.child_menu):focus-within > a,
.nav-sm #sidebar-menu ul.nav.side-menu > li:has(> ul.child_menu).active-sm > a {
    background: rgba(255, 255, 255, 0.1) !important;
    box-shadow: inset 3px 0 0 #00abfa;
}

.nav-sm #sidebar-menu ul.nav.side-menu > li:has(> ul.child_menu):hover > a[title]::after,
.nav-sm #sidebar-menu ul.nav.side-menu > li:has(> ul.child_menu):focus-within > a[title]::after,
.nav-sm #sidebar-menu ul.nav.side-menu > li:has(> ul.child_menu).active-sm > a[title]::after {
    opacity: 0 !important;
}

/* Panel flotante nav-sm: solo texto, sin iconos font-awesome en ítems */
.nav-sm #sidebar-menu ul.nav.child_menu li > a > i {
    display: none !important;
}

.nav-sm #sidebar-menu ul.nav.child_menu > li {
    position: relative;
}

.nav-sm #sidebar-menu ul.nav.child_menu > li > ul.nav.child_menu {
    z-index: 10061;
}

.nav-sm #sidebar-menu,
.nav-sm #sidebar-menu .menu_section {
    overflow: visible !important;
}

/* Tooltip con nombre del módulo usando title del <a> */
.nav-sm #sidebar-menu ul.nav.side-menu > li > a[title]::after {
    content: attr(title);
    position: absolute;
    left: 70px;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(8, 32, 100, 0.95);
    color: #fff;
    padding: 6px 10px;
    border-radius: 6px;
    font-size: 12px;
    line-height: 1.1;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    z-index: 10050;
    box-shadow: 0 6px 18px rgba(0,0,0,0.18);
}

.nav-sm #sidebar-menu ul.nav.side-menu > li > a[title]:hover::after {
    opacity: 1;
}

/* Menú encogido (nav-sm): aire para iconos más grandes */
.nav-sm #sidebar-menu ul.nav.side-menu > li > a {
    padding: 8px 4px !important;
}

/* Panel flotante: compacto (poco aire entre ítems) */
.nav-sm #sidebar-menu ul.nav.child_menu > li {
    padding: 0 3px !important;
}

.nav-sm #sidebar-menu ul.nav.child_menu > li > a {
    padding: 8px 12px !important;
    line-height: 1.35 !important;
    font-size: 12px !important;
    border-radius: 4px;
    color: rgba(255, 255, 255, 0.92) !important;
    font-weight: 400;
    transition: background 0.15s ease, color 0.15s ease;
}

.nav-sm #sidebar-menu ul.nav.child_menu > li > a:hover,
.nav-sm #sidebar-menu ul.nav.child_menu > li > a:focus {
    background: rgba(0, 171, 250, 0.18) !important;
    color: #fff !important;
}

.nav-sm #sidebar-menu ul.nav.side-menu > li > a i {
    margin-right: 6px !important; /* antes 8px */
}

.nav-sm #sidebar-menu ul.nav.side-menu li > a span.fa {
    margin-right: 6px !important; /* antes 8px */
}

/*
 * Menú expandido (nav-md): icono | margen | texto (custom.css .main_menu .fa width:26px queda corto con iconos grandes)
 */
.nav-md #sidebar-menu ul.nav.side-menu > li > a,
.nav-md #sidebar-menu ul.nav.child_menu > li > a {
    display: flex !important;
    align-items: center;
    flex-wrap: nowrap;
}

.nav-md #sidebar-menu ul.nav.side-menu > li > a > i.fa:first-of-type,
.nav-md #sidebar-menu ul.nav.child_menu > li > a > i.fa:first-of-type {
    font-size: 22px !important;
    line-height: 1 !important;
    flex: 0 0 38px;
    width: 38px !important;
    min-width: 38px;
    max-width: 38px;
    margin-right: 14px !important;
    margin-left: 0 !important;
    padding: 0 !important;
    text-align: center;
    float: none !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
}

.nav-md #sidebar-menu ul.nav.side-menu > li > a > span.fa.fa-chevron-down,
.nav-md #sidebar-menu ul.nav.side-menu > li > a > span.fa.fa-chevron-up,
.nav-md #sidebar-menu ul.nav.side-menu > li > a > span.fa.fa-chevron-right,
.nav-md #sidebar-menu ul.nav.child_menu > li > a > span.fa.fa-chevron-right {
    margin-left: auto !important;
    margin-right: 0 !important;
    float: none !important;
    flex-shrink: 0;
}

/* =============================================================================
   Menú lateral y submenús: #082064 (refuerzo tras custom.min.css)
   ============================================================================= */
.left_col {
    background: #082064 !important;
}
.nav_title {
    background: #082064 !important;
}
.sidebar-footer {
    background: #082064 !important;
}
body.nav-md,
body.nav-sm {
    background: #fff !important;
    font-family: Roboto, "Helvetica Neue", Arial, "Droid Sans", sans-serif !important;
    font-size: 13px !important;
    line-height: 1.471 !important;
}
#sidebar-menu ul.nav.child_menu {
    background-color: #082064 !important;
}

/* Sin barra cyan extra al expandir submenú (custom.css: border-right 5px #00abfa en .active) */
.nav-md .nav.side-menu > li.active,
.nav-md .nav.side-menu > li.current-page,
.nav-sm .nav.side-menu > li.active-sm,
.nav-sm .nav.child_menu li.active {
    border-right: none !important;
    border-left: none !important;
}

/* nav-sm: fondo del flyout definido arriba (gradiente #082064); no usar otro azul aquí */
.nav.side-menu > li.active > a {
    background: linear-gradient(rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.08)), #082064 !important;
    box-shadow: rgba(0, 0, 0, 0.25) 0 1px 0, inset rgba(255, 255, 255, 0.12) 0 1px 0 !important;
}

/* Marca JDTEAPP / sidebar: icono FA blanco (sin borde legacy .site_title i) */
.navbar.nav_title .site_title .site_title-brand-icon {
    color: #ffffff !important;
    font-size: 1.55rem;
    vertical-align: middle;
    margin-right: 10px;
    border: none !important;
    padding: 0 !important;
    border-radius: 0 !important;
}

.nav-md .navbar.nav_title .site_title {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px;
    padding-left: 10px !important;
}

.nav-md .navbar.nav_title .site_title .site_title-brand-icon {
    font-size: 1.75rem !important;
    margin-right: 0 !important;
    flex-shrink: 0;
}

/* Menú encogido: solo icono — grande y centrado en la franja */
.nav-sm .navbar.nav_title {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.nav-sm .navbar.nav_title .site_title {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    padding-left: 0 !important;
    margin: 0 !important;
    line-height: 1 !important;
}

.nav-sm .navbar.nav_title .site_title .site_title-brand-icon {
    display: inline-block !important;
    font-size: 2rem !important;
    margin: 0 auto !important;
    line-height: 1 !important;
}

.nav-sm .navbar.nav_title .site_title .site_title-brand-text {
    display: none !important;
}

/* Marca: factura (Font Awesome) — expandido: icono + texto */
.nav-md .navbar.nav_title .site_title .site_title-brand-icon,
.nav-md .navbar.nav_title .site_title .site_title-brand-text {
    display: inline-block;
}

.navbar.nav_title .site_title .site_title-brand-text {
    font-weight: 700;
    font-size: 16px;
    letter-spacing: 1px;
    color: #ecf0f1;
}

/*
 * Modales Bootstrap 3 por defecto ~1050; el sidebar nav-sm usa ~10050–10062,
 * por eso los modales quedaban detrás. Subimos modal + backdrop por encima del menú.
 */
.modal {
    z-index: 10070 !important;
}
.modal-backdrop {
    z-index: 10065 !important;
}

/*
 * bootstrap-select con container "body" mueve el menú a body > .bootstrap-select.bs-container.
 * Sin z-index por encima del modal (10070), el listado queda detrás del modal o parece "atrapado".
 */
body > .bootstrap-select.bs-container {
    z-index: 10100 !important;
}

/* Modales de tarjetas métricas (inicio): ancho acotado en escritorio, fluido en móvil */
.modal-dialog-dashboard-metric {
    width: 72%;
    max-width: 960px;
    margin: 30px auto;
}
.modal-dialog-dashboard-metric .modal-header {
    padding-right: 44px;
}
.modal-dialog-dashboard-metric .modal-header .close {
    margin-top: 2px;
}
.modal-dialog-dashboard-metric .modal-body .table-responsive {
    margin-bottom: 0;
    -webkit-overflow-scrolling: touch;
}
@media (max-width: 767px) {
    .modal-dialog-dashboard-metric {
        width: calc(100vw - 24px) !important;
        max-width: calc(100vw - 24px) !important;
        margin: 12px auto !important;
    }
    .modal-dialog-dashboard-metric .modal-content {
        border-radius: 8px;
        overflow: hidden;
    }
    .modal-dialog-dashboard-metric .modal-body {
        padding: 12px !important;
        max-height: min(75vh, calc(100vh - 140px)) !important;
    }
    .modal-dialog-dashboard-metric .modal-title {
        font-size: 15px !important;
        line-height: 1.35 !important;
        padding-right: 8px;
        word-wrap: break-word;
    }
}

/* ==============================
   Animación menú lateral (expandir / contraer)
   custom.min.css no incluye transiciones; se aplican aquí (carga después).
   ============================== */
@media (prefers-reduced-motion: reduce) {
    :root {
        --sidebar-duration: 0.01s;
    }
}

body.sidebar-state-applied .container.body .col-md-3.left_col,
body.sidebar-state-applied .left_col,
body.sidebar-state-applied .nav_title,
body.sidebar-state-applied .container.body .right_col,
body.sidebar-state-applied .main_container .top_nav {
    transition:
        width var(--sidebar-duration) var(--sidebar-ease),
        margin-left var(--sidebar-duration) var(--sidebar-ease),
        max-width var(--sidebar-duration) var(--sidebar-ease),
        opacity calc(var(--sidebar-duration) * 0.85) ease;
}

/* Anchos y márgenes del layout: solo escritorio (en móvil el drawer usa reglas @media arriba) */
@media (min-width: 992px) {
    body.sidebar-state-applied.nav-md .container.body .col-md-3.left_col {
        width: var(--sidebar-width-expanded) !important;
    }

    body.sidebar-state-applied.nav-sm .container.body .col-md-3.left_col {
        width: var(--sidebar-width-collapsed) !important;
    }

    body.sidebar-state-applied.nav-md .nav_title {
        width: var(--sidebar-width-expanded) !important;
    }

    body.sidebar-state-applied.nav-sm .nav_title {
        width: var(--sidebar-width-collapsed) !important;
    }

    body.sidebar-state-applied.nav-md .container.body .right_col,
    body.sidebar-state-applied.nav-md .main_container > .right_col {
        margin-left: var(--sidebar-width-expanded) !important;
        width: calc(100% - var(--sidebar-width-expanded)) !important;
        padding: var(--nav-top-offset) var(--layout-pad-x) var(--app-footer-height) !important;
        min-height: auto !important;
    }

    body.sidebar-state-applied.nav-sm .container.body .right_col,
    body.sidebar-state-applied.nav-sm .main_container > .right_col {
        margin-left: var(--sidebar-width-collapsed) !important;
        width: calc(100% - var(--sidebar-width-collapsed)) !important;
        padding: var(--nav-top-offset) var(--layout-pad-x) var(--app-footer-height) !important;
        min-height: auto !important;
    }

    body.sidebar-state-applied.nav-md .main_container > .top_nav {
        left: var(--sidebar-width-expanded) !important;
    }

    body.sidebar-state-applied.nav-sm .main_container > .top_nav {
        left: var(--sidebar-width-collapsed) !important;
    }
}

/* Texto de marca: desvanecer en lugar de ocultar de golpe */
body.sidebar-state-applied .navbar.nav_title .site_title .site_title-brand-text {
    display: inline-block !important;
    max-width: 140px;
    opacity: 1;
    overflow: hidden;
    white-space: nowrap;
    vertical-align: middle;
    transition:
        opacity calc(var(--sidebar-duration) * 0.75) ease,
        max-width var(--sidebar-duration) var(--sidebar-ease);
}

body.sidebar-state-applied.nav-sm .navbar.nav_title .site_title .site_title-brand-text {
    max-width: 0 !important;
    opacity: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

body.sidebar-state-applied.nav-md .navbar.nav_title .site_title .site_title-brand-text {
    transition-delay: 0.04s;
}

/* Etiquetas del menú (nav-md): aparecen un poco después de ensanchar */
body.sidebar-state-applied #sidebar-menu ul.nav.side-menu > li > a span:not(.fa) {
    display: inline-block !important;
    max-width: 160px;
    opacity: 1;
    overflow: hidden;
    white-space: nowrap;
    vertical-align: middle;
    transition:
        opacity calc(var(--sidebar-duration) * 0.8) ease,
        max-width var(--sidebar-duration) var(--sidebar-ease);
}

body.sidebar-state-applied.nav-sm #sidebar-menu ul.nav.side-menu > li > a span:not(.fa) {
    max-width: 0 !important;
    opacity: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

body.sidebar-state-applied.nav-md #sidebar-menu ul.nav.side-menu > li > a span:not(.fa) {
    transition-delay: 0.05s;
}

body.sidebar-state-applied.nav-sm #sidebar-menu ul.nav.side-menu > li > a {
    transition: font-size calc(var(--sidebar-duration) * 0.7) ease, padding var(--sidebar-duration) var(--sidebar-ease);
}

body.sidebar-state-applied.nav-md #sidebar-menu ul.nav.side-menu > li > a {
    font-size: 13px !important;
    transition: font-size calc(var(--sidebar-duration) * 0.7) ease 0.04s, padding var(--sidebar-duration) var(--sidebar-ease);
}

body.sidebar-transitioning #sidebar-menu a {
    pointer-events: none;
}

body.sidebar-transitioning #menu_toggle {
    pointer-events: none;
    opacity: 0.65;
}

/* Layout contenido + footer (fondo gris, ancho fluido) */
.container {
    width: 100% !important;
    max-width: none !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.container.body {
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
    margin: 0 !important;
    min-height: 0 !important;
    height: auto !important;
}

.container.body .main_container {
    width: 100% !important;
    max-width: none !important;
    background: var(--app-bg-page) !important;
    min-height: 0 !important;
    height: auto !important;
}

body .container.body .right_col,
body.nav-md .container.body .right_col,
body.nav-sm .container.body .right_col,
.main_container > .right_col {
    background: var(--app-bg-page) !important;
    box-sizing: border-box;
    max-width: none !important;
    min-height: 0 !important;
    height: auto !important;
    margin-top: 0 !important;
}

body.nav-md .container.body .right_col,
body.nav-md .main_container > .right_col {
    margin-left: var(--sidebar-width-expanded) !important;
    width: calc(100% - var(--sidebar-width-expanded)) !important;
    padding: var(--nav-top-offset) var(--layout-pad-x) var(--app-footer-height) !important;
}

body.nav-sm .container.body .right_col,
body.nav-sm .main_container > .right_col {
    margin-left: var(--sidebar-width-collapsed) !important;
    width: calc(100% - var(--sidebar-width-collapsed)) !important;
    padding: var(--nav-top-offset) var(--layout-pad-x) var(--app-footer-height) !important;
}

.main_container .right_col .container-fluid {
    width: 100% !important;
    max-width: none !important;
    padding-left: 0;
    padding-right: 0;
}

.main_container .right_col .x_panel {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    box-sizing: border-box;
}

.main_container > .right_col > .x_panel:last-child,
.main_container > .right_col .container-fluid > .row:last-child > [class*="col-"] > .x_panel:last-child {
    margin-bottom: 8px !important;
}

footer.app-layout-footer {
    position: fixed !important;
    bottom: 0 !important;
    right: 0 !important;
    left: 0 !important;
    z-index: 10010;
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin: 0 !important;
    padding: 10px 18px !important;
    min-height: var(--app-footer-height) !important;
    height: auto !important;
    max-height: none !important;
    flex: 0 0 auto !important;
    overflow: hidden;
    background: #fff;
    color: var(--app-text-muted);
    border-top: 1px solid var(--app-border-soft);
    box-sizing: border-box;
    font-size: 11px;
    line-height: 1.35;
}

/* Anula padding alto de Gentelella (custom.css footer { padding: 15px 20px }) */
body.nav-md footer.app-layout-footer,
body.nav-sm footer.app-layout-footer,
footer.app-layout-footer {
    display: flex !important;
    padding: 10px 18px !important;
    min-height: var(--app-footer-height) !important;
    height: auto !important;
    max-height: none !important;
}

.app-layout-footer__brand {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 6px;
    min-width: 0;
}

.app-layout-footer__brand strong {
    font-size: 12px;
    font-weight: 600;
    color: var(--app-text-strong);
}

.app-layout-footer__brand small {
    font-size: 11px;
    color: var(--app-text-muted);
}

.app-layout-footer__brand small::before {
    content: "·";
    margin-right: 6px;
    color: #94a3b8;
}

.app-layout-footer__meta {
    flex-shrink: 0;
    text-align: right;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--app-text-muted);
}

.app-layout-footer__credit {
    flex: 1 1 auto;
    min-width: 0;
    text-align: center;
    font-size: 11px;
    color: var(--app-text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.app-layout-footer__credit strong {
    font-weight: 600;
    color: var(--app-text-strong);
}

.app-layout-footer__credit a {
    color: #2454e0;
    text-decoration: none;
    font-weight: 500;
}

.app-layout-footer__credit a:hover,
.app-layout-footer__credit a:focus {
    text-decoration: underline;
}

@media (min-width: 992px) {
    body.nav-md footer.app-layout-footer {
        left: var(--sidebar-width-expanded) !important;
        margin-left: 0 !important;
        width: calc(100% - var(--sidebar-width-expanded)) !important;
    }

    body.nav-sm footer.app-layout-footer {
        left: var(--sidebar-width-collapsed) !important;
        margin-left: 0 !important;
        width: calc(100% - var(--sidebar-width-collapsed)) !important;
    }
}

@media (max-width: 991px) {
    footer.app-layout-footer {
        left: 0 !important;
        width: 100% !important;
        margin-left: 0 !important;
        padding: 10px 12px !important;
        flex-wrap: wrap;
        justify-content: center;
        row-gap: 4px;
    }

    .app-layout-footer__brand,
    .app-layout-footer__credit,
    .app-layout-footer__meta {
        flex: 1 1 100%;
        text-align: center;
        white-space: normal;
    }
}

/* Evita franja vacía enorme (html/body height 100% de Gentelella + min-height en .right_col) */
html {
    height: auto !important;
    min-height: 0 !important;
}

body.nav-md,
body.nav-sm {
    height: auto !important;
    min-height: 0 !important;
}

body.page-jdtepos-live .container.body .right_col,
body.page-jdtepos-live .main_container > .right_col {
    margin-left: 0 !important;
    width: 100% !important;
}

body.page-jdtepos-live footer.app-layout-footer {
    margin-left: 0 !important;
    width: 100% !important;
}