@keyframes floatAnimation {
    0% {
        transform: translateY(100vh) translateX(0);
        opacity: 0;
    }
    10% {
        transform: translateY(80vh) translateX(5px);
        opacity: 0;
    }
    30% {
        transform: translateY(70vh) translateX(-20px);
    }
    50% {
        transform: translateY(50vh) translateX(20px);
        opacity: .5;
    }
    70% {
        transform: translateY(30vh) translateX(-15px);
    }
    100% {
        transform: translateY(-10vh) translateX(10px);
        opacity: 0;
    }
}

.particle {
    position: absolute;
    width: 3px;
    height: 3px;
    background-color: white;
    border-radius: 50%;
    opacity: 0;
    box-shadow: 0 0 8px rgba(255, 255, 255, 0.8);
    filter: blur(2px); 
    animation: floatAnimation linear infinite;
}


.contenedor-esferas {
    display: block;
    position: relative;    
    top: 0px;
    height: 0;
    z-index: 100;
    filter: contrast(50);
    background-color: #fff;
}

@keyframes caidaAnimacion1 {
    0% {
        transform: translateY(-200px) translateX(0); /* Posición inicial */
        opacity: 100%;
        filter: blur(7px);
    }
    30% {
        transform: translateY(calc(100vh * 0.75)) translateX(0); /* 75% de bajada */
        opacity: 100%;
        filter: blur(9px);
    }
    60% {
        transform: translateY(calc(100vh * 0.53)) translateX(calc(100vw * 0.34)); /* Moverse hacia la derecha y hacia arriba */
        opacity: 100%;
        filter: blur(5px);
    }
    100% {
        transform: translateY(-200px) translateX(0); /* Vuelve a la posición inicial */
        opacity: 100%;
        filter: blur(7px);
    }
}

.esfera1 {    
    position: relative;
    z-index: 100;    
    height: 50px;
	width: 50px;
	border-radius: 25px;
	background-color: #9d46f9;
	opacity: .8;
    top: -200px; /* Posición inicial por encima de la pantalla */
    left: 50%; /* Centra horizontalmente */
    transform: translateX(-50%); /* Centra horizontalmente */
    animation-name: caidaAnimacion1;
    animation-iteration-count: infinite;
    animation-duration: 15s; /* Duración de la animación */
    animation-timing-function: ease-in-out;
    filter: blur(10px);
    /*box-shadow: 0 0 10px #9d46f9;*/
}

@media(max-width: 550px) {
    .esfera1{
        height:26px;
        width: 26px;
        border-radius: 13px;
    }
}

@keyframes caidaAnimacion2 {
    0% {
        transform: translateX(0); /* Posición inicial */
        opacity: 100%;
        filter: blur(10px);
    }
    50% {
        transform: translateX(calc(100vw * 0.50)); /* Moverse 50% hacia la derecha */
        opacity: 100%;
        filter: blur(3px);
    }
    90% {
        transform: translateX(calc(100vw * 0.72)); /* Moverse 22% más hacia la derecha */
        opacity: 100%;
        filter: blur(12px);
    }
    100% {
        transform: translateX(0); /* Vuelve a la posición inicial */
        opacity: 100%;
        filter: blur(10px);
    }
}

.esfera2 {
    position: relative;
    z-index: 100; 
    height: 120px;
	width: 120px;
	border-radius: 60px;
	background-color: #ff4040;
	opacity: .8;
    top: 120px; /* Posición inicial por encima de la pantalla */
    right: 20%; /* Posición inicial */
    transform: translateX(0); /* Posición inicial */
    animation-name: caidaAnimacion2;
    animation-iteration-count: infinite;
    animation-duration: 22s; /* Duración de la animación */
    animation-timing-function: ease-in-out;
    filter: blur(10px);
}

@media(max-width: 550px) {
    .esfera2{
        height:60px;
        width: 60px;
        border-radius: 30px;
    }
}

