.edenred-hero-slider {
  position: relative;
  padding: var(--edenred-y-padding-desktop) var(--edenred-x-padding-desktop);
  overflow: hidden;
}
.edenred-hero-slider::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;

  background-image: var(--edenred-bg-desktop);
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
}
.edenred-hero-slider__content,
.edenred-hero-slider__slider {
  position: relative;
  z-index: 1;
}

.edenred-hero-slider__content {
    position: relative;
    z-index: 1;
    max-width: 60rem;
    text-align: center;
    padding: 20px 45px 45px;
    margin: 0 auto;
}

.edenred-hero-slider__title {
  margin: 0 0 0.75rem;
}
.edenred-hero-slider__button {
  display: inline-block;
}

.edenred-hero-slider__slider {
  position: relative;
  z-index: 1;
}

.edenred-hero-slider__slide-img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 0.75rem;
  max-width: 60rem;
  margin: 0 auto;
}

/* Nav (flèches simples) */
.edenred-hero-slider__nav {
    position: absolute;
    inset: 0;
    pointer-events: none; /* permet de cliquer/drag sur le slider */
    z-index: 1;
}

.edenred-hero-slider__prev,
.edenred-hero-slider__next {
    outline: none;
  pointer-events: auto;
  position: absolute;
  top: 20%;
  transform: translateY(-50%);
  width: 50px;
  height: 50px;
  border-radius: 999px;
  cursor: pointer;

  /* Fond "verre" */
  background: rgba(255, 255, 255, 0.18);
  -webkit-backdrop-filter: blur(10px) saturate(140%);
  backdrop-filter: blur(10px) saturate(140%);

  /* Bordure + profondeur */
  border: 1px solid rgba(255, 255, 255, 0.35);
  box-shadow:
    0 10px 22px rgba(0, 0, 0, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.35),
    inset 0 -8px 18px rgba(0, 0, 0, 0.10);

  display: grid;
  place-items: center;
  padding: 0;

  /* Important pour l’overlay "reflet" */
  overflow: hidden;
}

.edenred-hero-slider__prev:focus,
.edenred-hero-slider__next:focus {
    outline: none;
}

/* Reflet/halo sur la bordure (style screenshot) */
.edenred-hero-slider__prev::after,
.edenred-hero-slider__next::after {
  content: "";
  position: absolute;
  inset: -2px;              /* légèrement plus grand que le bouton */
  border-radius: inherit;
  pointer-events: none;

  /* Reflet : un gradient qui "brille" sur un côté */
  background:
    radial-gradient(120% 90% at 30% 20%,
      rgba(255,255,255,0.55) 0%,
      rgba(255,255,255,0.20) 35%,
      rgba(255,255,255,0.00) 70%
    );
  opacity: 0.9;
}

/* Petite brillance interne pour donner l’effet "verre" */
.edenred-hero-slider__prev::before,
.edenred-hero-slider__next::before {
  content: "";
  width: 30px;
  height: 30px;

  /* Couleur de la flèche */
  background-color: rgba(255, 255, 255, 0.95);

  /* le mask utilise ton SVG */
  -webkit-mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;

  position: relative;
  z-index: 1;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,0.25));
}

/* SVG encodé en data URI (important: #, espaces, quotes encodés) */
.edenred-hero-slider__prev::before,
.edenred-hero-slider__next::before {
  -webkit-mask-image: url("../../icons/arrow-left.svg");
  mask-image: url("../../icons/arrow-left.svg");
}
.edenred-hero-slider__next::before { transform: rotate(180deg); }

/* Hover/active + accessibilité */
.edenred-hero-slider__prev:hover,
.edenred-hero-slider__next:hover {
  background: rgba(255, 255, 255, 0.22);
  border-color: rgba(255, 255, 255, 0.45);
}

.edenred-hero-slider__prev:active,
.edenred-hero-slider__next:active {
  transform: translateY(-50%) scale(0.98);
}

.edenred-hero-slider__prev:focus-visible,
.edenred-hero-slider__next:focus-visible {
  outline: 2px solid rgba(255,255,255,0.9);
  outline-offset: 3px;
}

/* Fallback si backdrop-filter n’est pas supporté */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .edenred-hero-slider__prev,
  .edenred-hero-slider__next {
    background: rgba(255, 255, 255, 0.32);
  }
}
/* Bounce à l’arrivée (quand ça vient de droite vers gauche) */
@keyframes edenredBounceLeft {
  0%   { transform: translateX(0); }
  55%  { transform: translateX(-10px); }
  100% { transform: translateX(0); }
}

@keyframes edenredBounceRight {
  0%   { transform: translateX(0); }
  55%  { transform: translateX(10px); }
  100% { transform: translateX(0); }
}

.edenred-hero-slider__slide.is-bouncing-left {
  animation: edenredBounceLeft 280ms ease-out;
}

.edenred-hero-slider__slide.is-bouncing-right {
  animation: edenredBounceRight 280ms ease-out;
}
.edenred-hero-slider__prev { left: 16px; }
.edenred-hero-slider__next { right: 16px; }

/* Mobile override */
@media (min-width: 768px) {
    .edenred-hero-slider__nav {
        left: 50%;
        transform: translateX(-50%);
    }
}
@media (max-width: 767px) {
  .edenred-hero-slider::before {
    background-image: var(--edenred-bg-mobile, var(--edenred-bg-desktop));
  }
    .edenred-hero-slider__prev { left: var(--edenred-x-padding-mobile); }
    .edenred-hero-slider__next { right: var(--edenred-x-padding-mobile); }
    .edenred-hero-slider__slider {
        margin-left: calc(var(--edenred-x-padding-mobile) * -1);
        margin-right: calc(var(--edenred-x-padding-mobile) * -1);
    }
    .edenred-hero-slider__prev,
    .edenred-hero-slider__next {
        top: 50%;
        background: rgba(0, 0, 0, 0.1);
    }
}