/* Estilo para el footer anclado al fondo */

/* Estructura principal */
html, body {
    height: 100%;
    margin: 0;
}

body {
    display: flex;
    flex-direction: column;
    min-height: 100vh; /* viewport height */
}

/* Contenedor principal que ocupa el espacio disponible */
.content-wrapper {
    flex: 1 0 auto; /* flex-grow, flex-shrink, flex-basis */
}

/* Footer anclado al fondo */
footer {
    flex-shrink: 0; /* Evita que el footer se encoja */
    background-color: var(--bs-dark); /* Mantener el tema oscuro */
    color: white;
    padding: 1.5rem 0;
    margin-top: auto; /* Empuja el footer hacia abajo */
}

/* Ajustes para card-footer */
.card-footer {
    background-color: rgba(var(--bs-dark-rgb), 0.95); /* Consistente con el tema oscuro */
    color: white;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

/* Clase para centrar contenido verticalmente en páginas con poco contenido */
.full-height-center {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: calc(100vh - 200px); /* Altura de viewport menos espacio para header/footer */
    padding: 2rem 0;
}

/* Media query para dispositivos móviles */
@media (max-width: 768px) {
    footer {
        padding: 1rem 0;
    }
    
    .full-height-center {
        min-height: calc(100vh - 180px);
    }
} 