/* Usamos un pseudo-elemento para crear una capa oscura sobre el fondo */
body::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0); /* Color negro con 50% de opacidad */
    z-index: 0; /* Aseguramos que quede detrás del contenido */
}

.transition-div {
    transition: opacity 0.5s ease, transform 0.3s ease;
    position: absolute; /* Necesario para superponer los divs */
    width: 100%; /* Ajusta el ancho según sea necesario */
    height: 100%; /* Ajusta la altura según sea necesario */
    opacity: 0; /* Comienza oculto */
    transform: scale(0.5); /* Comienza un poco más pequeño */
}

.visible {
    opacity: 1; /* Totalmente visible */
    transform: scale(1); /* Tamaño normal */
}

.hidden {
    opacity: 0; /* Oculto */
    transform: scale(0.5); /* Más pequeño */
}

li {
    margin-bottom: 10px;
}

