/* Testimonials Page Custom Styles */

.testimonials-hero {
  padding-top: var(--space-12);
  padding-bottom: var(--space-8);
  text-align: center;
}
.testimonials-lead {
  font-size: var(--font-size-lg);
  color: var(--color-gray-700);
  margin-left: auto;
  margin-right: auto;
  max-width: 600px;
}

.carousel-section {
  margin-bottom: var(--space-12);
}
.testimonial-carousel {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  gap: var(--space-4);
}
.carousel-btn {
  background: var(--color-surface);
  border: 1px solid var(--color-primary);
  color: var(--color-primary);
  border-radius: var(--radius-full);
  width: 44px;
  height: 44px;
  font-size: 1.5rem;
  transition: background var(--transition-fast) ease, box-shadow var(--transition-fast) ease;
  box-shadow: var(--shadow-sm);
}
.carousel-btn:hover, .carousel-btn:focus-visible {
  background: var(--color-primary);
  color: #fff;
  box-shadow: var(--shadow-md);
}
.carousel-track {
  display: flex;
  overflow: hidden;
  width: 100%;
  max-width: 650px;
  min-width: 0;
}
.carousel-slide {
  min-width: 100%;
  flex-shrink: 0;
  transition: transform var(--transition-slow) cubic-bezier(.4,0,.2,1), opacity 180ms;
  opacity: 1;
}
.testimonial-author {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-top: var(--space-4);
}
.author-avatar {
  width: 48px; height: 48px;
  border-radius: var(--radius-full);
  object-fit: cover;
  box-shadow: var(--shadow-sm);
}
.author-name {
  font-weight: 600;
  color: var(--color-primary);
}
.author-role {
  font-size: var(--font-size-sm);
  color: var(--color-gray-700);
}
.carousel-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: var(--space-3);
}
.carousel-dot {
  width: 10px;
  height: 10px;
  background: var(--color-primary);
  opacity: 0.4;
  border-radius: var(--radius-full);
  transition: opacity .2s;
  border: none;
}
.carousel-dot.active {
  opacity: 1;
  background: var(--color-primary-hover);
}

@media (max-width: 700px) {
  .testimonial-carousel {
    flex-direction: column;
  }
  .carousel-track {
    max-width: 95vw;
  }
}

/* Ratings Section */
.ratings-section {
  text-align: center;
  margin-bottom: var(--space-12);
}
.ratings-summary {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  font-size: var(--font-size-lg);
  margin-bottom: var(--space-2);
}
.rating-stars {
  color: #fbbf24;
  font-size: 2rem;
  letter-spacing: 1px;
  display: flex;
}
.rating-value {
  font-weight: bold;
  color: var(--color-gray-900);
}
.ratings-count {
  color: var(--color-gray-500);
  font-size: var(--font-size-sm);
}
.ratings-platforms {
  display: flex;
  gap: var(--space-6);
  justify-content: center;
  align-items: center;
  margin-top: var(--space-2);
}
.ratings-platforms img {
  height: 36px;
  width: auto;
  filter: grayscale(0.5);
  opacity: 0.9;
}

@media (max-width: 600px) {
  .ratings-summary {
    flex-direction: column;
    gap: var(--space-1);
  }
  .ratings-platforms {
    gap: var(--space-3);
  }
}

/* Video Section */
.video-section {
  margin-bottom: var(--space-12);
}
.video-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}
.video-testimonial video {
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  width: 100%;
  background: var(--color-gray-300);
}
.video-testimonial figcaption {
  margin-bottom: var(--space-2);
  color: var(--color-gray-700);
  font-size: var(--font-size-sm);
  font-style: italic;
}

@media (max-width: 900px) {
  .video-grid {
    grid-template-columns: 1fr;
  }
}

/* Influencer Section */
.influencer-section {
  margin-bottom: var(--space-12);
}
.influencer-grid {
  display: flex;
  gap: var(--space-6);
  flex-wrap: wrap;
  justify-content: center;
}
.influencer-endorsement {
  max-width: 350px;
  flex: 1 1 280px;
  padding-bottom: var(--space-4);
}
.influencer-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}
.influencer-avatar {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  object-fit: cover;
  box-shadow: var(--shadow-sm);
}
.influencer-name {
  font-weight: 600;
  color: var(--color-primary);
  display: block;
}
.influencer-role {
  font-size: var(--font-size-sm);
  color: var(--color-gray-700);
}

/* Partner Section */
.partner-section {
  margin-bottom: var(--space-12);
}
.partner-grid {
  display: flex;
  gap: var(--space-6);
  flex-wrap: wrap;
  justify-content: center;
}
.partner-testimonial {
  max-width: 340px;
  flex: 1 1 250px;
  padding-bottom: var(--space-4);
}
.partner-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}
.partner-logo {
  width: 48px; height: 48px;
  object-fit: contain;
  background: #fff;
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-gray-300);
}
.partner-name {
  font-weight: 600;
  color: var(--color-gray-700);
}

/* Case Studies Section */
.case-section {
  margin-bottom: var(--space-12);
}
.case-studies-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
.case-study h3 {
  font-size: var(--font-size-lg);
  color: var(--color-primary);
}
.case-study ul {
  margin-top: var(--space-2);
  margin-bottom: 0;
  padding-left: var(--space-4);
  color: var(--color-gray-700);
  font-size: var(--font-size-sm);
}
.case-study li {
  margin-bottom: var(--space-1);
  list-style-position: outside;
  list-style-type: disc;
}

@media (max-width: 900px) {
  .case-studies-grid {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
}

/* Call-To-Action Section */
.cta-section {
  margin-bottom: var(--space-8);
  text-align: center;
}
.call-to-action {
  background: var(--color-surface);
  border-left: 4px solid var(--color-primary);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  display: inline-block;
  padding: var(--space-5) var(--space-8);
}
.call-to-action a.button {
  vertical-align: middle;
  margin-right: var(--space-3);
}

@media (max-width: 700px) {
  .call-to-action {
    padding: var(--space-4) var(--space-3);
    width: 100%;
  }
}
