.member-review-row {
  border-bottom: 1px solid #eef1f4;
}
.member-review-row:last-child {
  border-bottom: 0;
}

.member-review-avatar img {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  object-fit: cover;
  display: block;
  border: 1px solid #e9ecef;
}

.member-review-social {
  color: #6c757d;
  text-decoration: none;
}
.member-review-social:hover { text-decoration: underline; }

/* ====== Длинный текст: clamp + плавное раскрытие ====== */
.member-review-text__inner {
  overflow: hidden;
  transition: max-height 220ms ease;
}

/* Состояние "свернуто": ограничиваем визуально (8 строк) через max-height, значение ставим JS-ом точно */
.member-review-text[data-collapsed="1"] .member-review-text__inner {
  /* max-height выставляет JS под 8 строк, чтобы было ровно */
}

.member-review-toggle {
  text-decoration: none;
}

/* ====== Скрытые отзывы (после 5): плавное появление блоков ====== */
.member-review-row.is-hidden {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 240ms ease, opacity 240ms ease;
}

/* Включаем при раскрытии "Все отзывы" */
.member-review-row.is-hidden.is-revealed {
  opacity: 1;
}

/* ====== Градиентный фейд снизу для свернутого текста ====== */
.member-review-text {
  position: relative;
}

.member-review-text[data-collapsed="1"]::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 40px;

  height: 100px; /* зона плавного затухания */
  pointer-events: none;

  /* Белый фон под список. Если фон другой — поменяй последнюю часть градиента. */
  background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0),
    rgba(255, 255, 255, 1)
  );
}

/* чтобы кнопка была поверх фейда и читалась */
.member-review-toggle {
  position: relative;
  z-index: 2;
}

.member-review-text__inner {
  padding-bottom: 8px;
}