.pw-logos-wrapper{
  --pw-speed: 30s;
  --pw-gap: 48px;
  --pw-dir: -1; /* -1 = right->left, 1 = left->right */
  position: relative;
  width: 100%;
  overflow: hidden;
}

.pw-logos-wrapper .pw-logos-track{
  display: flex;
  align-items: center;
  width: max-content;
  will-change: transform;
  animation: pwMarquee var(--pw-speed) linear infinite;
}

.pw-logos-wrapper .pw-logos-list{
  display: flex;
  align-items: center;
  gap: var(--pw-gap);
  padding: 10px 0;
}

.pw-logos-wrapper .pw-logo-item{
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity .25s ease, filter .25s ease, transform .25s ease;
}

.pw-logos-wrapper .pw-logo-item img{
  display: block;
  height: 42px;
  width: auto;
  max-width: none;
}

.pw-logos-wrapper .pw-logo-link{
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.pw-logos-wrapper.pw-grayscale .pw-logo-item{
  filter: grayscale(1);
}

.pw-logos-wrapper.pw-grayscale.pw-colorize-hover .pw-logo-item:hover{
  filter: grayscale(0);
  transform: translateY(-1px);
}

.pw-logos-wrapper.pw-pause-hover:hover .pw-logos-track{
  animation-play-state: paused;
}

.pw-logos-wrapper.pw-fade-edges{
  -webkit-mask-image: linear-gradient(to right, transparent, #000 10%, #000 90%, transparent);
  mask-image: linear-gradient(to right, transparent, #000 10%, #000 90%, transparent);
}

@keyframes pwMarquee{
  from { transform: translateX(0); }
  to   { transform: translateX(calc(var(--pw-dir) * 50%)); }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .pw-logos-wrapper .pw-logos-track{ animation: none; transform: translateX(0) !important; }
}
