.logo-marquee {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.logo-marquee__track {
  display: flex;
  width: max-content;
  will-change: transform;
  animation: marquee-left var(--marquee-duration, 30s) linear infinite;
}
.logo-marquee--reverse .logo-marquee__track {
  animation-name: marquee-right;
}
.logo-marquee--pause-hover:hover .logo-marquee__track {
  animation-play-state: paused;
}
.logo-marquee__set {
  display: flex;
  align-items: center;
  gap: var(--marquee-gap, 48px);
  padding-right: var(--marquee-gap, 48px);
  flex-shrink: 0;
}
.logo-marquee__item {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  height: var(--marquee-height, 50px);
}
.logo-marquee__link {
  display: flex;
  align-items: center;
  height: 100%;
  text-decoration: none;
  transition: opacity 0.2s ease;
}
.logo-marquee__link:hover {
  opacity: 0.7;
}
.logo-marquee__image {
  display: block;
  width: auto;
  height: var(--marquee-height, 50px);
  max-height: 50px;
  max-width: none;
  object-fit: contain;
}
.logo-marquee--empty {
  min-height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.03);
  border: 2px dashed rgba(0, 0, 0, 0.1);
  border-radius: 4px;
}
.logo-marquee--empty p {
  margin: 0;
  padding: 1rem;
  text-align: center;
  opacity: 0.6;
}

@keyframes marquee-left {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(calc(-1 * var(--set-width, 50%)), 0, 0);
  }
}
@keyframes marquee-right {
  from {
    transform: translate3d(calc(-1 * var(--set-width, 50%)), 0, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
@media (max-width: 767px) {
  .logo-marquee__track {
    animation-duration: var(--marquee-duration-mobile, var(--marquee-duration, 30s));
  }
  .logo-marquee__set {
    gap: var(--marquee-gap-mobile, var(--marquee-gap, 24px));
    padding-right: var(--marquee-gap-mobile, var(--marquee-gap, 24px));
  }
  .logo-marquee__item {
    height: var(--marquee-height-mobile, var(--marquee-height, 50px));
  }
  .logo-marquee__image {
    height: var(--marquee-height-mobile, var(--marquee-height, 50px));
    max-height: var(--marquee-height-mobile, 50px);
  }
}
@media (prefers-reduced-motion: reduce) {
  .logo-marquee__track {
    animation: none;
  }
}