/* reservations/reservations.css — Formulaire public de réservation */
.resa-topbar { display: flex; align-items: center; justify-content: space-between; padding: 1rem 1.5rem; border-bottom: 1px solid rgba(240,201,73,0.15); flex-wrap: wrap; gap: 1rem; }
.resa-logo { color: var(--accent, #f0c949); text-decoration: none; font-family: "Newsreader", Georgia, serif; font-size: 1.25rem; font-weight: 700; letter-spacing: 0.02em; }
.resa-topnav { display: flex; gap: 1.25rem; flex-wrap: wrap; }
.resa-topnav a { color: var(--text-muted, #aab3a7); text-decoration: none; font-size: 0.9rem; }
.resa-topnav a:hover { color: var(--accent, #f0c949); }

.resa-footer { padding: 2rem 1.5rem; text-align: center; color: var(--text-muted, #aab3a7); font-size: 0.85rem; border-top: 1px solid rgba(240,201,73,0.1); margin-top: 3rem; }
.resa-footer a { color: var(--accent, #f0c949); }

.reservations-page {
  max-width: 720px;
  margin: 0 auto;
  padding: 3rem 1.25rem 5rem;
  color: var(--text, #f5f2e8);
}

.resa-hero { text-align: center; margin-bottom: 2.5rem; }
.resa-hero h1 {
  font-family: "Newsreader", Georgia, serif;
  font-size: clamp(2rem, 4vw, 2.75rem);
  margin: 0 0 0.5rem;
  color: var(--accent, #f0c949);
  letter-spacing: -0.01em;
}
.resa-sub { color: var(--text-muted, #aab3a7); font-size: 0.95rem; margin: 0; }

.resa-form-wrap { background: var(--card, #122818); border: 1px solid rgba(240,201,73,0.18); border-radius: 16px; padding: 2rem 1.75rem; }

.resa-form .row { margin-bottom: 1.1rem; }
.resa-form .row--2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.resa-form .row--3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 1rem; }
@media (max-width: 600px) {
  .resa-form .row--2, .resa-form .row--3 { grid-template-columns: 1fr; }
}

.resa-form label {
  display: block; font-size: 0.85rem;
  color: var(--text-muted, #aab3a7);
  margin-bottom: 0;
  font-weight: 500;
}
.resa-form input[type="text"],
.resa-form input[type="email"],
.resa-form input[type="tel"],
.resa-form input[type="date"],
.resa-form select,
.resa-form textarea {
  width: 100%;
  margin-top: 0.35rem;
  padding: 0.7rem 0.9rem;
  background: rgba(0,0,0,0.25);
  border: 1px solid rgba(240,201,73,0.2);
  border-radius: 8px;
  color: var(--text, #f5f2e8);
  font-size: 0.95rem;
  font-family: inherit;
  line-height: 1.4;
}
.resa-form input:focus,
.resa-form select:focus,
.resa-form textarea:focus {
  outline: none;
  border-color: var(--accent, #f0c949);
  box-shadow: 0 0 0 3px rgba(240,201,73,0.15);
}
.resa-form textarea { resize: vertical; min-height: 80px; }
.resa-form select { appearance: none; background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath fill='%23f0c949' d='M7 10L2 4h10z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 0.9rem center; padding-right: 2.3rem; }

.resa-rgpd label { display: flex; gap: 0.6rem; align-items: flex-start; color: var(--text, #f5f2e8); font-size: 0.85rem; line-height: 1.5; cursor: pointer; }
.resa-rgpd input[type="checkbox"] { margin-top: 0.15rem; accent-color: var(--accent, #f0c949); width: 16px; height: 16px; flex-shrink: 0; }
.resa-rgpd a { color: var(--accent, #f0c949); }

.resa-actions { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; margin-top: 1.5rem; }
.btn-primary {
  display: inline-block; padding: 0.9rem 1.8rem;
  background: var(--accent, #f0c949);
  color: var(--bg, #0a1f0f);
  border: none; border-radius: 10px;
  font-weight: 700; font-size: 1rem; cursor: pointer;
  font-family: inherit;
  transition: transform 0.15s, background 0.15s;
  text-decoration: none;
}
.btn-primary:hover:not(:disabled) { background: #d4ae2b; transform: translateY(-1px); }
.btn-primary:disabled { opacity: 0.6; cursor: wait; }

.form-status { margin: 0; color: var(--text-muted, #aab3a7); font-size: 0.9rem; }
.form-status.error { color: #e66b4a; }
.form-status.success { color: #7ac77a; }

.resa-legal { color: var(--text-muted, #aab3a7); font-size: 0.8rem; margin-top: 1.75rem; line-height: 1.6; text-align: center; }
.resa-legal a { color: var(--accent, #f0c949); }

.resa-success { text-align: center; padding: 1rem 0; }
.resa-success h2 { color: var(--accent, #f0c949); font-family: "Newsreader", Georgia, serif; font-size: 1.75rem; margin-bottom: 1rem; }
.resa-success__sub { color: var(--text-muted, #aab3a7); font-size: 0.9rem; margin-top: 0.5rem; }

/* Honeypot — invisible to users and browsers */
.hp { position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; }
