/* Partner-logo marquee — small social-proof strip on the home page */

.partner-marquee {
  position: relative;
  width: 100%;
  margin-top: 0;
  padding: 22px 0 24px;
  border-top: 1px solid rgba(89, 175, 240, 0.12);
  border-bottom: 1px solid rgba(89, 175, 240, 0.12);
  background:
    linear-gradient(180deg, rgba(8, 18, 38, 0.35) 0%, rgba(8, 18, 38, 0.55) 100%);
  overflow: hidden;
  /* Edge fade so logos drift in/out smoothly instead of clipping */
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
}

.partner-marquee-label {
  display: block;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.45);
  margin-bottom: 14px;
}

.partner-marquee-track {
  display: flex;
  width: max-content;
  gap: 28px;
  align-items: center;
  animation: partner-marquee-scroll 28s linear infinite;
  will-change: transform;
}

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

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

.partner-marquee-item {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 140px;
  height: 64px;
  padding: 0 22px;
  border-radius: 8px 2px 8px 2px;
  border: 1px solid rgba(89, 175, 240, 0.18);
  text-decoration: none;
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
  background: #ffffff;
}

.partner-marquee-item.is-dark {
  background: #0a0a0a;
}

.partner-marquee-item.is-tint {
  background: #d3e7eb;
}

.partner-marquee-item img {
  display: block;
  height: 46px;
  width: auto;
  object-fit: contain;
}

.partner-marquee-item:hover {
  transform: translateY(-2px);
  border-color: rgba(37, 99, 235, 0.5);
  box-shadow: 0 8px 22px rgba(37, 99, 235, 0.18);
}

@media (prefers-reduced-motion: reduce) {
  .partner-marquee-track {
    animation: none;
  }
  /* Show items statically centered when motion is reduced */
  .partner-marquee-track {
    justify-content: center;
    width: 100%;
  }
}

@media (max-width: 600px) {
  .partner-marquee-track {
    gap: 18px;
    animation-duration: 22s;
  }
  .partner-marquee-item {
    height: 48px;
    padding: 0 14px;
  }
  .partner-marquee-item img {
    height: 30px;
  }
}
