/* ─── Loading screen shell ─────────────────────────────────────────── */

#loading-screen > * {
    position: absolute;
    z-index: 1000;
}

#loading-screen {
    position: absolute;
    left: 50%;
    top: 50%;
    touch-action: none;
    pointer-events: auto;
    user-select: none;
}

/* Full-viewport black backdrop */
#loading-screen-black {
    position: absolute;
    width: 100vw;
    height: 100vh;
    transform: translate(-50%, -50%);
    background: #2B0A2A;
}

/* ─── Scaled background panel ──────────────────────────────────────── */

#loading-screen-background {
    --scaleX: calc(var(--totalWidth) / var(--width));
    --scaleY: calc(var(--totalHeight) / var(--height));
    --scale: min(var(--scaleX), var(--scaleY));
    --finalWidth: min(var(--background-size), calc(var(--totalWidth) / var(--scale)));
    --finalHeight: min(var(--background-size), calc(var(--totalHeight) / var(--scale)));

    width: calc(1px * var(--finalWidth));
    height: calc(1px * var(--finalHeight));
    transform: scale(var(--scale), var(--scale));
    transform-origin: center center;
    position: absolute;
    left: calc(1px * calc(var(--finalWidth) / -2));
    top: calc(1px * calc(var(--finalHeight) / -2));

    background-image: -webkit-image-set(
            url("assets_gamestone/gj_bg_landscape.webp") type("image/webp"),
            url("assets_gamestone/gj_bg_landscape.png") type("image/png")
    );
    background-image: image-set(
            url("assets_gamestone/gj_bg_landscape.webp") type("image/webp"),
            url("assets_gamestone/gj_bg_landscape.png") type("image/png")
    );
    background-repeat: no-repeat;
    background-size: calc(1px * var(--background-size));

    /* Fade all four edges to transparent over 20px */
    -webkit-mask-image:
        linear-gradient(to right,  transparent 0px, black 20px, black calc(100% - 20px), transparent 100%);
    -webkit-mask-composite: source-in;

    mask-image:
        linear-gradient(to right,  transparent 0px, black 20px, black calc(100% - 20px), transparent 100%);
    mask-composite: intersect;
}

@media (orientation: portrait) {
    #loading-screen-background {
        --width: 1080;
        --height: 1920;
        --background-size: 2800;
        background-position: center center;
    }
}

@media (orientation: landscape) {
    #loading-screen-background {
        --width: 1920;
        --height: 1080;
        --background-size: 2800;
        background-position: center center;
    }
}

/* ─── YGG logo ─────────────────────────────────────────────────────── */

#loading-screen-ygg-logo {
    position: absolute;
}

@media (orientation: portrait) {
    #loading-screen-ygg-logo {
        width: 491px;
        height: 122px;
        left: 50%;
        top: calc(50% + 760px);
        transform: translate(-50%, -50%);
        background-image: -webkit-image-set(
                url("assets_gamestone/ygg_logo_portrait.webp") type("image/webp"),
                url("assets_gamestone/ygg_logo_portrait.png") type("image/png")
        );
        background-image: image-set(
                url("assets_gamestone/ygg_logo_portrait.webp") type("image/webp"),
                url("assets_gamestone/ygg_logo_portrait.png") type("image/png")
        );
        background-repeat: no-repeat;
        background-size: contain;
    }
}

@media (orientation: landscape) {
    #loading-screen-ygg-logo {
        width: 92px;
        height: 95px;
        left: 100px;
        top: 100px;
        transform: translate(-50%, -50%);
        background-image: -webkit-image-set(
                url("assets_gamestone/ygg_logo_landscape.webp") type("image/webp"),
                url("assets_gamestone/ygg_logo_landscape.png") type("image/png")
        );
        background-image: image-set(
                url("assets_gamestone/ygg_logo_landscape.webp") type("image/webp"),
                url("assets_gamestone/ygg_logo_landscape.png") type("image/png")
        );
        background-repeat: no-repeat;
        background-size: contain;
    }
}

/* ─── Float animation ──────────────────────────────────────────────── */

@keyframes logo-float {
    0%   { transform: translate(-50%, -50%); }
    50%  { transform: translate(-50%, calc(-50% - 18px)); }
    100% { transform: translate(-50%, -50%); }
}

/* ─── Game logo ────────────────────────────────────────────────────── */

#loading-screen-logo {
    position: absolute;
    left: 50%;
    width: 1116px;
    height: 700px;
    background-image: -webkit-image-set(
            url("assets_gamestone/GJ_logo.webp") type("image/webp"),
            url("assets_gamestone/GJ_logo.png") type("image/png")
    );
    background-image: image-set(
            url("assets_gamestone/GJ_logo.webp") type("image/webp"),
            url("assets_gamestone/GJ_logo.png") type("image/png")
    );
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    filter: drop-shadow(0px 20px 15px rgba(0, 0, 0, 0.4));
    animation: logo-float 9s ease-in-out infinite;
}

