/*
 * === SIDEBAR SCROLL FIX ===
 *
 * OverlayScrollbars fue deshabilitado desde config/adminlte.php
 * (layout_fixed_sidebar: null) ya que su JS envolvía el .sidebar
 * y bloqueaba el overflow nativo.
 *
 * Aquí replicamos el comportamiento de sidebar fija + scroll nativo.
 */

/* El aside ya es position: fixed gracias a AdminLTE */
.main-sidebar {
    position: fixed !important;
    top: 0;
    bottom: 0;
    left: 0;
    height: 100% !important;
    overflow: hidden !important;  /* El aside no scrollea, el .sidebar sí */
}

/* El div.sidebar ocupa desde debajo del logo hasta el fondo */
.main-sidebar .sidebar {
    position: absolute !important;
    top: 57px !important;   /* altura del brand-link/logo */
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    overflow-y: scroll !important;
    overflow-x: hidden !important;
    padding-bottom: 30px !important;
}

/* Barra de scroll siempre visible y elegante */
.main-sidebar .sidebar::-webkit-scrollbar {
    width: 5px;
}
.main-sidebar .sidebar::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.25);
}
.main-sidebar .sidebar::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.4);
    border-radius: 3px;
}
.main-sidebar .sidebar::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.65);
}

/* Firefox */
.main-sidebar .sidebar {
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,0.4) rgba(0,0,0,0.25);
}

/* ── Reducir espaciado sin afectar legibilidad ─────────────────── */
.nav-sidebar .nav-header {
    padding: 0.2rem 1rem !important;
    font-size: 0.73rem !important;
    margin-top: 0.2rem !important;
    opacity: 0.8;
}

.nav-sidebar .nav-item {
    margin-bottom: 0 !important;
}

.nav-sidebar .nav-link {
    padding-top: 0.35rem !important;
    padding-bottom: 0.35rem !important;
}

.nav-sidebar .nav-treeview > .nav-item > .nav-link {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
}
