/* ── Global overflow fix — prevents any element causing horizontal scroll ── */
html, body { overflow-x: hidden; max-width: 100%; }
*, *::before, *::after { box-sizing: border-box; }
.container { overflow: visible; }

@media (max-width: 1024px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .hero__inner { grid-template-columns: 1fr; }
  .hero__visual { display: none; }
  .hero__title { font-size: clamp(2rem, 4vw, 2.75rem); }
  .ai-grid { grid-template-columns: 1fr; }
  .ai-visual { display: none; }
  .services-problems-grid { grid-template-columns: repeat(2, 1fr); }
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .stats-bar__grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-8) var(--sp-6); }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: var(--sp-8); }
  .contact-page-grid { grid-template-columns: 1fr; }
  .about-story { grid-template-columns: 1fr; }
  .service-detail { grid-template-columns: 1fr; }
  .about-values { grid-template-columns: repeat(2, 1fr); }
  .process-grid { grid-template-columns: repeat(2, 1fr); }
  .process-grid::before { display: none; }
  .testimonials-grid { grid-template-columns: 1fr 1fr; }
  .portfolio-grid { grid-template-columns: repeat(2, 1fr); }
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .blog-preview-grid { grid-template-columns: repeat(2, 1fr); }
  .service-features { grid-template-columns: 1fr; }
  .case-study-body { grid-template-columns: 1fr !important; }
  .case-study-sidebar { order: -1; display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .case-study-sidebar > *:last-child { grid-column: 1 / -1; }
  /* Comparison table collapses to 2 cols */
  .comparison-table { grid-template-columns: 1fr 1fr; }
  .comparison-col--them { display: none; }
  .services-hub-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  :root { --container-px: 1rem; }
  .track-record-grid { grid-template-columns: repeat(2,1fr) !important; }
  .section-pad { padding-block: var(--sp-14); }
  .section-pad--lg { padding-block: var(--sp-16); }

  /* Nav */
  .site-nav { display: none; }
  .header-cta .btn { display: none; }
  .nav-toggle { display: flex; }

  /* Grids → single column */
  .services-problems-grid { grid-template-columns: 1fr; }
  .services-grid { grid-template-columns: 1fr; }
  .service-card { padding: var(--sp-5); }
  .stats-bar__grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr; gap: var(--sp-8); }
  .footer-bottom { flex-direction: column; text-align: center; gap: var(--sp-3); }
  .about-values { grid-template-columns: 1fr; }
  .process-grid { grid-template-columns: 1fr 1fr; }
  .testimonials-grid { grid-template-columns: 1fr; }
  .portfolio-grid { grid-template-columns: 1fr; }
  .blog-grid { grid-template-columns: 1fr; }
  .blog-preview-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .services-hub-grid { grid-template-columns: 1fr; }

  /* Hero */
  .hero__actions { flex-direction: column; align-items: stretch; }
  .hero__actions .btn { width: 100%; justify-content: center; }
  .hero__trust { flex-wrap: wrap; gap: var(--sp-3); }
  .hero__trust-sep { display: none; }
  .hero__results-strip { gap: 1rem; padding: 1rem; }
  .hero__result-sep { display: none; }
  .hero__result-num { font-size: 1.5rem; }

  /* Hero background glows — clip so they don't overflow */
  .hero__bg-glow, .hero__bg-glow-2 { display: none; }

  /* CTA section */
  .final-cta__actions { flex-direction: column; align-items: center; }
  .final-cta__actions .btn { width: 100%; max-width: 320px; justify-content: center; }

  /* Portfolio */
  .case-study-sidebar { grid-template-columns: 1fr !important; }
  .portfolio-hero-stats { gap: 1.5rem; }
  .page-hero { padding: 110px 0 60px; }
  .portfolio-hero { padding: 110px 0 60px; }
  .related-grid { grid-template-columns: 1fr !important; }

  /* Trust band */
  .trust-badges { flex-wrap: wrap; gap: var(--sp-2); }
  .trust-badge { min-width: calc(50% - var(--sp-2)); flex: 1; }
  .trust-badge__title { font-size: 0.8rem; }

  /* Industries pills → 2 per row */
  .industries-wrap { gap: var(--sp-2); }
  .industry-pill { flex: 1; min-width: calc(50% - 0.25rem); justify-content: center; font-size: 0.8rem; padding: var(--sp-2) var(--sp-3); }

  /* Comparison table → stack */
  .comparison-table { grid-template-columns: 1fr; }
  .comparison-col--feature { display: none; }
  .comparison-col--them { display: none; }
  .comparison-col--us { border-radius: var(--radius-xl); border: 1px solid rgba(255,139,0,0.3); }
  .comparison-header--us { padding: var(--sp-4) var(--sp-4); }
  .comparison-row { padding: var(--sp-3) var(--sp-4); }

  /* FAQ layout */
  .faq-layout { gap: 1.5rem; }

  /* Stats bar — dividers off */
  .stat-item { border-right: none !important; padding: 0; }
  .stats-bar__grid { gap: var(--sp-6); }
}