@media (orientation: portrait) {
    #loading-screen-logo {
        top: calc(50% - 50px);
    }
}

@media (orientation: landscape) {
    #loading-screen-logo {
        top: calc(50% - 100px);
    }
}

/* ─── Progress bar container ───────────────────────────────────────── */

#loading-screen-loader {
    position: absolute;
    left: 50%;
    transform: translate(-50%, -50%);
}

@media (orientation: portrait) {
    #loading-screen-loader {
        top: calc(50% + 550px);
    }
}

@media (orientation: landscape) {
    #loading-screen-loader {
        top: calc(50% + 450px);
    }
}

/* Bar background / border frame */
#loading-screen-loader-border {
    position: absolute;
    width: 649px;
    height: 123px;
    transform: translate(-50%, -50%);
    background-image: -webkit-image-set(
            url("assets_gamestone/preloader_bar_bg.webp") type("image/webp"),
            url("assets_gamestone/preloader_bar_bg.png") type("image/png")
    );
    background-image: image-set(
            url("assets_gamestone/preloader_bar_bg.webp") type("image/webp"),
            url("assets_gamestone/preloader_bar_bg.png") type("image/png")
    );
    background-repeat: no-repeat;
    background-size: contain;
}

/* ─── Progress bar fill — slides in from left using mask trick ──────── */
/* Bar fill — slides in from left using mask trick */
#loading-screen-loader-fill {
    --progress: 0;
    --maskPosition: calc(var(--progress) * 649px - 649px);

    position: absolute;
    width: 649px;
    height: 90px;
    transform: translate(-50%, -70%);

    background-image: -webkit-image-set(
            url("assets_gamestone/preloader_bar.webp") type("image/webp"),
            url("assets_gamestone/preloader_bar.png") type("image/png")
    );
    background-image: image-set(
            url("assets_gamestone/preloader_bar.webp") type("image/webp"),
            url("assets_gamestone/preloader_bar.png") type("image/png")
    );
    background-repeat: no-repeat;
    background-size: contain;

    /* Use the fill image itself as its own reveal mask */
    mask-image: -webkit-image-set(
            url("assets_gamestone/preloader_bar.webp") type("image/webp"),
            url("assets_gamestone/preloader_bar.png") type("image/png")
    );
    mask-image: image-set(
            url("assets_gamestone/preloader_bar.webp") type("image/webp"),
            url("assets_gamestone/preloader_bar.png") type("image/png")
    );
    mask-repeat: no-repeat;
    mask-size: contain;
    mask-position: var(--maskPosition);

    -webkit-mask-image: image-set(
            url("assets_gamestone/preloader_bar.webp") type("image/webp"),
            url("assets_gamestone/preloader_bar.png") type("image/png")
    );
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-size: contain;
    -webkit-mask-position: var(--maskPosition);
}



/* ─── GiaB logo (opposite corner to YGG) ──────────────────────────── */

#loading-screen-giab-logo {
    position: absolute;
}

@media (orientation: portrait) {
    #loading-screen-giab-logo {
        width: 491px;
        height: 230px;
        right: 100px;
        top: 150px;
        left: auto;
        transform: translate(50%, -50%);
        background-image: -webkit-image-set(
                url("assets_gamestone/Powered by GiaB Logo - Portrait.webp") type("image/webp"),
                url("assets_gamestone/Powered by GiaB Logo - Portrait.png") type("image/png")
        );
        background-image: image-set(
                url("assets_gamestone/Powered by GiaB Logo - Portrait.webp") type("image/webp"),
                url("assets_gamestone/Powered by GiaB Logo - Portrait.png") type("image/png")
        );
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center;
    }
}

@media (orientation: landscape) {
    #loading-screen-giab-logo {
        width: 150px;
        height: 180px;
        right: 100px;
        top: 130px;
        left: auto;
        bottom: auto;
        transform: translate(50%, -50%);
        background-image: -webkit-image-set(
                url("assets_gamestone/Powered by GiaB Logo - Portrait.webp") type("image/webp"),
                url("assets_gamestone/Powered by GiaB Logo - Portrait.png") type("image/png")
        );
        background-image: image-set(
                url("assets_gamestone/Powered by GiaB Logo - Portrait.webp") type("image/webp"),
                url("assets_gamestone/Powered by GiaB Logo - Portrait.png") type("image/png")
        );
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center;
    }
}

