/* reviews.css — apartado de reseñas (formulario + estrellas). Usa variables del sitio con fallback. */
.reviews-cta { text-align: center; margin-top: 34px; }
.rv-open-btn {
  background: transparent; color: var(--brand-green-dark, #157A3D);
  border: 2px solid var(--brand-green, #1FA050); border-radius: 999px;
  padding: 12px 30px; font-size: 16px; font-weight: 700; cursor: pointer;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}
.rv-open-btn:hover { background: var(--brand-green, #1FA050); color: #fff; transform: translateY(-1px); }

.review-form {
  max-width: 640px; margin: 26px auto 0; background: var(--bg-elevated, #fff);
  border: 1px solid var(--metal-300, #E5E5EA); border-radius: 18px;
  padding: 28px; box-shadow: 0 12px 32px rgba(0,0,0,.07);
  display: flex; flex-direction: column; gap: 14px; text-align: left;
}
.review-form[hidden] { display: none; }
.review-form h3 { margin: 0 0 2px; font-size: 20px; color: var(--text-primary, #1D1D1F); }
.rv-row { display: flex; gap: 12px; flex-wrap: wrap; }
.rv-row .rv-input { flex: 1 1 200px; }
.rv-input {
  width: 100%; box-sizing: border-box; padding: 12px 14px; font-size: 15px;
  border: 1px solid var(--metal-300, #E5E5EA); border-radius: 10px; font-family: inherit;
  color: var(--text-primary, #1D1D1F); background: var(--bg-primary, #fff);
}
.rv-input:focus { outline: none; border-color: var(--brand-green, #1FA050); box-shadow: 0 0 0 3px var(--brand-green-pale, #E5F7EC); }
textarea.rv-input { resize: vertical; min-height: 92px; }
.rv-rate { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.rv-rate > span { font-weight: 600; color: var(--text-secondary, #6E6E73); }
.rv-stars { display: inline-flex; gap: 4px; }
.rv-star {
  background: none; border: none; cursor: pointer; padding: 0 2px;
  font-size: 30px; line-height: 1; color: var(--metal-400, #C7C7CC);
  transition: color .12s ease, transform .12s ease;
}
.rv-star:hover { transform: scale(1.12); }
.rv-star.on { color: #FFB200; }
.rv-hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; opacity: 0; }
.rv-submit-btn {
  align-self: flex-start; background: var(--brand-green, #1FA050); color: #fff; border: none;
  border-radius: 999px; padding: 13px 30px; font-size: 16px; font-weight: 700; cursor: pointer;
  transition: background .2s ease, transform .2s ease;
}
.rv-submit-btn:hover { background: var(--brand-green-dark, #157A3D); transform: translateY(-1px); }
.rv-submit-btn:disabled { opacity: .6; cursor: default; transform: none; }
.rv-msg { font-size: 14px; min-height: 18px; }
.rv-msg.ok { color: var(--brand-green-dark, #157A3D); font-weight: 600; }
.rv-msg.err { color: var(--error, #FF453A); font-weight: 600; }
@media (max-width: 560px) {
  .review-form { padding: 20px; }
  .rv-submit-btn { width: 100%; align-self: stretch; text-align: center; }
}
