/* contact.css — Contact & Réservation */

.contact-hero {
  border-bottom: 1px solid var(--ink);
  padding: 56px var(--gutter-m) 48px;
}
.contact-hero__inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
}
.contact-hero__title {
  font-family: var(--ff-display);
  font-size: clamp(48px, 6.2vw, 88px);
  line-height: 0.94;
  font-weight: 900;
  letter-spacing: -0.025em;
  margin-top: 18px;
}
.contact-hero__title em { font-style: italic; font-family: var(--ff-italic); color: var(--rouge); font-weight: 400; }
.contact-hero__intro { font-size: 17px; line-height: 1.6; color: var(--ink-soft); margin-top: 18px; max-width: 480px; }
.contact-hero__side > * + * { margin-top: 18px; }
.contact-hero__field-label {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--gris-chaud);
  text-transform: uppercase;
}
.contact-hero__field-tel {
  font-family: var(--ff-display);
  font-size: 30px;
  color: var(--rouge);
  display: block;
  margin-top: 6px;
  font-weight: 700;
}
.contact-hero__field-email {
  font-family: var(--ff-italic);
  font-style: italic;
  font-size: 17px;
  color: var(--ink);
  display: block;
  margin-top: 6px;
}
.contact-hero__field-addr {
  font-size: 16px;
  color: var(--ink);
  margin-top: 6px;
  line-height: 1.4;
}
@media (min-width: 900px) {
  .contact-hero { padding: 88px var(--gutter-d) 64px; }
  .contact-hero__inner { grid-template-columns: 1.2fr 1fr; gap: 80px; }
  .contact-hero__side { align-self: end; }
  .contact-hero__field-tel { font-size: 38px; }
}

/* ════════ Quick contact mobile ══════════════════════════════ */
.contact-quick {
  background: var(--anthracite);
  color: #EDE6D6;
  padding: 18px var(--gutter-m);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.contact-quick__call,
.contact-quick__form-link {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
}
.contact-quick__call {
  background: var(--rouge);
  color: #fff;
}
.contact-quick__call-label {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: rgba(255, 255, 255, 0.7);
}
.contact-quick__call-tel {
  flex: 1;
  font-family: var(--ff-display);
  font-size: 20px;
  color: #fff;
  font-weight: 700;
}
.contact-quick__form-link {
  border: 1px solid rgba(237, 230, 214, 0.3);
}
.contact-quick__form-link-label {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--or-sourd);
}
.contact-quick__form-link-text { flex: 1; font-size: 14px; color: #EDE6D6; }
@media (min-width: 900px) { .contact-quick { display: none; } }

/* ════════ Body : form + horaires ═══════════════════════════ */
.contact-body { padding: 32px var(--gutter-m) 56px; max-width: var(--max-w); margin: 0 auto; }
.contact-body__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
}
@media (min-width: 900px) {
  .contact-body { padding: 64px var(--gutter-d) 96px; }
  .contact-body__inner { grid-template-columns: 1.3fr 1fr; gap: 56px; }
}

.contact-form__row {
  display: grid;
  gap: 14px;
  margin-bottom: 14px;
}
.contact-form__row--2 { grid-template-columns: 1fr 1fr; }
.contact-form__row--3 { grid-template-columns: 1fr; }
@media (min-width: 600px) { .contact-form__row--3 { grid-template-columns: 1fr 1fr 1fr; } }
.contact-form__actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 4px; }
.contact-form__note {
  font-family: var(--ff-italic);
  font-style: italic;
  font-size: 13.5px;
  color: var(--ink-soft);
  margin-top: 14px;
}

/* ════════ Horaires table ════════════════════════════════════ */
.contact-horaires { border-top: 1px solid var(--ink); }
.contact-horaires__row {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--hl);
  align-items: baseline;
}
.contact-horaires__row.is-ferme { opacity: 0.5; }
.contact-horaires__jour { font-family: var(--ff-display); font-size: 16px; }
.contact-horaires__times {
  font-family: var(--ff-mono);
  font-size: 11.5px;
  color: var(--ink-soft);
  text-align: right;
  letter-spacing: 0.04em;
}
@media (min-width: 900px) {
  .contact-horaires__row { grid-template-columns: 1fr 1fr 1fr; padding: 14px 0; }
  .contact-horaires__jour { font-size: 17px; }
  .contact-horaires__times { font-size: 12px; }
  .contact-horaires__times--midi { text-align: left; }
}
.contact-horaires__info {
  margin-top: 22px;
  padding: 16px 18px;
  background: var(--surface-2);
  border: 1px solid var(--hl);
}
.contact-horaires__info-label {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  color: var(--or-sourd);
  text-transform: uppercase;
  margin-bottom: 8px;
}
.contact-horaires__info-text {
  font-family: var(--ff-italic);
  font-style: italic;
  font-size: 14px;
  color: var(--ink);
  line-height: 1.55;
}

/* ════════ Map OSM ═══════════════════════════════════════════ */
.contact-map-section { border-top: 1px solid var(--hl); padding: 48px var(--gutter-m) 64px; }
.contact-map-section__inner { max-width: var(--max-w); margin: 0 auto; }
.contact-map {
  position: relative;
  width: 100%;
  height: 360px;
  border: 1px solid var(--hl);
  overflow: hidden;
}
.contact-map iframe {
  width: 100%;
  height: 100%;
  border: 0;
  filter: grayscale(0.15) contrast(0.96);
}
.contact-map__card {
  position: absolute;
  bottom: 16px;
  left: 16px;
  padding: 12px 16px;
  background: var(--papier);
  border: 1px solid var(--ink);
  max-width: 280px;
}
.contact-map__card-label {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--rouge);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.contact-map__card-addr { font-size: 13px; color: var(--ink); line-height: 1.5; }
.contact-map__card-link {
  margin-top: 8px;
  display: inline-block;
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--rouge);
  text-transform: uppercase;
}
.contact-venir-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 24px;
}
.contact-venir-card { padding: 14px 16px; border: 1px solid var(--hl); }
.contact-venir-card__label {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  color: var(--rouge);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.contact-venir-card__body { font-size: 14px; color: var(--ink); line-height: 1.5; }
@media (min-width: 900px) {
  .contact-map-section { padding: 64px var(--gutter-d) 96px; }
  .contact-map { height: 460px; }
  .contact-venir-grid { grid-template-columns: repeat(3, 1fr); gap: 24px; }
}