@media (max-width: 480px) {
  :root { --container-px: 0.875rem; }
  .track-record-grid { grid-template-columns: 1fr !important; }
  .stats-bar__grid { grid-template-columns: repeat(2, 1fr); }
  .process-grid { grid-template-columns: 1fr; }
  .hero__badge { font-size: 0.68rem; }
  .portfolio-filter-btn span { display: none; }
  .portfolio-hero-stats { gap: 1rem; }
  .portfolio-hero-stat__num { font-size: 1.4rem; }
  .case-results-row { gap: 1rem; }

  /* Industries → full width pills on small screens */
  .industry-pill { min-width: 100%; }

  /* Trust badges → 1 col */
  .trust-badge { min-width: 100%; }

  /* Problem cards → full width */
  .problem-card { flex-direction: column; }
  .problem-card__arrow { display: none; }
}

/* ── Homepage mobile fixes ── */

/* 10-service grid on tablet */
@media (max-width: 1024px) {
  .services-problems-grid--10 { grid-template-columns: repeat(2, 1fr) !important; }
}

@media (max-width: 768px) {
  /* ── Hero ── */
  .hero { min-height: auto; padding-top: 110px; padding-bottom: 3rem; }
  .hero__title { font-size: clamp(1.8rem, 6vw, 2.5rem); }
  .hero__sub { font-size: var(--fs-base); max-width: 100%; }
  .hero__results-strip { flex-wrap: nowrap; overflow-x: auto; }

  /* ── 10-service grid → single col ── */
  .services-problems-grid--10 { grid-template-columns: 1fr !important; }

  /* ── Stats bar ── */
  .stat-item__number { font-size: clamp(1.75rem, 6vw, 2.5rem); }

  /* ── AI Advantage ── */
  .ai-grid { gap: var(--sp-10); }
  .ai-terminal { font-size: 0.72rem; }

  /* ── Process ── */
  .process-step__title { font-size: var(--fs-base); }
  .process-step__num { width: 56px; height: 56px; font-size: var(--fs-lg); }

  /* ── Case studies section-head ── */
  #work .section-head { flex-direction: column !important; align-items: flex-start !important; gap: 1rem; }

  /* ── Testimonials ── */
  .testimonial-card { padding: var(--sp-5); }
  .testimonial-card__quote { font-size: 0.82rem; }

  /* ── Trust band ── */
  .trust-badges { justify-content: flex-start; gap: var(--sp-2); }
  .trust-badge { min-width: calc(50% - 0.25rem); }

  /* ── Google rating bar ── */
  .google-rating-bar { flex-direction: column; gap: 0.4rem; }
  .google-rating-bar__score { font-size: 1.6rem; }

  /* ── Blog preview ── */
  .blog-preview-card__thumb { aspect-ratio: 16/7; }

  /* ── Section headings on dark bg ── */
  .section-head--center .section-head__sub { max-width: 100%; }

  /* ── Comparison mobile visible ── */
  .comparison-table { display: none !important; }
  .comparison-mobile { display: block; }

  /* ── FAQ layout ── */
  .faq-layout { grid-template-columns: 1fr; gap: 1.5rem; }
  .faq-layout > div:first-child { text-align: left; }
}

