/* Vipluck Club — Contact/Réservation */
.contact-hero { padding: 220px 0 60px; }
.contact-wrap { display: grid; grid-template-columns: 1.3fr 1fr; gap: 64px; margin-top: 60px; align-items: start; }

/* Left: booking + form */
.booking { background: var(--bg-1); border: 1px solid var(--line); border-radius: var(--radius-xl); overflow: hidden; }
.booking-tabs { display: flex; border-bottom: 1px solid var(--line); }
.booking-tab { flex: 1; padding: 18px 24px; font-family: var(--font-display); font-size: 14px; color: var(--ink-2); background: transparent; border-bottom: 2px solid transparent; transition: all .2s; text-align: left; }
.booking-tab:hover { color: var(--ink-0); }
.booking-tab.is-active { color: var(--ink-0); border-bottom-color: var(--accent); background: var(--bg-2); }
.booking-tab .mono { display: block; font-size: 10px; color: var(--ink-3); letter-spacing: 0.14em; margin-bottom: 4px; }

.booking-body { padding: 32px; }
.booking-panel { display: none; flex-direction: column; gap: 24px; }
.booking-panel.is-active { display: flex; }

.field { display: flex; flex-direction: column; gap: 8px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field label { font-family: var(--font-mono); font-size: 10px; color: var(--ink-2); letter-spacing: 0.16em; text-transform: uppercase; }
.field input, .field select, .field textarea { width: 100%; padding: 14px 16px; background: var(--bg-0); border: 1px solid var(--line); border-radius: 10px; color: var(--ink-0); font: 15px var(--font-sans); transition: border-color .2s; }
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--accent); outline: none; }
.field textarea { min-height: 120px; resize: vertical; }
.field input.is-invalid, .field select.is-invalid, .field textarea.is-invalid { border-color: #E5484D; }
.field-error { font-family: var(--font-mono); font-size: 11px; color: #E5484D; display: none; }
.field-error.is-visible { display: block; }

/* Date & time slot selectors */
.date-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.date-chip { display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 12px 4px; background: var(--bg-0); border: 1px solid var(--line); border-radius: 10px; cursor: pointer; transition: all .2s; }
.date-chip:hover { border-color: var(--line-strong); }
.date-chip.is-selected { border-color: var(--accent); background: var(--accent-soft); }
.date-chip.is-disabled { opacity: .35; cursor: not-allowed; }
.date-chip .dow { font-family: var(--font-mono); font-size: 10px; color: var(--ink-2); letter-spacing: 0.1em; text-transform: uppercase; }
.date-chip .dnum { font-family: var(--font-display); font-size: 18px; color: var(--ink-0); letter-spacing: -0.01em; }
.date-chip.is-selected .dnum { color: var(--accent); }

.time-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.time-slot { padding: 12px; background: var(--bg-0); border: 1px solid var(--line); border-radius: 10px; font-family: var(--font-mono); font-size: 13px; color: var(--ink-1); cursor: pointer; transition: all .2s; letter-spacing: 0.06em; }
.time-slot:hover:not(.is-disabled) { border-color: var(--line-strong); color: var(--ink-0); }
.time-slot.is-selected { border-color: var(--accent); background: var(--accent); color: var(--accent-ink); font-weight: 500; }
.time-slot.is-disabled { opacity: .3; cursor: not-allowed; text-decoration: line-through; }

.party-control { display: flex; align-items: center; gap: 0; border: 1px solid var(--line); border-radius: 10px; overflow: hidden; background: var(--bg-0); width: fit-content; }
.party-control button { width: 44px; height: 44px; font-size: 18px; color: var(--ink-1); transition: all .2s; }
.party-control button:hover { color: var(--accent); background: var(--bg-2); }
.party-control .party-val { padding: 0 20px; font-family: var(--font-display); font-size: 18px; min-width: 50px; text-align: center; }

.booking-summary { margin-top: 8px; padding: 18px 20px; background: var(--bg-2); border: 1px solid var(--line); border-radius: 12px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.booking-summary > div { display: flex; flex-direction: column; gap: 4px; }
.booking-summary .mono { color: var(--ink-3); font-size: 10px; }
.booking-summary strong { font-family: var(--font-display); font-size: 15px; letter-spacing: -0.01em; color: var(--ink-0); }

.booking-actions { display: flex; gap: 12px; justify-content: flex-end; margin-top: 8px; padding-top: 24px; border-top: 1px solid var(--line); }

.booking-success { display: none; flex-direction: column; align-items: center; gap: 16px; text-align: center; padding: 48px 20px; }
.booking-success.is-visible { display: flex; }
.booking-success .success-icon { width: 56px; height: 56px; border-radius: 50%; background: var(--accent-soft); border: 1px solid var(--accent-line); position: relative; }
.booking-success .success-icon::before { content: ""; position: absolute; top: 50%; left: 40%; width: 10px; height: 18px; border-right: 2px solid var(--accent); border-bottom: 2px solid var(--accent); transform: translate(-50%, -60%) rotate(45deg); }
.booking-success h3 { font-size: 26px; }
.booking-success p { max-width: 40ch; }

/* Waitlist intro + chip picks */
.waitlist-intro { padding: 16px 18px; background: var(--accent-soft); border: 1px solid var(--accent-line); border-radius: 12px; }
.chip-picks { display: flex; flex-wrap: wrap; gap: 8px; }
.chip-pick { cursor: pointer; }
.chip-pick input { position: absolute; opacity: 0; pointer-events: none; }
.chip-pick span { display: inline-block; padding: 10px 14px; border: 1px solid var(--line); border-radius: 999px; font-size: 13px; color: var(--ink-1); background: var(--bg-2); transition: all .15s; }
.chip-pick:hover span { color: var(--ink-0); border-color: var(--line-strong); }
.chip-pick input:checked + span { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); font-weight: 500; }
.field-checkbox { margin-top: 4px; }
.checkbox-row { display: flex; gap: 12px; align-items: flex-start; cursor: pointer; font-size: 13px; color: var(--ink-1); line-height: 1.55; }
.checkbox-row input[type="checkbox"] { width: 18px; height: 18px; flex-shrink: 0; margin-top: 2px; accent-color: var(--accent); cursor: pointer; }

/* Right: info column */
.contact-info { display: flex; flex-direction: column; gap: 24px; }
.info-card { background: var(--bg-1); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 28px; display: flex; flex-direction: column; gap: 12px; }
.info-card h3 { font-size: 20px; }
.info-card .info-line { font-size: 14px; color: var(--ink-1); }
.info-card .mono { color: var(--ink-3); }

.map-card { aspect-ratio: 4/3; background: var(--bg-1); border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; position: relative; }
.map-card .map-art {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 40px 40px;
}
.map-card::before {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(110deg, transparent 40%, var(--accent-soft) 48%, transparent 56%),
    linear-gradient(70deg, transparent 30%, var(--line-strong) 38%, transparent 42%, transparent 60%, var(--line-strong) 64%, transparent 68%);
}
.map-pin { position: absolute; top: 45%; left: 52%; z-index: 3; transform: translate(-50%, -50%); }
.map-pin .pin-dot { width: 12px; height: 12px; background: var(--accent); border-radius: 50%; box-shadow: 0 0 0 4px var(--accent-soft), 0 0 30px var(--accent); }
.map-pin .pin-pulse { position: absolute; inset: -30px; border: 1px solid var(--accent); border-radius: 50%; animation: pulse 2.4s ease-out infinite; opacity: 0; }
@keyframes pulse { 0% { transform: scale(.5); opacity: 1; } 100% { transform: scale(1.4); opacity: 0; } }
.map-label { position: absolute; bottom: 16px; left: 16px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; color: var(--ink-1); text-transform: uppercase; background: var(--bg-0); border: 1px solid var(--line); padding: 8px 12px; border-radius: 8px; z-index: 2; }

@media (max-width: 960px) {
  .contact-wrap { grid-template-columns: 1fr; }
  .field-row { grid-template-columns: 1fr; }
  .booking-summary { grid-template-columns: 1fr; }
  .time-grid { grid-template-columns: repeat(3, 1fr); }
  .date-grid { grid-template-columns: repeat(5, 1fr); }
  .booking-tabs { flex-wrap: wrap; }
  .booking-tab { min-width: 0; }
  .contact-hero { padding: 160px 0 40px; }
}
