/* NK Travel — reviews page */

/* ─── REVIEW CARDS (mirrors home.css) ────────── */
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.review-card {
  background: white; border: 1.5px solid var(--cream-mid); border-radius: var(--radius);
  padding: 32px 28px; display: flex; flex-direction: column; gap: 16px;
  transition: box-shadow 0.3s, border-color 0.3s;
}
.review-card:hover { box-shadow: var(--shadow); border-color: rgba(45,74,62,0.15); }
.review-stars { display: flex; gap: 3px; color: var(--amber); font-size: 14px; }
.review-tour {
  font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--green-mid); background: rgba(45,74,62,0.07);
  display: inline-block; padding: 4px 10px; border-radius: 100px;
}
.review-text {
  font-family: var(--serif); font-size: 16px; font-style: italic;
  color: var(--ink-soft); line-height: 1.65; flex: 1;
}
.review-author { display: flex; align-items: center; gap: 12px; padding-top: 16px; border-top: 1px solid var(--cream-mid); }
.review-avatar {
  width: 42px; height: 42px; border-radius: 50%; background: var(--green); color: white;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 600; flex-shrink: 0;
}
.review-avatar-photo { object-fit: cover; }
.review-name { font-size: 13px; font-weight: 600; color: var(--ink); margin-bottom: 2px; }
.review-from { font-size: 11.5px; color: var(--stone); }

/* ─── PAGE SECTION ────────────────────────────── */
.reviews-page-section { padding: 60px; }

/* ─── REVEAL ANIMATION ────────────────────────── */
.review-card.reveal { opacity: 0; transform: translateY(18px); transition: opacity 0.5s ease, transform 0.5s ease; }
.review-card.reveal.is-visible { opacity: 1; transform: none; }

/* ─── RESPONSIVE ──────────────────────────────── */
@media (max-width: 1024px) {
  .reviews-page-section { padding: 48px 40px; }
  .reviews-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .reviews-page-section { padding: 40px 20px; }
  .reviews-grid { grid-template-columns: 1fr; }
}

/* ─── REVIEW SUBMIT MODAL ───────────────────── */
.review-open-button {
  margin-top: 24px; border: 0; border-radius: 999px; background: var(--green); color: white; cursor: pointer;
  padding: 14px 24px; font-weight: 700; letter-spacing: 0.02em; transition: transform 0.2s, box-shadow 0.2s;
}
.review-open-button:hover { transform: translateY(-1px); box-shadow: var(--shadow); }
.review-modal { position: fixed; inset: 0; z-index: 1000; display: none; align-items: center; justify-content: center; padding: 24px; }
.review-modal.is-open { display: flex; }
.review-modal-backdrop { position: absolute; inset: 0; background: rgba(18, 28, 24, 0.58); backdrop-filter: blur(4px); }
.review-modal-dialog {
  position: relative; z-index: 1; width: min(880px, 100%); max-height: min(760px, calc(100vh - 48px)); overflow: auto;
  padding: 36px; border: 1.5px solid var(--cream-mid); border-radius: var(--radius);
  background: linear-gradient(135deg, rgba(255,255,255,0.98), rgba(248,244,235,0.96)); box-shadow: var(--shadow);
}
.review-modal-close {
  position: absolute; top: 16px; right: 16px; width: 38px; height: 38px; border: 1px solid var(--cream-mid);
  border-radius: 50%; background: white; color: var(--ink); cursor: pointer; font-size: 24px; line-height: 1;
}
.review-submit-copy { max-width: 640px; margin-bottom: 24px; }
.review-submit-copy h2 { margin: 10px 0 12px; font-family: var(--serif); font-size: clamp(28px, 4vw, 42px); color: var(--ink); }
.review-submit-copy p { margin: 0; color: var(--ink-soft); line-height: 1.7; }
.review-submit-form { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.review-submit-form label { display: flex; flex-direction: column; gap: 8px; font-size: 12px; font-weight: 700; color: var(--green); text-transform: uppercase; letter-spacing: 0.06em; }
.review-submit-form input,
.review-submit-form textarea {
  width: 100%; border: 1px solid var(--cream-mid); border-radius: 16px; background: white; color: var(--ink);
  font: inherit; padding: 13px 14px; outline: none; transition: border-color 0.2s, box-shadow 0.2s;
}
.review-submit-form input:focus,
.review-submit-form textarea:focus { border-color: var(--green-mid); box-shadow: 0 0 0 3px rgba(45,74,62,0.10); }
.review-submit-form textarea { min-height: 140px; resize: vertical; }
.review-submit-wide,
.review-form-message { grid-column: 1 / -1; }
.review-form-message { padding: 12px 14px; border-radius: 14px; font-size: 14px; line-height: 1.5; }
.review-form-message.is-success { background: rgba(45,74,62,0.10); color: var(--green); }
.review-form-message.is-error { background: rgba(156,56,40,0.10); color: #9c3828; }
.review-submit-button {
  justify-self: start; border: 0; border-radius: 999px; background: var(--green); color: white; cursor: pointer;
  padding: 14px 24px; font-weight: 700; letter-spacing: 0.02em; transition: transform 0.2s, box-shadow 0.2s;
}
.review-submit-button:hover { transform: translateY(-1px); box-shadow: var(--shadow); }
.review-submit-button:disabled { cursor: wait; opacity: 0.72; }
.review-modal-open { overflow: hidden; }

@media (max-width: 640px) {
  .review-modal { padding: 12px; }
  .review-modal-dialog { padding: 28px 20px 22px; max-height: calc(100vh - 24px); }
  .review-submit-form { grid-template-columns: 1fr; }
}

.review-consent { flex-direction: row !important; align-items: flex-start; gap: 10px; font-size: 12px; line-height: 1.5; color: var(--ink-soft); text-transform: none; letter-spacing: 0; }
.review-consent input { width: 16px; height: 16px; margin-top: 2px; flex: 0 0 auto; }
.review-consent a { color: var(--green); text-decoration: underline; }
