html, body {
  height: 100%;
}


.backgroundxxx {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url('img/nocheestrellada.jpg'), url('img/nocheestrellada2.jpg');
    background-size: cover, cover;
    background-position: center, center;
    background-repeat: no-repeat, no-repeat;
    background-color: rgba(255, 255, 255, 0); /* Ajusta el color y la opacidad */
}

/*----------------------BARRA DE PROGRESO----------------------*/
#progress-container {
    display: none; /* Oculto por defecto */
    width: 100%;
    background: #f3f3f3;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9999;
}

#progress-bar {
    width: 0%;
    height: 5px;
    background: #4caf50;
}
/*------------------FIN-BARRA DE PROGRESO----------------------*/


/*--------------------------------------------------------------------------*/
    /* Estilos del spinner */
    
    
    @media (max-width: 768px) {
        /* Aquí van los estilos específicos para móviles */
        .loader {
            position: fixed;
            left: 45%;
            top: 50%;
            transform: translate(-50%, -50%);
            border: 10px solid #ccc8c8; /* Color de fondo */
            border-top: 10px solid #ffffff; /* Color del spinner */
            border-radius: 50%;
            width: 60px;
            height: 60px;
            animation: spin 2s linear infinite;
            z-index: 9999; /* Asegura que el spinner esté por encima de otros elementos */
        }      
        
    }
    
    @media (min-width: 769px) {
        /* Aquí van los estilos específicos para pantallas grandes */
        .loader {
            position: fixed;
            left: 40%;
            top: 50%;
            transform: translate(-50%, -50%);
            border: 16px solid #ccc8c8; /* Color de fondo */
            border-top: 16px solid #1452d6; /* Color del spinner */
            border-radius: 50%;
            width: 120px;
            height: 120px;
            animation: spin 2s linear infinite;
            z-index: 9999; /* Asegura que el spinner esté por encima de otros elementos */
        }
        
    }



    /* Animación de giro */
    @keyframes spin {
        0% { transform: rotate(0deg); }
        100% { transform: rotate(360deg); }
    }
    
    /* Ocultar el contenido inicialmente */
    .hidden {
        display: none;
    }
/*--------------------------------------------------------------------------*/

        .moon-container {
            position: fixed; /* Cambia de relative a fixed */
        }

        .moon {
            position: absolute;
            width: 100%;
            height: 100%;
            border-radius: 50%;
            background-color: #DEDEDE; /* Color de la luna cuarto */
            overflow: hidden;   
            box-shadow: 0 0 10px 5px rgba(255, 255, 255, 0.5);  
        }

        .moon::before {
            content: '';
            position: absolute;
            width: 100%;
            height: 100%;
            border-radius: 50%;
            background-color: #DEDEDE; /* Color de fondo para ocultar parte de la luna */
            clip-path: circle(50% at 90% 50%); 
        }


        @keyframes fadeOutIn {
            0% {
                opacity: 1; /* Totalmente opaco al inicio */
            }
            50% {
                opacity: 0; /* Totalmente transparente a mitad de la animación */
            }
            100% {
                opacity: 1; /* Vuelve a ser totalmente opaco al final */
            }
        }    



        .dotted-circle {
            position: absolute;
            top: 50%;
            left: 50%;
            border-radius: 50%;
            border-style: dashed;
            border-width: 1px;
            animation: fadeOutIn 6s infinite;              
        }
        
        .dotted-circle1 {
            width: 110%;
            height: 110%;
            border-color: rgba(255, 255, 255, 1); /* Borde blanco con 50% de opacidad */
            transform: translate(-50%, -50%) rotate(15deg); /* Rota levemente */
            animation: fadeOutIn 6s infinite; 
        }  

        .dotted-circle2 {
            width: 120%;
            height: 120%;
            border-color: rgba(255, 255, 255, 1); /* Borde blanco con 50% de opacidad */
            transform: translate(-50%, -50%) rotate(10deg); /* Rota levemente */
            animation: fadeOutIn 7s infinite; 
        }  

        .dotted-circle3 {
            width: 130%;
            height: 130%;
            border-color: rgba(255, 255, 255, 0.9); /* Borde blanco con 50% de opacidad */
            transform: translate(-50%, -50%) rotate(15deg); /* Rota levemente */
            animation: fadeOutIn 7s infinite; 
        }    

        .dotted-circle4 {
            width: 140%;
            height: 140%;
            border-color: rgba(249, 253, 0, 0.9); /* Color mostaza con 50% de opacidad */
            transform: translate(-50%, -50%) rotate(20deg); /* Rota levemente */
            animation: fadeOutIn 8s infinite; 
        }   

        .dotted-circle5 {
            width: 150%;
            height: 150%;
            border-color: rgba(249, 253, 0, 0.8); /* Color mostaza con 50% de opacidad */
            transform: translate(-50%, -50%) rotate(25deg); /* Rota levemente */
            animation: fadeOutIn 8s infinite; 
        }   

        .dotted-circle6 {
            width: 160%;
            height: 160%;
            border-color: rgba(178, 219, 255, 0.7); /* Color azul claro con 50% de opacidad */
            transform: translate(-50%, -50%) rotate(30deg); /* Rota levemente */
            animation: fadeOutIn 9s infinite; 
        }  

        .dotted-circle7 {
            width: 170%;
            height: 170%;
            border-color: rgba(178, 219, 255, 0.6); /* Color azul claro con 50% de opacidad */
            transform: translate(-50%, -50%) rotate(35deg); /* Rota levemente */
            animation: fadeOutIn 9s infinite; 
        } 

        .dotted-circle8 {
            width: 180%;
            height: 180%;
            border-color: rgba(255, 255, 255, 0.5); /* Borde blanco con 50% de opacidad */
            transform: translate(-50%, -50%) rotate(40deg); /* Rota levemente */
            animation: fadeOutIn 10s infinite; 
        } 
