/**
 * Transizioni globali stile Framer Motion (ease / timing simili ai default FM),
 * senza dipendenza runtime: il bundle usa già React key sul tab → remount `.app-page-shell`.
 */

:root {
  --ls-motion-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ls-motion-ease-soft: cubic-bezier(0.4, 0, 0.2, 1);
  --ls-motion-page-ms: 420ms;
  --ls-motion-content-ms: 380ms;
}

@media (prefers-reduced-motion: reduce) {
  .ls-page-motion,
  .ls-app-body--motion,
  .ls-nav-motion .nav-item,
  .page-content {
    animation: none !important;
    transition-duration: 0.01ms !important;
  }
}

@keyframes ls-motion-page-enter {
  from {
    opacity: 0;
    transform: translate3d(0, 14px, 0);
    filter: blur(6px);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    filter: blur(0);
  }
}

@keyframes ls-motion-content-enter {
  from {
    opacity: 0;
    transform: translate3d(0, 10px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@media (prefers-reduced-motion: no-preference) {
  .app-page-shell.ls-page-motion {
    animation: ls-motion-page-enter var(--ls-motion-page-ms) var(--ls-motion-ease) both;
    transform: translateZ(0);
    backface-visibility: hidden;
  }

  /* Contenuto interno dopo il guscio pagina */
  .app-page-shell.ls-page-motion > .page-content {
    animation: ls-motion-content-enter var(--ls-motion-content-ms) var(--ls-motion-ease) both;
    animation-delay: 55ms;
  }

  .ls-nav-motion .nav-item {
    transition:
      transform 0.22s var(--ls-motion-ease-soft),
      opacity 0.2s var(--ls-motion-ease-soft),
      color 0.2s ease,
      background-color 0.22s ease;
  }

  .ls-nav-motion .nav-item:active {
    transform: scale(0.94);
  }

  /* Pannelli fullscreen / overlay: comparsa leggermente ritardata */
  .seller-detail-page > .seller-detail-sheet .card {
    transition:
      transform 0.26s var(--ls-motion-ease-soft),
      box-shadow 0.26s ease,
      border-color 0.26s ease;
  }
}
