
.partners-section {
  padding: 3rem 0;
  background: #fff;
}

.partners-section .container {
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: 1rem;
}

.partners-title {
  margin: 0 0 1.5rem 0;
  text-align: center;
  font-weight: 800;
  font-size: clamp(1.25rem, 1rem + 1.2vw, 2rem);
  color: #0f172a; 
  letter-spacing: 0.5px;
}

.marquee {
  position: relative;
  overflow: hidden;
  mask-image: linear-gradient(to left, transparent, black 10%, black 90%, transparent);
  -webkit-mask-image: linear-gradient(to left, transparent, black 10%, black 90%, transparent);
}

.marquee-track {
  display: inline-flex;
  align-items: center;
  gap: 3rem;
  
  animation-name: marquee-rtl;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
  will-change: transform;
}

.logo-item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 120px;
  height: 64px;
  opacity: 0.9;
  transition: opacity 200ms ease, filter 300ms ease, transform 300ms ease;
}

.logo-item img {
  max-height: 48px;
  width: auto;
  filter: grayscale(100%) contrast(90%);
  opacity: 0.7;
  transition: filter 300ms ease, opacity 300ms ease, transform 300ms ease;
}

.logo-item:hover img {
  filter: grayscale(0%) contrast(100%);
  opacity: 1;
  transform: scale(1.03);
}


@keyframes marquee-rtl {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}


@media (max-width: 768px) {
  .logo-item { min-width: 96px; height: 56px; }
  .logo-item img { max-height: 40px; }
}