/*-------------------------------------------------------------------------*/
    
            .moon1 {
                width: 15vmin; /* Tamaño mayor */
                height: 15vmin;
                top: 120px;
                right: 15px;
                z-index:1;
            }

            .dotted-circle1, .dotted-circle2, .dotted-circle3, .dotted-circle4, .dotted-circle5, .dotted-circle6, .dotted-circle7, .dotted-circle8 {
                border-width: 1px; /* Grosor del borde más delgado en móviles */
            }
/*-------------------------------------------------------------------------*/

	  /*Full Screen */
		.firefly {
  			position: fixed;
  			left: 50%;
  			top: 50%;
  			width: 0.7vw;
  			height: 0.7vw;
  			margin: -0.2vw 0 0 9.8vw;
			box-shadow: 0 0 0vw 0vw yellow;
  			animation: ease 100s alternate infinite;
  			pointer-events: none;
		}			
	

	    
	  /*Mobile  */
		.firefly {
  			position: fixed;
  			left: 50%;
  			top: 50%;
  			width: 1.3vw;
  			height: 1.3vw;
  			margin: -0.2vw 0 0 9.8vw;
			box-shadow: 0 0 0vw 0vw yellow;
  			animation: ease 100s alternate infinite;
  			pointer-events: none;
		}	



.firefly::before, .firefly::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 60%;
  transform-origin: -10vw;
}
.firefly::before {
  background: black;
  opacity: 0.5;
  animation: drift ease alternate infinite;
}
.firefly::after {
  background: white;
  opacity: 1;
  box-shadow: 0 0 0vw 0vw yellow;
  animation: drift ease alternate infinite, flash ease infinite;
}

.firefly:nth-child(1) {
  animation-name: move1;
}
.firefly:nth-child(1)::before {
  animation-duration: 58s;
}
.firefly:nth-child(1)::after {
  animation-duration: 58s, 7172ms;
  animation-delay: 0ms, 4037ms;
}


.firefly:nth-child(2) {
  animation-name: move2;
}
.firefly:nth-child(2)::before {
  animation-duration: 78s;
}
.firefly:nth-child(2)::after {
  animation-duration: 78s, 8172ms;
  animation-delay: 0ms, 5037ms;
}




@keyframes move1 {
  0% {
    transform: translateX(-32vw) translateY(-35vh) scale(0.85);
  }
  4% {
    transform: translateX(5vw) translateY(12vh) scale(0.32);
  }
  8% {
    transform: translateX(-40vw) translateY(-18vh) scale(0.29);
  }
  12% {
    transform: translateX(-7vw) translateY(-1vh) scale(0.49);
  }
  16% {
    transform: translateX(19vw) translateY(19vh) scale(0.71);
  }
  20% {
    transform: translateX(-37vw) translateY(30vh) scale(0.75);
  }
  24% {
    transform: translateX(-4vw) translateY(31vh) scale(0.41);
  }
  28% {
    transform: translateX(35vw) translateY(24vh) scale(0.73);
  }
  32% {
    transform: translateX(14vw) translateY(-37vh) scale(0.8);
  }
  36% {
    transform: translateX(-17vw) translateY(32vh) scale(0.72);
  }
  40% {
    transform: translateX(-11vw) translateY(10vh) scale(0.31);
  }
  44% {
    transform: translateX(-46vw) translateY(-6vh) scale(0.34);
  }
  48% {
    transform: translateX(26vw) translateY(11vh) scale(0.58);
  }
  52% {
    transform: translateX(7vw) translateY(1vh) scale(0.9);
  }
  56% {
    transform: translateX(11vw) translateY(40vh) scale(0.39);
  }
  60% {
    transform: translateX(36vw) translateY(18vh) scale(0.87);
  }
  64% {
    transform: translateX(22vw) translateY(40vh) scale(0.48);
  }
  68% {
    transform: translateX(24vw) translateY(-49vh) scale(0.83);
  }
  72% {
    transform: translateX(0vw) translateY(-13vh) scale(0.33);
  }
  76% {
    transform: translateX(-49vw) translateY(13vh) scale(0.84);
  }
  80% {
    transform: translateX(0vw) translateY(36vh) scale(0.51);
  }
  84% {
    transform: translateX(30vw) translateY(-9vh) scale(0.85);
  }
  88% {
    transform: translateX(26vw) translateY(26vh) scale(0.44);
  }
  92% {
    transform: translateX(-44vw) translateY(-13vh) scale(0.26);
  }
  96% {
    transform: translateX(2vw) translateY(-49vh) scale(0.97);
  }
  100% {
    transform: translateX(5vw) translateY(22vh) scale(0.84);
  }
}
.firefly:nth-child(2) {
  animation-name: move2;
}
.firefly:nth-child(2)::before {
  animation-duration: 18s;
}
.firefly:nth-child(2)::after {
  animation-duration: 18s, 8770ms;
  animation-delay: 0ms, 3615ms;
}

@keyframes move2 {
  0% {
    transform: translateX(-14vw) translateY(14vh) scale(0.86);
  }
  6.2631578947% {
    transform: translateX(49vw) translateY(45vh) scale(0.86);
  }
  11.5263157895% {
    transform: translateX(50vw) translateY(22vh) scale(0.28);
  }
  16.7894736842% {
    transform: translateX(-14vw) translateY(46vh) scale(0.98);
  }
  22.0526315789% {
    transform: translateX(-42vw) translateY(-11vh) scale(0.8);
  }
  27.3157894737% {
    transform: translateX(-25vw) translateY(17vh) scale(0.65);
  }
  32.5789473684% {
    transform: translateX(38vw) translateY(14vh) scale(0.81);
  }
  37.8421052632% {
    transform: translateX(10vw) translateY(39vh) scale(0.72);
  }
  43.1052631579% {
    transform: translateX(49vw) translateY(36vh) scale(0.58);
  }
  47.3684210526% {
    transform: translateX(47vw) translateY(0vh) scale(0.52);
  }
  53.6315789474% {
    transform: translateX(-47vw) translateY(-39vh) scale(0.88);
  }
  58.8947368421% {
    transform: translateX(-7vw) translateY(-15vh) scale(0.97);
  }
  64.1578947368% {
    transform: translateX(49vw) translateY(-9vh) scale(0.7);
  }
  68.4210526316% {
    transform: translateX(27vw) translateY(8vh) scale(0.91);
  }
  74.6842105263% {
    transform: translateX(12vw) translateY(35vh) scale(0.8);
  }
  79.9473684211% {
    transform: translateX(30vw) translateY(-9vh) scale(0.28);
  }
  85.2105263158% {
    transform: translateX(-6vw) translateY(-47vh) scale(0.41);
  }
  90.4736842105% {
    transform: translateX(50vw) translateY(-6vh) scale(0.93);
  }
  95.7368421053% {
    transform: translateX(-48vw) translateY(-44vh) scale(0.98);
  }
  100% {
    transform: translateX(18vw) translateY(34vh) scale(0.49);
  }
}
.firefly:nth-child(3) {
  animation-name: move3;
}
.firefly:nth-child(3)::before {
  animation-duration: 10s;
}
.firefly:nth-child(3)::after {
  animation-duration: 10s, 8485ms;
  animation-delay: 0ms, 7346ms;
}

