/* ============================================================
   Contact Page — G.S. Le Serval
   ============================================================ */

/* ── Page Header ─────────────────────────────────────────── */
.page-header {
  background-image: url('../images/ecole/_ALI6304.jpg');
  background-size: cover;
  background-position: center;
  padding: 9rem 0 4rem;
  position: relative;
}
.page-header-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(10,40,18,0.88), rgba(15,70,30,0.75));
}
.page-header-title {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 900; color: var(--blanc);
  margin-bottom: 0.8rem;
}
.breadcrumb { margin: 0; }
.breadcrumb-item a { color: var(--or2); text-decoration: none; font-size: 0.9rem; }
.breadcrumb-item.active { color: rgba(255,255,255,0.7); font-size: 0.9rem; }
.breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,0.4); }

/* ── Cartes rapides ──────────────────────────────────────── */
.contact-quick { background: var(--blanc); }

.quick-card {
  display: flex; align-items: center; gap: 1rem;
  background: var(--blanc);
  border-radius: 16px; padding: 1.4rem 1.5rem;
  box-shadow: 0 6px 24px rgba(0,0,0,0.07);
  border: 1px solid rgba(15,70,30,0.08);
  text-decoration: none; color: inherit;
  transition: all 0.3s; height: 100%;
}
.quick-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 35px rgba(15,70,30,0.13);
  border-color: var(--vert3);
  color: inherit;
}
.quick-card.whatsapp:hover { border-color: #25d366; }

.quick-icon {
  width: 56px; height: 56px; min-width: 56px;
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem;
}
.quick-text h6 {
  font-weight: 700; color: var(--vert);
  margin-bottom: 0.2rem; font-size: 0.95rem;
}
.quick-text p {
  font-size: 0.85rem; color: #666;
  margin: 0; line-height: 1.5;
}

/* ── Formulaire ──────────────────────────────────────────── */
.contact-form-card {
  background: var(--blanc);
  border-radius: 24px; padding: 2.5rem;
  box-shadow: 0 10px 40px rgba(0,0,0,0.08);
  border: 1px solid rgba(15,70,30,0.07);
}

.form-label {
  font-weight: 600; font-size: 0.88rem;
  color: var(--vert); margin-bottom: 0.4rem;
}

.contact-input {
  border: 2px solid #e8f0eb;
  border-radius: 12px; padding: 0.7rem 1rem;
  font-size: 0.9rem; font-family: var(--font);
  transition: all 0.25s; background: #fafffe;
  color: var(--gris);
}
.contact-input:focus {
  border-color: var(--vert3);
  box-shadow: 0 0 0 4px rgba(46,160,70,0.1);
  background: var(--blanc);
  outline: none;
}
.contact-input::placeholder { color: #aaa; }

textarea.contact-input { resize: vertical; min-height: 130px; }

.btn-submit {
  background: linear-gradient(135deg, var(--vert), var(--vert2));
  color: var(--blanc); border: none;
  border-radius: 14px; padding: 1rem;
  font-weight: 700; font-size: 1rem;
  font-family: var(--font); cursor: pointer;
  transition: all 0.3s; letter-spacing: 0.5px;
  display: flex; align-items: center; justify-content: center;
}
.btn-submit:hover {
  background: linear-gradient(135deg, var(--vert2), var(--vert3));
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(15,70,30,0.3);
}

.form-success {
  text-align: center; padding: 3rem 2rem;
}
.form-success i {
  font-size: 4rem; color: var(--vert3);
  margin-bottom: 1rem; display: block;
}
.form-success h5 { color: var(--vert); font-weight: 800; margin-bottom: 0.5rem; }
.form-success p  { color: #666; font-size: 0.9rem; }

/* ── Infos contact ───────────────────────────────────────── */
.info-card {
  background: var(--blanc); border-radius: 20px;
  padding: 1.8rem 2rem;
  box-shadow: 0 8px 28px rgba(0,0,0,0.07);
  border: 1px solid rgba(15,70,30,0.08);
}
.info-card-title {
  font-weight: 800; color: var(--vert);
  font-size: 1rem; margin-bottom: 1.4rem;
  padding-bottom: 0.8rem;
  border-bottom: 2px solid var(--vert-clair);
  display: flex; align-items: center;
}
.info-card-title i { color: var(--or); }

.info-item {
  display: flex; gap: 1rem; align-items: flex-start;
  margin-bottom: 1.2rem; padding-bottom: 1.2rem;
  border-bottom: 1px solid #f0f5f1;
}
.info-item:last-of-type { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.info-icon {
  width: 40px; height: 40px; min-width: 40px;
  background: var(--vert-clair); border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: var(--vert2); font-size: 1rem;
}
.info-item strong { display: block; font-weight: 700; color: var(--vert); font-size: 0.88rem; margin-bottom: 0.2rem; }
.info-item p { margin: 0; font-size: 0.86rem; color: #555; line-height: 1.6; }
.info-item a { color: var(--vert2); text-decoration: none; }
.info-item a:hover { color: var(--or); }

.btn-whatsapp {
  display: flex; align-items: center; justify-content: center;
  gap: 0.5rem; width: 100%;
  background: #25d366; color: var(--blanc);
  border-radius: 12px; padding: 0.85rem;
  font-weight: 700; font-size: 0.95rem;
  text-decoration: none; transition: all 0.3s;
}
.btn-whatsapp:hover {
  background: #1ebe5d; color: var(--blanc);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(37,211,102,0.35);
}

/* ── Horaires ────────────────────────────────────────────── */
.horaire-list { margin-bottom: 1rem; }
.horaire-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0.65rem 0;
  border-bottom: 1px solid #f0f5f1;
  font-size: 0.88rem;
}
.horaire-jour { font-weight: 600; color: var(--vert); }
.horaire-heure {
  background: var(--vert-clair); color: var(--vert2);
  padding: 0.2rem 0.7rem; border-radius: 20px;
  font-weight: 700; font-size: 0.82rem;
}
.horaire-item.ferme .horaire-jour { color: #999; }
.badge-ferme {
  background: #fce4e4 !important; color: #c0392b !important;
}
.horaire-cours {
  background: var(--vert-clair);
  border-left: 3px solid var(--vert3);
  border-radius: 0 8px 8px 0;
  padding: 0.6rem 0.9rem;
  font-size: 0.82rem; color: var(--vert2);
  display: flex; align-items: flex-start; gap: 0.4rem;
  flex-wrap: wrap; line-height: 1.6;
}
.horaire-cours strong { color: var(--vert); }

.horaire-note {
  font-size: 0.78rem; color: #999;
  font-style: italic;
  display: flex; align-items: center; gap: 0.3rem;
}

/* ── Carte Maps ──────────────────────────────────────────── */
.map-section { background: var(--blanc); padding-bottom: 0; }
.map-container { position: relative; }
.map-container iframe { display: block; }
.map-overlay-card {
  position: absolute;
  top: 1.5rem; left: 1.5rem;
  background: var(--blanc); border-radius: 14px;
  padding: 0.9rem 1.2rem;
  display: flex; align-items: center; gap: 0.8rem;
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  border-left: 4px solid var(--or);
}
.map-overlay-card img { height: 44px; border-radius: 8px; border: 2px solid var(--or); }
.map-overlay-card strong { display: block; color: var(--vert); font-size: 0.9rem; font-weight: 800; }
.map-overlay-card p { margin: 0; font-size: 0.75rem; color: #666; }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 768px) {
  .contact-form-card { padding: 1.5rem; }
  .map-overlay-card { display: none; }
  .page-header { padding: 8rem 0 3rem; }
}
