/* review-modal.css — styles for script.review-modal.js (new-review quick rate).
   Mirrors the bottom-sheet pattern of call-modal.css / email-modal.css. */

.review-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
}

.review-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
}

.review-modal__sheet {
  --rvm-bg: #ffffff;
  --rvm-surface: #f4f5f7;
  --rvm-primary: #2991cf;
  --rvm-on-primary: #ffffff;
  --rvm-text: #111111;
  --rvm-radius: 16px;

  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  max-width: 480px;
  margin: 0 auto;
  background: var(--rvm-bg);
  color: var(--rvm-text);
  border-radius: var(--rvm-radius) var(--rvm-radius) 0 0;
  padding: 20px 20px calc(24px + env(safe-area-inset-bottom, 0px));
  box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.18);
  animation: review-modal-up 0.22s ease-out;
  font-family: 'Montserrat', sans-serif;
}

@keyframes review-modal-up {
  from { transform: translateY(40px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}

@media (min-width: 600px) {
  .review-modal__sheet {
    bottom: auto;
    top: 50%;
    transform: translateY(-50%);
    border-radius: var(--rvm-radius);
  }
}

.review-modal__close {
  position: absolute;
  top: 10px;
  right: 14px;
  border: 0;
  background: none;
  font-size: 26px;
  line-height: 1;
  color: var(--rvm-text);
  opacity: 0.5;
  cursor: pointer;
  padding: 6px;
}

.review-modal__avatar {
  display: block;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  object-fit: cover;
  margin: 0 auto 10px;
}

.review-modal__title {
  margin: 0 0 16px;
  font-size: 18px;
  font-weight: 600;
  text-align: center;
}

/* stars */
.review-modal__stars {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-bottom: 4px;
}

.review-modal__star {
  border: 0;
  background: none;
  padding: 4px;
  cursor: pointer;
}

.review-modal__star svg {
  width: 44px;
  height: 44px;
  fill: var(--rvm-surface);
  stroke: #c9ced6;
  stroke-width: 1;
  transition: fill 0.12s ease, transform 0.12s ease;
}

.review-modal__star.is-filled svg {
  fill: #ffc234;
  stroke: #ffc234;
  transform: scale(1.08);
}

/* emoji options */
.review-modal__emojis {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 4px;
}

.review-modal__emoji {
  border: 2px solid transparent;
  background: var(--rvm-surface);
  border-radius: 12px;
  padding: 8px;
  cursor: pointer;
  transition: border-color 0.12s ease, transform 0.12s ease;
}

.review-modal__emoji img {
  width: 40px;
  height: 40px;
  display: block;
}

.review-modal__emoji.is-active {
  border-color: var(--rvm-primary);
  transform: scale(1.06);
}

/* actions */
.review-modal__actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 18px;
}

.review-modal__btn {
  width: 100%;
  border: 1px solid var(--rvm-primary);
  background: var(--rvm-bg);
  color: var(--rvm-primary);
  font: inherit;
  font-weight: 600;
  padding: 13px 16px;
  border-radius: 12px;
  cursor: pointer;
  min-height: 48px;
}

.review-modal__btn--primary {
  background: var(--rvm-primary);
  color: var(--rvm-on-primary);
}

/* thanks */
.review-modal__thanks {
  text-align: center;
}

.review-modal__check {
  width: 56px;
  height: 56px;
  margin: 4px auto 14px;
  border-radius: 50%;
  background: #22c55e;
  color: #fff;
  font-size: 30px;
  line-height: 56px;
}

.review-modal__share {
  margin: 0 0 10px;
  font-size: 14px;
  opacity: 0.75;
}

.review-modal__platforms {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-bottom: 16px;
}

.review-modal__platform {
  display: inline-block;
  padding: 10px 18px;
  border-radius: 999px;
  background: var(--rvm-surface);
  color: var(--rvm-text);
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
}

/* loading / error */
.review-modal__loading,
.review-modal__error {
  text-align: center;
  padding: 18px 0;
}

.review-modal__spinner {
  width: 28px;
  height: 28px;
  margin: 0 auto 12px;
  border: 3px solid var(--rvm-surface);
  border-top-color: var(--rvm-primary);
  border-radius: 50%;
  animation: review-modal-spin 0.8s linear infinite;
}

@keyframes review-modal-spin {
  to { transform: rotate(360deg); }
}