@keyframes move3 {
  0% {
    transform: translateX(-17vw) translateY(-4vh) scale(0.96);
  }
  3.8461538462% {
    transform: translateX(-35vw) translateY(-5vh) scale(0.76);
  }
  7.6923076923% {
    transform: translateX(0vw) translateY(-42vh) scale(0.65);
  }
  11.5384615385% {
    transform: translateX(47vw) translateY(-44vh) scale(0.65);
  }
  15.3846153846% {
    transform: translateX(-24vw) translateY(-44vh) scale(0.81);
  }
  19.2307692308% {
    transform: translateX(22vw) translateY(29vh) scale(0.56);
  }
  23.0769230769% {
    transform: translateX(39vw) translateY(-8vh) scale(0.68);
  }
  26.9230769231% {
    transform: translateX(48vw) translateY(-10vh) scale(0.32);
  }
  30.7692307692% {
    transform: translateX(-34vw) translateY(0vh) scale(0.81);
  }
  34.6153846154% {
    transform: translateX(32vw) translateY(26vh) scale(0.43);
  }
  38.4615384615% {
    transform: translateX(27vw) translateY(47vh) scale(0.26);
  }
  42.3076923077% {
    transform: translateX(-34vw) translateY(42vh) scale(0.42);
  }
  46.1538461538% {
    transform: translateX(40vw) translateY(23vh) scale(0.93);
  }
  50% {
    transform: translateX(-13vw) translateY(-29vh) scale(0.56);
  }
  53.8461538462% {
    transform: translateX(-24vw) translateY(-46vh) scale(0.79);
  }
  57.6923076923% {
    transform: translateX(-42vw) translateY(-49vh) scale(0.35);
  }
  61.5384615385% {
    transform: translateX(20vw) translateY(48vh) scale(0.5);
  }
  65.3846153846% {
    transform: translateX(40vw) translateY(-25vh) scale(0.99);
  }
  69.2307692308% {
    transform: translateX(9vw) translateY(2vh) scale(0.63);
  }
  73.0769230769% {
    transform: translateX(-24vw) translateY(10vh) scale(0.39);
  }
  76.9230769231% {
    transform: translateX(1vw) translateY(-33vh) scale(0.45);
  }
  80.7692307692% {
    transform: translateX(41vw) translateY(-35vh) scale(0.52);
  }
  84.6153846154% {
    transform: translateX(46vw) translateY(10vh) scale(0.98);
  }
  88.4615384615% {
    transform: translateX(26vw) translateY(-18vh) scale(0.92);
  }
  92.3076923077% {
    transform: translateX(45vw) translateY(36vh) scale(0.53);
  }
  96.1538461538% {
    transform: translateX(38vw) translateY(-13vh) scale(0.84);
  }
  100% {
    transform: translateX(-4vw) translateY(-15vh) scale(0.52);
  }
}
.firefly:nth-child(4) {
  animation-name: move4;
}
.firefly:nth-child(4)::before {
  animation-duration: 15s;
}
.firefly:nth-child(4)::after {
  animation-duration: 15s, 10052ms;
  animation-delay: 0ms, 1328ms;
}

@keyframes move4 {
  0% {
    transform: translateX(3vw) translateY(31vh) scale(0.68);
  }
  3.7037037037% {
    transform: translateX(-48vw) translateY(15vh) scale(0.73);
  }
  7.4074074074% {
    transform: translateX(-32vw) translateY(-34vh) scale(0.39);
  }
  11.1111111111% {
    transform: translateX(-45vw) translateY(27vh) scale(0.73);
  }
  14.8148148148% {
    transform: translateX(-31vw) translateY(-47vh) scale(0.32);
  }
  18.5185185185% {
    transform: translateX(37vw) translateY(-11vh) scale(0.57);
  }
  22.2222222222% {
    transform: translateX(4vw) translateY(49vh) scale(0.71);
  }
  25.9259259259% {
    transform: translateX(44vw) translateY(19vh) scale(0.48);
  }
  29.6296296296% {
    transform: translateX(-31vw) translateY(33vh) scale(0.5);
  }
  33.3333333333% {
    transform: translateX(-33vw) translateY(-18vh) scale(0.9);
  }
  37.037037037% {
    transform: translateX(-1vw) translateY(41vh) scale(0.37);
  }
  40.7407407407% {
    transform: translateX(-48vw) translateY(10vh) scale(0.9);
  }
  44.4444444444% {
    transform: translateX(-48vw) translateY(33vh) scale(0.64);
  }
  48.1481481481% {
    transform: translateX(48vw) translateY(-7vh) scale(0.64);
  }
  51.8518518519% {
    transform: translateX(39vw) translateY(-7vh) scale(0.92);
  }
  55.5555555556% {
    transform: translateX(-27vw) translateY(-26vh) scale(0.5);
  }
  59.2592592593% {
    transform: translateX(3vw) translateY(43vh) scale(0.78);
  }
  62.962962963% {
    transform: translateX(-8vw) translateY(4vh) scale(0.52);
  }
  66.6666666667% {
    transform: translateX(-1vw) translateY(24vh) scale(0.74);
  }
  70.3703703704% {
    transform: translateX(-34vw) translateY(42vh) scale(0.39);
  }
  74.0740740741% {
    transform: translateX(28vw) translateY(-15vh) scale(0.64);
  }
  77.7777777778% {
    transform: translateX(41vw) translateY(-34vh) scale(0.49);
  }
  81.4814814815% {
    transform: translateX(-38vw) translateY(5vh) scale(0.26);
  }
  85.1851851852% {
    transform: translateX(8vw) translateY(1vh) scale(0.71);
  }
  88.8888888889% {
    transform: translateX(26vw) translateY(3vh) scale(0.49);
  }
  92.5925925926% {
    transform: translateX(-22vw) translateY(-14vh) scale(0.8);
  }
  96.2962962963% {
    transform: translateX(-49vw) translateY(11vh) scale(0.41);
  }
  100% {
    transform: translateX(-7vw) translateY(47vh) scale(0.76);
  }
}
.firefly:nth-child(5) {
  animation-name: move5;
}
.firefly:nth-child(5)::before {
  animation-duration: 9s;
}
.firefly:nth-child(5)::after {
  animation-duration: 9s, 7648ms;
  animation-delay: 0ms, 4450ms;
}

