/**
 * @file ratings-reviews-widget.css
 * Widget Ratings & Reviews — estilos del snapshot, average, lista y paginación.
 */

/* ── Custom properties ───────────────────────────────────────────────────── */
:root {
  --rr-primary:    #002663;
  --rr-star:       #f5a623;
  --rr-bg:         #f5f5f5;
  --rr-white:      #ffffff;
  --rr-text:       #212529;
  --rr-gray:       #6c757d;
  --rr-border:     #dee2e6;
  --rr-radius:     6px;
  --rr-shadow:     0 2px 8px rgba(0,0,0,.07);
  --rr-speed:      0.18s;
}

/* ── Sección wrapper ────────────────────────────────────────────────────── */
.rr-section { background: var(--rr-bg); padding: 3rem 0; }
.rr-container { max-width: 980px; margin: 0 auto; padding: 0 1.25rem; }

/* ── Título ─────────────────────────────────────────────────────────────── */
.rr-heading  { border-bottom: 2px solid var(--rr-border); padding-bottom: .75rem; }
.rr-title    { font-size: 1.6rem; font-weight: 700; color: var(--rr-text); margin: 0; }

/* ══════════════════════════════════════════════════════════════════════════
   STATS — Rating Snapshot + Average
══════════════════════════════════════════════════════════════════════════ */

/* Columna snapshot */
.rr-snapshot-col { padding: 1rem 1.25rem; }
.rr-snapshot__label {
  font-size: .78rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: var(--rr-primary); margin-bottom: .75rem;
}

/* Fila por estrella — usa clases .row/.col del tema porque el HTML original las tenía */
.rr-bar-row { align-items: center; }

.rr-bar-row__star {
  font-size: .82rem; color: var(--rr-gray);
  display: flex; align-items: center; gap: .2rem;
}
.rr-bar-row__star .fa-star { font-size: .78rem; color: var(--rr-star); }

/* Barra de fondo */
.rating-container__bg {
  width: 100%; height: 10px;
  background: var(--rr-border); border-radius: 999px; overflow: hidden;
}
/* Barra de relleno */
.rating-container__percentage {
  height: 100%; border-radius: 999px;
  transition: width .45s cubic-bezier(.4,0,.2,1);
  font-size: 0; /* oculta el texto del % dentro de la barra */
  color: transparent;
}
.bar-green { background: var(--rr-primary); }

.rr-bar-row__count {
  font-size: .82rem; font-weight: 600; color: var(--rr-gray); text-align: left;
}

/* Columna average */
.rr-average-col {
  padding: 1rem 1.25rem;
  display: flex; flex-direction: column;
  align-items: flex-start; justify-content: center;
}
.rr-average__label {
  font-size: .78rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: var(--rr-gray); margin-bottom: .35rem;
}
.rr-average__number {
  font-size: 4.5rem; font-weight: 700; line-height: 1;
  color: var(--rr-text); margin-bottom: .3rem;
}
.rr-average__stars { font-size: 1.4rem; color: var(--rr-border); margin-bottom: .3rem; }
.rr-average__stars .fa-star { margin-right: .1rem; }
.rr-average__stars .rr-star-icon--filled { color: var(--rr-star); }
.rr-average__total { font-size: .82rem; color: var(--rr-gray); margin: 0; }

/* Icono estrella genérico en snapshot */
.rr-star-icon { color: var(--rr-star); }

/* ══════════════════════════════════════════════════════════════════════════
   FILTER BAR — Sort + botón
══════════════════════════════════════════════════════════════════════════ */
.rr-filter-bar {
  display: flex; flex-wrap: wrap;
  align-items: center; justify-content: space-between;
  gap: .75rem; padding: .75rem 1rem;
  background: var(--rr-white); border: 1px solid var(--rr-border);
  border-radius: var(--rr-radius); margin: 1.5rem 0;
}
.rr-sort { display: flex; align-items: center; gap: .5rem; }
.rr-sort__label {
  font-size: .78rem; text-transform: uppercase;
  letter-spacing: .05em; color: var(--rr-gray); white-space: nowrap;
}
.rr-sort__select {
  padding: .35rem .65rem; border: 1px solid var(--rr-border);
  border-radius: var(--rr-radius); font-size: .85rem;
  background: var(--rr-white); cursor: pointer; color: var(--rr-text);
  transition: border-color var(--rr-speed);
}
.rr-sort__select:focus { outline: none; border-color: var(--rr-primary); }
.rr-status-notice { font-size: .85rem; color: var(--rr-gray); margin: 0; font-style: italic; }

