/* ─── Reviews Header ─── */
.reviews__header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 24px;
}
.reviews__star {
  width: 22px;
  height: 22px;
  fill: var(--color-star);
}
.reviews__header .section-title { margin-bottom: 0; }

/* ─── Score bars ─── */
.reviews__scores {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px 40px;
  margin-bottom: 32px;
}

.score-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
}
.score-item > span:first-child {
  flex: 0 0 100px;
  color: var(--color-text-secondary);
}
.score-item > span:last-child {
  flex-shrink: 0;
  font-weight: 500;
  color: var(--color-text);
  min-width: 28px;
  text-align: right;
}

.score-bar {
  flex: 1;
  height: 4px;
  background: var(--color-border);
  border-radius: var(--radius-full);
  overflow: hidden;
}
.score-fill {
  height: 100%;
  background: var(--color-text);
  border-radius: var(--radius-full);
  transition: width 0.8s cubic-bezier(0.4,0,0.2,1);
  width: 0;
}
.score-fill.animated { /* width set inline */ }

/* ─── Review cards ─── */
.reviews__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
  margin-bottom: 24px;
}

.review-card { display: flex; flex-direction: column; gap: 12px; }
.review-card--hidden { display: none; }
.review-card--hidden.show { display: flex; }

.review-card__header {
  display: flex;
  align-items: center;
  gap: 12px;
}
.review-card__avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.review-card__header > div strong { display: block; font-size: 15px; font-weight: 600; }
.review-card__header > div p { font-size: 13px; color: var(--color-text-secondary); }

.review-card__text {
  font-size: 14px;
  line-height: 1.7;
  color: var(--color-text);
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.review-card__text.expanded {
  display: block;
  -webkit-line-clamp: unset;
}

.reviews__more {
  display: block;
  margin-top: 8px;
}

@media (max-width: 768px) {
  .reviews__scores { grid-template-columns: 1fr; }
  .reviews__list { grid-template-columns: 1fr; }
  .score-item > span:first-child { flex: 0 0 80px; }
}
