/* responsive.css — mobile-first : on élargit depuis 390px */

@media (min-width: 768px) {
  html { scroll-padding-top: var(--header-h); }
  section { padding: 80px 0; }
  .stats-strip { padding: 56px 0; }
  .fab-call { display: none !important; }
}

/* ============ HEADER ============ */
@media (max-width: 767px) {
  .site-header { height: var(--header-h-mobile); }
  /* Cacher nav et CTA header sur mobile — burger prend le relais */
  .header-nav { display: none; }
  .header-cta { display: none; }
  /* FAB visible en mobile */
  .fab-call { display: flex; }
  /* Ajout espace en bas pour ne pas masquer contenu par le FAB */
  .site-footer { padding-bottom: 80px; }
}

@media (min-width: 768px) {
  .site-header { height: var(--header-h); }
}

/* ============ HERO ============ */
@media (max-width: 768px) {
  .hero-section { padding-top: var(--header-h-mobile); }
  .hero-grid75 {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: calc(var(--header-h-mobile) + 24px) 20px 40px;
  }
  .hero-grid75__media {
    aspect-ratio: 16/10;
    order: -1; /* photo en premier sur mobile */
    border-radius: var(--r-lg);
  }
  /* CTA hero mobile : empilés pleine largeur — PIÈGE #2 */
  .hero-grid75__cta {
    flex-direction: column;
    gap: 10px;
  }
  .hero-grid75__cta .btn {
    width: 100%;
    justify-content: center;
  }
  .hero-grid75__sub { max-width: 100%; }
}

/* ============ SERVICES ============ */
@media (max-width: 768px) {
  .svc-asym {
    grid-template-columns: 1fr;
  }
  .svc-asym__card,
  .svc-asym__card--wide,
  .svc-asym__card--lead {
    grid-column: 1 / -1;
  }
}
@media (min-width: 769px) and (max-width: 1024px) {
  .svc-asym {
    grid-template-columns: repeat(4, 1fr);
  }
  .svc-asym__card { grid-column: span 2; }
  .svc-asym__card--wide { grid-column: span 2; }
  .svc-asym__card--lead { grid-column: span 4; }
}

/* ============ GALERIE ============ */
@media (max-width: 560px) {
  /* PIÈGE #7 — galerie 1 colonne en mobile */
  .gal-feat {
    grid-template-columns: 1fr;
    grid-auto-rows: 240px;
  }
  .gal-feat__big {
    grid-column: 1;
    grid-row: 1;
  }
}
@media (min-width: 561px) and (max-width: 900px) {
  .gal-feat {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 200px;
  }
  .gal-feat__big {
    grid-column: span 2;
    grid-row: span 1;
  }
}

/* ============ AVIS ============ */
@media (max-width: 640px) {
  .avis-rows__item {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .avis-note { margin-bottom: 6px; }
}

/* ============ STATS ============ */
@media (max-width: 600px) {
  .stats-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .stat-divider { display: none; }
}

/* ============ FOOTER ============ */
@media (max-width: 768px) {
  .footer-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}

/* ============ CONTACT ============ */
@media (max-width: 768px) {
  .contact-wrapper {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .contact-btns .btn { justify-content: center; }
}

/* ============ MODAL ML ============ */
@media (max-width: 520px) {
  .ml-box { padding: 24px 20px; }
}

/* ============ SECTION HEADER ============ */
@media (max-width: 640px) {
  .realisations-section .section-header {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* ============ FAQ SECTION ============ */
@media (max-width: 767px) {
  .faq-section .container { max-width: 100%; }
}

/* ============ DESKTOP ============ */
@media (min-width: 1024px) {
  .hero-grid75 {
    padding: clamp(60px, 8vw, 110px) 32px clamp(50px, 7vw, 90px);
  }
}

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