/* responsive.css — derniers ajustements mobile-first */

@media (max-width: 480px) {
  .hero-mega__title { font-size: clamp(2.4rem, 12vw, 3.4rem); }
  .stat-number { font-size: 2.2rem; }
  .avis-single { padding: 30px 18px; }
  .avis-single::before { font-size: 4.6rem; top: -4px; left: 14px; }
}

/* Safe area iOS */
@supports (padding: env(safe-area-inset-bottom)) {
  .fab-call { bottom: max(16px, env(safe-area-inset-bottom)); }
}

/* Hide elements per breakpoint */
.show-mobile { display: block; }
.show-desktop { display: none; }
@media (min-width: 1000px) {
  .show-mobile { display: none; }
  .show-desktop { display: block; }
}

/* Realisations page (multi-page) */
.page-hero {
  padding: calc(var(--header-h-mobile) + 36px) 20px 36px;
  text-align: center;
  max-width: 900px;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .page-hero { padding: calc(var(--header-h) + 56px) 40px 56px; }
}
.back-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--ff-ui);
  font-size: .88rem;
  color: var(--text-2);
  padding: 8px 16px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text) 5%, var(--bg));
  border: 1px solid var(--border);
  margin-bottom: 22px;
  transition: background var(--t-fast), color var(--t-fast);
}
.back-link:hover { background: color-mix(in srgb, var(--accent) 12%, var(--bg)); color: var(--accent-deep); }
.back-link svg { width: 14px; height: 14px; }

.gal-full {
  column-count: 1;
  column-gap: 16px;
  margin-top: 32px;
}
@media (min-width: 600px) { .gal-full { column-count: 2; } }
@media (min-width: 1000px) { .gal-full { column-count: 3; } }

.page-cta {
  margin-top: 56px;
  padding: 40px 24px;
  background: var(--accent-deep);
  border-radius: var(--r-lg);
  text-align: center;
  color: var(--on-dark);
}
.page-cta h2 {
  color: var(--on-dark);
  font-family: var(--ff-display);
  font-size: clamp(1.6rem, 3.4vw, 2.4rem);
  margin-bottom: 20px;
}
.page-cta-buttons {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 360px;
  margin: 0 auto;
}
@media (min-width: 520px) {
  .page-cta-buttons { flex-direction: row; max-width: none; justify-content: center; }
}

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