/* responsive.css — mobile-first media queries */

/* ── MOBILE < 768px ──────────────────────────────── */
@media (max-width: 768px) {

  /* Header : taille mobile */
  .site-header { height: var(--header-h-mobile); }
  .header-nav  { display: none; }   /* nav desktop masquée */
  .header-cta  { display: none; }   /* CTA header masqué (burger prend le relais) — PIÈGE #13 */

  /* Burger et menu mobile visibles */
  .burger      { display: grid; }
  .menu-mobile { /* visible uniquement — géré via .is-open */ }

  /* FAB mobile visible */
  .fab-call { display: flex; }

  /* ── Hero GRILLE-7-5 : 1 colonne, photo en haut ── */
  .hero-grid75 {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: calc(var(--header-h-mobile) + 24px) 20px 40px;
  }
  .hero-grid75__media { order: -1; aspect-ratio: 16/10; }
  .hero-grid75__title {
    font-size: clamp(2rem, 8vw, 2.8rem);
  }
  .hero-grid75__sub { max-width: 100%; margin-bottom: 24px; }

  /* CTA hero : empilés pleine largeur (PIÈGE #2) */
  .hero-grid75__cta {
    flex-direction: column;
    width: 100%;
    gap: 10px;
  }
  .hero-grid75__cta .btn { width: 100%; }

  /* Services : 1 colonne */
  .svc-grid { grid-template-columns: 1fr; gap: 14px; }

  /* Galerie : 2 colonnes max sur mobile (PIÈGE #7 : 1 colonne < 560px) */
  .gal-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }

  /* Avis : 1 colonne */
  .avis-cols { grid-template-columns: 1fr; }

  /* Stats : 3 colonnes compactes */
  .stats-grid { gap: 16px; }
  .stat-item + .stat-item { border-left: none; border-top: 1px solid rgba(255,255,255,0.2); }

  /* Zone : 1 colonne */
  .zone-cols { grid-template-columns: 1fr; gap: 24px; }

  /* Contact : 1 colonne */
  .contact-wrap { grid-template-columns: 1fr; }

  /* About (si présent) : 1 colonne */
  .about-cols { grid-template-columns: 1fr; }
  .about-media { order: -1; }

  /* Footer */
  .footer-inner {
    grid-template-columns: 1fr;
    gap: 28px;
    text-align: center;
  }
  .footer-links { align-items: center; }
  .footer-brand { align-items: center; }

  /* Sections padding */
  .section-services,
  .section-realisations,
  .section-avis,
  .section-faq,
  .section-zone,
  .section-contact {
    padding: 48px 20px;
  }

  /* Container mobile */
  .container { padding: 0 20px; }

  /* Form */
  .contact-form { padding: 24px 18px; }

  /* Sections padding stats */
  .stats-strip { padding: 36px 0; }
}

/* ── < 560px : galerie 1 colonne ──────────────────── */
@media (max-width: 560px) {
  .gal-grid { grid-template-columns: 1fr; } /* PIÈGE #7 */
  .svc-grid { grid-template-columns: 1fr; }
}

/* ── TABLETTE 768–1024 ───────────────────────────── */
@media (min-width: 768px) and (max-width: 1024px) {
  .hero-grid75 { grid-template-columns: 1fr 1fr; }
  .svc-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-inner { grid-template-columns: 1fr 1fr; }
  .footer-links { grid-column: 1 / -1; flex-direction: row; flex-wrap: wrap; }
}

/* ── DESKTOP 900px ───────────────────────────────── */
@media (min-width: 900px) {
  .svc-grid { grid-template-columns: repeat(3, 1fr); }
  .gal-grid { grid-template-columns: repeat(3, 1fr); }
}

/* wf-noxoverflow : reveal vertical (le slide horizontal deborde la largeur sur mobile) */
[data-reveal]:not(.in){ transform: translateY(18px) !important; }