/* ── Botones ────────────────────────────────────────────────────────────── */
.rr-btn {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .55rem 1.4rem; border: 2px solid transparent;
  border-radius: var(--rr-radius); font-size: .85rem;
  font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
  cursor: pointer; text-decoration: none; line-height: 1.4;
  transition: filter var(--rr-speed), box-shadow var(--rr-speed);
}
.rr-btn--primary { background: var(--rr-primary); border-color: var(--rr-primary); color: #fff; }
.rr-btn--primary:hover,
.rr-btn--primary:focus { filter: brightness(1.08); box-shadow: 0 3px 10px rgba(133,179,54,.35); outline: none; }
.rr-btn--primary:active { filter: brightness(.96); }
.rr-btn:disabled,
.rr-btn.rr-btn--disabled { opacity: .5; cursor: not-allowed; pointer-events: none; }

/* ══════════════════════════════════════════════════════════════════════════
   LISTA DE REVIEWS
══════════════════════════════════════════════════════════════════════════ */
.rr-list { position: relative; min-height: 80px; }

/* Loading spinner */
.rr-loading {
  display: flex; justify-content: center;
  align-items: center; padding: 2.5rem 0;
}
.rr-loading__spinner {
  width: 36px; height: 36px;
  border: 3px solid var(--rr-border);
  border-top-color: var(--rr-primary);
  border-radius: 50%; animation: rr-spin .65s linear infinite;
}
@keyframes rr-spin { to { transform: rotate(360deg); } }

/* Empty state */
.rr-empty {
  text-align: center; color: var(--rr-gray);
  padding: 3rem 0; font-size: .95rem;
}

/* ── Tarjeta review ─────────────────────────────────────────────────────── */
.rr-review {
  background: var(--rr-white);
  border: 1px solid var(--rr-border);
  border-radius: var(--rr-radius);
  padding: 1.25rem 1.5rem;
  margin-bottom: .875rem;
  box-shadow: var(--rr-shadow);
  transition: box-shadow var(--rr-speed), transform var(--rr-speed);
}
.rr-review:last-child { margin-bottom: 0; }
.rr-review:hover { box-shadow: 0 5px 18px rgba(0,0,0,.11); transform: translateY(-1px); }

.rr-review__header {
  display: flex; align-items: center;
  flex-wrap: wrap; gap: .5rem .75rem;
  margin-bottom: .65rem;
}
.rr-review__stars { font-size: 1rem; color: var(--rr-border); flex-shrink: 0; }
.rr-review__stars .fa-star { margin-right: .05rem; }
.rr-review__stars .rr-star-icon--filled { color: var(--rr-star); }

.rr-review__meta {
  display: flex; flex-wrap: wrap;
  gap: .2rem .6rem; align-items: baseline;
}
.rr-review__author { font-size: .82rem; font-weight: 700; color: var(--rr-text); }
.rr-review__date   { font-size: .78rem; color: var(--rr-gray); }

.rr-review__title {
  font-size: 1rem; font-weight: 700;
  color: var(--rr-text); margin: 0 0 .4rem;
}
.rr-review__body {
  font-size: .88rem; color: var(--rr-text);
  line-height: 1.7; margin: 0;
}
.rr-review__recommend {
  display: inline-flex; align-items: center; gap: .35rem;
  margin-top: .6rem; font-size: .8rem; font-weight: 600;
  padding: .2rem .6rem; border-radius: 999px;
}
.rr-review__recommend--yes {
  color: var(--rr-primary); background: rgba(133,179,54,.1);
}
.rr-review__recommend--no {
  color: var(--rr-gray); background: rgba(108,117,125,.08);
}

/* ══════════════════════════════════════════════════════════════════════════
   PAGINACIÓN
══════════════════════════════════════════════════════════════════════════ */
.rr-pagination { margin-top: 1.75rem; }
.rr-pagination__list {
  display: flex; justify-content: center; align-items: center;
  gap: .5rem; list-style: none; margin: 0; padding: 0;
}
.rr-pagination__btn {
  width: 36px; height: 36px; padding: 0;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--rr-border); border-radius: var(--rr-radius);
  background: var(--rr-white); font-size: .85rem; cursor: pointer;
  color: var(--rr-text);
  transition: background var(--rr-speed), color var(--rr-speed), border-color var(--rr-speed);
}
.rr-pagination__btn:hover:not(:disabled) {
  background: var(--rr-primary); border-color: var(--rr-primary); color: #fff;
}
.rr-pagination__btn:disabled,
.rr-pagination__item.is-disabled .rr-pagination__btn {
  opacity: .35; cursor: not-allowed;
}
.rr-pagination__info {
  font-size: .85rem; font-weight: 600; color: var(--rr-gray);
  min-width: 3.5rem; text-align: center;
}

/* ── Accessibility ──────────────────────────────────────────────────────── */
.visually-hidden {
  position: absolute; width: 1px; height: 1px;
  padding: 0; overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 767px) {
  .rr-average-col { border-top: 1px solid var(--rr-border); margin-top: 1rem; }
  .rr-filter-bar  { flex-direction: column; align-items: flex-start; }
  .rr-review      { padding: 1rem; }
  .rr-average__number { font-size: 3.2rem; }
}
