/* ---- RESERVATION PAGE ---- */
.reservation-page {
  padding-top: 120px;
  min-height: 70vh;
}

.reservation-container {
  max-width: 680px;
}

/* Password gate */
.reservation-gate {
  text-align: center;
  background: var(--color-white);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: var(--radius-lg);
  padding: 48px 32px;
  box-shadow: var(--shadow-md);
}

.reservation-gate h1 {
  font-family: var(--font-heading-en);
  font-size: 1.8rem;
  color: var(--color-teal);
  margin-bottom: 12px;
}

.reservation-gate p {
  color: var(--color-charcoal);
  opacity: 0.8;
  margin-bottom: 24px;
}

.reservation-gate form {
  max-width: 320px;
  margin: 0 auto;
}

.reservation-gate .form__group label {
  color: var(--color-charcoal);
}

.reservation-gate .form__group input {
  background: var(--color-warm-white);
  color: var(--color-charcoal);
  border: 1.5px solid rgba(0,0,0,0.12);
}

.reservation-gate__error {
  color: #c0392b;
  font-size: 0.9rem;
  margin-bottom: 16px;
}

.reservation-gate #reservation-gate-submit {
  width: 100%;
  justify-content: center;
}

/* Dynamic form (light theme, unlike the dark .booking__form) */
.reservation-form.booking__form {
  background: var(--color-white);
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: var(--shadow-md);
  backdrop-filter: none;
  padding: 32px;
}

.reservation-form .form__group label {
  color: var(--color-charcoal);
}

.reservation-form .form__group input,
.reservation-form .form__group select,
.reservation-form .form__group textarea {
  background: var(--color-warm-white);
  color: var(--color-charcoal);
  border: 1.5px solid rgba(0,0,0,0.12);
}

.reservation-form .form__group--checkbox {
  background: var(--color-warm-white);
  border-radius: var(--radius);
  padding: 14px 16px;
}

.reservation-notice {
  background: rgba(232, 168, 56, 0.1);
  border-inline-start: 3px solid var(--color-gold);
  border-radius: var(--radius);
  padding: 14px 16px;
  margin-bottom: 18px;
  font-size: 0.9rem;
  line-height: 1.6;
  color: var(--color-charcoal);
}

.reservation-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  color: var(--color-charcoal);
  font-size: 0.92rem;
  line-height: 1.4;
}

.reservation-checkbox input {
  margin-top: 3px;
  width: auto !important;
  flex-shrink: 0;
}

.reservation-form__status {
  text-align: center;
  margin-bottom: 16px;
  font-weight: 600;
  color: var(--color-teal);
}

.reservation-form__status--error {
  color: #c0392b;
}

/* Success state */
.reservation-success {
  text-align: center;
  background: var(--color-white);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: var(--radius-lg);
  padding: 48px 32px;
}

.reservation-success h2 {
  font-family: var(--font-heading-en);
  color: var(--color-teal);
  margin-bottom: 12px;
}

.navbar__link--active {
  color: var(--color-gold) !important;
}
