/* =========================================================
   Sponsor Marquee (scrolling logos right -> left)
   ========================================================= */

.sponsor-marquee{
  background: #ffffff;
  border-bottom: 1px solid rgba(0,0,0,.08);
  padding: 10px 0;
}

/* Visible lane */
.sponsor-marquee__wrap{
  position: relative;
  overflow: hidden;

  /* Desktop */
  height: 90px;
  padding-top: 30px;          /* shift down on desktop */
  padding-bottom: 10px;
  box-sizing: border-box;

  display: flex;
  align-items: flex-start;
}

/* Edge fade */
.sponsor-marquee__wrap::before,
.sponsor-marquee__wrap::after{
  content: "";
  position: absolute;
  top: 0;
  width: 80px;
  height: 100%;
  z-index: 2;
  pointer-events: none;
}
.sponsor-marquee__wrap::before{
  left: 0;
  background: linear-gradient(to right, #fff, rgba(255,255,255,0));
}
.sponsor-marquee__wrap::after{
  right: 0;
  background: linear-gradient(to left, #fff, rgba(255,255,255,0));
}

/* Moving track */
.sponsor-marquee__track{
  display: inline-flex;
  align-items: center;
  gap: 36px;
  white-space: nowrap;
  will-change: transform;
  animation: sponsorMarquee 28s linear infinite;
}

.sponsor-marquee__item{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 6px;
}

.sponsor-marquee__item img{
  display: block;
  width: auto;
  height: auto;
  max-height: 34px;           /* desktop logo size */
  max-width: 160px;
  object-fit: contain;
  opacity: .95;
  filter: grayscale(20%);
  transition: opacity .2s ease, filter .2s ease, transform .2s ease;
}

.sponsor-marquee__item img:hover{
  opacity: 1;
  filter: none;
  transform: translateY(-1px);
}

/* Pause on hover */
.sponsor-marquee__wrap:hover .sponsor-marquee__track{
  animation-play-state: paused;
}

/* Infinite loop (logo list duplicated) */
@keyframes sponsorMarquee{
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .sponsor-marquee__track{ animation: none; }
}
/* =========================
   MOBILE (extra safe, no cut)
   ========================= */
@media (max-width: 576px){

  .sponsor-marquee__wrap{
    height: 104px;            /* MORE room to prevent any clipping */
    padding: 8px 0;           /* tiny padding (top+bottom) */
    align-items: center;      /* vertical centering */
  }

  .sponsor-marquee__track{
    height: 100%;
    gap: 18px;
    animation-duration: 22s;
  }

  .sponsor-marquee__item{
    height: 100%;
  }

  .sponsor-marquee__item img{
    max-height: 26px;         /* a bit smaller on mobile */
    max-width: 140px;
    filter: none;
  }

  .sponsor-marquee__wrap::before,
  .sponsor-marquee__wrap::after{
    width: 34px;
  }
}
