div.preloader {
    padding: 0;
    width: 100%;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 140;
    backdrop-filter: blur(9px);
    -webkit-backdrop-filter: blur(9px);
}

div.preloader h3 {
    margin-top: 1vw;
    animation: animate-title-loader 1s ease-in-out infinite;
}

@keyframes animate-title-loader {
    0%{opacity: 0.5}
    50%{opacity: 1}
    100%{opacity: 0.5}
}

.lds-roller {
    display: inline-block;
    position: relative;
    width: 80px;
    height: 80px;
}

.lds-roller div {
    animation: lds-roller 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;
    transform-origin: 40px 40px;
}

.lds-roller div:after {
    content: " ";
    display: block;
    position: absolute;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: linear-gradient(15deg, var(--green), var(--green), var(--green));
    margin: -4px 0 0 -4px;
}

.lds-roller div:nth-child(1) {
    animation-delay: -0.036s;
}

.lds-roller div:nth-child(1):after {
    top: 63px;
    left: 63px;
}

.lds-roller div:nth-child(2) {
    animation-delay: -0.072s;
}

.lds-roller div:nth-child(2):after {
    top: 68px;
    left: 56px;
}

.lds-roller div:nth-child(3) {
    animation-delay: -0.108s;
}

.lds-roller div:nth-child(3):after {
    top: 71px;
    left: 48px;
}

.lds-roller div:nth-child(4) {
    animation-delay: -0.144s;
}

.lds-roller div:nth-child(4):after {
    top: 72px;
    left: 40px;
}

.lds-roller div:nth-child(5) {
    animation-delay: -0.18s;
}

.lds-roller div:nth-child(5):after {
    top: 71px;
    left: 32px;
}

.lds-roller div:nth-child(6) {
    animation-delay: -0.216s;
}

.lds-roller div:nth-child(6):after {
    top: 68px;
    left: 24px;
}

.lds-roller div:nth-child(7) {
    animation-delay: -0.252s;
}

.lds-roller div:nth-child(7):after {
    top: 63px;
    left: 17px;
}

.lds-roller div:nth-child(8) {
    animation-delay: -0.288s;
}

.lds-roller div:nth-child(8):after {
    top: 56px;
    left: 12px;
}


/**/
div.preloader h1 {
    margin: 0;
    padding: 0;
    font-family: Roboto, sans-serif;
    letter-spacing: 1px;
    font-size: 1.1em;
    color: var(--light-font);
    position: relative;
    top: -5%;
}

body.light div.preloader h1 {
    color: var(--dark-font);
}

div.preloader span {
    position: relative;
    top: 0.63em;
    display: inline-block;
    text-transform: uppercase;
    opacity: 0;
    transform: rotateX(-90deg);
}

div.preloader .let1 {
    animation: drop 1.2s ease-in-out infinite;
    animation-delay: 0.2s;
}

div.preloader .let2 {
    animation: drop 1.2s ease-in-out infinite;
    animation-delay: 0.3s;
}

div.preloader .let3 {
    animation: drop 1.2s ease-in-out infinite;
    animation-delay: 0.4s;
}

div.preloader .let4 {
    animation: drop 1.2s ease-in-out infinite;
    animation-delay: 0.5s;

}

div.preloader .let5 {
    animation: drop 1.2s ease-in-out infinite;
    animation-delay: 0.6s;
}

div.preloader .let6 {
    animation: drop 1.2s ease-in-out infinite;
    animation-delay: 0.7s;
}

div.preloader .let7 {
    animation: drop 1.2s ease-in-out infinite;
    animation-delay: 0.8s;
}


@keyframes lds-roller {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

@keyframes drop {
    10% {
        opacity: 0.5;
    }
    20% {
        opacity: 1;
        top: 3.78em;
        transform: rotateX(-360deg);
    }
    80% {
        opacity: 1;
        top: 3.78em;
        transform: rotateX(-360deg);
    }
    90% {
        opacity: 0.5;
    }
    100% {
        opacity: 0;
        top: 6.94em
    }
}

@media screen and (max-width: 992px) {

    div.preloader {
        margin-top: 50px;
    }

    div.preloader {
        height: 105vh;
    }

    .lds-roller {
        transform: translateY(-20vw);
    }

    .lds-roller div:after {
        box-shadow: 0 0 6px rgba(0, 0, 0, 0.4);
    }

    div.preloader h3 {
        font-size: 15px!important;
        top: 0;
        transform: translateY(-10vw);
    }
}