@keyframes move5 {
  0% {
    transform: translateX(48vw) translateY(-37vh) scale(0.62);
  }
  5.8823529412% {
    transform: translateX(-30vw) translateY(47vh) scale(0.81);
  }
  11.7647058824% {
    transform: translateX(-25vw) translateY(-14vh) scale(0.62);
  }
  17.6470588235% {
    transform: translateX(26vw) translateY(-5vh) scale(0.58);
  }
  23.5294117647% {
    transform: translateX(3vw) translateY(-43vh) scale(0.27);
  }
  29.4117647059% {
    transform: translateX(-21vw) translateY(-24vh) scale(0.27);
  }
  35.2941176471% {
    transform: translateX(8vw) translateY(46vh) scale(0.7);
  }
  41.1764705882% {
    transform: translateX(-35vw) translateY(-45vh) scale(0.52);
  }
  47.0588235294% {
    transform: translateX(-47vw) translateY(22vh) scale(0.76);
  }
  52.9411764706% {
    transform: translateX(-35vw) translateY(-48vh) scale(0.65);
  }
  58.8235294118% {
    transform: translateX(-20vw) translateY(-43vh) scale(0.41);
  }
  64.7058823529% {
    transform: translateX(18vw) translateY(38vh) scale(0.61);
  }
  70.5882352941% {
    transform: translateX(5vw) translateY(44vh) scale(0.44);
  }
  76.4705882353% {
    transform: translateX(-14vw) translateY(15vh) scale(0.63);
  }
  82.3529411765% {
    transform: translateX(37vw) translateY(-22vh) scale(0.29);
  }
  88.2352941176% {
    transform: translateX(41vw) translateY(41vh) scale(0.37);
  }
  94.1176470588% {
    transform: translateX(38vw) translateY(-25vh) scale(0.85);
  }
  100% {
    transform: translateX(22vw) translateY(-9vh) scale(0.35);
  }
}
.firefly:nth-child(6) {
  animation-name: move6;
}
.firefly:nth-child(6)::before {
  animation-duration: 11s;
}
.firefly:nth-child(6)::after {
  animation-duration: 11s, 10209ms;
  animation-delay: 0ms, 5839ms;
}

@keyframes move6 {
  0% {
    transform: translateX(50vw) translateY(2vh) scale(0.53);
  }
  4% {
    transform: translateX(23vw) translateY(17vh) scale(0.76);
  }
  8% {
    transform: translateX(-3vw) translateY(42vh) scale(0.93);
  }
  12% {
    transform: translateX(-20vw) translateY(49vh) scale(0.94);
  }
  16% {
    transform: translateX(-44vw) translateY(-47vh) scale(0.28);
  }
  20% {
    transform: translateX(36vw) translateY(-1vh) scale(0.53);
  }
  24% {
    transform: translateX(-10vw) translateY(38vh) scale(0.6);
  }
  28% {
    transform: translateX(34vw) translateY(-13vh) scale(0.55);
  }
  32% {
    transform: translateX(-5vw) translateY(16vh) scale(0.57);
  }
  36% {
    transform: translateX(-49vw) translateY(-47vh) scale(0.61);
  }
  40% {
    transform: translateX(-15vw) translateY(-18vh) scale(0.73);
  }
  44% {
    transform: translateX(14vw) translateY(-44vh) scale(0.74);
  }
  48% {
    transform: translateX(-28vw) translateY(35vh) scale(0.48);
  }
  52% {
    transform: translateX(-11vw) translateY(-20vh) scale(0.61);
  }
  56% {
    transform: translateX(27vw) translateY(33vh) scale(0.76);
  }
  60% {
    transform: translateX(-37vw) translateY(-34vh) scale(0.32);
  }
  64% {
    transform: translateX(5vw) translateY(-6vh) scale(0.39);
  }
  68% {
    transform: translateX(5vw) translateY(1vh) scale(0.45);
  }
  72% {
    transform: translateX(11vw) translateY(-20vh) scale(0.35);
  }
  76% {
    transform: translateX(-7vw) translateY(35vh) scale(0.59);
  }
  80% {
    transform: translateX(-44vw) translateY(20vh) scale(0.44);
  }
  84% {
    transform: translateX(-23vw) translateY(6vh) scale(0.91);
  }
  88% {
    transform: translateX(41vw) translateY(-42vh) scale(0.59);
  }
  92% {
    transform: translateX(32vw) translateY(28vh) scale(0.37);
  }
  96% {
    transform: translateX(31vw) translateY(9vh) scale(0.49);
  }
  100% {
    transform: translateX(-21vw) translateY(0vh) scale(0.9);
  }
}
.firefly:nth-child(7) {
  animation-name: move7;
}
.firefly:nth-child(7)::before {
  animation-duration: 15s;
}
.firefly:nth-child(7)::after {
  animation-duration: 15s, 8704ms;
  animation-delay: 0ms, 539ms;
}

