/* Reviews page specific styles - keeps consistency with base and avoids duplication */
:root {
  --hb-gold: #d4af37;
  --hb-black: #0a0a0a;
  --hb-red: #8b1e2d;
  --hb-amber: #c98a2a;
  --hb-champagne: #f7f3ea;
}

.reviews-hero {
  position: relative;
  color: var(--hb-champagne);
  background: linear-gradient(180deg, rgba(10,10,10,0.65), rgba(10,10,10,0.85)), url('/assets/images/live-performances.webp') center/cover no-repeat;
  padding: clamp(4rem, 8vw, 8rem) 0;
}
.reviews-hero .breadcrumb ol { display: flex; gap: .5rem; align-items: center; font-size: .9rem; }
.reviews-hero .breadcrumb a { color: var(--hb-champagne); opacity: .85; }
.reviews-hero h1 { font-weight: 700; letter-spacing: .5px; margin-top: .75rem; }
.reviews-hero .lead { max-width: 60ch; opacity: .95; }
.reviews-hero .hero-ctas { display: flex; gap: .75rem; margin-top: 1.25rem; flex-wrap: wrap; }

.btn { display: inline-flex; align-items: center; justify-content: center; padding: .8rem 1.1rem; border-radius: 999px; border: 1px solid transparent; text-decoration: none; font-weight: 600; transition: transform .2s ease, background .2s ease; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: linear-gradient(135deg, var(--hb-gold), var(--hb-amber)); color: #1a1a1a; }
.btn-ghost { background: transparent; color: var(--hb-champagne); border-color: rgba(255,255,255,.25); }
.btn-ghost:hover { border-color: rgba(255,255,255,.5); }

.reviews-controls { background: #0e0e0e; border-top: 1px solid rgba(255,255,255,.06); border-bottom: 1px solid rgba(255,255,255,.06); }
.filters { display: flex; gap: .5rem; flex-wrap: wrap; padding: 1rem 0; }
.filter-btn { background: #151515; color: #eae7df; border: 1px solid rgba(212,175,55,.25); padding: .6rem .9rem; border-radius: 999px; cursor: pointer; transition: background .2s ease, border-color .2s ease; }
.filter-btn:hover { background: #1b1b1b; }
.filter-btn.is-active { background: linear-gradient(135deg, rgba(212,175,55,.25), rgba(201,138,42,.25)); border-color: var(--hb-gold); }

.section { padding: clamp(3rem, 6vw, 5rem) 0; background: var(--hb-black); color: #efece6; }
.section.highlight { background: radial-gradient(80% 80% at 50% 0%, rgba(212,175,55,.12), transparent), var(--hb-black); }
.section-head { margin-bottom: 1.25rem; }
.section-head h2 { color: var(--hb-champagne); }
.section .cta-row { margin-top: 1rem; display: flex; gap: .75rem; flex-wrap: wrap; }
.section .cta-row.center { justify-content: center; }

.reviews-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1rem; }
.review-card { background: #111; border: 1px solid rgba(212,175,55,.18); border-radius: 14px; padding: 1rem; box-shadow: 0 10px 20px rgba(0,0,0,.35); outline: none; }
.review-card:focus-visible { box-shadow: 0 0 0 3px rgba(212,175,55,.6); }
.review-card.large { padding: 1.25rem 1.25rem; }
.review-card .rating { color: var(--hb-gold); letter-spacing: 2px; font-size: 1rem; margin-bottom: .3rem; }
.review-card blockquote { margin: .25rem 0 .5rem; font-size: 1.05rem; line-height: 1.65; }
.review-card .review-meta { color: #c9c5bb; font-size: .9rem; }

.media-split .split { display: grid; grid-template-columns: 1.2fr 1fr; gap: 1.25rem; align-items: center; }
.media-split .split.reverse { grid-template-columns: 1fr 1.2fr; }
.media-split .split-media img { width: 100%; height: auto; border-radius: 16px; border: 1px solid rgba(212,175,55,.18); box-shadow: 0 14px 28px rgba(0,0,0,.35); }
.media-split .split-content { display: grid; gap: .75rem; }

.overall { display: grid; gap: 1rem; grid-template-columns: 1.2fr .8fr; align-items: start; }
.overall-card { background: #101010; border: 1px solid rgba(212,175,55,.18); border-radius: 14px; padding: 1rem; }
.bullets { list-style: none; margin: 0; padding: 0; display: grid; gap: .5rem; }
.bullets li { position: relative; padding-left: 1.25rem; }
.bullets li::before { content: ""; position: absolute; left: 0; top: .6rem; width: .55rem; height: .55rem; border-radius: 50%; background: linear-gradient(135deg, var(--hb-gold), var(--hb-amber)); box-shadow: 0 0 0 2px rgba(212,175,55,.15); }

/* Utilities */
.visually-hidden { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }

/* Responsive */
@media (max-width: 980px) {
  .media-split .split, .media-split .split.reverse { grid-template-columns: 1fr; }
  .overall { grid-template-columns: 1fr; }
}
