/* SmartPay Energy - Splash Screen */

body fuse-splash-screen {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: fixed;
    inset: 0;
    background: #ffffff;
    z-index: 999999;
    pointer-events: none;
    opacity: 1;
    visibility: visible;
    transition: opacity 500ms ease-out;
    overflow: hidden;
}

/* Logo — matches header exactly */
body fuse-splash-screen .logo {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    font-size: clamp(1.5rem, 5vw, 2.25rem);
    letter-spacing: -0.025em;
    line-height: 1;
    display: flex;
    align-items: baseline;
    gap: 0.2em;
    animation: logoEntrance 0.6s ease-out 0.1s forwards;
    opacity: 0;
}

body fuse-splash-screen .logo-smartpay {
    font-weight: 700;
    color: #1a3f4e;
}

body fuse-splash-screen .logo-energy {
    font-weight: 400;
    color: rgba(26, 63, 78, 0.8);
}

body fuse-splash-screen .logo-tm {
    font-size: 0.35em;
    font-weight: 400;
    color: rgba(26, 63, 78, 0.6);
    margin-left: 1px;
    vertical-align: super;
    line-height: 0;
}

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

/* Tagline */
body fuse-splash-screen .tagline {
    font-family: 'Inter', sans-serif;
    font-size: 0.85rem;
    font-weight: 500;
    color: #94a3b8;
    margin-top: 8px;
    letter-spacing: 0.05em;
    animation: taglineEntrance 0.5s ease-out 0.3s forwards;
    opacity: 0;
}

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

/* Progress Loader */
body fuse-splash-screen .loader {
    margin-top: 40px;
    animation: loaderEntrance 0.4s ease-out 0.5s forwards;
    opacity: 0;
}

body fuse-splash-screen .loader-track {
    width: 160px;
    height: 3px;
    background: #e8f2f5;
    border-radius: 3px;
    overflow: hidden;
}

body fuse-splash-screen .loader-fill {
    width: 40%;
    height: 100%;
    background: linear-gradient(90deg, #1a3f4e 0%, #2d6c83 50%, #1a3f4e 100%);
    background-size: 200% 100%;
    border-radius: 3px;
    animation: loaderSlide 1.5s ease-in-out infinite;
}

@keyframes loaderEntrance {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

@keyframes loaderSlide {
    0% {
        transform: translateX(-100%);
        background-position: 100% 0;
    }
    50% {
        background-position: 0% 0;
    }
    100% {
        transform: translateX(350%);
        background-position: 100% 0;
    }
}

/* Body overflow */
body:not(.fuse-splash-screen-hidden) {
    overflow: hidden;
}

/* App root - hidden until splash screen starts hiding */
body:not(.fuse-splash-screen-hidden) app-root {
    opacity: 0;
}

/* App entrance animation */
body.fuse-splash-screen-hidden app-root {
    animation: appEntrance 0.5s ease-out 0.2s forwards;
}

@keyframes appEntrance {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

/* Splash screen exit */
body.fuse-splash-screen-hidden fuse-splash-screen {
    animation: splashExit 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

@keyframes splashExit {
    0% {
        opacity: 1;
        transform: scale(1);
        filter: blur(0);
    }
    100% {
        opacity: 0;
        transform: scale(1.03);
        filter: blur(4px);
        visibility: hidden;
    }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    body fuse-splash-screen .logo,
    body fuse-splash-screen .tagline,
    body fuse-splash-screen .loader {
        animation: none;
        opacity: 1;
        transform: none;
    }

    body fuse-splash-screen .loader-fill {
        animation: loaderPulse 1.5s ease-in-out infinite;
    }

    @keyframes loaderPulse {
        0%, 100% { opacity: 0.5; }
        50% { opacity: 1; }
    }
}
