/* =========================================================
   Marquee logos — boucle continue sans trou (home + global)
   ========================================================= */

.marquee {
  overflow: hidden;
  border-block: 1px solid transparent;
  border-image: linear-gradient(90deg, transparent, var(--hairline-2) 12%, var(--hairline-2) 88%, transparent) 1;
  padding-block: clamp(24px, 4vw, 32px);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.02) 0%, transparent 50%, rgba(255, 255, 255, 0.02) 100%);
  --marquee-gap: clamp(40px, 7vw, 80px);
  --marquee-logo-h: clamp(26px, 4.8vw, 32px);
  --marquee-duration: 45s;
  --marquee-wave-duration: 5.2s;
  --marquee-wave-step: 0.34s;
  mask-image: linear-gradient(90deg, transparent, black 6%, black 94%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, black 6%, black 94%, transparent);
}

.marquee:hover .marquee-track {
  animation-play-state: paused;
}

.marquee:hover .marquee-item img {
  animation-play-state: paused;
}

.marquee-viewport {
  overflow: hidden;
  width: 100%;
}

.marquee-track {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  width: max-content;
  gap: 0;
  will-change: transform;
  animation: marquee-scroll var(--marquee-duration, 45s) linear infinite;
}

.marquee-set {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  flex-shrink: 0;
  gap: var(--marquee-gap);
  padding-right: var(--marquee-gap);
}

.marquee-item {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  height: var(--marquee-logo-h);
}

.marquee-item img {
  display: block;
  height: 100%;
  width: auto;
  max-width: clamp(100px, 22vw, 160px);
  object-fit: contain;
  opacity: 0.48;
  filter: brightness(0) invert(1) drop-shadow(0 0 10px rgba(97, 177, 188, 0));
  transform: scale(1);
  will-change: opacity, filter, transform;
}

.marquee[data-marquee-ready] .marquee-item img {
  animation: marquee-logo-wave var(--marquee-wave-duration) ease-in-out infinite;
  animation-delay: calc(var(--marquee-wave-i, 0) * var(--marquee-wave-step) * -1);
}

.marquee-item img:hover {
  opacity: 1;
  filter: brightness(0) invert(1) drop-shadow(0 0 14px rgba(97, 177, 188, 0.45));
  transform: scale(1.05);
  animation-play-state: paused;
}

@keyframes marquee-scroll {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(calc(-1 * var(--marquee-shift, 0px)), 0, 0);
  }
}

@keyframes marquee-logo-wave {
  0%,
  100% {
    opacity: 0.48;
    filter: brightness(0) invert(1) drop-shadow(0 0 10px rgba(97, 177, 188, 0));
    transform: scale(1);
  }
  12% {
    opacity: 0.62;
    filter: brightness(0) invert(1) drop-shadow(0 0 8px rgba(97, 177, 188, 0.12));
    transform: scale(1.01);
  }
  24%,
  36% {
    opacity: 1;
    filter: brightness(0) invert(1) drop-shadow(0 0 14px rgba(97, 177, 188, 0.4));
    transform: scale(1.045);
  }
  52% {
    opacity: 0.55;
    filter: brightness(0) invert(1) drop-shadow(0 0 8px rgba(97, 177, 188, 0.08));
    transform: scale(1);
  }
}

/* Ne pas casser l'anim reveal mobile sur le conteneur */
.marquee[data-reveal] {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  .marquee-track {
    animation: none;
    transform: none;
  }

  .marquee-item img {
    animation: none;
    opacity: 0.72;
  }

  .marquee-viewport {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .marquee-viewport::-webkit-scrollbar {
    display: none;
  }
}