@keyframes move7 {
  0% {
    transform: translateX(-20vw) translateY(11vh) scale(0.47);
  }
  5.5555555556% {
    transform: translateX(12vw) translateY(6vh) scale(0.78);
  }
  11.1111111111% {
    transform: translateX(0vw) translateY(-3vh) scale(0.91);
  }
  16.6666666667% {
    transform: translateX(-21vw) translateY(-45vh) scale(0.49);
  }
  22.2222222222% {
    transform: translateX(-47vw) translateY(-47vh) scale(0.91);
  }
  27.7777777778% {
    transform: translateX(31vw) translateY(-41vh) scale(0.42);
  }
  33.3333333333% {
    transform: translateX(6vw) translateY(-6vh) scale(0.37);
  }
  38.8888888889% {
    transform: translateX(-6vw) translateY(-10vh) scale(0.38);
  }
  44.4444444444% {
    transform: translateX(-23vw) translateY(-13vh) scale(0.82);
  }
  50% {
    transform: translateX(-45vw) translateY(36vh) scale(0.36);
  }
  55.5555555556% {
    transform: translateX(-48vw) translateY(-33vh) scale(0.88);
  }
  61.1111111111% {
    transform: translateX(50vw) translateY(-21vh) scale(0.88);
  }
  66.6666666667% {
    transform: translateX(-36vw) translateY(-7vh) scale(0.58);
  }
  72.2222222222% {
    transform: translateX(-26vw) translateY(-24vh) scale(0.96);
  }
  77.7777777778% {
    transform: translateX(-33vw) translateY(47vh) scale(0.77);
  }
  83.3333333333% {
    transform: translateX(47vw) translateY(21vh) scale(1);
  }
  88.8888888889% {
    transform: translateX(-19vw) translateY(-12vh) scale(0.77);
  }
  94.4444444444% {
    transform: translateX(-22vw) translateY(3vh) scale(0.88);
  }
  100% {
    transform: translateX(17vw) translateY(-43vh) scale(0.77);
  }
}
.firefly:nth-child(8) {
  animation-name: move8;
}
.firefly:nth-child(8)::before {
  animation-duration: 12s;
}
.firefly:nth-child(8)::after {
  animation-duration: 12s, 9575ms;
  animation-delay: 0ms, 3759ms;
}

@keyframes move8 {
  0% {
    transform: translateX(2vw) translateY(-46vh) scale(0.45);
  }
  3.8461538462% {
    transform: translateX(8vw) translateY(31vh) scale(0.28);
  }
  7.6923076923% {
    transform: translateX(-44vw) translateY(-18vh) scale(0.4);
  }
  11.5384615385% {
    transform: translateX(47vw) translateY(-38vh) scale(0.92);
  }
  15.3846153846% {
    transform: translateX(-3vw) translateY(-19vh) scale(0.3);
  }
  19.2307692308% {
    transform: translateX(-36vw) translateY(32vh) scale(0.49);
  }
  23.0769230769% {
    transform: translateX(-27vw) translateY(9vh) scale(0.65);
  }
  26.9230769231% {
    transform: translateX(-18vw) translateY(17vh) scale(0.51);
  }
  30.7692307692% {
    transform: translateX(-41vw) translateY(-40vh) scale(0.44);
  }
  34.6153846154% {
    transform: translateX(50vw) translateY(9vh) scale(0.68);
  }
  38.4615384615% {
    transform: translateX(25vw) translateY(-44vh) scale(0.67);
  }
  42.3076923077% {
    transform: translateX(-40vw) translateY(16vh) scale(0.3);
  }
  46.1538461538% {
    transform: translateX(31vw) translateY(-40vh) scale(0.48);
  }
  50% {
    transform: translateX(-22vw) translateY(-25vh) scale(0.73);
  }
  53.8461538462% {
    transform: translateX(28vw) translateY(0vh) scale(0.53);
  }
  57.6923076923% {
    transform: translateX(-3vw) translateY(22vh) scale(0.38);
  }
  61.5384615385% {
    transform: translateX(16vw) translateY(37vh) scale(0.47);
  }
  65.3846153846% {
    transform: translateX(23vw) translateY(-45vh) scale(0.79);
  }
  69.2307692308% {
    transform: translateX(-9vw) translateY(-9vh) scale(0.99);
  }
  73.0769230769% {
    transform: translateX(-35vw) translateY(-26vh) scale(0.49);
  }
  76.9230769231% {
    transform: translateX(42vw) translateY(-25vh) scale(0.91);
  }
  80.7692307692% {
    transform: translateX(21vw) translateY(-39vh) scale(0.65);
  }
  84.6153846154% {
    transform: translateX(-27vw) translateY(-1vh) scale(0.44);
  }
  88.4615384615% {
    transform: translateX(31vw) translateY(29vh) scale(0.91);
  }
  92.3076923077% {
    transform: translateX(29vw) translateY(-43vh) scale(0.43);
  }
  96.1538461538% {
    transform: translateX(-13vw) translateY(-12vh) scale(0.27);
  }
  100% {
    transform: translateX(-1vw) translateY(45vh) scale(0.3);
  }
}
.firefly:nth-child(9) {
  animation-name: move9;
}
.firefly:nth-child(9)::before {
  animation-duration: 14s;
}
.firefly:nth-child(9)::after {
  animation-duration: 14s, 6652ms;
  animation-delay: 0ms, 8375ms;
}