@keyframes caidaAnimacion3 {
    0% {
        transform: translateX(0); /* Posición inicial */
        opacity: 100%;
        filter: blur(5px);
    }
    30% {
        transform: translateX(calc(-100vw * 0.40)); /* Moverse 40% hacia la izquierda */
        opacity: 100%;
        filter: blur(10px);
    }
    72% {
        transform: translateX(calc(-100vw * 0.61)); /* Moverse 21% más hacia la izquierda */
        opacity: 100%;
        filter: blur(3px);
    }
    90% {
        transform: translateX(calc(-100vw * 0.64)); /* Moverse 3% más hacia la izquierda */
        opacity: 100%;
        filter: blur(20px);
    }
    100% {
        transform: translateX(0); /* Vuelve a la posición inicial */
        opacity: 100%;
        filter: blur(5px);
    }
}

.esfera3 {
    position: relative;
    z-index: 100; 
    height: 144px;
	width: 144px;
	border-radius: 77px;
	background-color: #078cd8;
	opacity: .8;
    top: 180px; /* Ajustar según la altura deseada */
    left: 80%; /* Posición inicial */
    transform: translateX(0); /* Posición inicial */
    animation-name: caidaAnimacion3;
    animation-iteration-count: infinite;
    animation-duration: 18s; /* Duración de la animación */
    animation-timing-function: ease-in-out;
    filter: blur(5px);
}

@media(max-width: 550px) {
    .esfera3{
        height:72px;
        width: 72px;
        border-radius: 36px;
    }
}

@keyframes caidaAnimacion4 {
    0% {
        transform: translateY(300px) translateX(0); /* Posición inicial */
        opacity: 100%;
        filter: blur(8px);
    }
    30% {
        transform: translateY(calc(100vh * 0.22)) translateX(0); /* 75% de bajada */
        opacity: 100%;
        filter: blur(14px);
    }
    60% {
        transform: translateY(calc(100vh * 0.53)) translateX(calc(100vw * 0.74)); /* Moverse hacia la derecha y hacia arriba */
        opacity: 100%;
        filter: blur(8px);
    }
    75% {
        transform: translateY(calc(100vh * 0.33)) translateX(calc(100vw * 0.24)); /* Moverse hacia la derecha y hacia arriba */
        opacity: 100%;
        filter: blur(3px);
    }
    100% {
        transform: translateY(300px) translateX(0); /* Vuelve a la posición inicial */
        opacity: 100%;
        filter: blur(8px);
    }
}

.esfera4 {
    position: relative;
    z-index: 100; 
    height: 90px;
	width: 90px;
	border-radius: 45px;
	background-color: #ccc;
	opacity: .8;
    top: -200px; /* Posición inicial por encima de la pantalla */
    left: 50%; /* Centra horizontalmente */
    transform: translateX(-50%); /* Centra horizontalmente */
    animation-name: caidaAnimacion4;
    animation-iteration-count: infinite;
    animation-duration: 32s; /* Duración de la animación */
    animation-timing-function: ease-in-out; 
    filter: blur(8px);
}

@media(max-width: 550px) {
    .esfera4{
        height:46px;
        width: 46px;
        border-radius: 23px;
    }
}

@keyframes caidaAnimacion5 {
    0% {
        transform: translateY(-350px) translateX(0); /* Posición inicial */
        opacity: 100%;
        filter: blur(5px);
    }
    30% {
        transform: translateY(calc(100vh * 0.10)) translateX(calc(100vw * 0.50)); /* 75% de bajada */
        opacity: 100%;
        filter: blur(12px);
    }
    60% {
        transform: translateY(calc(100vh * 0.50)) translateX(calc(100vw * 0.10)); /* Moverse hacia la derecha y hacia arriba */
        opacity: 100%;
        filter: blur(3px);
    }
    75% {
        transform: translateY(calc(100vh * 0.30)) translateX(calc(-100vw * 0.20)); /* Moverse hacia la derecha y hacia arriba */
        opacity: 100%;
        filter: blur(8px);
    }
    90% {
        transform: translateY(calc(100vh * 0.80)) translateX(calc(100vw * 0.50)); /* Moverse hacia la derecha y hacia arriba */
        opacity: 100%;
        filter: blur(16px);
    }
    100% {
        transform: translateY(-350px)  translateX(0); /* Vuelve a la posición inicial */
        opacity: 100%;
        filter: blur(5px);
    }
}

.esfera5 {
    position: relative;
    z-index: 90; 
    height: 72px;
    width: 72px;
    border-radius: 36px;
    background-color: #df0000;
    opacity: .8;
    top: -350px; /* Ajustar según la altura deseada */
    left: 20%; /* Posición inicial */
    transform: translateX(-50%); /* Posición inicial */
    animation-name: caidaAnimacion5;
    animation-iteration-count: infinite;
    animation-duration: 35s; /* Duración de la animación */
    animation-timing-function: ease-in-out;
    filter: blur(5px);
}

