/* ============================================================
   L'Effet Mur — page Contact (formulaire + carte des zones)
   S'appuie sur effet-mur.css.
   ============================================================ */

/* La page contact ouvre directement sur le formulaire : on lui
   redonne un peu d'air en haut. */
.site > .contact { padding-top: clamp(40px, 6vw, 80px); }

/* ---------------------------------------------------------- ZONES */
.zones__grid { display: grid; grid-template-columns: .82fr 1.18fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
.zones__intro .lead { margin-top: 16px; }

.zones__list { list-style: none; margin: 30px 0 0; padding: 0; display: flex; flex-direction: column; }
.zones__list li {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 4px; border-bottom: 1px solid var(--line);
  font-size: 18px;
}
.zones__list li:first-child { border-top: 1px solid var(--line); }
.zones__pin { width: 13px; height: 13px; border-radius: 4px; flex: none; box-shadow: 0 0 12px currentColor; }
.zones__list b { font-family: var(--font-display); font-weight: 600; }
.zones__no {
  margin-left: auto; font-family: var(--font-display); font-weight: 700;
  font-size: 15px; color: var(--muted);
  border: 1px solid var(--line-2); border-radius: 8px; padding: 3px 10px;
}
.zones__note { margin-top: 22px; color: var(--muted); font-size: 15px; max-width: 42ch; }

.zones__map { position: relative; }
.zmap {
  width: 100%; height: clamp(420px, 52vh, 560px);
  border: 1px solid var(--line); border-radius: var(--radius-lg);
  overflow: hidden; background: #0c0c14; z-index: 1;
}
.zones__hint { margin-top: 14px; color: var(--muted); font-size: 13.5px; }

/* Leaflet — habillage sombre cohérent */
.zmap .leaflet-container { background: #0c0c14; font-family: var(--font-body); }
.zmap .leaflet-control-zoom a {
  background: var(--card-solid); color: var(--ink); border-color: var(--line-2);
}
.zmap .leaflet-control-zoom a:hover { background: var(--card-2); }
.zmap .leaflet-bar { border: 1px solid var(--line-2); box-shadow: var(--halo); }
.zmap .leaflet-control-attribution {
  background: rgba(10,10,18,.7); color: var(--muted);
}
.zmap .leaflet-control-attribution a { color: var(--ink-2); }
.zmap .leaflet-tooltip {
  background: var(--card-solid); color: var(--ink);
  border: 1px solid var(--line-2); border-radius: 8px;
  box-shadow: var(--halo); font-weight: 700; font-size: 13px; padding: 5px 9px;
}
.zmap .leaflet-tooltip::before { display: none; }

/* Repère Poitiers */
.poi-icon { background: none; border: 0; }
.poi-dot {
  display: block; width: 14px; height: 14px; border-radius: 50%;
  background: #fff; border: 3px solid #ff5c5c;
  box-shadow: 0 0 0 4px rgba(255,92,92,.3), 0 0 16px #ff5c5c;
  animation: poipulse 2s ease-out infinite;
}
.poi-tip {
  background: var(--card-solid) !important; color: #fff !important;
  border: 1px solid #ff5c5c !important; font-weight: 700;
}
@keyframes poipulse { 50% { box-shadow: 0 0 0 8px rgba(255,92,92,0), 0 0 16px #ff5c5c; } }
@media (prefers-reduced-motion: reduce) { .poi-dot { animation: none; } }

/* ---------------------------------------------------------- RESPONSIVE */
@media (max-width: 980px) {
  .zones__grid { grid-template-columns: 1fr; }
  .zones__map { order: -1; }
}
