/* ============================================================================
   mobile.css — Responsive overrides for Cralux Kempen dealer site
   ----------------------------------------------------------------------------
   Strategy:
   - Explicit classes (m-hero, m-sim-card, …) on the key layout containers
     override their inline styles with !important.
   - A generic fallback rule collapses any remaining inline multi-column grid.
   - Section padding, display font-size, and absolute-positioned overlays
     are reset at three breakpoints: 960 / 720 / 480.
   ============================================================================ */

html { scroll-padding-top: 72px; }
img, svg { max-width: 100%; height: auto; }
input, select, textarea, button { font-size: 16px; } /* prevent iOS zoom */

/* ============================================================================
   ≤ 960px — tablet
   ============================================================================ */
@media (max-width: 960px) {
  /* --- Hero --- */
  .m-hero { padding: 32px 24px 56px !important; }
  .m-hero-grid {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
    padding-top: 16px !important;
  }
  .m-hero-headline { font-size: 48px !important; line-height: 1.05 !important; }
  .m-hero-portrait { height: 460px !important; }
  .m-hero-photo { width: 90% !important; max-width: 420px !important; height: 420px !important; right: 0 !important; top: 0 !important; }
  .m-hero-card { width: 280px !important; }
  .m-hero-region { width: 200px !important; }

  /* --- Simulator (5-step wizard) --- */
  .m-sim { padding: 64px 24px !important; }
  .m-sim-header { grid-template-columns: 1fr !important; gap: 28px !important; }
  .m-sim-card { grid-template-columns: 1fr !important; }
  .m-sim-progress { padding: 20px 24px 0 !important; }
  .m-sim-step { padding: 24px 24px 18px !important; min-height: 0 !important; }
  .m-sim-controls { padding: 16px 24px !important; }
  .m-sim-right { padding: 28px 24px !important; }

  /* --- Headlines everywhere --- */
  section h2.display { font-size: 40px !important; line-height: 1.08 !important; letter-spacing: -0.015em !important; }

  /* --- Section padding defaults via class fallback for everything with inline 96/110 --- */
  section[style*="padding: 96px 40px"],
  section[style*="padding: 110px 40px"] { padding: 64px 24px !important; }
  section[style*="padding: 0 40px 96px"] { padding: 0 24px 64px !important; }
  footer[style*="padding: 40px 40px 48px"] { padding: 28px 20px 36px !important; }

  /* --- Asymmetric 2-col grids: stack --- */
  [style*="grid-template-columns: 0.9fr 1.1fr"],
  [style*="grid-template-columns: 1.1fr 0.9fr"],
  [style*="grid-template-columns: 0.95fr 1.05fr"],
  [style*="grid-template-columns: 1fr 1.2fr"],
  [style*="grid-template-columns: 1.25fr 1fr"],
  [style*="grid-template-columns: 1.1fr 1fr"],
  [style*="grid-template-columns: 380px 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  /* 3/4/5-col repeats → 2 cols */
  [style*="grid-template-columns: repeat(3"],
  [style*="grid-template-columns: repeat(4"],
  [style*="grid-template-columns: repeat(5"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  /* Footer 4-col */
  [style*="grid-template-columns: 1.4fr 1fr 1fr 1fr"] {
    grid-template-columns: 1fr 1fr !important;
    gap: 28px !important;
  }
}

/* ============================================================================
   ≤ 720px — mobile
   ============================================================================ */
@media (max-width: 720px) {
  html, body { overflow-x: hidden; }
  body { padding-bottom: 84px !important; } /* room for mobile sticky CTA */

  /* --- Hero: full stacked layout --- */
  .m-hero { padding: 20px 16px 48px !important; }
  .m-hero-grid { gap: 24px !important; padding-top: 8px !important; }
  .m-hero-headline { font-size: 34px !important; line-height: 1.1 !important; letter-spacing: -0.01em !important; }
  .m-hero-portrait {
    position: relative !important;
    height: auto !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
    align-items: stretch !important;
  }
  .m-hero-photo {
    position: static !important;
    width: 100% !important;
    max-width: none !important;
    height: 340px !important;
    margin: 0 !important;
  }
  .m-hero-card {
    position: static !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
  }
  .m-hero-region {
    position: static !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
  }

  /* Hero stat row: allow wrap, smaller gap */
  .m-hero-grid [style*="display: flex"][style*="gap: 44px"] {
    gap: 18px !important;
    flex-wrap: wrap !important;
  }

  /* --- Simulator wizard --- */
  .m-sim { padding: 48px 16px !important; }
  .m-sim-progress { padding: 16px 16px 0 !important; gap: 4px !important; }
  .m-sim-progress > div > div:last-child { font-size: 9.5px !important; letter-spacing: 0.02em !important; }
  .m-sim-step { padding: 20px 16px 14px !important; }
  .m-sim-controls { padding: 14px 16px !important; gap: 8px !important; }
  .m-sim-controls > div { font-size: 11px !important; }
  .m-sim-controls button { padding: 10px 14px !important; font-size: 13px !important; }
  .m-sim-right { padding: 24px 18px !important; gap: 16px !important; }
  .m-sim-right .display[style*="font-size: 52px"] { font-size: 42px !important; }

  /* --- Sections --- */
  section[style*="padding: 96px 40px"],
  section[style*="padding: 110px 40px"] { padding: 48px 16px !important; }
  section[style*="padding: 0 40px 96px"] { padding: 0 16px 48px !important; }
  footer[style*="padding: 40px 40px 48px"] { padding: 24px 14px 32px !important; }

  /* --- Collapse every inline grid to 1 col (blanket fallback) --- */
  [style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  /* Keep dl specs 2-col (short labels like €95/m²) */
  dl[style*="grid-template-columns"] { grid-template-columns: 1fr 1fr !important; gap: 12px !important; }
  /* Trust bar keeps 2-col */
  .trust-bar { grid-template-columns: 1fr 1fr !important; }
  /* Simulator chip grids (Woning types, Planning chips): 2-col */
  .m-sim-step [style*="grid-template-columns: repeat(4"],
  .m-sim-step [style*="grid-template-columns: repeat(3"] {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }
  /* Auto-fill color swatches: keep flow */
  [style*="grid-template-columns: repeat(auto-fill"] {
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr)) !important;
    gap: 8px !important;
  }

  /* --- Display headlines: hard cap on mobile --- */
  section h2.display { font-size: 30px !important; line-height: 1.12 !important; letter-spacing: -0.01em !important; }
  .display[style*="font-size: 68px"],
  .display[style*="font-size: 64px"],
  .display[style*="font-size: 58px"],
  .display[style*="font-size: 56px"],
  .display[style*="font-size: 52px"],
  .display[style*="font-size: 48px"],
  .display[style*="font-size: 46px"] { font-size: 30px !important; line-height: 1.12 !important; }
  .display[style*="font-size: 38px"],
  .display[style*="font-size: 36px"],
  .display[style*="font-size: 34px"],
  .display[style*="font-size: 32px"] { font-size: 26px !important; }
  .display[style*="font-size: 28px"],
  .display[style*="font-size: 26px"],
  .display[style*="font-size: 24px"] { font-size: 22px !important; }

  /* --- Paragraph widths clamp --- */
  section p { max-width: 100% !important; }

  /* --- Wide inline paddings → tight --- */
  [style*="padding: 40px 44px"],
  [style*="padding: 40px 40px"],
  [style*="padding: 48px 48px"],
  [style*="padding: 56px 56px 56px 48px"],
  [style*="padding: 36px 36px"],
  [style*="padding: 40px"] { padding: 22px 18px !important; }

  /* --- About section punctuality callout: stack rather than overflow --- */
  section#over [style*="position: absolute"][style*="right: -20px"][style*="bottom: -20px"] {
    position: static !important;
    width: 100% !important;
    margin-top: 14px !important;
  }
  section#over [style*="height: 520px"] { height: 320px !important; }

  /* --- Showroom: reduce placeholder height --- */
  section#showroom [style*="min-height: 460px"] { min-height: 220px !important; }
  section#showroom [style*="padding: 56px 56px 56px 48px"] { padding: 28px 20px !important; }

  /* --- Footer co-brand row: stack --- */
  footer [style*="justify-content: space-between"] {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 12px !important;
  }
  footer [style*="margin-left: auto"] { margin-left: 0 !important; }

  /* --- Tables / lists of stats (flex rows): wrap nicely --- */
  [style*="display: flex"][style*="gap: 48px"] { gap: 20px !important; flex-wrap: wrap !important; }
  [style*="display: flex"][style*="gap: 44px"] { gap: 18px !important; flex-wrap: wrap !important; }
  [style*="display: flex"][style*="gap: 40px"] { gap: 18px !important; flex-wrap: wrap !important; }

  /* --- Breadcrumb padding --- */
  nav[aria-label="Broodkruimel"] { padding: 12px 16px !important; }
}