@media (max-width: 480px) {
  /* ── Hero ── */
  .hero { padding-top: 90px; }
  .hero__badge { font-size: 0.65rem; padding: 0.3rem 0.75rem; }
  .hero__results-strip { flex-direction: column; align-items: flex-start; gap: 0.75rem; }
  .hero__result-sep { display: none; }
  .hero__result-item { display: flex; align-items: center; gap: 0.75rem; text-align: left; }
  .hero__result-num { font-size: 1.5rem; }

  /* ── Stats ── */
  .stat-item__number { font-size: 1.75rem; }
  .stat-item__label { font-size: 0.8rem; }

  /* ── Section padding ── */
  .section-pad { padding-block: var(--sp-12); }
  .section-head { margin-bottom: var(--sp-8); }

  /* ── Process ── */
  .process-grid { grid-template-columns: 1fr; }

  /* ── Testimonials ── */
  .testimonials-grid { grid-template-columns: 1fr; }

  /* ── Trust band ── */
  .trust-badge { min-width: 100%; }

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

/* ── Service page responsive ── */
@media (max-width: 1024px) {
  .service-hero__inner { grid-template-columns: 1fr; }
  .service-hero__card { display: none; }
  .service-included-grid { grid-template-columns: repeat(2, 1fr); }
  .service-process-grid { grid-template-columns: repeat(2, 1fr); }
  .service-process-grid::before { display: none; }
}
@media (max-width: 768px) {
  .service-hero { padding: 110px 0 60px; }
  .service-hero__title { font-size: clamp(1.9rem, 5vw, 2.5rem); }
  .service-hero__actions { flex-direction: column; align-items: stretch; }
  .service-hero__actions .btn { width: 100%; justify-content: center; }
  .service-hero__trust { gap: 1rem; }
  .service-included-grid { grid-template-columns: 1fr; }
  .service-process-grid { grid-template-columns: 1fr; }
  .service-sidebar__cta { position: static; }
}
@media (max-width: 480px) {
  .service-hero__trust { flex-direction: column; align-items: flex-start; gap: 0.5rem; }
}

/* ════════════════════════════════════════════════════════════
   New CSS classes replacing inline styles — full responsive
   ════════════════════════════════════════════════════════════ */

/* Page hero CTA row — stack on mobile */
@media (max-width: 600px) {
  .page-hero__cta-row {
    flex-direction: column;
    align-items: stretch;
  }
  .page-hero__cta-row .btn { width: 100%; justify-content: center; }
}

/* Page hero trust bar — smaller gap on mobile */
@media (max-width: 600px) {
  .page-hero__trust-bar { gap: 0.875rem; margin-top: 1.25rem; }
}

/* Google Ads trust band — wrap tightly on small screens */
@media (max-width: 768px) {
  .ads-trust-strip { gap: 1.25rem; justify-content: flex-start; }
}
@media (max-width: 480px) {
  .ads-trust-strip { gap: 0.75rem; flex-wrap: wrap; }
  .ads-trust-item { font-size: 0.8rem; }
}

/* Case study sidebar: hide Key Results card on mobile/tablet — hero already shows them */
@media (max-width: 1024px) {
  .cs-sidebar-card--dark { display: none; }
}

/* Case study sidebar cards — tighter padding on small phones */
@media (max-width: 600px) {
  .cs-sidebar-card { padding: 1.25rem; }
  .cs-sidebar-card--cta { padding: 1.5rem; }
}

/* Portfolio card results strip — scale down on mobile */
@media (max-width: 480px) {
  .portfolio-result__num { font-size: 1.15rem; }
  .portfolio-result__label { font-size: 0.65rem; }
  .portfolio-card__results { padding: var(--sp-3) var(--sp-5); }
}

/* Services hub stat strip — 4→2 cols on tablet, 2 cols on phone */
@media (max-width: 768px) {
  .hub-stat-strip { grid-template-columns: repeat(2, 1fr); gap: 1.25rem; padding: 1.5rem; }
  .hub-why-grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-4); }
}
@media (max-width: 480px) {
  .hub-stat-strip { grid-template-columns: repeat(2, 1fr); gap: 1rem; padding: 1.25rem; }
  .hub-why-grid > div { padding: var(--sp-4); }
}

/* Case study CTA row — stack on mobile */
@media (max-width: 600px) {
  .case-study-cta-row { flex-direction: column; align-items: stretch; }
  .case-study-cta-row .btn { width: 100%; justify-content: center; }
}

/* Case study featured image — less padding on phones */
@media (max-width: 480px) {
  .case-study-featured-img .container { padding-block: 1rem; }
  .case-study-featured-img__inner { border-radius: 8px; }
}

/* Case study quote — tighter on phones */
@media (max-width: 480px) {
  .case-study-quote { padding: 1.25rem; }
  .case-study-quote p { font-size: 1rem !important; }
}

/* ════════════════════════════════════════════════════════════
   Services & Portfolio — mobile refinements (2026-05-30)
   Additive overrides (later rules win); desktop untouched.
   ════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* Service hero: tighter rhythm, readable trust row */
  .service-hero__sub { font-size: var(--fs-base); }
  .service-hero__trust { row-gap: 0.5rem; }
  .service-included-card { padding: var(--sp-6); }

  /* Service body: stop wide media/tables from breaking the layout */
  .service-content :is(img, iframe, video, table, pre) { max-width: 100%; height: auto; }
  .service-content table { display: block; overflow-x: auto; }
  .service-content { overflow-wrap: anywhere; }

  /* Portfolio filters: horizontal scroll strip on tablet/mobile */
  .portfolio-filters {
    flex-wrap: nowrap;
    justify-content: flex-start;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    margin-left: calc(var(--container-px) * -1);
    margin-right: calc(var(--container-px) * -1);
    padding: 0 var(--container-px) 0.5rem;
    margin-bottom: 2rem;
  }
  .portfolio-filters::-webkit-scrollbar { display: none; }
  .portfolio-filter-btn { flex: 0 0 auto; }

  /* Related portfolio on service pages: force responsive grid */
  .portfolio-grid--3col { grid-template-columns: repeat(2, 1fr) !important; }
}

