/* LOLUIS Customer Reviews page (/customer-reviews/) — scoped to .loluis-rpage
   Composes with the existing review.css palette (gold/navy). */

.loluis-rpage{
  --gold: #dd901c;
  --navy: #1b1717;
  --border: #e5e5e5;
  --soft: #f3f0e8;
  color: var(--navy);
  padding-bottom: 60px;
}
.loluis-rpage .container{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(16px, 3vw, 24px);
}

/* ---- Header ---- */
.loluis-rpage__header{
  padding: 48px 0 24px;
  text-align: center;
  border-bottom: 1px solid var(--border);
}
.loluis-rpage__title{
  margin: 0 0 14px;
  font-size: clamp(28px, 4.4vw, 44px);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 700;
}
.loluis-rpage__intro{
  max-width: 720px;
  margin: 0 auto;
  color: #555;
  font-size: 15px;
  line-height: 1.6;
}
.loluis-rpage__h2{
  text-align: center;
  font-size: clamp(20px, 2.4vw, 26px);
  font-weight: 600;
  letter-spacing: .04em;
  margin: 40px 0 20px;
}

/* ---- 1. Hero stats card ---- */
.loluis-rpage__hero{
  padding: 36px 0 20px;
}
.loluis-rpage__hero .loluis-rsum{
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(280px, 1.6fr) minmax(180px, 1fr);
  gap: clamp(16px, 3vw, 40px);
  align-items: center;
  padding: 28px clamp(16px, 3vw, 32px);
  margin: 0;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #fff;
}
.loluis-rpage__hero .loluis-rsum__overall{
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
.loluis-rpage__hero .loluis-rsum__overall .star-rating{
  font-size: 22px;
  width: 5.4em;
  margin: 0 auto 4px;
}
.loluis-rpage__hero .loluis-rsum__avg{
  font-size: 22px;
  font-weight: 700;
  color: var(--navy);
}
.loluis-rpage__hero .loluis-rsum__count{
  font-size: 14px;
  color: #6b6b6b;
  line-height: 1.5;
}
.loluis-rpage__hero .loluis-rsum__sub{
  color: #888;
  font-size: 13px;
}

/* Bars column: re-uses the row markup pattern from product page */
.loluis-rpage__hero .loluis-rsum__bars .wcpr-stars-count{
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.loluis-rpage__hero .loluis-rsum__bars .wcpr-row{
  display: flex;
  align-items: center;
  gap: 12px;
}
.loluis-rpage__hero .loluis-rsum__bars .wcpr-col-number{
  display: none;
}
.loluis-rpage__hero .loluis-rsum__bars .wcpr-col-star{
  flex: 0 0 auto;
}
.loluis-rpage__hero .loluis-rsum__bars .wcpr-col-star .star-rating{
  font-size: 12px;
  width: 5em;
  margin: 0;
}
.loluis-rpage__hero .loluis-rsum__bars .wcpr-col-process{
  flex: 1;
  min-width: 0;
}
.loluis-rpage__hero .loluis-rsum__bars .rate-percent-bg{
  position: relative;
  width: 100%;
  height: 8px;
  background: #ebe6d8;
  border-radius: 999px;
  overflow: hidden;
}
.loluis-rpage__hero .loluis-rsum__bars .rate-percent{
  height: 100%;
  background: var(--gold);
  border-radius: 999px;
}
.loluis-rpage__hero .loluis-rsum__bars .wcpr-col-rank-count{
  flex: 0 0 auto;
  font-size: 13px;
  color: #6b6b6b;
  font-variant-numeric: tabular-nums;
}

/* Meta number card on the right */
.loluis-rpage__hero .loluis-rsum__cta-wrap{
  text-align: center;
}
.loluis-rpage__meta{
  display: inline-flex;
  flex-direction: column;
  padding: 18px 24px;
  background: var(--soft);
  border-radius: 12px;
  min-width: 160px;
}
.loluis-rpage__meta-num{
  font-size: 32px;
  font-weight: 700;
  color: var(--navy);
  line-height: 1;
}
.loluis-rpage__meta-label{
  font-size: 12px;
  color: #6b6b6b;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-top: 6px;
}

@media (max-width: 900px){
  .loluis-rpage__hero .loluis-rsum{
    grid-template-columns: 1fr;
    gap: 20px;
  }
}

/* ---- 2. Photo wall ---- */
.loluis-rpage__wall{
  padding: 0 0 8px;
}
.loluis-rwall{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px;
}
.loluis-rwall__item{
  margin: 0;
}
.loluis-rwall__item a{
  position: relative;
  display: block;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border-radius: 10px;
  background: var(--soft);
  text-decoration: none;
  border: 1px solid var(--border);
  transition: transform .15s ease, box-shadow .15s ease;
}
.loluis-rwall__item a:hover{
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,.12);
}
.loluis-rwall__item img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.loluis-rwall__caption{
  position: absolute;
  inset: auto 0 0 0;
  padding: 10px 12px 8px;
  background: linear-gradient(to top, rgba(0,0,0,.7), rgba(0,0,0,0));
  color: #fff;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: .01em;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .15s ease, transform .15s ease;
}
.loluis-rwall__item a:hover .loluis-rwall__caption,
.loluis-rwall__item a:focus-visible .loluis-rwall__caption{
  opacity: 1;
  transform: translateY(0);
}

/* ---- 3. Category pills ---- */
.loluis-rpage__cats{
  padding: 0 0 12px;
}
.loluis-rcats{
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
}
.loluis-rcats li{
  margin: 0;
}
.loluis-rcat{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #fff;
  border: 1px solid var(--border);
  color: var(--navy);
  padding: 10px 16px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.loluis-rcat:hover{
  border-color: #b8b8b8;
  text-decoration: none;
}
.loluis-rcat--active{
  background: var(--gold);
  border-color: var(--gold);
  color: #fff !important;
}
.loluis-rcat__count{
  font-size: 12px;
  opacity: .8;
  font-variant-numeric: tabular-nums;
}
.loluis-rcat--active .loluis-rcat__count{
  opacity: .9;
}

/* ---- 4. Reviews grid (WCPR shortcode) — uses `shortcode-wcpr-*` class prefix
   (different from the product-page version which uses `wcpr-*`) ---- */
.loluis-rpage__grid{
  padding: 8px 0 0;
}

/* Filter container: 3-column grid layout
   NOTE: plugin emits an inline `<style>` rule
   `#woocommerce-photo-reviews-shortcode-N .shortcode-wcpr-filter-container { border:... !important }`
   (specificity 110). We prefix with `#loluis-customer-reviews` (on the page wrapper) +
   `.loluis-rpage__grid` to reach specificity 120 and win. */
#loluis-customer-reviews .loluis-rpage__grid .shortcode-wcpr-filter-container{
  margin: 16px auto 28px !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  max-width: 680px;
  border: 0 !important;
  background: transparent !important;
  padding: 0 !important;
}
.loluis-rpage__grid .shortcode-wcpr-filter-container .shortcode-wcpr-filter-button{
  background: #fff !important;
  border: 1px solid var(--border) !important;
  color: var(--navy) !important;
  border-radius: 8px !important;
  padding: 12px 16px !important;
  font-weight: 500;
  font-size: 14px;
  text-align: center;
  box-shadow: none !important;
}
.loluis-rpage__grid .shortcode-wcpr-filter-container .shortcode-wcpr-filter-button:hover{
  border-color: #b8b8b8 !important;
}
/* Active state — gold, applies to anchor buttons AND the wrap div */
.loluis-rpage__grid .shortcode-wcpr-filter-container a.shortcode-wcpr-filter-button.shortcode-wcpr-active,
.loluis-rpage__grid .shortcode-wcpr-filter-container .shortcode-wcpr-filter-button-wrap.shortcode-wcpr-active{
  background: var(--gold) !important;
  border-color: var(--gold) !important;
  color: #fff !important;
}
/* Placeholder span (rating dropdown trigger) edge-to-edge */
.loluis-rpage__grid .shortcode-wcpr-filter-rating-placeholder{
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  color: inherit !important;
  width: 100% !important;
  text-align: center;
  font-weight: 500;
  font-size: 14px;
  display: block;
}
/* Dropdown list — items pill-shaped, same width AND height as trigger button.
   Hidden by default; shown on wrap :hover (matches plugin behavior). */
.loluis-rpage__grid .shortcode-wcpr-filter-button-wrap{
  position: relative;
}
.loluis-rpage__grid .shortcode-wcpr-filter-button-ul{
  display: none !important;
  position: absolute !important;
  top: calc(100% + 6px) !important;
  left: 0 !important;
  right: auto !important;
  width: 100% !important;
  min-width: 100% !important;
  box-sizing: border-box;
  border: 0 !important;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  padding: 8px !important;
  margin: 0 !important;
  flex-direction: column;
  gap: 6px;
  border-radius: 12px;
  background: #fff !important;
  z-index: 50;
}
.loluis-rpage__grid .shortcode-wcpr-filter-button-wrap:hover .shortcode-wcpr-filter-button-ul,
.loluis-rpage__grid .shortcode-wcpr-filter-button-wrap:focus-within .shortcode-wcpr-filter-button-ul{
  display: flex !important;
}
.loluis-rpage__grid .shortcode-wcpr-filter-button-li{
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none;
  overflow: hidden;
  width: 100% !important;
  box-sizing: border-box;
  display: block !important;
}
/* Plugin hard-codes `width: 125px !important` on these anchors via inline CSS
   with selector `.shortcode-wcpr-filter-container li.x a` (specificity 30).
   We need >30 specificity to override → prefix with `.shortcode-wcpr-filter-container`. */
.loluis-rpage__grid .shortcode-wcpr-filter-container li.shortcode-wcpr-filter-button-li a,
.loluis-rpage__grid .shortcode-wcpr-filter-container li.shortcode-wcpr-filter-button-li > span,
.loluis-rpage__grid .shortcode-wcpr-filter-container li.shortcode-wcpr-filter-button-li > *{
  display: flex !important;
  align-items: center;
  justify-content: center;
  height: 40px;
  padding: 0 16px !important;
  width: 100% !important;
  min-width: 100% !important;
  text-decoration: none;
  color: var(--navy) !important;
  font-size: 14px;
  font-weight: 500;
  box-sizing: border-box;
  background: transparent !important;
  border: 0 !important;
}
.loluis-rpage__grid .shortcode-wcpr-filter-button-li:hover{
  border-color: #b8b8b8 !important;
}
.loluis-rpage__grid .shortcode-wcpr-filter-button-li.shortcode-wcpr-active,
.loluis-rpage__grid .shortcode-wcpr-filter-button-li.shortcode-wcpr-current{
  background: var(--gold) !important;
  border-color: var(--gold) !important;
}
.loluis-rpage__grid .shortcode-wcpr-filter-button-li.shortcode-wcpr-active a,
.loluis-rpage__grid .shortcode-wcpr-filter-button-li.shortcode-wcpr-active > span,
.loluis-rpage__grid .shortcode-wcpr-filter-button-li.shortcode-wcpr-current a,
.loluis-rpage__grid .shortcode-wcpr-filter-button-li.shortcode-wcpr-current > span{
  color: #fff !important;
}

/* All stars wrap is a DIV not an A — force same width as anchor buttons in 3-col grid */
.loluis-rpage__grid .shortcode-wcpr-filter-container .shortcode-wcpr-filter-button-wrap{
  width: 100% !important;
  display: block !important;
}

/* Star color (override Flatsome neutral) */
.loluis-rpage__grid .star-rating:before,
.loluis-rpage__grid .star-rating span:before{
  color: var(--gold) !important;
}

/* ===========================================================================
   Per-review card layout — avatar | (meta row), stars below name, body full-width
   =========================================================================== */
.loluis-rpage__grid .comment_container{
  display: grid !important;
  grid-template-columns: 40px 1fr;
  column-gap: 14px;
  row-gap: 4px;
  align-items: start;
  padding: 20px 22px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 12px;
  margin-bottom: 12px;
}
.loluis-rpage__grid .comment_container > .shortcode-wcpr-review-before{
  display: none;
}
/* Avatar — col 1 row 1 */
.loluis-rpage__grid .comment_container > img.avatar,
.loluis-rpage__grid .comment_container > .loluis-avatar{
  grid-column: 1;
  grid-row: 1;
  width: 40px;
  height: 40px;
  margin: 0;
  border-radius: 50%;
}
/* Promote .comment-text's children to direct grid items */
.loluis-rpage__grid .comment_container > .comment-text{
  display: contents;
}
/* 1. Meta (name + verified + date) — col 2, row 1, beside avatar.
   All inter-item spacing comes from flex `gap` only (uniform across items). */
.loluis-rpage__grid .comment_container .comment-text > .meta{
  grid-column: 2;
  grid-row: 1;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 3px;
  margin: 6px 0 0;
  padding: 0;
  font-size: 14px;
  line-height: 1.4;
}
.loluis-rpage__grid .woocommerce-review__author{
  font-weight: 600;
  color: var(--navy);
  font-size: 14px;
  margin: 0 !important;
}
.loluis-rpage__grid .woocommerce-review__dash{
  color: #aaa;
  margin: 0 !important;
}
.loluis-rpage__grid time.woocommerce-review__published-date{
  color: #888;
  font-size: 13px;
  white-space: nowrap;
}
/* 2. Stars — span both columns, row 2 (BELOW meta, no longer floating right) */
.loluis-rpage__grid .comment_container .comment-text > .star-rating{
  grid-column: 1 / -1;
  grid-row: 2;
  margin: 4px 0 2px;
  float: none !important;          /* override plugin default float:right */
  font-size: 14px;
  width: 5.4em;
}
/* 3. Title — row 3 */
.loluis-rpage__grid .comment_container .comment-text > .shortcode-wcpr-review-title{
  grid-column: 1 / -1;
  grid-row: 3;
  font-weight: 700;
  font-size: 15px;
  color: var(--navy);
  margin: 2px 0 6px;
}
/* 4. Body description — row 4 */
.loluis-rpage__grid .comment_container .comment-text > .description{
  grid-column: 1 / -1;
  grid-row: 4;
  color: #444;
  line-height: 1.6;
  font-size: 14px;
}
/* 5. Review images — row 5 */
.loluis-rpage__grid .comment_container .comment-text > .kt-reviews-image-container{
  grid-column: 1 / -1;
  grid-row: 5;
  margin-top: 8px;
}

/* ===========================================================================
   Initial-letter avatar (built by customer-reviews.js)
   =========================================================================== */
.loluis-rpage .loluis-avatar{
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 700;
  font-size: 17px;
  line-height: 1;
  text-transform: uppercase;
  flex-shrink: 0;
  user-select: none;
  letter-spacing: 0;
}

/* Verified tick — green check, tight to name, vertically centered via flex parent */
.loluis-rpage__grid em.woocommerce-photo-reviews-badge-tick,
.loluis-rpage__grid em.woocommerce-review__verified{
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  background-size: 14px 14px !important;
  background-position: center !important;
  margin: 0 !important;
  padding: 0 !important;
  flex-shrink: 0;
  vertical-align: middle;
  line-height: 1;
}

/* Pagination — uses `.shortcode-wcpr-pagination` + `.wcpr-page-numbers` */
.loluis-rpage__grid .shortcode-wcpr-pagination{
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 28px;
  flex-wrap: wrap;
}
.loluis-rpage__grid .shortcode-wcpr-pagination .wcpr-page-numbers{
  padding: 8px 14px;
  border-radius: 6px;
  border: 1px solid var(--border) !important;
  background: #fff !important;
  color: var(--navy) !important;
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  min-width: 38px;
  text-align: center;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.loluis-rpage__grid .shortcode-wcpr-pagination .wcpr-page-numbers.wcpr-current,
.loluis-rpage__grid .shortcode-wcpr-pagination a.wcpr-page-numbers:hover{
  background: var(--gold) !important;
  border-color: var(--gold) !important;
  color: #fff !important;
}
.loluis-rpage__grid .shortcode-wcpr-pagination .wcpr-no-page{
  border-color: transparent !important;
  background: transparent !important;
  cursor: default;
}

/* ---- Empty state ---- */
.loluis-rpage__empty{
  padding: 60px 0;
  text-align: center;
  color: #6b6b6b;
}
.loluis-rpage__empty a{
  color: var(--gold);
  font-weight: 600;
}

/* ---- Lightbox (standalone, built by customer-reviews.js) ---- */
#loluis-rlightbox{
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .92);
  z-index: 999999;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: loluis-rlb-fade .15s ease;
}
@keyframes loluis-rlb-fade{
  from{opacity:0} to{opacity:1}
}
.loluis-rlb__stage{
  max-width: 90vw;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.loluis-rlb__img{
  max-width: 90vw;
  max-height: 75vh;
  object-fit: contain;
  border-radius: 8px;
  background: #111;
  display: block;
}
.loluis-rlb__caption{
  color: #fff;
  font-size: 14px;
  text-align: center;
  max-width: 720px;
  line-height: 1.5;
}
.loluis-rlb__caption a{
  color: var(--gold);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.loluis-rlb__counter{
  color: #bbb;
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}
.loluis-rlb__close,
.loluis-rlb__nav{
  position: absolute;
  background: rgba(255,255,255,.12);
  color: #fff;
  border: 0;
  cursor: pointer;
  font-size: 32px;
  line-height: 1;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: background .15s ease, transform .15s ease;
}
.loluis-rlb__close:hover,
.loluis-rlb__nav:hover{
  background: rgba(255,255,255,.22);
}
.loluis-rlb__close{
  top: 24px;
  right: 24px;
  font-size: 28px;
}
.loluis-rlb__nav--prev{ left: 24px; top: 50%; transform: translateY(-50%); }
.loluis-rlb__nav--next{ right: 24px; top: 50%; transform: translateY(-50%); }

@media (max-width: 600px){
  .loluis-rlb__close{ top: 12px; right: 12px; }
  .loluis-rlb__nav--prev{ left: 8px; }
  .loluis-rlb__nav--next{ right: 8px; }
  .loluis-rlb__nav, .loluis-rlb__close{
    width: 40px;
    height: 40px;
    font-size: 24px;
  }
}

/* Mobile gallery & cats */
@media (max-width: 600px){
  .loluis-rwall{
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
  .loluis-rcats{
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 6px;
    -webkit-overflow-scrolling: touch;
  }
  .loluis-rcat{
    white-space: nowrap;
    flex: 0 0 auto;
  }
}