/* ============================================================================
   ≤ 480px — small mobile
   ============================================================================ */
@media (max-width: 480px) {
  .m-hero { padding: 16px 12px 40px !important; }
  .m-hero-headline { font-size: 28px !important; }
  .m-hero-photo { height: 280px !important; }

  .m-sim { padding: 40px 12px !important; }
  .m-sim-step { padding: 16px 14px 12px !important; }
  .m-sim-progress { padding: 14px 14px 0 !important; }
  .m-sim-progress > div > div:last-child { font-size: 8.5px !important; }
  .m-sim-controls { padding: 12px 14px !important; }

  section[style*="padding: 96px 40px"],
  section[style*="padding: 110px 40px"] { padding: 40px 12px !important; }

  section h2.display { font-size: 26px !important; }
  .display[style*="font-size: 68px"],
  .display[style*="font-size: 64px"],
  .display[style*="font-size: 58px"],
  .display[style*="font-size: 56px"],
  .display[style*="font-size: 52px"],
  .display[style*="font-size: 48px"],
  .display[style*="font-size: 46px"] { font-size: 26px !important; }

  [style*="padding: 40px 44px"],
  [style*="padding: 40px 40px"],
  [style*="padding: 48px 48px"],
  [style*="padding: 56px 56px 56px 48px"],
  [style*="padding: 36px 36px"],
  [style*="padding: 40px"] { padding: 18px 14px !important; }
}