@media (max-width: 600px) {
  /* Portfolio hero stats: non-wrapping 4-col flex → tidy 2×2 grid */
  .portfolio-hero-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem 1rem;
    margin-top: var(--sp-8);
  }
  .portfolio-hero-stat { text-align: left; }
  .portfolio-hero-stat__num { font-size: 1.6rem; }

  /* Portfolio card: comfortable spacing on small screens */
  .portfolio-card__body { padding: var(--sp-5); }
  .portfolio-card__results { gap: var(--sp-2); padding: var(--sp-3); }
  .portfolio-result__num { font-size: var(--fs-lg); }

  /* Related portfolio on service pages: single column */
  .portfolio-grid--3col { grid-template-columns: 1fr !important; }
}

/* ════════════════════════════════════════════════════════════
   PORTFOLIO PAGE — Comprehensive mobile fix
   These rules are last so they win over all earlier fragments.
   ════════════════════════════════════════════════════════════ */

/* ── Stats row: clean 2×2 grid from 768px down ── */
@media (max-width: 768px) {
  .portfolio-hero-stats {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem 2rem;
    margin-top: 2.5rem;
  }
  .portfolio-hero-stat { text-align: left; }
  .portfolio-hero-stat__num { font-size: 1.6rem; }
  .portfolio-hero-stat__label { font-size: 0.78rem; }
}

/* ── Filter bar: horizontal scroll with right fade ── */
@media (max-width: 768px) {
  .portfolio-filters-wrap {
    position: relative;
  }
  .portfolio-filters {
    flex-wrap: nowrap;
    justify-content: flex-start;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 0.25rem;
    margin-bottom: 2rem;
    /* Fade on right edge to hint scrollability */
    -webkit-mask-image: linear-gradient(to right, black 80%, transparent 100%);
    mask-image: linear-gradient(to right, black 80%, transparent 100%);
  }
  .portfolio-filters::-webkit-scrollbar { display: none; }
  .portfolio-filter-btn { flex: 0 0 auto; }
  /* Restore count badge — we scroll so space isn't a problem */
  .portfolio-filter-btn__count { display: inline !important; }
}

/* ── Portfolio cards: prevent tall cards on mobile ── */
@media (max-width: 768px) {
  .portfolio-card__thumb { aspect-ratio: 16 / 8; }
  .portfolio-card__body { padding: 1.25rem; }
  .portfolio-card__title { font-size: 1.05rem; margin-bottom: 0.5rem; }
  .portfolio-card__desc {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom: 0.875rem;
    font-size: 0.82rem;
  }
  .portfolio-card__results {
    gap: 0.5rem;
    padding: 0.75rem;
    margin-bottom: 0.75rem;
  }
  .portfolio-result__num { font-size: 1.1rem; }
  .portfolio-result__label { font-size: 0.7rem; }
  .portfolio-card__client { margin-bottom: 0.25rem; }
  /* Placeholder icon — slightly larger so it fills the space */
  .portfolio-card__thumb-placeholder svg { width: 48px; height: 48px; }
}

/* ── Tiny phones (≤480px) ── */
@media (max-width: 480px) {
  .portfolio-hero-stats { gap: 1rem 1.5rem; }
  .portfolio-hero-stat__num { font-size: 1.4rem; }
  .portfolio-card__thumb { aspect-ratio: 16 / 7; }
  .portfolio-card__body { padding: 1rem; }
  .portfolio-card__title { font-size: 1rem; }
  .portfolio-result__num { font-size: 1rem; }
  .page-hero { padding: 90px 0 50px; }
  .page-hero__title { font-size: clamp(1.5rem, 7vw, 2rem); }
}

/* ── Service generic redesign — responsive ── */
@media (max-width: 1024px) {
  .service-generic-body { grid-template-columns: 1fr; gap: var(--sp-10); }
  .service-generic-aside { position: static; }
}
@media (max-width: 768px) {
  .service-features { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .service-hero__badge-row { flex-wrap: wrap; gap: 0.5rem; }
  .process-grid { grid-template-columns: 1fr 1fr; gap: var(--sp-6); }
  .process-grid::before { display: none; }
  .services-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .process-grid { grid-template-columns: 1fr; }
}
