/* ==========================================================================
   DUBNET CZ - ANIMACE A MICRO-INTERAKCE (CSS3)
   ========================================================================== */

/* 1. Definice klíčových snímků (Keyframes) */

/* Jemné vyjetí nahoru */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Plovoucí efekt (floating cards) */
@keyframes float-slow {
    0% {
        transform: translateY(0px) rotate(0deg);
    }
    50% {
        transform: translateY(-12px) rotate(1deg);
    }
    100% {
        transform: translateY(0px) rotate(0deg);
    }
}

/* Nekonečné točení (loader) */
@keyframes spin {
    to { transform: rotate(360deg); }
}

/* Pulsování pro CTA */
@keyframes pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(40, 116, 252, 0.4);
    }
    70% {
        box-shadow: 0 0 0 12px rgba(40, 116, 252, 0);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(40, 116, 252, 0);
    }
}

/* 2. Aplikační třídy animací */

/* Hero animace při načtení */
.animate-fade-in-up {
    animation: fadeInUp 0.8s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

/* Scroll Trigger základní třída */
.animate-scroll-trigger {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.8s cubic-bezier(0.25, 1, 0.5, 1),
                transform 0.8s cubic-bezier(0.25, 1, 0.5, 1);
}

/* Stav po aktivaci Intersection Observerem v JS */
.animate-scroll-trigger.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Staggered delaye pro mřížky a skupiny karet */
.services-grid > div:nth-child(1) { transition-delay: 0.1s; }
.services-grid > div:nth-child(2) { transition-delay: 0.2s; }
.services-grid > div:nth-child(3) { transition-delay: 0.3s; }

.portfolio-grid > div:nth-child(3n+1) { transition-delay: 0.1s; }
.portfolio-grid > div:nth-child(3n+2) { transition-delay: 0.2s; }
.portfolio-grid > div:nth-child(3n)   { transition-delay: 0.3s; }

.about-badges > div:nth-child(1) { transition-delay: 0.1s; }
.about-badges > div:nth-child(2) { transition-delay: 0.2s; }
.about-badges > div:nth-child(3) { transition-delay: 0.3s; }

/* Aktivace pulsování na tlačítku odeslání */
.nav-cta .btn-cta {
    animation: pulse 2.5s infinite;
}
.nav-cta .btn-cta:hover {
    animation: none;
}
