/**
 * Animations légères sur les boutons réservation / CTA pour attirer l’attention.
 * Désactivées si l’utilisateur demande moins de mouvement (accessibilité).
 */

@media (prefers-reduced-motion: no-preference) {
  @keyframes cta-pulse-glow {
    0%,
    100% {
      transform: scale(1);
      box-shadow: 0 4px 14px rgba(0, 0, 0, 0.15);
    }
    50% {
      transform: scale(1.025);
      box-shadow: 0 8px 28px rgba(0, 0, 0, 0.28);
    }
  }

  @keyframes cta-float-pulse {
    0%,
    100% {
      transform: translateY(0) scale(1);
      box-shadow: 0 8px 24px rgba(0, 0, 0, 0.22);
    }
    50% {
      transform: translateY(-6px) scale(1.04);
      box-shadow: 0 16px 40px rgba(0, 0, 0, 0.32);
    }
  }

  @keyframes cta-soft-sway {
    0%,
    100% {
      transform: translateY(0);
    }
    50% {
      transform: translateY(-3px);
    }
  }

  @keyframes cta-ghost-soft {
    0%,
    100% {
      opacity: 0.92;
      transform: translateY(0);
    }
    50% {
      opacity: 1;
      transform: translateY(-1px);
    }
  }

  @keyframes cta-ring-dot {
    0%,
    100% {
      transform: scale(1);
      opacity: 1;
    }
    50% {
      transform: scale(1.18);
      opacity: 0.85;
    }
  }

  /* FAB fixe gauche — mouvement + léger pulsage */
  a.reserve-popup-fab.open-reserve-popup {
    animation: cta-float-pulse 2.6s ease-in-out infinite;
    will-change: transform, box-shadow;
  }

  a.reserve-popup-fab.open-reserve-popup:hover {
    animation-play-state: paused;
    transform: translateY(-2px) scale(1.06);
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.35);
    opacity: 1;
  }

  /* Bouton noir dans le popup : pulse ombre */
  .reserve-popup .reserve-popup__btn[type="submit"] {
    animation: cta-pulse-glow 2.2s ease-in-out infinite;
    will-change: transform, box-shadow;
  }

  .reserve-popup .reserve-popup__btn[type="submit"]:hover {
    animation-play-state: paused;
    transform: scale(1.03);
  }

  /* Fermer (secondaires) dans le popup */
  .reserve-popup .reserve-popup__btn--ghost {
    animation: cta-ghost-soft 3s ease-in-out infinite;
  }

  .reserve-popup .reserve-popup__btn--ghost:hover {
    animation-play-state: paused;
  }

  /* Cartes abonnements + CTA bloc */
  .memberships-plan__btn.open-reserve-popup,
  .memberships-block__btn.open-reserve-popup {
    animation: cta-pulse-glow 2.4s ease-in-out infinite;
    will-change: transform, box-shadow;
  }

  .memberships-plan__btn.open-reserve-popup:hover,
  .memberships-block__btn.open-reserve-popup:hover {
    animation-play-state: paused;
    transform: scale(1.04);
    opacity: 1;
  }

  /* Héros + bandeaux noir : liens réservation */
  a.block-f__cta.open-reserve-popup {
    animation: cta-soft-sway 2.8s ease-in-out infinite;
  }

  a.block-f__cta.open-reserve-popup:hover {
    animation-play-state: paused;
    transform: translateY(-2px);
    opacity: 1;
  }

  a.block-c__cta.open-reserve-popup {
    animation: cta-pulse-glow 2.3s ease-in-out infinite;
    will-change: transform, box-shadow;
  }

  a.block-c__cta.open-reserve-popup:hover {
    animation-play-state: paused;
    transform: scale(1.06);
    opacity: 1;
  }

  /* Lien principal navigation (Réserver / Commodités) */
  a.header__menu-main-lnk--1.open-reserve-popup {
    display: inline-block;
    animation: cta-soft-sway 3s ease-in-out infinite;
  }

  a.header__menu-main-lnk--1.open-reserve-popup:hover {
    animation-play-state: paused;
    transform: translateY(-2px);
    opacity: 1;
  }

  /* Liens image du carrousel commodités (index) */
  .block-c__dcarousel .dcarousel--item > div > a.open-reserve-popup {
    display: block;
    animation: cta-soft-sway 3.1s ease-in-out infinite;
    transform-origin: center center;
  }

  .block-c__dcarousel .dcarousel--item > div > a.open-reserve-popup:hover {
    animation-play-state: paused;
    transform: translateY(-2px);
  }

  /* Petit point à droite du libellé « Réserver » en header — pulse discret */
  .header__reserve-toggle::after {
    animation: cta-ring-dot 2s ease-in-out infinite;
  }

  body.is-reserve-open .header__reserve-toggle::after {
    animation: none;
  }

  body.is-reserve-open .header__reserve-toggle span {
    animation: none;
  }

  /* Popup réservation ouvert : calmer le header pour ne pas rivaliser avec le formulaire */
  body.reserve-popup-open .header__reserve-toggle::after,
  body.reserve-popup-open .header__reserve-toggle span {
    animation: none;
  }

  .header__reserve-toggle:hover::after {
    animation-play-state: paused;
  }

  /* Légère oscillation du libellé fixe Réserver / Fermer */
  .header__reserve-toggle span {
    display: inline-block;
    animation: cta-soft-sway 3.2s ease-in-out infinite;
  }

  .header__reserve-toggle:hover span {
    animation-play-state: paused;
  }
}
