/* =============================================================
   MyProduction — Preloader
   Fichier : css/preloader.css
   À enqueue dans functions.php via wp_enqueue_style()
   ============================================================= */

/* ── Variables ──────────────────────────────────────────────── */
:root {
    --mpl-bg:        #0e0320;
    --mpl-accent:    #53FF03;
    --mpl-purple:    #7b3fff;
    --mpl-text:      rgba(255, 255, 255, 0.82);
    --mpl-bar-h:     3px;
    --mpl-bar-r:     999px;
    --mpl-duration:  0.9s;
    --mpl-ease:      cubic-bezier(0.22, 1, 0.36, 1);
}

/* ── Lock scroll pendant chargement ────────────────────────── */
body.mpl-loading {
    overflow: hidden;
    height: 100vh;
}

/* ── Overlay principal ──────────────────────────────────────── */
#myprod-preloader {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: all;

    /* Sortie : slide-up + fade */
    transition:
        opacity   0.55s var(--mpl-ease),
        transform 0.75s var(--mpl-ease);
    will-change: opacity, transform;
}

#myprod-preloader.is-done {
    opacity: 0;
    transform: translateY(-6px);
    pointer-events: none;
}

/* ── Fond dégradé ────────────────────────────────────────────── */
.mpl-bg {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 80% 60% at 70% 10%,  rgba(116, 59, 255, 0.28) 0%, transparent 65%),
        radial-gradient(ellipse 60% 50% at 15% 90%,  rgba(83, 255, 3,   0.10) 0%, transparent 55%),
        #0e0320;
    z-index: 0;
}

/* ── Grain ───────────────────────────────────────────────────── */
.mpl-grain {
    position: absolute;
    inset: -50%;
    width: 200%;
    height: 200%;
    z-index: 1;
    opacity: 0.045;
    pointer-events: none;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    background-size: 256px 256px;
    animation: mpl-grain-drift 7s steps(10) infinite;
}

@keyframes mpl-grain-drift {
    0%   { transform: translate(0, 0); }
    10%  { transform: translate(-3%, -5%); }
    20%  { transform: translate(-6%,  2%); }
    30%  { transform: translate( 4%, -4%); }
    40%  { transform: translate(-4%,  6%); }
    50%  { transform: translate(-6%, -2%); }
    60%  { transform: translate( 3%,  5%); }
    70%  { transform: translate( 5%, -3%); }
    80%  { transform: translate(-3%,  3%); }
    90%  { transform: translate( 4%, -1%); }
    100% { transform: translate(0,   0);  }
}

/* ── Contenu central ─────────────────────────────────────────── */
.mpl-inner {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    width: min(480px, 88vw);
}

/* ── Logo ─────────────────────────────────────────────────────── */
.mpl-logo {
    display: flex;
    align-items: center;
    justify-content: center;

    /* Entrée : fade + slide depuis le bas */
    opacity: 0;
    transform: translateY(18px);
    animation: mpl-reveal 0.75s var(--mpl-ease) 0.1s forwards;
}

.mpl-logo img {
    max-width: 200px;
    max-height: 72px;
    width: auto;
    height: auto;
    object-fit: contain;
    filter: brightness(0) invert(1); /* blanc par défaut */
}

.mpl-logo__text {
    font-family: "Vend Sans", sans-serif;
    font-size: clamp(1.8rem, 5vw, 2.8rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #fff;
    text-transform: uppercase;
}

/* ── Barre de progression ─────────────────────────────────────── */
.mpl-bar-wrap {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 14px;
    align-items: center;

    opacity: 0;
    transform: translateY(12px);
    animation: mpl-reveal 0.7s var(--mpl-ease) 0.28s forwards;
}

.mpl-bar {
    position: relative;
    width: 100%;
    height: var(--mpl-bar-h);
    border-radius: var(--mpl-bar-r);
    background: rgba(255, 255, 255, 0.10);
    overflow: visible;
}

/* Fond animé "shimmer" de la barre vide */
.mpl-bar::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: rgba(255, 255, 255, 0.06);
    animation: mpl-shimmer 2.2s ease-in-out infinite;
}

@keyframes mpl-shimmer {
    0%, 100% { opacity: 0.5; }
    50%       { opacity: 1;   }
}

/* Remplissage */
.mpl-bar__fill {
    position: absolute;
    left: 0; top: 0;
    height: 100%;
    width: 0%;
    border-radius: var(--mpl-bar-r);
    background: linear-gradient(90deg, #53FF03 0%, #a0ff60 100%);
    transition: width 0.32s cubic-bezier(0.34, 1.56, 0.64, 1);
    will-change: width;
}

/* Lueur verte sur la barre */
.mpl-bar__glow {
    position: absolute;
    left: 0; top: 50%;
    transform: translateY(-50%);
    height: 14px;
    width: var(--mpl-glow-w, 0%);
    border-radius: var(--mpl-bar-r);
    background: rgba(83, 255, 3, 0.35);
    filter: blur(8px);
    pointer-events: none;
    transition: width 0.32s cubic-bezier(0.34, 1.56, 0.64, 1);
    will-change: width;
}

/* Pourcentage */
.mpl-percent {
    font-family: "Vend Sans", sans-serif;
    font-size: 1.15rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--mpl-accent);
    min-width: 3ch;
    text-align: center;
    font-variant-numeric: tabular-nums;
}

/* ── Label ────────────────────────────────────────────────────── */
.mpl-label {
    margin: 0;
    font-size: 0.85rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.38);
    font-weight: 500;

    opacity: 0;
    animation: mpl-reveal 0.7s var(--mpl-ease) 0.42s forwards;
}

/* Pulse sur le label quand chargement en cours */
.mpl-label.is-loading {
    animation: mpl-reveal 0.7s var(--mpl-ease) 0.42s forwards,
               mpl-pulse 2.4s ease-in-out 1.2s infinite;
}

@keyframes mpl-pulse {
    0%, 100% { opacity: 0.38; }
    50%       { opacity: 0.70; }
}

/* ── Keyframe reveal partagé ──────────────────────────────────── */
@keyframes mpl-reveal {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ── Responsive ───────────────────────────────────────────────── */
@media (max-width: 480px) {
    .mpl-inner {
        gap: 32px;
    }

    .mpl-logo img {
        max-width: 150px;
        max-height: 56px;
    }

    .mpl-logo__text {
        font-size: 1.6rem;
    }

    .mpl-percent {
        font-size: 1rem;
    }

    .mpl-label {
        font-size: 0.78rem;
        letter-spacing: 0.08em;
    }
}