/* ============================================================
   vm_animations.css — Vision Manager animations + utility classes
   ============================================================
   Skapad 2026-05-15 (FAS F av Tidomat-tema-migration).
   Använd via klasser på element eller via animation-name i andra CSS.
   ============================================================ */

@keyframes vm-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

@keyframes vm-fade-out {
    from { opacity: 1; }
    to   { opacity: 0; }
}

@keyframes vm-scale-in {
    from { opacity: 0; transform: scale(0.95); }
    to   { opacity: 1; transform: scale(1); }
}

@keyframes vm-slide-in-up {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

@keyframes vm-slide-in-down {
    from { opacity: 0; transform: translateY(-8px); }
    to   { opacity: 1; transform: translateY(0); }
}

@keyframes vm-pulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.5; }
}

@keyframes vm-spin {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

/* ── Utility classes ───────────────────────────────────────── */
.vm-anim-fade-in {
    animation: vm-fade-in 180ms ease-out;
}

.vm-anim-fade-out {
    animation: vm-fade-out 180ms ease-in;
}

.vm-anim-scale-in {
    animation: vm-scale-in 200ms cubic-bezier(0.4, 0, 0.2, 1);
}

.vm-anim-slide-in {
    animation: vm-slide-in-up 240ms cubic-bezier(0.4, 0, 0.2, 1);
}

.vm-anim-slide-in-down {
    animation: vm-slide-in-down 240ms cubic-bezier(0.4, 0, 0.2, 1);
}

.vm-loading-spinner {
    animation: vm-spin 800ms linear infinite;
}

.vm-anim-pulse {
    animation: vm-pulse 2s infinite;
}

/* ── A11Y: reduced-motion (kompletterar regeln i vm_tokens.css) ── */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}