@media(max-width: 550px) {
    .esfera5{
        height:36px;
        width: 36px;
        border-radius: 18px;
    }
}

@keyframes caidaAnimacion6 {
    0% {
        transform: translateX(0) translateY(0); /* Posición inicial */
        opacity: 100%;
        filter: blur(2px);
    }
    30% {
        transform: translateY(calc(100vh * 0.16)) translateX(calc(100vw * 0.63)); /* Moverse 40% hacia la izquierda */
        opacity: 100%;
        filter: blur(5px);
    }
    72% {
        transform: translateY(calc(100vh * 0.72)) translateX(calc(100vw * 0.94)); /* Moverse 21% más hacia la izquierda */
        opacity: 100%;
        filter: blur(8px);
    }
    90% {
        transform: translateY(calc(100vh * 0.46)) translateX(calc(100vw * 0.79)); /* Moverse 3% más hacia la izquierda */
        opacity: 100%;
        filter: blur(13px);
    }
    95% {
        transform: translateY(calc(-100vh * 0.58)) translateX(calc(100vw * 0.39)); /* Moverse 3% más hacia la izquierda */
        opacity: 100%;
        filter: blur(10px);
    }
    100% {
        transform: translateX(0); /* Vuelve a la posición inicial */
        opacity: 100%;
        filter: blur(2px);
    }
}

.esfera6 {
    position: relative;
    z-index: 100; 
    height: 56px;
    width: 56px;
    border-radius: 28px;
    background-color: #00df8a;
    opacity: .8;
    top: -450px; /* Ajustar según la altura deseada */
    right: 20%; /* Posición inicial */
    transform: translateX(0); /* Posición inicial */
    animation-name: caidaAnimacion6;
    animation-iteration-count: infinite;
    animation-duration: 28s; /* Duración de la animación */
    animation-timing-function: ease-in-out;
    filter: blur(5px);
}

@media(max-width: 550px) {
    .esfera6{
        height:28px;
        width: 28px;
        border-radius: 14px;
    }
}

@keyframes caidaAnimacion7 {
    0% {
        transform: translateY(-350px) translateX(-390px); /* Posición inicial */
        opacity: 100%;
        filter: blur(4px);
    }
    30% {
        transform: translateY(-300px) translateX(200px); /* 75% de bajada */
        opacity: 100%;
        filter: blur(8px);
    }
    60% {
        transform: translateY(calc(-100vh * 0.33)) translateX(calc(100vw * 0.64)); /* Moverse hacia la derecha y hacia arriba */
        opacity: 100%;
        filter: blur(3px);
    }
    70% {
        transform: translateY(calc(-100vh * 0.13)) translateX(calc(100vw * 0.24)); /* Moverse hacia la derecha y hacia arriba */
        opacity: 100%;
        filter: blur(3px);
    }
    85% {
        transform: translateY(calc(-100vh * 0.0)) translateX(calc(100vw * 0.24)); /* Moverse hacia la derecha y hacia arriba */
        opacity: 100%;
        filter: blur(3px);
    }    
    100% {
        transform: translateY(-150px) translateX(-390px); /* Vuelve a la posición inicial */
        opacity: 100%;
        filter: blur(4px);
    }
}

.esfera7 {    
    position: relative;
    z-index: 100;    
    height: 50px;
    width: 50px;
    border-radius: 25px;
    background-color: #90ff80;
    opacity: .8;
    top: -200px; /* Posición inicial por encima de la pantalla */
    left: 20%; /* Centra horizontalmente */
    transform: translateX(-20%); /* Centra horizontalmente */
    animation-name: caidaAnimacion7;
    animation-iteration-count: infinite;
    animation-duration: 38s; /* Duración de la animación */
    animation-timing-function: ease-in-out;
    filter: blur(10px);
    /*box-shadow: 0 0 10px #9d46f9;*/
}

@media(max-width: 550px) {
    .esfera7{
        height:26px;
        width: 26px;
        border-radius: 13px;
    }
}

