/* === Contact (public) — DA v2 === */
.contact-title {
  font-family: 'Playfair Display', Georgia, serif;
  text-align: center; display: block;
  width: min(88%, var(--max-width));
  max-width: var(--max-width);
  margin: 0 auto 1.1rem;
}

.contact-page { margin: 1.25rem 0 2rem; }
.contact-container {
  width: min(88%, var(--max-width));
  max-width: var(--max-width);
  margin: 0 auto;
}

.contact-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 16px;
}
@media (max-width: 980px) { .contact-grid { grid-template-columns: 1fr; } }

/* Cards */
.card {
  background: var(--card, #fff);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: 0 4px 16px rgba(20,8,0,.06);
  padding: 1.2rem 1.3rem;
}
.section__head h2 { margin: 0 0 .4rem; font-family: 'Playfair Display', Georgia, serif; }

/* Coordonnées */
.contact-list {
  list-style: none; margin: .25rem 0 1rem; padding: 0;
  display: flex; flex-direction: column; gap: .55rem;
}
.contact-list li  { display: flex; gap: .6rem; align-items: flex-start; }
.contact-list .icon { font-size: 1.1rem; line-height: 1.4; }

/* Social chips */
.socials { display: flex; flex-wrap: wrap; gap: 8px; }
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: .28rem .7rem; border-radius: 999px;
  border: 1px solid var(--line); background: #fff;
  font-weight: 700; font-size: .85rem;
  transition: background .2s, border-color .2s;
}
.chip:hover { background: var(--bg-soft); }

.link {
  color: var(--accent); border-bottom: 1px dashed rgba(44,107,74,.3);
  transition: border-color .15s;
}
.link:hover { border-color: transparent; }

/* Carte */
.map { margin-top: .75rem; border-radius: 12px; overflow: hidden; box-shadow: 0 4px 16px rgba(20,8,0,.08); }
.map iframe { width: 100%; height: 320px; display: block; }

/* Formulaire */
.contact-form .form-row { margin: .65rem 0; }
.contact-form label { display: block; font-weight: 700; margin-bottom: .28rem; font-size: .94rem; }
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form input[type="url"],
.contact-form input[type="search"],
.contact-form input[type="password"],
.contact-form textarea {
  width: 100%; padding: .7rem .9rem;
  border: 1.5px solid #DDD6CB; border-radius: 8px;
  background: #fff; font-size: .96rem; font-family: inherit;
  color: var(--text);
  transition: border-color .2s, box-shadow .2s;
}
.contact-form input:focus,
.contact-form textarea:focus {
  outline: none; border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(181,117,46,.15);
}
.contact-form textarea { resize: vertical; min-height: 150px; }

.form-actions { display: flex; align-items: center; gap: .75rem; margin-top: .5rem; }
.muted { color: var(--muted); }
.hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