@keyframes move9 {
  0% {
    transform: translateX(5vw) translateY(-49vh) scale(0.95);
  }
  5.8823529412% {
    transform: translateX(-5vw) translateY(23vh) scale(0.88);
  }
  11.7647058824% {
    transform: translateX(-32vw) translateY(-40vh) scale(0.75);
  }
  17.6470588235% {
    transform: translateX(44vw) translateY(20vh) scale(0.6);
  }
  23.5294117647% {
    transform: translateX(8vw) translateY(-18vh) scale(0.43);
  }
  29.4117647059% {
    transform: translateX(29vw) translateY(12vh) scale(0.35);
  }
  35.2941176471% {
    transform: translateX(13vw) translateY(40vh) scale(0.81);
  }
  41.1764705882% {
    transform: translateX(-28vw) translateY(-28vh) scale(0.73);
  }
  47.0588235294% {
    transform: translateX(27vw) translateY(-25vh) scale(0.29);
  }
  52.9411764706% {
    transform: translateX(-42vw) translateY(-35vh) scale(0.9);
  }
  58.8235294118% {
    transform: translateX(-20vw) translateY(-25vh) scale(0.31);
  }
  64.7058823529% {
    transform: translateX(25vw) translateY(8vh) scale(0.34);
  }
  70.5882352941% {
    transform: translateX(1vw) translateY(-17vh) scale(0.55);
  }
  76.4705882353% {
    transform: translateX(13vw) translateY(-13vh) scale(0.93);
  }
  82.3529411765% {
    transform: translateX(46vw) translateY(48vh) scale(0.54);
  }
  88.2352941176% {
    transform: translateX(18vw) translateY(43vh) scale(0.95);
  }
  94.1176470588% {
    transform: translateX(-1vw) translateY(-17vh) scale(0.83);
  }
  100% {
    transform: translateX(14vw) translateY(31vh) scale(0.65);
  }
}
.firefly:nth-child(10) {
  animation-name: move10;
}
.firefly:nth-child(10)::before {
  animation-duration: 11s;
}
.firefly:nth-child(10)::after {
  animation-duration: 11s, 6628ms;
  animation-delay: 0ms, 3186ms;
}

@keyframes move10 {
  0% {
    transform: translateX(-8vw) translateY(37vh) scale(0.5);
  }
  3.8461538462% {
    transform: translateX(42vw) translateY(-7vh) scale(0.96);
  }
  7.6923076923% {
    transform: translateX(8vw) translateY(40vh) scale(0.7);
  }
  11.5384615385% {
    transform: translateX(11vw) translateY(-33vh) scale(0.65);
  }
  15.3846153846% {
    transform: translateX(42vw) translateY(45vh) scale(0.54);
  }
  19.2307692308% {
    transform: translateX(35vw) translateY(-24vh) scale(0.27);
  }
  23.0769230769% {
    transform: translateX(-4vw) translateY(-22vh) scale(0.87);
  }
  26.9230769231% {
    transform: translateX(46vw) translateY(-15vh) scale(0.83);
  }
  30.7692307692% {
    transform: translateX(37vw) translateY(37vh) scale(0.33);
  }
  34.6153846154% {
    transform: translateX(45vw) translateY(37vh) scale(0.42);
  }
  38.4615384615% {
    transform: translateX(-31vw) translateY(-47vh) scale(0.74);
  }
  42.3076923077% {
    transform: translateX(-26vw) translateY(-24vh) scale(0.84);
  }
  46.1538461538% {
    transform: translateX(-38vw) translateY(-13vh) scale(0.82);
  }
  50% {
    transform: translateX(28vw) translateY(-37vh) scale(0.52);
  }
  53.8461538462% {
    transform: translateX(42vw) translateY(-1vh) scale(0.79);
  }
  57.6923076923% {
    transform: translateX(34vw) translateY(3vh) scale(0.49);
  }
  61.5384615385% {
    transform: translateX(-27vw) translateY(41vh) scale(0.81);
  }
  65.3846153846% {
    transform: translateX(36vw) translateY(-34vh) scale(0.63);
  }
  69.2307692308% {
    transform: translateX(-6vw) translateY(29vh) scale(0.58);
  }
  73.0769230769% {
    transform: translateX(41vw) translateY(15vh) scale(0.82);
  }
  76.9230769231% {
    transform: translateX(8vw) translateY(-21vh) scale(0.52);
  }
  80.7692307692% {
    transform: translateX(-33vw) translateY(-43vh) scale(0.47);
  }
  84.6153846154% {
    transform: translateX(-28vw) translateY(-18vh) scale(0.68);
  }
  88.4615384615% {
    transform: translateX(40vw) translateY(27vh) scale(0.53);
  }
  92.3076923077% {
    transform: translateX(-49vw) translateY(-26vh) scale(0.48);
  }
  96.1538461538% {
    transform: translateX(-47vw) translateY(14vh) scale(0.41);
  }
  100% {
    transform: translateX(39vw) translateY(30vh) scale(0.97);
  }
}
.firefly:nth-child(11) {
  animation-name: move11;
}
.firefly:nth-child(11)::before {
  animation-duration: 11s;
}
.firefly:nth-child(11)::after {
  animation-duration: 11s, 10175ms;
  animation-delay: 0ms, 2857ms;
}

@keyframes move11 {
  0% {
    transform: translateX(-7vw) translateY(-8vh) scale(0.34);
  }
  5.5555555556% {
    transform: translateX(28vw) translateY(-27vh) scale(0.84);
  }
  11.1111111111% {
    transform: translateX(-5vw) translateY(-26vh) scale(0.49);
  }
  16.6666666667% {
    transform: translateX(46vw) translateY(-2vh) scale(0.78);
  }
  22.2222222222% {
    transform: translateX(-39vw) translateY(-11vh) scale(0.45);
  }
  27.7777777778% {
    transform: translateX(-43vw) translateY(-46vh) scale(0.98);
  }
  33.3333333333% {
    transform: translateX(26vw) translateY(-39vh) scale(0.75);
  }
  38.8888888889% {
    transform: translateX(1vw) translateY(-34vh) scale(0.76);
  }
  44.4444444444% {
    transform: translateX(1vw) translateY(-28vh) scale(0.77);
  }
  50% {
    transform: translateX(-31vw) translateY(-32vh) scale(0.54);
  }
  55.5555555556% {
    transform: translateX(13vw) translateY(50vh) scale(0.65);
  }
  61.1111111111% {
    transform: translateX(-38vw) translateY(11vh) scale(0.58);
  }
  66.6666666667% {
    transform: translateX(-18vw) translateY(1vh) scale(0.57);
  }
  72.2222222222% {
    transform: translateX(-19vw) translateY(36vh) scale(0.41);
  }
  77.7777777778% {
    transform: translateX(-46vw) translateY(46vh) scale(0.73);
  }
  83.3333333333% {
    transform: translateX(16vw) translateY(25vh) scale(0.66);
  }
  88.8888888889% {
    transform: translateX(48vw) translateY(20vh) scale(0.62);
  }
  94.4444444444% {
    transform: translateX(-31vw) translateY(-26vh) scale(0.9);
  }
  100% {
    transform: translateX(28vw) translateY(45vh) scale(0.74);
  }
}
.firefly:nth-child(12) {
  animation-name: move12;
}
.firefly:nth-child(12)::before {
  animation-duration: 11s;
}
.firefly:nth-child(12)::after {
  animation-duration: 11s, 8912ms;
  animation-delay: 0ms, 4222ms;
}

