/* ============================================================
   COMPLYN — Reviews
   Shared review-card design + horizontal scroller + static grid.
   Builds on css/styles.css (brand tokens). Self-contained so the
   /partials/reviews-scroller.html snippet can be dropped onto any
   page that links this file and js/reviews-scroller.js.

   Section A — .review-card        (used in scroller AND about grid)
   Section B — .reviews-scroller    (horizontal scroller layout)
   Section C — .review-grid         (static grid for the about page)
   ============================================================ */

/* ============================================================
   SECTION A — .review-card  (shared)
   ============================================================ */

.review-card {
  display: flex;
  flex-direction: column;
  background: #fffdf9;
  border: 1px solid var(--line);
  border-radius: 2px;
  box-shadow: 0 1px 3px rgba(10, 22, 40, 0.05);
  padding: 32px;
}

.review-card__stars {
  display: flex;
  gap: 4px;
  margin-bottom: 20px;
  color: var(--accent);
}

.review-card__stars svg {
  width: 17px;
  height: 17px;
  display: block;
  fill: currentColor;
}

.review-card__quote {
  margin: 0;
  padding: 0;
  border: 0;
  font-family: var(--display);
  font-style: italic;
  font-weight: 400;
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink);
  transition: max-height 0.4s ease;
}

.review-card__quote p {
  margin: 0;
  padding: 0;
  font: inherit;
  color: inherit;
}

/* Truncated state (added by JS only when text > ~150 chars) */
.review-card__quote.is-clamped {
  position: relative;
  max-height: 6.8em;
  overflow: hidden;
}

.review-card__quote.is-clamped::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2.4em;
  background: linear-gradient(to bottom, rgba(255, 253, 249, 0), #fffdf9);
  pointer-events: none;
}

.review-card__read-more {
  align-self: flex-start;
  margin-top: 14px;
  padding: 0;
  background: none;
  border: 0;
  font-family: var(--body);
  font-size: 13px;
  font-weight: 500;
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
  cursor: pointer;
}

.review-card__read-more:hover { color: var(--ink); }

.review-card__read-more:focus-visible,
.reviews-scroller__arrow:focus-visible,
.reviews-scroller__cta-button:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.review-card__attribution {
  margin-top: auto;
  padding-top: 24px;
}

.review-card__name {
  margin: 0;
  font-family: var(--body);
  font-weight: 600;
  font-size: 15px;
  color: var(--ink);
}

.review-card__title {
  margin: 2px 0 0;
  font-family: var(--body);
  font-size: 14px;
  color: var(--ink-soft);
}

.review-card__date {
  margin: 10px 0 0;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* ============================================================
   SECTION B — .reviews-scroller  (horizontal scroller)
   ============================================================ */

.reviews-scroller {
  --reviews-bg: var(--paper-warm);
  background: var(--reviews-bg);
  border-top: 1px solid var(--line);
  padding: 80px 0;
}

.reviews-scroller__inner {
  max-width: var(--wrap-max);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}

.reviews-scroller__header {
  max-width: 720px;
  margin: 0 auto 44px;
  text-align: center;
}

.reviews-scroller__eyebrow {
  margin: 0 0 16px;
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
}

.reviews-scroller__heading {
  margin: 0;
  font-family: var(--display);
  font-weight: 600;
  font-size: clamp(32px, 4vw, 42px);
  line-height: 1.12;
  letter-spacing: -0.02em;
  color: var(--ink);
}

/* Track wrapper holds the scroll track, edge fades, and arrows */
.reviews-scroller__track-wrapper {
  position: relative;
}

.reviews-scroller__track-wrapper::before,
.reviews-scroller__track-wrapper::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 44px;
  z-index: 2;
  pointer-events: none;
}

.reviews-scroller__track-wrapper::before {
  left: 0;
  background: linear-gradient(to right, var(--reviews-bg), rgba(243, 238, 226, 0));
}

.reviews-scroller__track-wrapper::after {
  right: 0;
  background: linear-gradient(to left, var(--reviews-bg), rgba(243, 238, 226, 0));
}

.reviews-scroller__track {
  display: flex;
  gap: 24px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-overflow-scrolling: touch;
  padding: 10px 4px;
}

.reviews-scroller__track::-webkit-scrollbar { display: none; }

.reviews-scroller__track .review-card {
  flex: 0 0 380px;
  width: 380px;
}

/* Arrow controls (desktop) */
.reviews-scroller__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: #fffdf9;
  color: var(--ink);
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(10, 22, 40, 0.08);
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.reviews-scroller__arrow:hover {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.reviews-scroller__arrow svg { width: 22px; height: 22px; }
.reviews-scroller__arrow--prev { left: -14px; }
.reviews-scroller__arrow--next { right: -14px; }
.reviews-scroller__arrow[hidden] { display: none; }

/* Pagination dots (mobile-only swipe affordance) */
.reviews-scroller__dots {
  display: none;
  justify-content: center;
  gap: 10px;
  margin-top: 20px;
}
.reviews-scroller__dot {
  width: 8px;
  height: 8px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: var(--line);
  cursor: pointer;
  transition: background 0.2s ease, transform 0.2s ease;
}
.reviews-scroller__dot.is-active {
  background: var(--accent);
  transform: scale(1.15);
}
.reviews-scroller__dot:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

/* Leave-a-review CTA (also reused below the about grid) */
.reviews-scroller__cta {
  margin-top: 48px;
  text-align: center;
}

.reviews-scroller__cta-button {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 26px;
  font-family: var(--body);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--ink);
  background: transparent;
  border: 1px solid var(--ink);
  border-radius: 2px;
  transition: background 0.2s ease, color 0.2s ease;
}

.reviews-scroller__cta-button:hover {
  background: var(--ink);
  color: var(--paper);
}

.reviews-scroller__cta-button svg { width: 14px; height: 14px; }

.reviews-scroller__cta-note {
  margin: 16px 0 0;
  font-size: 14px;
  color: var(--ink-mute);
}

/* ============================================================
   SECTION C — embedded scroller (about page)
   Reuses the scroller inside an existing section (e.g. the about
   testimonials block), dropping the standalone band styling so it
   inherits the host section's background and heading.
   ============================================================ */

.reviews-scroller--embedded {
  --reviews-bg: var(--paper);
  background: transparent;
  border-top: 0;
  padding: 0;
  margin-top: 8px;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 768px) {
  .reviews-scroller { padding: 48px 0; }
  .reviews-scroller__track .review-card { flex: 0 0 320px; width: 320px; }
  .reviews-scroller__controls { display: none; }
  .reviews-scroller__arrow { display: none; }
  /* Native swipe with clean card-by-card snapping */
  .reviews-scroller__track { scroll-snap-type: x mandatory; }
  .reviews-scroller__track .review-card { scroll-snap-align: start; }
  /* Show pagination dots as the swipe affordance */
  .reviews-scroller__dots { display: flex; }
}

@media (max-width: 480px) {
  .reviews-scroller__track .review-card { flex: 0 0 280px; width: 280px; }
  .review-card { padding: 28px 24px; }
}

@media (prefers-reduced-motion: reduce) {
  .review-card__quote { transition: none; }
  .reviews-scroller__track { scroll-behavior: auto; }
}
