/* coucou */
/* =============================================================
   Custom Post Slider — styles de base
   Les couleurs, typos et tailles sont contrôlées par Elementor.
   ============================================================= */

/* ── Wrapper ───────────────────────────────────────────────── */
/* Racine du carrousel.
   Les variables servent de valeurs de base et peuvent etre surchargees par Elementor. */
.mega-wooplee-wrapper {
  position: relative;
  width: 100%;
  --mega-wooplee-arrow-button-size: 44px;
  --mega-wooplee-arrow-outside-gap: 12px;
  --mega-wooplee-arrow-inside-gap: 12px;
  --mega-wooplee-arrow-side-offset: calc((var(--mega-wooplee-arrow-button-size) + var(--mega-wooplee-arrow-outside-gap)) * -1);
  --mega-wooplee-arrow-vertical-offset: 0px;
  --mega-wooplee-arrow-focus-style: solid;
  --mega-wooplee-arrow-focus-width: 3px;
  --mega-wooplee-arrow-focus-color: rgba(21, 156, 228, 0.6);
  --mega-wooplee-arrow-focus-offset: 2px;
}

/* ── Viewport / masque ─────────────────────────────────────── */
/* Fenetre visible du slider.
   overflow hidden masque les slides hors champ, et touch-action: pan-y garde
   le scroll vertical naturel tout en laissant le JS gerer le swipe horizontal. */
.mega-wooplee-viewport {
  overflow: hidden;
  touch-action: pan-y;
  user-select: none;
  /* Ne pas forcer le curseur 'main' : laisser le comportement par défaut
     (texte sélectionnable) et n'afficher le curseur de saisie que pendant
     le drag via le script JS qui mettra 'grabbing' sur mousedown. */
  cursor: default;
}

/* ── Track ─────────────────────────────────────────────────── */
/* Rail horizontal anime par le JS avec transform: translateX(...).
   Les !important protegent le slider contre les CSS de themes/plugins qui
   pourraient empiler les slides en colonne. */
.mega-wooplee-track {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
}

/* ── Slide ──────────────────────────────────────────────────── */
/* Une slide ne doit jamais retrecir automatiquement: le JS calcule sa largeur. */
.mega-wooplee-slide {
  flex-shrink: 0 !important;
  min-width: 0 !important;
}

/* ── Carte ──────────────────────────────────────────────────── */
/* Carte article interne a chaque slide. */
.mega-wooplee-card {
  height: 100%;
  display: flex;
  flex-direction: column;
  background-color: #fff;
  overflow: hidden;
  transition: box-shadow 0.2s ease;
}

/* ── Image ──────────────────────────────────────────────────── */
/* Zone de l'image mise en avant.
   La hauteur par defaut est remplacee par le controle Elementor si configure. */
.mega-wooplee-image-wrap {
  display: block;
  overflow: hidden;
  height: 200px; /* valeur par défaut, surchargée par Elementor */
  flex-shrink: 0;
}

.mega-wooplee-image-wrap a {
  display: block;
  width: 100%;
  height: 100%;
}

.mega-wooplee-image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 0.4s ease;
}

.mega-wooplee-card:hover .mega-wooplee-image-wrap img {
  transform: scale(1.04);
}

/* ── Contenu ────────────────────────────────────────────────── */
/* Zone verticale contenant meta, titre, extrait et bouton. */
.mega-wooplee-content {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 16px;
}

/* ── Méta ───────────────────────────────────────────────────── */
/* Ligne date/auteur. Les styles peuvent etre remplaces par Elementor. */
.mega-wooplee-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 8px;
  font-size: 0.8rem;
  color: #888;
}

.mega-wooplee-meta-sep {
  opacity: 0.5;
}

/* ── Titre ──────────────────────────────────────────────────── */
.mega-wooplee-title {
  margin: 0 0 8px;
  line-height: 1.3;
}

.mega-wooplee-title a {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s ease;
}

.mega-wooplee-title a:hover {
  opacity: 0.8;
}

/* ── Extrait ────────────────────────────────────────────────── */
/* L'extrait prend l'espace disponible pour pousser le bouton vers le bas. */
.mega-wooplee-excerpt {
  margin: 0 0 12px;
  flex: 1; /* pousse le bouton en bas */
  line-height: 1.6;
}

