/* Testimonials + Footer Area */

/* ==============================
   Testimonials Container
   ============================== */
.testimonials {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 var(--page-padding);
  background: var(--color-bg-page);
  overflow: hidden;
}

.testimonials__inner {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
  width: min(100%, 1560px);
  max-width: 100%;
  min-height: 200px;
  gap: 40px;
}

/* ==============================
   Carousel
   ============================== */
.testimonials__carousel {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-width: 1129px;
  width: 100%;
  overflow: hidden;
}

.testimonials__track {
  display: flex;
  flex-direction: row;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  gap: 40px;
}

.testimonials__track::-webkit-scrollbar {
  display: none;
}

.testimonials__card {
  flex: 0 0 100%;
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* Quote */
.testimonials__quote {
  margin: 0;
  padding: 0;
}

.testimonials__quote p {
  font-size: var(--testimonial-font-size);
  font-weight: var(--font-weight-regular);
  line-height: var(--testimonial-line-height);
  color: var(--color-text-primary);
  margin: 0;
  max-width: 680px;
}

/* Attribution */
.testimonials__attribution {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.testimonials__name {
  font-size: var(--testimonial-font-size);
  font-weight: var(--testimonial-attr-font-weight);
  line-height: var(--testimonial-attr-line-height);
  letter-spacing: var(--testimonial-attr-letter-spacing);
  color: var(--color-text-primary);
}

.testimonials__separator {
  font-size: var(--testimonial-font-size);
  color: var(--color-text-secondary);
}

.testimonials__role,
.testimonials__company {
  font-size: var(--testimonial-font-size);
  font-weight: var(--font-weight-regular);
  line-height: var(--testimonial-attr-line-height);
  letter-spacing: var(--testimonial-attr-letter-spacing);
  color: var(--color-text-secondary);
}

/* Pagination dots */
.testimonials__dots {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-start;
  padding-top: 8px;
}

.testimonials__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background: var(--color-text-tertiary);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-in-out);
  position: relative;
}

.testimonials__dot--active {
  background: var(--color-accent-orange);
}

/* ==============================
   Footer Area (SVG circle + links)
   ============================== */
.footer-area {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 24px;
  flex-shrink: 0;
}

.footer-area__circle-wrap {
  width: 112px;
  height: 112px;
  flex-shrink: 0;
}

.footer-area__svg-circle {
  animation: footer-rotate 20s linear infinite;
  display: block;
}

@keyframes footer-rotate {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

.footer-area__links {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}

.footer-area__social {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-primary);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-in-out);
}

.footer-area__social:hover {
  color: var(--color-text-secondary);
}

.footer-area__social svg {
  width: 24px;
  height: 24px;
}

.footer-area__divider {
  width: 24px;
  height: 1px;
  background: var(--color-border);
}

/* ==============================
   Site footer (minimal)
   ============================== */
.site-footer {
  /* Footer is visually integrated into testimonials per design */
}

/* ==============================
   Responsive: Tablet (<1100px)
   ============================== */
@media (max-width: 1099.98px) {
  .testimonials {
    padding: 0 24px;
  }

  .testimonials__inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 40px;
  }

  .footer-area {
    align-self: flex-end;
  }
}

/* ==============================
   Responsive: Small tablet (<640px)
   ============================== */
@media (max-width: 639.98px) {
  .testimonials {
    padding: 0 20px;
  }

  .testimonials__inner {
    gap: 32px;
  }

  .footer-area__circle-wrap {
    width: 96px;
    height: 96px;
  }

  .footer-area__svg-circle {
    width: 96px;
    height: 96px;
  }
}

/* ==============================
   Responsive: Mobile (<520px)
   ============================== */
@media (max-width: 519.98px) {
  .testimonials {
    padding: 0 16px;
  }

  .testimonials__inner {
    gap: 32px;
  }

  .testimonials__quote p {
    font-size: 13px;
    line-height: 17px;
  }

  /* Pagination dots: enlarge touch targets to 44px with visible dot at center */
  .testimonials__dot {
    width: 12px;
    height: 12px;
    padding: 0;
    /* Use box-shadow for larger invisible touch area */
    position: relative;
  }

  .testimonials__dots {
    flex-direction: row;
    gap: 12px;
  }

  /* Make dot touch target 44px via pseudo-element */
  .testimonials__dot::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 44px;
    height: 44px;
  }

  .footer-area {
    align-self: center;
  }

  .footer-area__circle-wrap {
    width: 80px;
    height: 80px;
  }

  .footer-area__svg-circle {
    width: 80px;
    height: 80px;
  }

  /* Social links: enlarge touch targets */
  .footer-area__social {
    width: 44px;
    height: 44px;
  }

  .footer-area__social svg {
    width: 24px;
    height: 24px;
  }
}
