.loader_wrapper {
    height: 100%;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    background-color: #fff;
    z-index: 11;
    top: 0
}

.loader_wrapper svg {
    width: 0;
    height: 0
}

.loader_wrapper .loader_index {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    filter: url(#loader_filter)
}

.loader_wrapper .loader_index:after {
    content: "";
    width: 4em;
    height: 4em;
    background: #7bb74b;
    border-radius: 50%;
    position: absolute;
    transform: scale(0.5);
    animation: grow 2s cubic-bezier(0.14, 0.05, 0.55, 0.5) infinite alternate
}

.loader_wrapper .loader_index span {
    width: 2em;
    height: 2em;
    background: #f3a53b;
    border-radius: 50%;
    margin-right: 2em;
    position: relative;
    transform: translateX(7em);
    animation: move 4s ease-in-out infinite
}

.loader_wrapper .loader_index span:before {
    content: "";
    width: 2em;
    height: 2em;
    background: #7bb74b;
    border-radius: 50%;
    position: absolute;
    left: 3em;
    transform: translateX(0em);
    animation: shrink 2s ease-in-out infinite
}

.loader_wrapper .loader_index span:after {
    content: "";
    width: 2em;
    height: 2em;
    background: #f07171;
    border-radius: 50%;
    position: absolute;
    right: 3em;
    transform: translateX(0em);
    animation: shrink 2s ease-in-out infinite
}

@keyframes grow {
    0% {
        transform: scale(0.5);
        background: #f07171
    }
    50% {
        transform: scale(1);
        background: #f3a53b
    }
}

@keyframes move {
    0% {
        transform: translateX(7em)
    }
    50% {
        transform: translateX(-5em)
    }
}

@keyframes shrink {
    0% {
        transform: translateX(0em)
    }
    50% {
        transform: translateX(-1em)
    }
}

.loader_wrapper.loderhide {
    display: none
}