@keyframes caidaAnimacion8 {
    0% {
        transform: translateY(-130px) translateX(0); /* Posición inicial */
        opacity: 100%;
        filter: blur(6px);
    }
    50% {
        transform: translateY(-280px) translateX(calc(100vw * 0.40)); /* Moverse 50% hacia la derecha */
        opacity: 100%;
        filter: blur(9px);
    }
    70% {
        transform: translateY(-190px) translateX(calc(100vw * 0.92)); /* Moverse 22% más hacia la derecha */
        opacity: 100%;
        filter: blur(5px);
    }
    90% {
        transform: translateY(-240px) translateX(calc(100vw * 0.62)); /* Moverse 22% más hacia la derecha */
        opacity: 100%;
        filter: blur(5px);
    }
    100% {
        transform: translateY(-130px) translateX(0); /* Vuelve a la posición inicial */
        opacity: 100%;
        filter: blur(6px);
    }
}

.esfera8 {
    position: relative;
    z-index: 100; 
    height: 36px;
    width: 36px;
    border-radius: 18px;
    background-color: #184ee7;
    opacity: .8;
    top: -120px; /* Posición inicial por encima de la pantalla */
    right: 15%; /* Posición inicial */
    transform: translateX(0); /* Posición inicial */
    animation-name: caidaAnimacion8;
    animation-iteration-count: infinite;
    animation-duration: 36s; /* Duración de la animación */
    animation-timing-function: ease-in-out;
    filter: blur(10px);
}

@media(max-width: 550px) {
    .esfera8{
        height:18px;
        width: 18px;
        border-radius: 9px;
    }
}

@keyframes caidaAnimacion9 {
    0% {
        transform: translateY(360px) translateX(0); /* Posición inicial */
        opacity: 100%;
        filter: blur(3px);
    }
    30% {
        transform: translateY(230px) translateX(calc(-100vw * 0.40)); /* Moverse 40% hacia la izquierda */
        opacity: 100%;
        filter: blur(1px);
    }
    72% {
        transform: translateY(120px) translateX(calc(-100vw * 0.61)); /* Moverse 21% más hacia la izquierda */
        opacity: 100%;
        filter: blur(6px);
    }
    90% {
        transform: translateY(330px) translateX(calc(-100vw * 0.64)); /* Moverse 3% más hacia la izquierda */
        opacity: 100%;
        filter: blur(5px);
    }
    100% {
        transform: translateY(360px) translateX(0); /* Vuelve a la posición inicial */
        opacity: 100%;
        filter: blur(3px);
    }
}

.esfera9 {
    position: relative;
    z-index: 100; 
    height: 102px;
    width: 102px;
    border-radius: 51px;
    background-color: #bc2398;
    opacity: .8;
    top: 260px; /* Ajustar según la altura deseada */
    left: 68%; /* Posición inicial */
    transform: translateX(0); /* Posición inicial */
    animation-name: caidaAnimacion9;
    animation-iteration-count: infinite;
    animation-duration: 27s; /* Duración de la animación */
    animation-timing-function: ease-in-out;
    filter: blur(5px);
}

@media(max-width: 550px) {
    .esfera9{
        height:52px;
        width: 52px;
        border-radius: 26px;
    }
}

@keyframes caidaAnimacion10 {
    0% {
        transform: translateY(-580px) translateX(0); /* Posición inicial */
        opacity: 100%;
        filter: blur(5px);
    }
    30% {
        transform: translateY(calc(100vh * 0.22)) translateX(0); /* 75% de bajada */
        opacity: 100%;
        filter: blur(2px);
    }
    60% {
        transform: translateY(calc(100vh * 0.53)) translateX(calc(100vw * 0.74)); /* Moverse hacia la derecha y hacia arriba */
        opacity: 100%;
        filter: blur(4px);
    }
    75% {
        transform: translateY(calc(100vh * 0.33)) translateX(calc(100vw * 0.24)); /* Moverse hacia la derecha y hacia arriba */
        opacity: 100%;
        filter: blur(3px);
    }
    100% {
        transform: translateY(-580px) translateX(0); /* Vuelve a la posición inicial */
        opacity: 100%;
        filter: blur(5px);
    }
}