@keyframes move12 {
  0% {
    transform: translateX(11vw) translateY(8vh) scale(0.61);
  }
  4.347826087% {
    transform: translateX(-13vw) translateY(-34vh) scale(0.6);
  }
  8.6956521739% {
    transform: translateX(-44vw) translateY(-48vh) scale(0.65);
  }
  13.0434782609% {
    transform: translateX(-28vw) translateY(36vh) scale(0.89);
  }
  17.3913043478% {
    transform: translateX(-22vw) translateY(44vh) scale(0.58);
  }
  21.7391304348% {
    transform: translateX(2vw) translateY(32vh) scale(0.88);
  }
  26.0869565217% {
    transform: translateX(38vw) translateY(38vh) scale(0.65);
  }
  30.4347826087% {
    transform: translateX(6vw) translateY(-26vh) scale(1);
  }
  34.7826086957% {
    transform: translateX(25vw) translateY(45vh) scale(0.66);
  }
  39.1304347826% {
    transform: translateX(-21vw) translateY(-38vh) scale(0.39);
  }
  43.4782608696% {
    transform: translateX(12vw) translateY(38vh) scale(0.3);
  }
  47.8260869565% {
    transform: translateX(29vw) translateY(-3vh) scale(0.71);
  }
  52.1739130435% {
    transform: translateX(13vw) translateY(-34vh) scale(0.34);
  }
  56.5217391304% {
    transform: translateX(-16vw) translateY(-34vh) scale(0.37);
  }
  60.8695652174% {
    transform: translateX(-10vw) translateY(-47vh) scale(0.32);
  }
  65.2173913043% {
    transform: translateX(32vw) translateY(0vh) scale(0.79);
  }
  69.5652173913% {
    transform: translateX(-8vw) translateY(-40vh) scale(0.28);
  }
  73.9130434783% {
    transform: translateX(-36vw) translateY(17vh) scale(0.51);
  }
  78.2608695652% {
    transform: translateX(-23vw) translateY(-24vh) scale(0.56);
  }
  82.6086956522% {
    transform: translateX(34vw) translateY(27vh) scale(0.99);
  }
  86.9565217391% {
    transform: translateX(-33vw) translateY(10vh) scale(0.46);
  }
  91.3043478261% {
    transform: translateX(-2vw) translateY(-45vh) scale(0.37);
  }
  95.652173913% {
    transform: translateX(-46vw) translateY(-21vh) scale(0.42);
  }
  100% {
    transform: translateX(-7vw) translateY(-8vh) scale(0.79);
  }
}
.firefly:nth-child(13) {
  animation-name: move13;
}
.firefly:nth-child(13)::before {
  animation-duration: 13s;
}
.firefly:nth-child(13)::after {
  animation-duration: 13s, 7433ms;
  animation-delay: 0ms, 3757ms;
}

@keyframes move13 {
  0% {
    transform: translateX(-20vw) translateY(5vh) scale(0.45);
  }
  3.8461538462% {
    transform: translateX(7vw) translateY(44vh) scale(0.62);
  }
  7.6923076923% {
    transform: translateX(-27vw) translateY(48vh) scale(0.95);
  }
  11.5384615385% {
    transform: translateX(36vw) translateY(-48vh) scale(0.99);
  }
  15.3846153846% {
    transform: translateX(15vw) translateY(-44vh) scale(0.75);
  }
  19.2307692308% {
    transform: translateX(18vw) translateY(20vh) scale(0.94);
  }
  23.0769230769% {
    transform: translateX(16vw) translateY(43vh) scale(0.63);
  }
  26.9230769231% {
    transform: translateX(-33vw) translateY(-30vh) scale(0.32);
  }
  30.7692307692% {
    transform: translateX(5vw) translateY(23vh) scale(0.61);
  }
  34.6153846154% {
    transform: translateX(-38vw) translateY(28vh) scale(0.87);
  }
  38.4615384615% {
    transform: translateX(32vw) translateY(-23vh) scale(0.34);
  }
  42.3076923077% {
    transform: translateX(-41vw) translateY(-25vh) scale(0.91);
  }
  46.1538461538% {
    transform: translateX(-20vw) translateY(42vh) scale(0.41);
  }
  50% {
    transform: translateX(-37vw) translateY(-7vh) scale(0.91);
  }
  53.8461538462% {
    transform: translateX(-11vw) translateY(20vh) scale(0.39);
  }
  57.6923076923% {
    transform: translateX(-5vw) translateY(17vh) scale(0.74);
  }
  61.5384615385% {
    transform: translateX(-49vw) translateY(5vh) scale(0.81);
  }
  65.3846153846% {
    transform: translateX(-12vw) translateY(-48vh) scale(0.73);
  }
  69.2307692308% {
    transform: translateX(31vw) translateY(34vh) scale(0.34);
  }
  73.0769230769% {
    transform: translateX(-49vw) translateY(-48vh) scale(0.31);
  }
  76.9230769231% {
    transform: translateX(-11vw) translateY(10vh) scale(0.67);
  }
  80.7692307692% {
    transform: translateX(-24vw) translateY(30vh) scale(0.31);
  }
  84.6153846154% {
    transform: translateX(-36vw) translateY(-30vh) scale(0.63);
  }
  88.4615384615% {
    transform: translateX(8vw) translateY(16vh) scale(0.47);
  }
  92.3076923077% {
    transform: translateX(-36vw) translateY(-18vh) scale(0.4);
  }
  96.1538461538% {
    transform: translateX(22vw) translateY(-34vh) scale(0.7);
  }
  100% {
    transform: translateX(-9vw) translateY(2vh) scale(0.92);
  }
}
.firefly:nth-child(14) {
  animation-name: move14;
}
.firefly:nth-child(14)::before {
  animation-duration: 18s;
}
.firefly:nth-child(14)::after {
  animation-duration: 18s, 7067ms;
  animation-delay: 0ms, 1649ms;
}

