/* ══════════════════════════════════════════════════════════
   Dango Utils — Loader de Carga | Front CSS
   ══════════════════════════════════════════════════════════ */

.dango-page-loader {
    position: fixed;
    inset: 0;
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #ffffff;
    opacity: 1;
    visibility: visible;
    transition: opacity .35s ease, visibility 0s linear 0s;
}

.dango-page-loader.is-hidden {
    opacity: 0;
    visibility: hidden;
    transition: opacity .35s ease, visibility 0s linear .35s;
    pointer-events: none;
}

.dango-page-loader__spinner {
    position: relative;
    width: calc(var(--dango-pl-logo-size, 46px) + 26px);
    height: calc(var(--dango-pl-logo-size, 46px) + 26px);
    border: 3px solid rgba(0, 0, 0, 0.08);
    border-top-color: #b1060b;
    border-radius: 50%;
    animation: dango-page-loader-spin 0.9s linear infinite;
    flex: 0 0 auto;
}

.dango-page-loader__logo {
    position: absolute;
    top: 50%;
    left: 50%;
    width: var(--dango-pl-logo-size, 46px);
    height: var(--dango-pl-logo-size, 46px);
    transform: translate(-50%, -50%);
    object-fit: contain;
    opacity: var(--dango-pl-logo-opacity, 0.45);
    filter: grayscale(var(--dango-pl-logo-grayscale, 0.33));
    pointer-events: none;
}

@keyframes dango-page-loader-spin {
    to { transform: rotate(360deg); }
}

@media (prefers-reduced-motion: reduce) {
    .dango-page-loader__spinner { animation-duration: 1.8s; }
    .dango-page-loader { transition: opacity .01s linear; }
}
