/* Partners Section Styling */
.partners-section {
  padding: 60px 0 80px;
  background-color: #ffffff;
  border-top: 1px solid #f3f4f6;
  overflow: hidden;
}

.partners-title {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  width: 100%;
  font-size: 2.25rem;
  font-weight: 800;
  margin-bottom: 60px;
  color: #111827;
  font-family: 'Tajawal', sans-serif;
  position: relative;
}

/* RTL Support for Title */
[dir="rtl"] .partners-title {
  font-weight: 900;
}

/* --- Universal Marquee System --- */
/* Works for both Partners and Features. 
   direction: ltr is forced so the track always starts at the left, 
   providing content on the right for the translateX pull. */

.partners-marquee, 
.features-marquee {
  width: 100%;
  overflow: hidden;
  direction: ltr !important; 
  margin: 0;
  pointer-events: none;
}

.partners-marquee-track,
.features-marquee-track {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0;
  width: max-content;
  direction: ltr;
  animation: universalMarqueeScroll 50s linear infinite;
  will-change: transform;
}

@keyframes universalMarqueeScroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Items carry their own gap for perfect loop math */
.partner-item,
.features-marquee .feature-item {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  padding-inline-end: clamp(40px, 6vw, 88px);
  transition: opacity 0.3s ease;
}

/* Feature Item Specific Overrides for Marquee Mode */
.features-marquee .feature-item {
  background: #fafafa;
  border-radius: 12px;
  padding: 20px;
  margin: 10px 0;
  margin-inline-end: clamp(20px, 3vw, 40px);
  min-width: 320px;
}

.partner-item img {
  max-width: 200px;
  height: auto;
  max-height: 90px;
  object-fit: contain;
  transition: transform 0.3s ease;
}

/* Responsive Adjustments */
@media (max-width: 1024px) {
  .partner-item,
  .features-marquee .feature-item {
    padding-inline-end: 48px;
  }
  .features-marquee .feature-item {
    min-width: 280px;
    margin-inline-end: 24px;
  }
}

@media (max-width: 768px) {
  .partners-marquee-track,
  .features-marquee-track {
    animation-duration: 35s;
  }
  .partner-item,
  .features-marquee .feature-item {
    padding-inline-end: 32px;
  }
  .features-marquee .feature-item {
    min-width: 240px;
    padding: 15px;
  }
}

@media (max-width: 480px) {
  .partners-marquee-track,
  .features-marquee-track {
    animation-duration: 25s;
  }
  .partner-item,
  .features-marquee .feature-item {
    padding-inline-end: 24px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .partners-marquee-track,
  .features-marquee-track {
    animation: none;
  }
}


.bundles-section {
  margin-top: 80px;
}
