@import url('https://fonts.googleapis.com/css2?family=Fredoka:wdth,wght@75..125,300..700&family=Quicksand:wght@300..700&display=swap');

::-webkit-scrollbar {
    display: none;
}

.heroAnimation {
    animation: heroAnimation 1s ease-in-out;
}

.delaySpan {
    animation: heroAnimation 5s ease-in-out;
}

.fade {
    animation: fadeTransition 0.5s ease-in-out;
}

.fadeOut {
    animation: fadeOut 0.5s ease-in-out;
}

.animate-praise {
    animation: praise-pop 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
}

.animate-pop {
    animation: pop-in 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
}

.confetti {
    position: fixed;
    width: 10px;
    height: 10px;
    z-index: 100;
    pointer-events: none;
}

.animate-shake {
    animation: shake 0.4s cubic-bezier(.36,.07,.19,.97) both;
}

/* --- Efek Screen Shake --- */
@keyframes shake {
    0%, 100% { transform: translate(0, 0); }
    10%, 30%, 50%, 70%, 90% { transform: translate(-5px, -2px); }
    20%, 40%, 60%, 80% { transform: translate(5px, 2px); }
}

/* --- Efek Confetti --- */
@keyframes confetti-fall-left {
    0% { transform: translate(0, 0) rotate(0deg); opacity: 1; }
    25% { transform: translate(15vw, -50vh) rotate(90deg); }
    100% { transform: translate(30vw) rotate(720deg); opacity: 0; }
}

@keyframes confetti-fall-right {
    0% { transform: translate(0, 0) rotate(0deg); opacity: 1; }
    25% { transform: translate(-15vw, -50vh) rotate(-90deg); }
    100% { transform: translate(-30vw) rotate(-720deg); opacity: 0; }
}

@keyframes pop-in {
    0% { transform: scale(0.5); opacity: 0; }
    80% { transform: scale(1.1); }
    100% { transform: scale(1); opacity: 1; }
}

@keyframes praise-pop {
    0% { transform: scale(0); opacity: 0; }
    80% { transform: scale(1.2); opacity: 1; }
    100% { transform: scale(1); }
}

@keyframes heroAnimation {
    from {
        opacity: 0;
        transform: translateY(-50px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeTransition {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes fadeOut {
    from {
        opacity: 1;
    }
    to {
        opacity: 0;
    }
}