08

Анимация

Токены длительностей, Apple-style easing и контракт уменьшенного движения.

Длительности

TokenValueUseAnchor
duration-fast200mshover color and transformbg:motion:duration-fast
duration-normal300mscard hover, FAQ answer collapsebg:motion:duration-normal
duration-slow600msscroll-reveal transitionsbg:motion:duration-slow
duration-colors150msquick color flipsbg:motion:duration-colors

Кривые easing-а

ease-out
ease-out
bg:motion:ease-out
ease-apple
cubic-bezier(0.32, 0.72, 0, 1)
bg:motion:ease-apple

Поднятие карточек

card-lift-smtranslateY(-2px)bg:motion:card-lift-sm
card-lift-mdtranslateY(-4px)bg:motion:card-lift-md

Уменьшенное движение

Жёсткое правило. Каждая анимация должна включать @media (prefers-reduced-motion: reduce) override, который её отключает или заменяет статическим состоянием. Базовый reset в base.css уже нейтрализует все transition для пользователей с уменьшенным движением; per-component анимации должны дополнительно убирать transform-ы при hover.
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}