/**
 * G2RD Micro-interactions — effets de survol, transitions et animations d'entrée
 *
 * Ces styles améliorent l'UX sans dépendance JS.
 * Respecte prefers-reduced-motion pour l'accessibilité.
 */

/* ──────────────────────────────────────────────
   Utilitaires d'animation (classes directement
   applicables depuis l'éditeur via className)
   ────────────────────────────────────────────── */

/* Apparition au scroll — état initial */
.scroll-animation {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}

.scroll-animation.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Variantes de direction */
.scroll-animation--left {
  transform: translateX(-32px);
}
.scroll-animation--right {
  transform: translateX(32px);
}
.scroll-animation--scale {
  transform: scale(0.92);
}
.scroll-animation--left.is-visible,
.scroll-animation--right.is-visible,
.scroll-animation--scale.is-visible {
  transform: none;
}

/* Délais en cascade pour groupes */
.scroll-animation:nth-child(1) { transition-delay: 0s; }
.scroll-animation:nth-child(2) { transition-delay: 0.08s; }
.scroll-animation:nth-child(3) { transition-delay: 0.16s; }
.scroll-animation:nth-child(4) { transition-delay: 0.24s; }
.scroll-animation:nth-child(5) { transition-delay: 0.32s; }
.scroll-animation:nth-child(6) { transition-delay: 0.40s; }

/* ──────────────────────────────────────────────
   Cartes — hover lift
   ────────────────────────────────────────────── */

.g2rd-card-hover {
  transition: transform 0.22s ease, box-shadow 0.22s ease;
  will-change: transform;
}

.g2rd-card-hover:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.10);
}

/* ──────────────────────────────────────────────
   Boutons — effet press + underline animé
   ────────────────────────────────────────────── */

.wp-block-button__link,
.button-primary,
.button-secondary {
  transition: transform 0.14s ease, box-shadow 0.14s ease, background-color 0.2s ease, border-color 0.2s ease;
  will-change: transform;
}

.wp-block-button__link:active,
.button-primary:active {
  transform: scale(0.97);
}

/* Lien avec underline animé */
.g2rd-link-animated {
  position: relative;
  text-decoration: none;
}

.g2rd-link-animated::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 0;
  height: 2px;
  background: currentColor;
  transition: width 0.25s ease;
}

.g2rd-link-animated:hover::after {
  width: 100%;
}

/* ──────────────────────────────────────────────
   Images — zoom doux au survol
   ────────────────────────────────────────────── */

.wp-block-image img,
.g2rd-img-zoom img {
  transition: transform 0.4s ease;
  will-change: transform;
}

.wp-block-post figure:hover .wp-post-image,
.g2rd-img-zoom:hover img {
  transform: scale(1.04);
}

/* ──────────────────────────────────────────────
   Icônes — rotation légère / bounce
   ────────────────────────────────────────────── */

.g2rd-icon-bounce {
  display: inline-block;
  transition: transform 0.2s ease;
}

.g2rd-icon-bounce:hover {
  transform: translateY(-3px);
}

/* ──────────────────────────────────────────────
   Focus visible amélioré (accessibilité)
   ────────────────────────────────────────────── */

:focus-visible {
  outline: 2px solid var(--wp--preset--color--secondary, #D4A373);
  outline-offset: 3px;
  border-radius: 3px;
}

/* ──────────────────────────────────────────────
   Réduction des mouvements (accessibilité)
   ────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
  .scroll-animation,
  .wp-block-post,
  .g2rd-card-hover,
  .wp-block-button__link,
  .button-primary,
  .wp-block-image img,
  .g2rd-img-zoom img,
  .g2rd-link-animated::after,
  .g2rd-icon-bounce {
    transition: none !important;
    animation: none !important;
    transform: none !important;
  }

  .scroll-animation {
    opacity: 1;
  }
}
