/* ── Global Animations ───────────────────────────────────────── */

/* Scroll-reveal (Intersection Observer) */
.reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: 
        opacity 0.8s var(--ease-out), 
        transform 0.8s var(--ease-out);
    will-change: transform, opacity;
}

.reveal.active {
    opacity: 1;
    transform: translateY(0);
}

/* Float effect (e.g. for logos, icons) */
@keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}

.animate-float {
    animation: float 3s ease-in-out infinite;
}

/* Status dot pulse */
@keyframes status-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.5; transform: scale(1.3); }
}

/* Spinner rotation */
@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.animate-spin {
    animation: spin 1s linear infinite;
}

/* Hover Scale */
.hover-scale {
    transition: transform 0.2s var(--ease-out);
}
.hover-scale:hover {
    transform: scale(1.05);
}
