/* =================================================================
   GUEST REVIEWS PAGE  ([paleopetres_reviews])
   Summary band · featured rotator · filter bar · card grid · load more
   ================================================================= */
.lux-rv {
  max-width: 1080px;
  margin:    0 auto;
}

/* ---- Summary band ---------------------------------------------- */
.lux-rv__summary {
  display:         flex;
  flex-wrap:       wrap;
  align-items:     center;
  justify-content: center;
  gap:             .5rem .75rem;
  font-family:     "Poppins", sans-serif;
  font-size:       .9rem;
  color:           var(--lux-muted);
  margin:          .5rem 0 2rem;
}
.lux-rv__stars { color: var(--lux-accent); letter-spacing: .15em; }
.lux-rv__stat strong { color: var(--lux-ink); font-weight: 600; }
.lux-rv__sep { color: var(--lux-line); }

/* ---- Featured rotator ------------------------------------------ */
.lux-rv__featured {
  position:  relative;
  overflow:  hidden;
  max-width: 760px;
  margin:    0 auto 2.5rem;
  min-height: 1px;
}
.lux-rv__feat-track { position: relative; }
.lux-rv__feat {
  margin:     0;
  padding:    0;
  text-align: center;
  opacity:    0;
  visibility: hidden;
  position:   absolute;
  inset:      0;
  display:    flex;
  flex-direction: column;
  justify-content: center;
  transition: opacity .8s ease, visibility .8s ease;
}
.lux-rv__feat.is-active { opacity: 1; visibility: visible; position: relative; }
.lux-rv__feat-quote {
  margin:      0 0 1rem;
  padding:     0;
  border:      0;
  font-family: "Playfair Display", serif;
  font-style:  italic;
  font-size:   clamp(1.15rem, 1.8vw, 1.55rem);
  line-height: 1.55;
  color:       var(--lux-ink);
}
.lux-rv__feat-quote::before { content: "\201C"; color: var(--lux-accent); }
.lux-rv__feat-quote::after  { content: "\201D"; color: var(--lux-accent); }
.lux-rv__feat-meta .lux-rv__name  { display: block; }
.lux-rv__feat-meta .lux-rv__where { display: block; margin-top: .2rem; }

.lux-rv__feat-dots {
  display:         flex;
  justify-content: center;
  gap:             .5rem;
  margin-top:      1.4rem;
}
.lux-rv__feat-dot {
  width: 7px; height: 7px; padding: 0; border: 0; border-radius: 50%;
  background: var(--lux-line); cursor: pointer; transition: background .2s, transform .2s;
}
.lux-rv__feat-dot:hover { transform: scale(1.2); }
.lux-rv__feat-dot.is-active { background: var(--lux-accent); }

/* ---- Filter / sort / search bar -------------------------------- */
.lux-rv__controls {
  display:     flex;
  flex-wrap:   wrap;
  align-items: flex-end;
  gap:         .75rem 1rem;
  padding:     1.1rem 0;
  margin:      0 0 1.5rem;
  border-top:    1px solid var(--lux-line);
  border-bottom: 1px solid var(--lux-line);
}
.lux-rv__control { display: flex; flex-direction: column; gap: .3rem; }
.lux-rv__control--search { flex: 1 1 200px; min-width: 160px; }
.lux-rv__control-label {
  font-family:    "Poppins", sans-serif;
  font-size:      .62rem;
  font-weight:    700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color:          var(--lux-muted);
}
.lux-rv__filter,
.lux-rv__sort,
.lux-rv__search {
  height:        40px;
  border:        1px solid var(--lux-line);
  border-radius: 4px;
  background:    #fff;
  color:         var(--lux-ink);
  font-size:     .9rem;
  padding:       0 .7em;
}
.lux-rv__search { width: 100%; }
.lux-rv__filter:focus,
.lux-rv__sort:focus,
.lux-rv__search:focus { border-color: var(--lux-accent); outline: none; }

.lux-rv__count {
  font-family: "Poppins", sans-serif;
  font-size:   .78rem;
  color:       var(--lux-muted);
  margin:      0 0 1.2rem;
}

/* ---- Card grid -------------------------------------------------- */
.lux-rv__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
@media (max-width: 60em) { .lux-rv__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 40em) { .lux-rv__grid { grid-template-columns: 1fr; } }

.lux-rv__card {
  display:       flex;
  flex-direction: column;
  margin:        0;
  padding:       1.4rem 1.3rem;
  background:    var(--lux-card);
  border:        1px solid var(--lux-line);
  border-radius: 4px;
  box-shadow:    var(--lux-shadow);
}
/* Hidden by JS (filtered out or beyond the current page). */
.lux-rv__card[hidden] { display: none; }

.lux-rv__quote {
  margin:      0 0 1rem;
  padding:     0;
  border:      0;
  font-family: "Playfair Display", serif;
  font-style:  italic;
  font-size:   1rem;
  line-height: 1.55;
  color:       var(--lux-ink);
  /* clamp very long reviews so the grid stays tidy */
  display: -webkit-box;
  -webkit-line-clamp: 8;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.lux-rv__quote::before { content: "\201C"; color: var(--lux-accent); }
.lux-rv__quote::after  { content: "\201D"; color: var(--lux-accent); }

.lux-rv__meta { margin-top: auto; font-family: "Poppins", sans-serif; }
.lux-rv__name {
  display:        block;
  font-size:      .78rem;
  font-weight:    600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color:          var(--lux-primary);
}
.lux-rv__where {
  display:    block;
  margin-top: .2rem;
  font-size:  .74rem;
  color:      var(--lux-muted);
}
.lux-rv__src {
  display:        inline-block;
  margin-top:     .5rem;
  font-size:      .62rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color:          var(--lux-muted);
  background:     var(--lux-paper);
  border:         1px solid var(--lux-line);
  border-radius:  2px;
  padding:        .12rem .45rem;
}

/* ---- Load more -------------------------------------------------- */
.lux-rv__more-wrap { text-align: center; margin-top: 2rem; }
.lux-rv__more {
  font-family:    "Poppins", sans-serif;
  font-size:      .72rem;
  font-weight:    600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color:          #fff;
  background:     var(--lux-accent);
  border:         0;
  border-radius:  4px;
  padding:        .85em 2.2em;
  cursor:         pointer;
  transition:     background .2s;
}
.lux-rv__more:hover { background: var(--lux-accent-deep); }
.lux-rv__more[hidden] { display: none; }

/* No-results message (created by JS). */
.lux-rv__empty {
  grid-column: 1 / -1;
  text-align:  center;
  color:       var(--lux-muted);
  font-style:  italic;
  padding:     2rem 0;
}
