/* HTML: <div class="loader"></div> */
.loader-overlay-container {
    display: none;
}

.loading-messages {
    display: block;
    position: absolute;
    top: 52vh;
    left: 50%;
    transform: translateX(-50%);
    z-index: 100;
    font-weight: bold;
}

@media(min-width: 768px) {
    .loading-messages {
        white-space: nowrap;
    }
}

.loader-overlay-container.visible {
    display: block;
}

.loader {
    position: absolute;
    top: 45%;
    left: 50%;
    z-index: 100;
    margin-left: -25px;
    width: 50px;
    aspect-ratio: 1;
    display: grid;
    border: 4px solid #0000;
    border-radius: 50%;
    border-right-color: var(--black);
    animation: l15 1s infinite linear;
}
.loader::before,
.loader::after {
    content: "";
    grid-area: 1/1;
    margin: 2px;
    border: inherit;
    border-radius: 50%;
    animation: l15 2s infinite;
}
.loader::after {
    margin: 8px;
    animation-duration: 3s;
}
@keyframes l15{
    100%{transform: rotate(1turn)}
}

.overlay {
    position: absolute;
    z-index: 99;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255,255,255, .6);
}
