/* ================================================================
   MOBILE Oven Clean — Mobile-Only Fixes
   Applied to ALL pages. Desktop (>768px) unchanged.
   v1 — March 2026
================================================================ */

@media (max-width: 768px) {

  /* ── Global ───────────────────────────────────────────────── */
  * { box-sizing: border-box; }

  body { overflow-x: hidden; }

  img { max-width: 100%; height: auto; }

  /* Prevent any container overflowing viewport */
  .container, .w { padding-left: 16px !important; padding-right: 16px !important; max-width: 100% !important; }

  /* ── Typography ──────────────────────────────────────────── */
  h1 { font-size: clamp(1.5rem, 6vw, 2rem) !important; line-height: 1.2 !important; }
  h2 { font-size: clamp(1.2rem, 5vw, 1.6rem) !important; line-height: 1.3 !important; }
  h3 { font-size: clamp(1rem, 4vw, 1.2rem) !important; }

  /* ── All inline grids → single column ───────────────────── */

  /* 2-col SEO content grids */
  #seo-intro    [style*="grid-template-columns:1fr 1fr"],
  #seo-inclusions [style*="grid-template-columns:1fr 1fr"],
  #seo-why-choose [style*="grid-template-columns:1fr 1fr"],
  #seo-why-choose [style*="grid-template-columns:repeat(2,1fr)"],
  #seo-areas    [style*="grid-template-columns:1fr 1fr"],
  #hub-spec-content [style*="grid-template-columns:1fr 1fr"],
  #hub-spec-content [style*="grid-template-columns:repeat(2,1fr)"],
  #hub-spec-content [style*="grid-template-columns:repeat(auto-fit,minmax(175px,1fr))"],
  #hub-final-content [style*="grid-template-columns:1fr 1fr"],
  #hub-final-content [style*="grid-template-columns:repeat(2,1fr)"],
  #hub-seo-intro [style*="grid-template-columns:1fr 1fr"],
  #kitchen-extractor-fan-cleaning [style*="grid-template-columns:1fr 1fr"],
  #cooker-hood-filter-cleaning [style*="grid-template-columns:1fr 1fr"],
  #extractor-fan-filter-degreasing [style*="grid-template-columns:1fr 1fr"],
  #catering-extractor-fan-cleaning [style*="grid-template-columns:1fr 1fr"],
  #kitchen-exhaust-fan-cleaning [style*="grid-template-columns:1fr 1fr"],
  #our-strengths [style*="grid-template-columns:repeat(3,1fr)"],
  #deep-cleaning-domestic-single-ovens [style*="grid-template-columns:1fr 1fr"],
  #single-oven-strengths [style*="grid-template-columns:1fr 1fr"],
  #professional-gas-electric-hob-cleaning [style*="grid-template-columns:1fr 1fr"],
  #ceramic-glass-hob-cleaning-specialists [style*="grid-template-columns:1fr 1fr"],
  #hob-cleaning-strengths-areas [style*="grid-template-columns:1fr 1fr"],
  #double-oven-cleaning-service [style*="grid-template-columns:1fr 1fr"],
  #double-oven-cleaning-cost [style*="grid-template-columns:1fr 1fr"],
  #professional-vs-self-cleaning [style*="grid-template-columns:1fr 1fr"],
  #areas-we-cover [style*="grid-template-columns:repeat(5,1fr)"],
  .seo-internal-links [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }

  /* Hub page service card grids */
  #hub-spec-content [style*="grid-template-columns:repeat(auto-fit,minmax"],
  #hub-final-content [style*="grid-template-columns:repeat(auto-fit,minmax"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  /* Why-choose 2-col → 1-col */
  #why-choose-single-oven-cleaning [style*="grid-template-columns:repeat(2,1fr)"] {
    grid-template-columns: 1fr !important;
  }

  /* Service grid on service pages */
  [style*="grid-template-columns:repeat(3,1fr)"] {
    grid-template-columns: 1fr !important;
  }
  [style*="grid-template-columns:repeat(4,1fr)"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  [style*="grid-template-columns:repeat(6,1fr)"] {
    grid-template-columns: repeat(3, 1fr) !important;
  }

  /* Sidebar layout: 1fr 320px → single col */
  [style*="grid-template-columns:1fr 320px"],
  [style*="grid-template-columns:1fr 380px"],
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns:2fr 1fr"] {
    grid-template-columns: 1fr !important;
  }

  /* Nav footer: multi-col → 2-col */
  [style*="grid-template-columns:2fr 1fr 1fr 1fr"] {
    grid-template-columns: 1fr 1fr !important;
  }

  /* ── Before/After images ─────────────────────────────────── */
  #before-after [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  #before-after img { height: 260px !important; }
  #before-after [style*="gap:28px"] { gap: 12px !important; flex-wrap: wrap !important; }
  #before-after [style*="width:1px"] { display: none !important; }

  /* ── Trust strip (after before/after) ───────────────────── */
  #before-after ~ div [style*="gap:0"] {
    flex-direction: column !important;
  }

  /* ── Homepage hero ───────────────────────────────────────── */
  .hero-grid { grid-template-columns: 1fr !important; }
  .hero-img-col { display: none !important; }
  .hero-content { padding: 0 !important; }
  .hero-btns { flex-direction: column !important; gap: 10px !important; }
  .hero-btn { width: 100% !important; justify-content: center !important; text-align: center !important; }
  .hero-rating { flex-wrap: wrap !important; gap: 8px !important; }

  /* ── Services grid on homepage ───────────────────────────── */
  .services-grid { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
  .service-card { padding: 12px !important; }
  .service-img { padding: 16px 12px 8px !important; }
  .service-img svg, .service-img img { max-width: 80px !important; }

  /* ── Why section ─────────────────────────────────────────── */
  .why-grid { grid-template-columns: 1fr !important; }

  /* ── Areas section ───────────────────────────────────────── */
  .areas-grid { grid-template-columns: repeat(2, 1fr) !important; }

  /* ── Stats bar ───────────────────────────────────────────── */
  .stats-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }

  /* ── CTA band ────────────────────────────────────────────── */
  .cta-inner { flex-direction: column !important; gap: 16px !important; text-align: center !important; }
  .cta-btns { flex-direction: column !important; width: 100% !important; }
  .cta-btns a, .cta-btns button { width: 100% !important; justify-content: center !important; text-align: center !important; }

  /* ── Blog grid ───────────────────────────────────────────── */
  .blog-grid { grid-template-columns: 1fr !important; }

  /* ── Footer ──────────────────────────────────────────────── */
  .footer-grid { grid-template-columns: 1fr !important; gap: 20px !important; }

  /* ── Service pages (styles3.css template) ─────────────────── */
  .page-hero { padding: 36px 0 28px !important; }
  .page-hero-badge { font-size: 0.68rem !important; }
  .page-hero h1 { font-size: clamp(1.4rem, 6vw, 1.9rem) !important; }
  .page-hero-trust { flex-wrap: wrap !important; gap: 6px !important; }

  /* Feature cards 3-col → 2-col */
  .fc-g { grid-template-columns: 1fr 1fr !important; }

  /* Main content grid: sidebar → stack */
  .main-g { grid-template-columns: 1fr !important; }

  /* Sticky sidebar → static */
  [style*="position:sticky"] { position: static !important; }

  /* Pricing grid on service pages */
  .pp-g { grid-template-columns: 1fr !important; }

  /* Availability slots */
  #avSlots { grid-template-columns: repeat(2, 1fr) !important; }

  /* ── Area/Location pages (area-styles.css) ──────────────── */
  .loc-hero { padding: 32px 0 24px !important; }
  .loc-content { grid-template-columns: 1fr !important; }

  /* ── Service+Location pages (styles2.css) ───────────────── */
  .svc-loc-grid { grid-template-columns: 1fr !important; }

  /* Injected SEO content: seo-inclusions sidebar */
  #seo-inclusions > .container > div,
  #seo-inclusions [style*="display:grid"] {
    grid-template-columns: 1fr !important;
  }

  /* Internal links block */
  .seo-internal-links > div > div {
    grid-template-columns: 1fr !important;
  }

  /* ── MQ strip (on service pages) ────────────────────────── */
  .mq-strip { flex-wrap: wrap !important; gap: 6px !important; padding: 10px 14px !important; }
  .mq-item { flex: 0 0 calc(50% - 4px) !important; }

  /* ── Buttons / CTAs ──────────────────────────────────────── */
  .btn { width: 100% !important; text-align: center !important; }

  /* ── Blog pages ──────────────────────────────────────────── */
  .blog-content { padding: 24px 0 !important; }
  .blog-content img { width: 100% !important; height: auto !important; }

  /* ── Breadcrumb ──────────────────────────────────────────── */
  .breadcrumb { font-size: 0.72rem !important; flex-wrap: wrap !important; }

  /* ── Overflow safety net ─────────────────────────────────── */
  section, div, article, aside {
    max-width: 100vw;
    overflow-x: hidden;
  }

  /* ── Hub page: trust strip after before/after ────────────── */
  #trust-strip-after-ba { flex-direction: column !important; }
  #trust-strip-after-ba > div { border-right: none !important; border-bottom: 1px solid rgba(255,255,255,0.08) !important; }

  /* Stats repeat block → 2×2 grid */
  .stats-repeat-block { display: grid !important; grid-template-columns: 1fr 1fr !important; }

  /* ── FAQ sections ────────────────────────────────────────── */
  details { padding: 14px 14px !important; }
  details summary { font-size: 0.88rem !important; }

  /* ── Postcode chips ──────────────────────────────────────── */
  #seo-areas .container > div > div:first-child div[style*="flex-wrap:wrap"],
  #areas-we-cover > .w > div[style*="grid-template-columns:repeat(5"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  /* ── Padding reductions on mobile ───────────────────────── */
  section[style*="padding:64px"] { padding-top: 40px !important; padding-bottom: 36px !important; }
  section[style*="padding:60px"] { padding-top: 36px !important; padding-bottom: 32px !important; }
  section[style*="padding:56px"] { padding-top: 34px !important; padding-bottom: 30px !important; }
  section[style*="padding:48px"] { padding-top: 30px !important; padding-bottom: 28px !important; }
  div[style*="padding:56px"] { padding-top: 34px !important; padding-bottom: 30px !important; }

}

/* Small phones */
@media (max-width: 400px) {
  .services-grid { grid-template-columns: 1fr !important; }
  .areas-grid { grid-template-columns: 1fr !important; }
  h1 { font-size: 1.4rem !important; }
}