.esfera10 {
    position: relative;
    z-index: 100; 
    height: 38px;
    width: 38px;
    border-radius: 19px;
    background-color: #ffefbf;
    opacity: .8;
    top: -180px; /* Posición inicial por encima de la pantalla */
    left: 35%; /* Centra horizontalmente */
    transform: translateX(-50%); /* Centra horizontalmente */
    animation-name: caidaAnimacion10;
    animation-iteration-count: infinite;
    animation-duration: 44s; /* Duración de la animación */
    animation-timing-function: ease-in-out; 
    filter: blur(8px);
}

@media(max-width: 550px) {
    .esfera10{
        height:20px;
        width: 20px;
        border-radius: 10px;
    }
}

@keyframes caidaAnimacion11 {
    0% {
        transform: translateY(350px) translateX(50%); /* Posición inicial */
        opacity: 100%;
        filter: blur(8px);
    }
    30% {
        transform: translateY(calc(100vh * 0.10)) translateX(calc(100vw * 0.50)); /* 75% de bajada */
        opacity: 100%;
        filter: blur(10px);
    }
    60% {
        transform: translateY(calc(100vh * 0.50)) translateX(calc(100vw * 0.70)); /* Moverse hacia la derecha y hacia arriba */
        opacity: 100%;
        filter: blur(3px);
    }
    75% {
        transform: translateY(calc(100vh * 0.30)) translateX(calc(100vw * 0.90)); /* Moverse hacia la derecha y hacia arriba */
        opacity: 100%;
        filter: blur(5px);
    }
    90% {
        transform: translateY(calc(100vh * 0.80)) translateX(calc(100vw * 0.60)); /* Moverse hacia la derecha y hacia arriba */
        opacity: 100%;
        filter: blur(11px);
    }
    100% {
        transform: translateY(350px)  translateX(50%); /* Vuelve a la posición inicial */
        opacity: 100%;
        filter: blur(8px);
    }
}

.esfera11 {
    position: relative;
    z-index: 90; 
    height: 82px;
    width: 82px;
    border-radius: 41px;
    background-color: #0e8ad1;
    opacity: .8;
    top: -450px; /* Ajustar según la altura deseada */
    left: -20%; /* Posición inicial */
    transform: translateX(-50%); /* Posición inicial */
    animation-name: caidaAnimacion11;
    animation-iteration-count: infinite;
    animation-duration: 60s; /* Duración de la animación */
    animation-timing-function: ease-in-out;
    filter: blur(5px);
}

@media(max-width: 550px) {
    .esfera11{
        height:42px;
        width: 42px;
        border-radius: 21px;
    }
}

@keyframes caidaAnimacion12 {
    0% {
        transform: translateX(0) translateY(0); /* Posición inicial */
        opacity: 100%;
        filter: blur(3px);
    }
    30% {
        transform: translateY(calc(-100vh * 0.16)) translateX(calc(100vw * 0.63)); /* Moverse 40% hacia la izquierda */
        opacity: 100%;
        filter: blur(7px);
    }
    72% {
        transform: translateY(calc(100vh * 0.22)) translateX(calc(100vw * 0.44)); /* Moverse 21% más hacia la izquierda */
        opacity: 100%;
        filter: blur(4px);
    }
    90% {
        transform: translateY(calc(-100vh * 0.36)) translateX(calc(100vw * 0.79)); /* Moverse 3% más hacia la izquierda */
        opacity: 100%;
        filter: blur(3px);
    }
    95% {
        transform: translateY(calc(-100vh * 0.18)) translateX(calc(100vw * 0.39)); /* Moverse 3% más hacia la izquierda */
        opacity: 100%;
        filter: blur(5px);
    }
    100% {
        transform: translateX(0); /* Vuelve a la posición inicial */
        opacity: 100%;
        filter: blur(3px);
    }
}

.esfera12 {
    position: relative;
    z-index: 100; 
    height: 68px;
    width: 68px;
    border-radius: 34px;
    background-color: #ff8082;
    opacity: .8;
    top: -500px; /* Ajustar según la altura deseada */
    right: 30%; /* Posición inicial */
    transform: translateX(0); /* Posición inicial */
    animation-name: caidaAnimacion12;
    animation-iteration-count: infinite;
    animation-duration: 41s; /* Duración de la animación */
    animation-timing-function: ease-in-out;
    filter: blur(5px);
}

@media(max-width: 550px) {
    .esfera12{
        height:34px;
        width: 34px;
        border-radius: 17px;
    }
}