/* Reviews page styles - GoudenVoorwaarden */

.section-pad { padding-block: var(--space-12); }
.section-intro { color: var(--color-text-muted); margin-bottom: var(--space-7); }

/* Hero */
.hero { position: relative; background: linear-gradient(120deg, rgba(140,27,42,0.22), rgba(212,175,55,0.12)), radial-gradient(80rem 40rem at 10% -10%, rgba(212,175,55,0.08), transparent 60%); }
.hero-inner { display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--space-10); align-items: center; padding-block: var(--space-12); }
.hero-text p { color: var(--color-text-muted); }
.hero-media { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); border: 1px solid rgba(255,255,255,0.08); }
@media (max-width: 900px) {
  .hero-inner { grid-template-columns: 1fr; }
}

/* Filter bar */
.filter-bar { margin-top: var(--space-7); display: grid; gap: var(--space-4); }
.filter-form { display: grid; grid-template-columns: 1fr 220px 220px auto; gap: var(--space-4); }
@media (max-width: 900px) {
  .filter-form { grid-template-columns: 1fr; }
}

/* Reviews grid */
.reviews-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-7); margin-top: var(--space-8); }
.review-title { font-size: var(--text-xl); }
@media (max-width: 1100px) {
  .reviews-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 700px) {
  .reviews-grid { grid-template-columns: 1fr; }
}

/* Star rating (accessible, CSS-only fill) */
.rating { position: relative; display: inline-block; line-height: 1; font-size: 1.05rem; letter-spacing: 2px; }
.rating__base, .rating__fill { font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; }
.rating__base { color: rgba(255,255,255,0.2); }
.rating__fill { position: absolute; inset: 0; color: var(--color-accent); width: calc((var(--rating, 0) / 5) * 100%); overflow: hidden; white-space: nowrap; }

/* Top rated */
.top-rated-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-7); margin-top: var(--space-7); }
@media (max-width: 1100px) { .top-rated-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 700px) { .top-rated-grid { grid-template-columns: 1fr; } }

/* Editors' picks */
.grid-two { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--space-9); align-items: center; }
.pick-media { border-radius: var(--radius-lg); overflow: hidden; border: 1px solid rgba(255,255,255,0.08); box-shadow: var(--shadow-md); }
.picks-list { display: grid; gap: var(--space-5); margin-top: var(--space-6); }
@media (max-width: 900px) { .grid-two { grid-template-columns: 1fr; } }

/* Testimonials */
.testimonials-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-7); }
@media (max-width: 1100px) { .testimonials-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 700px) { .testimonials-grid { grid-template-columns: 1fr; } }

/* Comparison */
.table-scroll { overflow: auto; border: 1px solid rgba(255,255,255,0.08); border-radius: var(--radius-md); }
.table-scroll table { min-width: 720px; background: var(--color-elevated); }

/* Methodology */
.methodology-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--space-9); align-items: start; }
.method-media { border-radius: var(--radius-lg); overflow: hidden; border: 1px solid rgba(255,255,255,0.08); box-shadow: var(--shadow-md); }
.criteria-list { display: grid; gap: var(--space-3); margin-top: var(--space-5); }
@media (max-width: 900px) { .methodology-grid { grid-template-columns: 1fr; } }

/* Trending topics */
.topics { display: flex; flex-wrap: wrap; gap: var(--space-4); margin-top: var(--space-6); }
.topic { display: inline-flex; align-items: center; padding: 0.5rem 0.75rem; border-radius: var(--radius-full); border: 1px solid rgba(255,255,255,0.12); background: rgba(255,255,255,0.04); color: var(--color-text); }
.topic:hover { background: rgba(255,255,255,0.08); }

/* FAQs */
.faqs { display: grid; gap: var(--space-4); }
.faqs details { background: var(--color-elevated); border: 1px solid rgba(255,255,255,0.08); border-radius: var(--radius-md); padding: var(--space-5); }
.faqs summary { cursor: pointer; font-weight: 600; }
.faqs p { margin-top: var(--space-4); margin-bottom: 0; }
