/* =========================================================
   COMPONENT — Parceiros (card flutuante sobre o hero,
   carrossel infinito horizontal)
   ========================================================= */

.partners {
  margin-top: -80px;
  position: relative;
  z-index: 5;
}

.partners__card {
  background: #fff;
  border-radius: 32px;
  padding: var(--space-6) 0;
  box-shadow: var(--shadow-md);
  overflow: hidden;
  /* Card é uma "ilha" — um pouco mais estreito que o container do hero.
     Escala com os breakpoints (acompanha --container-max). */
  max-width: 100%;
  margin: 0 auto;
}

.partners__title {
  text-align: center;
  color: var(--color-blue);
  font-size: var(--fs-lg);
  font-weight: 600;
  margin-bottom: var(--space-6);
  padding: 0 var(--space-6);
}

/* Carrossel: fade nas laterais via máscara */
.partners__marquee {
  overflow: hidden;
  position: relative;
  mask-image: linear-gradient(to right, transparent, #000 6%, #000 94%, transparent);
  -webkit-mask-image: linear-gradient(to right, transparent, #000 6%, #000 94%, transparent);
  padding: var(--space-2) 0;
}

.partners__track {
  display: flex;
  align-items: center;
  gap: 48px;
  width: max-content;
  animation: partners-scroll 80s linear infinite;
}

.partners__track:hover {
  animation-play-state: paused;
}

.partners__item {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.partners__item img {
  height: 42px;
  width: auto;
  max-width: 180px;
  object-fit: contain;
  display: block;
}

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

/* Respeita preferência de movimento reduzido */
@media (prefers-reduced-motion: reduce) {
  .partners__track { animation: none; }
}

@media (min-width: 768px) {
  .partners__card {
    padding: var(--space-8) 0;
    max-width: 680px;
  }
  .partners__title {
    font-size: var(--fs-xl);
    margin-bottom: var(--space-8);
  }
  .partners__track { gap: 72px; }
  .partners__item img { height: 50px; max-width: 200px; }
}

/* Escala junto com o container responsivo */
@media (min-width: 1024px) { .partners__card { max-width: 900px;  } }
@media (min-width: 1280px) { .partners__card { max-width: 1140px; } }
@media (min-width: 1536px) { .partners__card { max-width: 1360px; } }
@media (min-width: 1920px) { .partners__card { max-width: 1700px; } }
