/* ─── RESPONSIVE ─────────────────────────────────────────────── */

/* Tablet landscape */
@media (max-width: 1024px) {
  :root { --section-pad: 6rem 5%; }

  .pricing-packs { gap: 1rem; }

  .counters-row { grid-template-columns: repeat(4, 1fr); gap: 1rem; }
  .counter-box { padding: 2rem 1rem; }
  .counter-num { font-size: 2.4rem; }
}

/* Tablet portrait */
@media (max-width: 900px) {
  .contact-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .footer-grid { grid-template-columns: 1fr 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }

  .pricing-packs { grid-template-columns: 1fr; max-width: 440px; margin-left: auto; margin-right: auto; }
  .pricing-pack--featured { transform: none; }
  .services-grid     { grid-template-columns: repeat(2, 1fr); }
  .pain-item         { display: flex; flex-direction: column; gap: 0.4rem; padding: 1.5rem 1.25rem; }
  .pain-num          { font-size: 1.6rem; line-height: 1; }
  .pain-impact       { display: none; }
  .pain-content h3   { font-size: 0.92rem; }
  .pain-content p    { font-size: 0.8rem; word-break: break-word; overflow-wrap: break-word; }
  .pain-cta          { flex-direction: column; align-items: flex-start; gap: 1rem; }
  .testimonials      { grid-template-columns: 1fr; max-width: 520px; margin: 0 auto; }
  .counters-row      { grid-template-columns: repeat(2, 1fr); }
  .portfolio-grid    { grid-template-columns: repeat(2, 1fr); }

  .addon-banner { flex-direction: column; text-align: center; gap: 1rem; }
  .devis-type-grid { grid-template-columns: repeat(3, 1fr); }
}

/* Mobile */
@media (max-width: 768px) {
  :root { --section-pad: 5rem 5%; }

  .nav-links, .nav-ctas { display: none; }
  .hamburger { display: flex; }
  nav { padding: 0 5%; }

  .hero-stats { gap: 1.5rem; }
  .divider-v { height: 30px; }

  .counters-row { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .counter-num { font-size: 2.2rem; }

  h1 { font-size: clamp(2rem, 7vw, 3rem); }
  .section-title { font-size: clamp(1.6rem, 5vw, 2.2rem); }

  .hero-glow { width: 120%; height: 80%; }

  .services-grid  { grid-template-columns: 1fr; max-width: 520px; margin: 0 auto; }
  .portfolio-grid { grid-template-columns: 1fr; }
  .portfolio-grid--home { grid-template-columns: 1fr; }
  .pricing-packs { max-width: 100%; }

  .devis-panel { width: 100vw; }
  .devis-type-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 600px) {
  .form-row { grid-template-columns: 1fr; }

  .hero-content { padding: 0 1.25rem; padding-top: 72px; }
  .hero-stats { gap: 1rem; }
  .hero-stat .num { font-size: 1.5rem; }

  .devis-price-row { grid-template-columns: 1fr; }
  .devis-type-grid { grid-template-columns: repeat(2, 1fr); }
  .devis-q-options { gap: 0.4rem; }
  .devis-q-btn { font-size: 0.78rem; padding: 0.4rem 0.8rem; }
}

@media (max-width: 480px) {
  :root { --section-pad: 4rem 4%; }

  .devis-bubble__label { display: none; }
  .devis-bubble { padding: 0.75rem; bottom: 1.25rem; right: 1.25rem; }

  .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
  nav { padding: 0 4%; }

  .glass-card { padding: 1.5rem; }

  footer { background: var(--bg) !important; }

  .portfolio-filters-bar { gap: 0.35rem; }
  .portfolio-filter-btn { font-size: 0.75rem; padding: 0.4rem 0.8rem; }
}

/* ─── LEGAL PAGE RESPONSIVE ──────────────────────────────── */
@media (max-width: 768px) {
  .legal-tabs { flex-direction: column; }
  .legal-header { padding: 6rem 5% 1.5rem; }
  .legal-content { padding: 2rem 5% 3rem; }
  .legal-card { padding: 2rem 1.5rem; }
}

@media (max-width: 480px) {
  .legal-header { padding: 5.5rem 4% 1.5rem; }
  .legal-content { padding: 1.5rem 4% 2.5rem; }
  .legal-card { padding: 1.5rem 1rem; }
}

/* Simplify background on small screens */
@media (max-width: 768px) {
  body::before { display: none; }
  body { background-size: 60px 60px; }
}

/* Hide custom cursor on touch */
@media (pointer: coarse) {
  body { cursor: auto; }
  #cursor, #cursor-ring { display: none; }
}