/* ── Bouton ─────────────────────────────────────────────────── */
/* Bouton "Lire la suite". Les !important limitent les interferences du theme. */
.mega-wooplee-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px;
  align-self: flex-start;
  text-decoration: none;
  cursor: pointer;
  border: none;
  transition:
    background-color 0.2s ease,
    color 0.2s ease,
    transform 0.1s ease;
  line-height: 1;
}

/* Quand l'icone est apres le texte, row-reverse evite de dupliquer le markup. */
.mega-wooplee-button--icon-after {
  flex-direction: row-reverse;
}

.mega-wooplee-button-icon,
.mega-wooplee-button-text {
  display: inline-flex !important;
  align-items: center !important;
}

.mega-wooplee-button-icon {
  flex-shrink: 0;
  line-height: 0;
}

.mega-wooplee-button-icon svg {
  display: block !important;
  width: 1em;
  height: 1em;
  fill: currentColor;
}

.mega-wooplee-button-icon i {
  font-size: 1em;
}

.mega-wooplee-button:hover {
  transform: translateY(-1px);
}

.mega-wooplee-button:active {
  transform: translateY(0);
}

/* ── Navigation (flèches) ───────────────────────────────────── */
/* Conteneur des fleches.
   Il couvre la largeur du slider, mais pointer-events:none laisse cliquer les
   cartes; seuls les boutons fleches reactivent les clics. */
.mega-wooplee-nav {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px;
  margin-top: 0;
  box-sizing: border-box;
  position: absolute;
  top: calc(50% + var(--mega-wooplee-arrow-vertical-offset));
  left: var(--mega-wooplee-arrow-side-offset);
  right: var(--mega-wooplee-arrow-side-offset);
  transform: translateY(-50%);
  padding: 0 !important;
  pointer-events: none;
  z-index: 10;
}

/* Bouton flèche */
/* Les selecteurs sont scopes sous .mega-wooplee-wrapper pour eviter les conflits
   avec d'autres plugins qui utilisent aussi des boutons de navigation. */
.mega-wooplee-wrapper .mega-wooplee-arrow {
  appearance: none;
  -webkit-appearance: none;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: var(--mega-wooplee-arrow-button-size) !important;
  height: var(--mega-wooplee-arrow-button-size) !important;
  min-width: 0 !important;
  min-height: 0 !important;
  cursor: pointer;
  border: 0 solid transparent;
  padding: 0 !important;
  margin: 0 !important;
  pointer-events: all;
  background-color: #fff;
  border-radius: 50%;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
  transition:
    background-color 0.2s ease,
    box-shadow 0.2s ease,
    transform 0.1s ease;
  flex-shrink: 0;
  line-height: 1 !important;
  text-align: center;
  text-decoration: none;
  box-sizing: border-box;
}

.mega-wooplee-wrapper .mega-wooplee-arrow:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.16);
  transform: translateY(-1px);
}

.mega-wooplee-wrapper .mega-wooplee-arrow:active {
  transform: translateY(0);
}

.mega-wooplee-wrapper .mega-wooplee-arrow.is-disabled,
.mega-wooplee-wrapper .mega-wooplee-arrow[aria-disabled="true"] {
  opacity: 0.35;
  pointer-events: none;
}

.mega-wooplee-wrapper .mega-wooplee-arrow svg {
  display: block !important;
  width: 20px;
  height: 20px;
  fill: #333;
  pointer-events: none !important;
  flex-shrink: 0 !important;
  margin: 0 !important;
}

/* ── Dots ───────────────────────────────────────────────────── */
/* Conteneur des points de navigation generes par le JS. */
.mega-wooplee-dots {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 20px;
}

/* Bouton de point.
   Les resets evitent les styles de boutons du theme et gardent un point propre. */
.mega-wooplee-wrapper .mega-wooplee-dot {
  appearance: none;
  -webkit-appearance: none;
  display: block !important;
  width: 8px !important;
  height: 8px !important;
  min-width: 0 !important;
  min-height: 0 !important;
  border-radius: 50px;
  border: 0 solid transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  cursor: pointer;
  background: #ccc !important;
  background-image: none !important;
  box-shadow: none !important;
  color: transparent !important;
  text-shadow: none !important;
  line-height: 1 !important;
  font-size: 0;
  font-family: inherit;
  text-indent: -9999px;
  text-transform: none;
  overflow: hidden;
  box-sizing: border-box;
  transition:
    background 0.25s ease,
    width 0.25s ease;
}

.mega-wooplee-wrapper .mega-wooplee-dot:hover,
.mega-wooplee-wrapper .mega-wooplee-dot:active {
  background: #ccc !important;
  box-shadow: none !important;
  transform: none !important;
}

