/*
 * preloader.css — Natoya Goule Theme
 * Loaded first on every page. Isolated from main.css.
 * Controls the full-screen cinematic preloader.
 */

/* ── LOCK SCROLL WHILE LOADING ── */
html.ng-loading {
    overflow: hidden !important;
}

/* ── PRELOADER CONTAINER ── */
#ng-preloader {
    position: fixed;
    inset: 0;
    z-index: 9990;
    background: #080808;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    /* Exit transition — triggered by JS adding .ng-preloader-done */
    transition: opacity 1.2s cubic-bezier(0.16, 1, 0.3, 1) 0.4s,
                visibility 1.2s linear 0.4s;
}

#ng-preloader.ng-preloader-done {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

/* ── INNER WRAP (rings + logo centered) ── */
.pl-wrap {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: clamp(260px, 38vw, 420px);
    height: clamp(260px, 38vw, 420px);
}

/* ── RINGS ── */
.pl-rings {
    position: absolute;
    inset: 0;
}

.pl-ring {
    position: absolute;
    border-radius: 50%;
    border: 1px solid rgba(255, 119, 94, 0);
    animation: ngRingIn 1s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.pl-ring--1 { inset: 0;    animation-delay: 0.25s; }
.pl-ring--2 { inset: 20px; animation-delay: 0.42s; }
.pl-ring--3 { inset: 40px; animation-delay: 0.58s; }

@keyframes ngRingIn {
    0%   { border-color: rgba(255, 119, 94, 0);    transform: scale(0.82); }
    55%  { border-color: rgba(255, 119, 94, 0.32); }
    100% { border-color: rgba(255, 119, 94, 0.09); transform: scale(1); }
}

/* ── SPINNING ARC ── */
.pl-arc {
    position: absolute;
    inset: -28px;
    border-radius: 50%;
    border: 1px solid transparent;
    border-top:   1px solid #FF775E;
    border-right: 1px solid rgba(255, 119, 94, 0.28);
    opacity: 0;
    animation:
        ngArcAppear 0.5s ease 0.6s forwards,
        ngArcSpin   2s linear 0.6s infinite;
}

@keyframes ngArcAppear { to { opacity: 1; } }
@keyframes ngArcSpin   { to { transform: rotate(360deg); } }

/* ── LOGO INSIDE RINGS ── */
.pl-logo {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: clamp(160px, 22vw, 280px);
}

/* If WP custom logo image */
.pl-logo-img,
.pl-logo .custom-logo {
    width: 100%;
    height: auto;
    /* Invert to white — remove if logo is already light */
    filter: brightness(0) invert(1);
    opacity: 0;
    animation: ngLogoReveal 0.8s ease 0.9s forwards;
    display: block;
}

/* Text fallback logo */
.pl-logo-text {
    font-family: 'Josefin Sans', sans-serif;
    font-size: clamp(22px, 4vw, 38px);
    font-weight: 700;
    letter-spacing: 8px;
    text-transform: uppercase;
    color: #F5F0EA;
    opacity: 0;
    animation: ngLogoReveal 0.8s ease 0.9s forwards;
    white-space: nowrap;
}
.pl-logo-text span {
    color: #FF775E;
}

@keyframes ngLogoReveal {
    0%   { opacity: 0; transform: translateY(8px); }
    100% { opacity: 1; transform: translateY(0); }
}

/* ── TAGLINE ── */
.pl-tagline {
    position: relative;
    z-index: 2;
    margin-top: clamp(52px, 9vw, 88px);
    font-family: 'Josefin Sans', sans-serif;
    font-size: clamp(10px, 1vw, 12px);
    letter-spacing: 6px;
    text-transform: uppercase;
    color: rgba(245, 240, 234, 0.28);
    opacity: 0;
    animation: ngFadeUp 0.8s ease 1.5s forwards;
}

/* ── PROGRESS BAR ── */
.pl-bar-wrap {
    position: absolute;
    bottom: clamp(44px, 6vh, 72px);
    left: 50%;
    transform: translateX(-50%);
    width: clamp(160px, 24vw, 240px);
    height: 1px;
    background: rgba(255, 119, 94, 0.1);
}

.pl-bar {
    height: 100%;
    width: 0;
    background: linear-gradient(to right, #FF775E, #DB6923);
    transition: width 0.1s linear;
}

.pl-pct {
    position: absolute;
    right: 0;
    top: -26px;
    font-family: 'Josefin Sans', sans-serif;
    font-size: clamp(9px, 0.8vw, 11px);
    letter-spacing: 3px;
    color: #FF775E;
    opacity: 0;
    animation: ngFadeUp 0.4s ease 0.65s forwards;
}

/* ── KEYFRAMES ── */
@keyframes ngFadeUp {
    0%   { opacity: 0; transform: translateY(8px); }
    100% { opacity: 1; transform: translateY(0); }
}

/* ── SITE WRAPPER — hidden until preloader done ── */
#ng-site {
    opacity: 0;
    transition: opacity 0.9s ease;
}

#ng-site.ng-site-visible {
    opacity: 1;
}

/* ── RESPONSIVE ── */
@media (max-width: 480px) {
    .pl-wrap {
        width: 280px;
        height: 280px;
    }
    .pl-logo-text {
        font-size: 20px;
        letter-spacing: 5px;
    }
}
