/* MOBILE ADAPTIVE SLIDER */

@media (max-width: 760px) {
  :root {
    --side: 24px;
    --mobile-slider-gap: 18px;
    --mobile-slide-width: 88%;
  }

  html,
  body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden !important;
  }

  .services,
  .supply,
  .faq,
  .provider-list,
  .benefits,
  .about-cycle {
    overflow: hidden !important;
  }

  .services .container,
  .supply .container,
  .faq .container,
  .provider-list .container,
  .benefits .container,
  .about-cycle .container {
    width: calc(100% - var(--side) * 2) !important;
    max-width: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    box-sizing: border-box !important;
  }

  /* SERVICES — grid itself must NOT be a carousel */
  .services__grid,
  .services__grid.is-mobile-slider-ready,
  .services__grid.has-mobile-services-track {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    overflow-x: visible !important;
    overflow-y: visible !important;
    white-space: normal !important;
    scroll-snap-type: none !important;
    box-sizing: border-box !important;
  }

  /* Intro stays full-width and readable */
  .services__grid > .services__intro,
  .services__intro {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 0 24px !important;
    padding: 30px 28px 34px !important;
    border: 2px solid #ffe248 !important;
    white-space: normal !important;
    transform: none !important;
    order: 0 !important;
    box-sizing: border-box !important;
    overflow: visible !important;
  }

  .services__intro h2 {
    max-width: 100% !important;
    margin: 0 0 24px !important;
    font-size: clamp(38px, 12vw, 54px) !important;
    line-height: .95 !important;
    letter-spacing: 0 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
  }

  .services__intro p {
    max-width: 100% !important;
    margin: 0 0 20px !important;
    font-size: 18px !important;
    line-height: 1.45 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
  }

  .services__intro .btn {
    width: min(265px, 100%) !important;
    height: 58px !important;
    margin-top: 26px !important;
  }

  /* JS creates this wrapper around only .service-card and .service-photo */
  .mobile-services-track {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: var(--mobile-slider-gap) !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 0 18px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    white-space: normal !important;
    scroll-snap-type: x mandatory !important;
    scroll-padding-left: 0 !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    box-sizing: border-box !important;
  }

  .mobile-services-track::-webkit-scrollbar {
    display: none !important;
  }

  .mobile-services-track > .service-card,
  .mobile-services-track > .service-photo {
    display: flex !important;
    flex: 0 0 var(--mobile-slide-width) !important;
    width: var(--mobile-slide-width) !important;
    max-width: var(--mobile-slide-width) !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    aspect-ratio: 1 / 1 !important;
    margin: 0 !important;
    scroll-snap-align: start !important;
    scroll-snap-stop: always !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    white-space: normal !important;
  }

  .mobile-services-track > .service-card {
    padding: 28px 26px !important;
    flex-direction: column !important;
    justify-content: space-between !important;
  }

  .mobile-services-track > .service-card img {
    width: 72px !important;
    height: 72px !important;
    object-fit: contain !important;
  }

  .mobile-services-track > .service-card p {
    margin: 0 !important;
    max-width: 100% !important;
    font-size: 18px !important;
    line-height: 1.28 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
  }

  .mobile-services-track > .service-photo img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
  }

  /* Fallback if JS is not loaded: no broken horizontal strip */
  .services__grid:not(.has-mobile-services-track) > .service-card,
  .services__grid:not(.has-mobile-services-track) > .service-photo {
    display: flex !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 0 18px !important;
    aspect-ratio: 1 / 1 !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    white-space: normal !important;
  }

  /* Other card groups: horizontal swipe without touching their headings */
  .supply-blocks,
  .faq__grid,
  .provider__grid,
  .benefits__grid,
  .about-cycle__grid,
  .mobile-swipe-track {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    align-items: stretch !important;
    gap: var(--mobile-slider-gap) !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 0 0 18px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    box-sizing: border-box !important;
  }

  .supply-blocks::-webkit-scrollbar,
  .faq__grid::-webkit-scrollbar,
  .provider__grid::-webkit-scrollbar,
  .benefits__grid::-webkit-scrollbar,
  .about-cycle__grid::-webkit-scrollbar,
  .mobile-swipe-track::-webkit-scrollbar {
    display: none !important;
  }

  .supply-blocks > .supply-card,
  .faq__grid > .faq-card,
  .provider__grid > .provider-card,
  .benefits__grid > .benefit,
  .about-cycle__grid > .about-cycle-card {
    flex: 0 0 var(--mobile-slide-width) !important;
    width: var(--mobile-slide-width) !important;
    max-width: var(--mobile-slide-width) !important;
    min-width: 0 !important;
    margin: 0 !important;
    scroll-snap-align: start !important;
    scroll-snap-stop: always !important;
    box-sizing: border-box !important;
  }

  .supply-blocks > .supply-card {
    min-height: 450px !important;
    height: auto !important;
    aspect-ratio: auto !important;
    padding: 30px 26px 32px !important;
    overflow: hidden !important;
  }

  .supply-card img {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
  }

  .faq__grid > .faq-card,
  .provider__grid > .provider-card {
    display: block !important;
    height: auto !important;
    min-height: 285px !important;
    max-height: none !important;
    padding: 24px 24px 68px !important;
    overflow: hidden !important;
  }

  .benefits__grid > .benefit {
    min-height: 300px !important;
    height: auto !important;
    padding: 30px 28px !important;
    overflow: hidden !important;
  }

  .about-cycle__grid > .about-cycle-card {
    min-height: 360px !important;
    height: auto !important;
    aspect-ratio: 1 / 1 !important;
    overflow: hidden !important;
  }
}

@media (max-width: 430px) {
  :root {
    --side: 24px;
    --mobile-slide-width: 88%;
  }

  .mobile-services-track > .service-card,
  .supply-blocks > .supply-card,
  .faq__grid > .faq-card,
  .provider__grid > .provider-card,
  .benefits__grid > .benefit {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }
}
