/* ================================================================
   TITLE HQ — Reviews Section Styles
   Skeleton placeholders + real review cards rendered by reviews.js.
   ================================================================ */

/* ── SECTION ── */
.reviews-section {
  background: var(--sand);
  padding: 72px 0;
}

.reviews-header { text-align: center; margin-bottom: 48px; }
.reviews-header h2 { margin-bottom: 10px; }
.reviews-header p { color: var(--text-body); max-width: 520px; margin: 0 auto; }

.reviews-aggregate {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 16px;
  flex-wrap: wrap;
}
.aggregate-score {
  font-family: var(--font-serif);
  font-size: 3rem;
  font-weight: 700;
  color: var(--teal);
  line-height: 1;
}
.aggregate-right { text-align: left; }
.aggregate-stars { display: flex; gap: 3px; margin-bottom: 4px; }
.aggregate-stars .star { font-size: 1.2rem; }
.aggregate-count { font-size: 0.78rem; color: var(--mid-gray); }

/* ── GRID ── */
.reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

/* ── CARDS (shared) ── */
.review-card {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 24px;
  border: 1px solid var(--stone);
  box-shadow: var(--shadow-sm);
  transition: var(--transition);
}
.review-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }

.review-stars { display: flex; gap: 3px; margin-bottom: 12px; }
.review-card blockquote {
  font-family: var(--font-serif);
  font-size: 0.98rem;
  font-style: italic;
  color: var(--text-dark);
  line-height: 1.7;
  margin-bottom: 16px;
}

.reviewer { display: flex; align-items: center; gap: 10px; }
.reviewer-avatar {
  width: 38px; height: 38px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-serif);
  font-size: 0.9rem;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
}
.reviewer-name { font-size: 0.875rem; font-weight: 600; color: var(--text-dark); }
.reviewer-meta { font-size: 0.73rem; color: var(--mid-gray); margin-top: 1px; }

.review-source {
  font-size: 0.7rem;
  color: var(--mid-gray);
  margin-top: 10px;
  display: flex;
  align-items: center;
  gap: 5px;
}

.google-g {
  width: 14px; height: 14px;
  background: #4285F4;
  border-radius: 2px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  font-family: Arial, sans-serif;
  flex-shrink: 0;
}

/* ── FEATURED CARD (dark) ── */
.review-card.review-featured {
  grid-column: 1 / -1;
  background: var(--dark-bg);
}
.review-card.review-featured blockquote { color: rgba(255,255,255,0.9); }
.review-card.review-featured .reviewer-name { color: #fff; }
.review-card.review-featured .reviewer-meta { color: rgba(255,255,255,0.45); }
.review-card.review-featured .star { color: var(--sky); }
.review-card.review-featured .review-source { color: rgba(255,255,255,0.35); }

/* ── SKELETON SHIMMER ── */
.reviews-skel-bar {
  display: block;
  background: linear-gradient(90deg, var(--stone) 0%, #f5f0e8 50%, var(--stone) 100%);
  background-size: 200% 100%;
  animation: reviewsSkelShimmer 1.4s linear infinite;
  border-radius: 6px;
  margin-bottom: 6px;
}
.reviews-skel-circle {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: linear-gradient(90deg, var(--stone) 0%, #f5f0e8 50%, var(--stone) 100%);
  background-size: 200% 100%;
  animation: reviewsSkelShimmer 1.4s linear infinite;
}
.review-skeleton .skel-star { color: var(--stone); }
.review-featured.review-skeleton { background: var(--dark-bg); }
.review-featured.review-skeleton .reviews-skel-bar {
  background: linear-gradient(90deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0.15) 50%, rgba(255,255,255,0.08) 100%);
  background-size: 200% 100%;
  animation: reviewsSkelShimmer 1.4s linear infinite;
}
.review-featured.review-skeleton .reviews-skel-circle {
  background: linear-gradient(90deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0.15) 50%, rgba(255,255,255,0.08) 100%);
  background-size: 200% 100%;
  animation: reviewsSkelShimmer 1.4s linear infinite;
}
.review-featured.review-skeleton .skel-star { color: rgba(255,255,255,0.12); }

@keyframes reviewsSkelShimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ── FALLBACK ── */
.reviews-fallback {
  text-align: center;
  padding: 32px 24px;
  color: var(--mid-gray);
  font-size: 0.95rem;
}
.reviews-fallback a { color: var(--teal); font-weight: 600; }

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  .reviews-grid { grid-template-columns: 1fr 1fr; }
  .review-card.review-featured { grid-column: 1 / -1; }
}
@media (max-width: 768px) {
  .reviews-grid { grid-template-columns: 1fr; }
  .review-card.review-featured { grid-column: 1; }
}