/* Clic sur image / titre / bouton */
/* Les elements de navigation vers l'article gardent un curseur de lien. */
.mega-wooplee-button,
.mega-wooplee-image-wrap a,
.mega-wooplee-title a {
  cursor: pointer;
}

/* Etat actif du point courant.
   Le JS pose aussi aria-current="true" pour l'accessibilite. */
.mega-wooplee-wrapper .mega-wooplee-dot.is-active,
.mega-wooplee-wrapper .mega-wooplee-dot.is-active:hover,
.mega-wooplee-wrapper .mega-wooplee-dot[aria-current="true"] {
  background: #333 !important;
  width: 24px !important;
}

/* ── Visibilité responsive Elementor ───────────────────────── */
/* Ces classes sont ajoutees par le PHP pour afficher fleches/dots selon
   les switchers responsive Elementor. */
@media (min-width: 1025px) {
  .mega-wooplee-responsive-visibility:not(.mega-wooplee-show-desktop) {
    display: none !important;
  }
}

@media (min-width: 768px) and (max-width: 1024px) {
  .mega-wooplee-responsive-visibility:not(.mega-wooplee-show-tablet) {
    display: none !important;
  }
}

@media (max-width: 767px) {
  .mega-wooplee-responsive-visibility:not(.mega-wooplee-show-mobile) {
    display: none !important;
  }
}

/* ── Message vide ───────────────────────────────────────────── */
/* Message affiche quand la WP_Query ne retourne aucun article. */
.mega-wooplee-no-posts {
  padding: 24px;
  text-align: center;
  color: #888;
}

/* ── Responsive ─────────────────────────────────────────────── */
/* Ajustements mobiles des fleches. Le nombre de slides visibles est gere par JS. */
@media (max-width: 767px) {
  .mega-wooplee-wrapper {
    --mega-wooplee-arrow-button-size: 38px;
  }

  .mega-wooplee-nav {
    left: var(--mega-wooplee-arrow-side-offset);
    right: var(--mega-wooplee-arrow-side-offset);
  }

  .mega-wooplee-nav {
    gap: 6px;
  }
  .mega-wooplee-arrow {
    width: var(--mega-wooplee-arrow-button-size) !important;
    height: var(--mega-wooplee-arrow-button-size) !important;
  }
  .mega-wooplee-arrow svg {
    width: 18px;
    height: 18px;
  }
}

/* Accessibility helper: visually hidden but available to screen readers */
/* Texte cache visuellement mais disponible aux lecteurs d'ecran. */
.mega-wooplee-sr-only {
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap;
  border: 0;
  padding: 0;
  margin: -1px;
}

/* Visible focus states for keyboard users */
/* Focus visible de base pour tous les elements interactifs du slider. */
.mega-wooplee-arrow:focus,
.mega-wooplee-dot:focus,
.mega-wooplee-button:focus,
.mega-wooplee-image-wrap a:focus,
.mega-wooplee-title a:focus {
  outline: 3px solid rgba(21, 156, 228, 0.6);
  outline-offset: 2px;
}

/* Les fleches utilisent des variables car Elementor expose leurs reglages de focus. */
.mega-wooplee-arrow:focus,
.mega-wooplee-arrow:focus-visible {
  outline: var(--mega-wooplee-arrow-focus-width) var(--mega-wooplee-arrow-focus-style) var(--mega-wooplee-arrow-focus-color);
  outline-offset: var(--mega-wooplee-arrow-focus-offset);
}

/* Respecte la preference systeme de reduction des animations. */
@media (prefers-reduced-motion: reduce) {
  .mega-wooplee-track,
  .mega-wooplee-card,
  .mega-wooplee-image-wrap img,
  .mega-wooplee-title a,
  .mega-wooplee-button,
  .mega-wooplee-arrow,
  .mega-wooplee-dot {
    animation: none !important;
    transition: none !important;
  }

  .mega-wooplee-card:hover .mega-wooplee-image-wrap img,
  .mega-wooplee-button:hover,
  .mega-wooplee-wrapper .mega-wooplee-arrow:hover {
    transform: none;
  }
}

/* En mode contrastes forces, les controles restent visibles. */
@media (forced-colors: active) {
  .mega-wooplee-wrapper .mega-wooplee-arrow,
  .mega-wooplee-wrapper .mega-wooplee-dot {
    border: 1px solid ButtonText !important;
  }
}