@keyframes move14 {
  0% {
    transform: translateX(28vw) translateY(10vh) scale(0.36);
  }
  5.5555555556% {
    transform: translateX(-18vw) translateY(26vh) scale(0.59);
  }
  11.1111111111% {
    transform: translateX(30vw) translateY(-23vh) scale(0.31);
  }
  16.6666666667% {
    transform: translateX(-12vw) translateY(-11vh) scale(0.52);
  }
  22.2222222222% {
    transform: translateX(16vw) translateY(-29vh) scale(0.71);
  }
  27.7777777778% {
    transform: translateX(2vw) translateY(-23vh) scale(0.7);
  }
  33.3333333333% {
    transform: translateX(-42vw) translateY(-23vh) scale(0.96);
  }
  38.8888888889% {
    transform: translateX(-5vw) translateY(-19vh) scale(0.7);
  }
  44.4444444444% {
    transform: translateX(-38vw) translateY(14vh) scale(0.39);
  }
  50% {
    transform: translateX(-30vw) translateY(4vh) scale(0.27);
  }
  55.5555555556% {
    transform: translateX(18vw) translateY(-36vh) scale(0.5);
  }
  61.1111111111% {
    transform: translateX(-3vw) translateY(0vh) scale(0.37);
  }
  66.6666666667% {
    transform: translateX(-7vw) translateY(-20vh) scale(0.95);
  }
  72.2222222222% {
    transform: translateX(-34vw) translateY(-8vh) scale(0.73);
  }
  77.7777777778% {
    transform: translateX(20vw) translateY(-39vh) scale(0.61);
  }
  83.3333333333% {
    transform: translateX(5vw) translateY(15vh) scale(0.67);
  }
  88.8888888889% {
    transform: translateX(18vw) translateY(38vh) scale(0.78);
  }
  94.4444444444% {
    transform: translateX(22vw) translateY(-38vh) scale(0.31);
  }
  100% {
    transform: translateX(0vw) translateY(-26vh) scale(0.29);
  }
}
.firefly:nth-child(15) {
  animation-name: move15;
}
.firefly:nth-child(15)::before {
  animation-duration: 17s;
}
.firefly:nth-child(15)::after {
  animation-duration: 17s, 9268ms;
  animation-delay: 0ms, 2464ms;
}

@keyframes move15 {
  0% {
    transform: translateX(34vw) translateY(35vh) scale(0.53);
  }
  3.5714285714% {
    transform: translateX(48vw) translateY(-33vh) scale(0.78);
  }
  7.1428571429% {
    transform: translateX(6vw) translateY(-13vh) scale(0.72);
  }
  10.7142857143% {
    transform: translateX(35vw) translateY(-23vh) scale(0.65);
  }
  14.2857142857% {
    transform: translateX(41vw) translateY(-10vh) scale(0.41);
  }
  17.8571428571% {
    transform: translateX(49vw) translateY(-2vh) scale(0.61);
  }
  21.4285714286% {
    transform: translateX(-14vw) translateY(-11vh) scale(0.7);
  }
  25% {
    transform: translateX(26vw) translateY(-28vh) scale(0.81);
  }
  28.5714285714% {
    transform: translateX(17vw) translateY(-25vh) scale(0.44);
  }
  32.1428571429% {
    transform: translateX(21vw) translateY(40vh) scale(0.38);
  }
  35.7142857143% {
    transform: translateX(-40vw) translateY(7vh) scale(0.71);
  }
  39.2857142857% {
    transform: translateX(50vw) translateY(1vh) scale(0.33);
  }
  42.8571428571% {
    transform: translateX(0vw) translateY(44vh) scale(0.62);
  }
  46.4285714286% {
    transform: translateX(-39vw) translateY(44vh) scale(0.37);
  }
  50% {
    transform: translateX(-12vw) translateY(-36vh) scale(0.85);
  }
  53.5714285714% {
    transform: translateX(-16vw) translateY(-30vh) scale(0.41);
  }
  57.1428571429% {
    transform: translateX(25vw) translateY(46vh) scale(0.96);
  }
  60.7142857143% {
    transform: translateX(28vw) translateY(-28vh) scale(0.73);
  }
  64.2857142857% {
    transform: translateX(-34vw) translateY(22vh) scale(0.49);
  }
  67.8571428571% {
    transform: translateX(-49vw) translateY(1vh) scale(0.44);
  }
  71.4285714286% {
    transform: translateX(-30vw) translateY(-25vh) scale(0.77);
  }
  75% {
    transform: translateX(-3vw) translateY(-31vh) scale(0.59);
  }
  78.5714285714% {
    transform: translateX(28vw) translateY(-3vh) scale(0.64);
  }
  82.1428571429% {
    transform: translateX(-5vw) translateY(-40vh) scale(0.85);
  }
  85.7142857143% {
    transform: translateX(9vw) translateY(-1vh) scale(0.38);
  }
  89.2857142857% {
    transform: translateX(23vw) translateY(-13vh) scale(0.45);
  }
  92.8571428571% {
    transform: translateX(-41vw) translateY(38vh) scale(0.9);
  }
  96.4285714286% {
    transform: translateX(5vw) translateY(41vh) scale(0.56);
  }
  100% {
    transform: translateX(20vw) translateY(6vh) scale(0.55);
  }
}
@keyframes drift {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes flash {
  0%, 30%, 100% {
    opacity: 0;
    box-shadow: 0 0 0vw 0vw yellow;
  }
  5% {
    opacity: 1;
    box-shadow: 0 0 2vw 0.4vw yellow;
  }
}