/* ============================================
   Costela e Cia — Depoimentos
   ============================================ */

.reviews {
  position: relative;
  background: var(--bg-2);
  border-top: 1px solid var(--line);
  padding: clamp(72px, 12vh, 152px) clamp(20px, 4vw, 64px);
}

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

.reviews-head {
  max-width: 700px;
  margin-bottom: clamp(38px, 6vh, 70px);
}

.reviews-tag {
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: clamp(18px, 2.6vh, 26px);
}

.reviews-tag-rule {
  width: clamp(28px, 4vw, 54px);
  height: 2px;
  background: var(--accent);
}

.reviews-title {
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(31px, 4.2vw, 58px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--ink);
}

.reviews-title em { font-style: italic; color: var(--accent-2); }

.reviews-intro {
  margin-top: clamp(16px, 2.4vh, 24px);
  font-size: clamp(15px, 1.1vw, 17.5px);
  line-height: 1.62;
  color: var(--ink-soft);
}

/* ---- grade ---- */
.reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(16px, 2vw, 24px);
}

.review {
  display: flex;
  flex-direction: column;
  padding: clamp(26px, 2.6vw, 38px);
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 5px;
}

.review-quote-mark {
  font-family: var(--f-display);
  font-style: italic;
  font-size: 56px;
  line-height: 0.7;
  color: var(--accent);
  opacity: 0.55;
}

.review-quote {
  margin-top: 16px;
  font-family: var(--f-display);
  font-size: clamp(16px, 1.3vw, 19px);
  font-style: italic;
  line-height: 1.5;
  color: var(--ink);
}

.review-author {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: auto;
  padding-top: 24px;
}

.review-author-dot {
  width: 30px;
  height: 30px;
  flex-shrink: 0;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  background: var(--bg-2);
}

.review-author-name {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
}

.review-author-meta {
  display: block;
  margin-top: 2px;
  font-size: 11.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

.reviews-note {
  margin-top: clamp(26px, 4vh, 40px);
  text-align: center;
  font-size: 13px;
  color: var(--ink-mute);
}

/* ---- reveal ---- */
.reviews-head > *,
.review {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}
.reviews.is-revealed .reviews-head > *,
.reviews.is-revealed .review {
  opacity: 1;
  transform: translateY(0);
}
.reviews.is-revealed .reviews-tag { transition-delay: 0.08s; }
.reviews.is-revealed .reviews-title { transition-delay: 0.16s; }
.reviews.is-revealed .reviews-intro { transition-delay: 0.24s; }
.reviews.is-revealed .review:nth-child(1) { transition-delay: 0.3s; }
.reviews.is-revealed .review:nth-child(2) { transition-delay: 0.38s; }
.reviews.is-revealed .review:nth-child(3) { transition-delay: 0.46s; }

@media (prefers-reduced-motion: reduce) {
  .reviews-head > *,
  .review { opacity: 1; transform: none; transition: none; }
}

/* ---- responsivo ---- */
@media (max-width: 860px) {
  .reviews-grid { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; }
}
