#content {
            flex: 1;
            display: flex;
            flex-direction: column;
            min-height: 100vh;
            margin-left: var(--sidebar-width);
            transition: margin-left 0.3s ease;
        }

        main {
            flex: 1 0 auto; /* Esto hace que el footer siempre se vaya al fondo */
        }

        .navbar-brand img {
            width: 120px;
        }

        .btn-panel {
            width: 100%;
            margin-top: 1rem;
            transition: transform 0.2s;
        }

        .btn-panel:hover {
            transform: translateY(-3px);
        }

        footer {
            background-color: #00a859;
            padding: 15px 0;
            width: 100%;
            position: relative;
            z-index: 5;
        }

        .row.g-4 {
            display: flex !important; /* ACTÍVALO */
            flex-wrap: wrap;
            width: 100%;
            margin: 0;
        }

        
        .contenedor-categoria {
            display: block !important; 
            min-height: 50px;
        }
        
        :root {
            --sidebar-width: 260px;
            --primary-green: #00a859;
        }

        body {
            /*display: flex;*/
            min-height: 100vh;
            margin: 0;
            overflow-x: hidden;
        }
        
        .card-body {
            flex: 1 1 auto;
            display: block !important; /* Fuerza el flujo vertical de botones */
        }

        .card-title {
            writing-mode: horizontal-tb !important; /* Fuerza la escritura horizontal */
            display: block !important;
        }

        .seccion-privada {
            display: block; 
            width: 100% !important;
            margin-bottom: 5px;
        }
        
        /* Sidebar Estilo */
        #sidebar {
            width: var(--sidebar-width);
            height: 100vh !important;
            position: fixed; /* Mantenlo fijo */
            background: white;
            z-index: 1000;
            
            overflow-y: auto !important; 
            overflow-x: hidden;
            
        }
        
        #sidebar .nav-link {
            color: #444;
            padding: 10px 20px;
            font-weight: 500;
            border-radius: 5px;
            margin: 2px 15px;
        }
        
        #sidebar .nav-link:hover {
            background-color: #f0fdf4;
            color: var(--primary-green);
        }
        
        #sidebar .nav-link i {
            width: 25px;
        }
        
        #botones-funcionales-ocultos {
            display: none !important;
        }

        .main-container {
            padding: 30px;
        }
        
        .categoria-visible {
            display: block !important;
            opacity: 1 !important;
        }
        
        @media (max-width: 768px) {
            /* Eliminamos el margen para que el contenido use toda la pantalla del celular */
            .col-md-6, .col-lg-4 {
                width: 100% !important;
                padding-left: 15px !important;
                padding-right: 15px !important;
            }
            .card-body {
                padding: 15px !important;
            }
            
            #content {
                margin-left: 0 !important;
                width: 100% !important;
                padding: 10px !important;
            }
        
            /* Aseguramos que el Sidebar se vea por encima de todo */
            #sidebar {
                left: -280px !important; 
                z-index: 9999 !important;
                background-color: white !important;
                box-shadow: 5px 0 15px rgba(0,0,0,0.2);
                
                position: fixed;
                top: 0;
                left: 0;
                display: flex;
                flex-direction: column;
                
                overflow-y: auto; 
                overflow-x: hidden;
                transition: all 0.3s;
            }
            
            #sidebar.active {
                left: 0 !important;
            }
            
            #sidebar-overlay {
                display: none !important;
            }
        
            /* Forzamos que los iconos y textos del menú sean visibles */
            #sidebar .nav-link {
                color: #333 !important;
                display: block !important;
            }
            
            #sidebarCollapse {
                display: flex !important;
                align-items: center;
                justify-content: center;
                margin-right: 10px;
            }
        }

        .menu-link {
            transition: all 0.2s;
            font-weight: 500;
        }
        
        .menu-link:hover {
            background-color: #f8f9fa;
            padding-left: 15px !important;
            color: #00a859 !important; /* Verde JPF */
        }
        
        .contenedor-categoria {
            min-width: 250px; /* Evita que la tarjeta se haga demasiado flaca */
            flex: 1 1 300px;  /* Permite que crezcan pero con un base de 300px */
        }

        .card {
            display: flex !important;
            flex-direction: column;
            width: 100%;
            overflow: hidden;
        }

        .btn-panel, .btn-outline-primary, .btn-outline-success, .btn-outline-warning, .btn-outline-danger {
            width: 100% !important;
            text-align: center !important; /* Centrado absoluto */
            justify-content: center !important;
            padding: 12px 10px !important; /* Más alto para que sea fácil de tocar */
            font-weight: 500;
            margin-bottom: 8px;
            display: flex;
            align-items: center;
            padding: 12px 10px !important;
        }

        .btn-panel:active {
            transform: scale(0.98);
            background-color: #f8f9fa;
        }

        .flex-grow-1 {
            min-width: 0;
        }