/* =========================
   BASE ANIMATION STATES
========================= */

.fade-up {
    opacity: 0;
    transform: translateY(40px);
    transition: all 0.8s ease;
}

.zoom-in {
    opacity: 1;
    transform: scale(0.9);
    transition: all 0.8s ease;
}

.animate-section {
    opacity: 0;
    transform: translateY(60px);
    transition: all 1s ease;
}

/* =========================
   ACTIVE STATE
========================= */

.animated.fade-up {
    opacity: 1;
    transform: translateY(0);
}

.animated.zoom-in {
    opacity: 1;
    transform: scale(1);
}

.animated.animate-section {
    opacity: 1;
    transform: translateY(0);
}

/* =========================
   DELAY UTILITIES
========================= */

.delay-100 { transition-delay: 0.1s; }
.delay-200 { transition-delay: 0.2s; }
.delay-300 { transition-delay: 0.3s; }
.delay-400 { transition-delay: 0.4s; }
.delay-500 { transition-delay: 0.5s; }
.delay-600 { transition-delay: 0.6s; }
.delay-700 { transition-delay: 0.7s; }
.delay-800 { transition-delay: 0.8s; }

/* =========================
   OPTIONAL FLOATING IMAGE
========================= */

/* Pehle wala CSS waisa hi rahega, bas floating ko thoda change karein */

.floating {
    /* scale(1) yahan add karna zaroori hai taaki zoom-in state bani rahe */
    animation: floating 3s ease-in-out infinite;
}

@keyframes floating {
    0%   { transform: scale(1) translateY(0); }
    50%  { transform: scale(1) translateY(-15px); } /* Thoda zyada movement smoothly */
    100% { transform: scale(1) translateY(0); }
}
