/* Animazione Logo che emerge dal fumo */
.logo-smoke-container {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 10002;
    width: 300px;
    height: 300px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.emerging-logo {
    width: 250px;
    height: auto;
    opacity: 0;
    filter: blur(20px);
    animation: emergeFromSmoke 2.5s ease-in-out forwards;
    animation-delay: 0.5s;
}

@keyframes emergeFromSmoke {
    0% {
        opacity: 0;
        filter: blur(20px) brightness(0);
        transform: scale(0.8);
    }
    20% {
        opacity: 0.2;
        filter: blur(16px) brightness(0.2);
        transform: scale(0.84);
    }
    40% {
        opacity: 0.4;
        filter: blur(12px) brightness(0.4);
        transform: scale(0.88);
    }
    60% {
        opacity: 0.6;
        filter: blur(8px) brightness(0.6);
        transform: scale(0.92);
    }
    80% {
        opacity: 0.8;
        filter: blur(4px) brightness(0.8);
        transform: scale(0.96);
    }
    100% {
        opacity: 1;
        filter: blur(0px) brightness(1);
        transform: scale(1);
    }
}

/* Modifiche al testo KARMA per mantenerlo animato e sopra il logo */
.txt-loading {
    position: absolute;
    bottom: 20%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10005 !important;
    text-align: center;
    user-select: none;
    white-space: nowrap !important;
    display: block !important;
}

/* Non sovrascrivere le animazioni originali - forza display inline */
.handle-preloader .animation-preloader .txt-loading .letters-loading {
    display: inline-block !important;
    float: none !important;
}

/* Reset eventuali flex containers */
.animation-preloader {
    display: block !important;
}

@keyframes fadeInText {
    0% {
        opacity: 0;
        transform: translateX(-50%) translateY(20px);
    }
    100% {
        opacity: 1;
        transform: translateX(-50%) translateY(0);
    }
}

/* Posizionamento canvas per effetto fumo centrato */
.tcg-smoke-cursor {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10000;
    pointer-events: none;
}

/* Loader wrap semi-trasparente per far vedere il fumo sotto */
.loader-wrap {
    background: rgba(0, 0, 0, 0.75) !important;
    z-index: 10001;
}

.preloader {
    background: transparent !important;
}

/* Nasconde spinner originale per non interferire */
.animation-preloader .spinner {
    display: none;
}
