/* =============================================================
   hugo-review-carousel — component stylesheet
   Override any --reviews-* variable in your site CSS to re-theme.
   Dark-mode values are the built-in defaults.

   Minimal mapping for a Tailwind v4 site (add to input.css):
     :root {
       --reviews-accent:      var(--color-green);
       --reviews-accent-dark: var(--color-green-dark);
       --reviews-card-bg:     var(--color-surface2);
       --reviews-section-bg:  var(--color-surface);
       --reviews-border:      var(--color-border);
       --reviews-text:        var(--color-text);
       --reviews-muted:       var(--color-muted);
     }
   ============================================================= */

/* ---- Section wrappers ---------------------------------------- */
.reviews-section {
  padding: 4rem 1rem;
  background: var(--reviews-section-bg, #26262c);
}

.reviews-inner {
  max-width: 960px;
  margin: 0 auto;
}

.reviews-heading {
  font-size: clamp(1.6rem, 4vw, 2.25rem);
  font-weight: 700;
  text-transform: uppercase;
  text-align: center;
  color: var(--reviews-heading, #ffffff);
  margin: 0 0 0.75rem;
  letter-spacing: 0.05em;
}

.reviews-subtext {
  text-align: center;
  color: var(--reviews-muted, #9a9aaa);
  font-size: 0.875rem;
  max-width: 480px;
  margin: 0 auto 2.5rem;
}

.reviews-subtext a {
  color: var(--reviews-accent, #339966);
  text-decoration: none;
}
.reviews-subtext a:hover {
  color: var(--reviews-heading, #ffffff);
}

/* ---- Carousel (crossfade between slides) --------------------- */
[data-reviews-track] { position: relative; }

.reviews-slide {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  align-items: start;
  position: absolute;
  top: 0; left: 0; right: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
}
.reviews-slide.active {
  position: relative;
  opacity: 1;
  pointer-events: auto;
}

@media (max-width: 860px) { .reviews-slide { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .reviews-slide { grid-template-columns: 1fr; } }

.reviews-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.25rem;
  margin-top: 1.75rem;
}

.reviews-dots { display: flex; gap: 0.5rem; }

.reviews-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--reviews-border, #3d3d46);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background 0.2s;
}
.reviews-dot.active { background: var(--reviews-accent, #339966); }

.reviews-nav {
  background: none;
  border: none;
  color: var(--reviews-muted, #9a9aaa);
  font-size: 1.2rem;
  cursor: pointer;
  padding: 0.4rem 0.6rem;
  line-height: 1;
  transition: color 0.15s;
}
.reviews-nav:hover { color: var(--reviews-accent, #339966); }

/* ---- Full grid (testimonials page) --------------------------- */
.reviews-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
}

/* ---- Card ---------------------------------------------------- */
.review-item {
  display: flex;
  flex-direction: column;
}

.review-bubble {
  background: var(--reviews-card-bg, #2e2e36);
  border: 1px solid var(--reviews-border, #3d3d46);
  padding: 1.4rem 1.25rem;
  position: relative;
  margin-bottom: 1.6rem;
}

/* Speech-bubble tail — border layer */
.review-bubble::before {
  content: '';
  position: absolute;
  bottom: -21px; left: 26px;
  border-left:  16px solid transparent;
  border-right: 16px solid transparent;
  border-top:   21px solid var(--reviews-border, #3d3d46);
}
/* Speech-bubble tail — fill layer */
.review-bubble::after {
  content: '';
  position: absolute;
  bottom: -18px; left: 27px;
  border-left:  15px solid transparent;
  border-right: 15px solid transparent;
  border-top:   18px solid var(--reviews-card-bg, #2e2e36);
}

.reviews-stars {
  color: var(--reviews-stars, #f5a623);
  font-size: 1rem;
  letter-spacing: 0.08em;
  flex: 1;
}

.review-text {
  color: var(--reviews-text, #e0e0e0);
  font-size: 0.875rem;
  line-height: 1.7;
  margin: 0;
}

.review-author-row {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding-left: 0.25rem;
}

.review-avatar {
  width: 46px; height: 46px;
  border-radius: 50%;
  background: var(--reviews-card-bg, #2e2e36);
  border: 2px solid var(--reviews-border, #3d3d46);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.review-author {
  color: var(--reviews-text, #e0e0e0);
  font-weight: 600;
  font-size: 0.95rem;
}
