/* Notification animation styles */
.notification {
    animation: slideIn 0.5s var(--transition-bounce) forwards;
}

@keyframes slideIn {
    0% {
        opacity: 0;
        transform: translateX(100%);
    }
    70% {
        transform: translateX(-10px);
    }
    100% {
        opacity: 1;
        transform: translateX(0);
    }
}

.notification.removing {
    animation: slideOut 0.5s var(--transition-smooth) forwards;
}

@keyframes slideOut {
    0% {
        opacity: 1;
        transform: translateX(0);
    }
    30% {
        transform: translateX(-10px);
    }
    100% {
        opacity: 0;
        transform: translateX(120%);
    }
}

/* Style button animations */
.style-btn:active,
.gen-style-btn:active,
.language-btn:active {
    transform: scale(0.95);
    transition: transform 0.1s ease;
}

.style-btn.active,
.gen-style-btn.active,
.language-btn.active {
    animation: selectButton 0.3s var(--transition-bounce);
}

@keyframes selectButton {
    0% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.1);
    }
    100% {
        transform: scale(1);
    }
}

/* Add animation for action buttons */
.action-btn {
    position: relative;
    overflow: hidden;
}

.action-btn::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 5px;
    height: 5px;
    background: rgba(255, 255, 255, 0.7);
    opacity: 0;
    border-radius: 100%;
    transform: scale(1, 1) translate(-50%);
    transform-origin: 50% 50%;
}

.action-btn:active::after {
    animation: ripple 0.6s ease-out;
}

@keyframes ripple {
    0% {
        transform: scale(0, 0);
        opacity: 0.5;
    }
    20% {
        transform: scale(25, 25);
        opacity: 0.3;
    }
    100% {
        opacity: 0;
        transform: scale(40, 40);
    }
}
