@media (max-width: 991px) {
  html,
  body {
    max-width: 100%;
    overflow-x: hidden;
  }

  .container {
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
  }

  .single-hero {
    padding: 120px 0 349px;
    background:
      linear-gradient(rgba(51, 54, 57, 0.35), rgba(51, 54, 57, 0.35)),
      var(--single-hero-bg-mobile, var(--single-hero-bg, url("../../images/pages/service-single/hero.webp"))) center top/cover no-repeat;
  }

  .single-hero--service-1 { --single-hero-bg-mobile: url("../../images/pages/services/mobile/service-mobile-1.webp"); }
  .single-hero--service-2 { --single-hero-bg-mobile: url("../../images/pages/services/mobile/service-mobile-2.webp"); }
  .single-hero--service-3 { --single-hero-bg-mobile: url("../../images/pages/services/mobile/service-mobile-3.webp"); }
  .single-hero--service-4 { --single-hero-bg-mobile: url("../../images/pages/services/mobile/service-mobile-4.webp"); }
  .single-hero--service-5 { --single-hero-bg-mobile: url("../../images/pages/services/mobile/service-mobile-5.webp"); }
  .single-hero--service-6 { --single-hero-bg-mobile: url("../../images/pages/services/mobile/service-mobile-6.webp"); }
  .single-hero--service-7 { --single-hero-bg-mobile: url("../../images/pages/services/mobile/service-mobile-7.webp"); }
  .single-hero--service-8 { --single-hero-bg-mobile: url("../../images/pages/services/mobile/service-mobile-8.webp"); }
  .single-hero--service-9 { --single-hero-bg-mobile: url("../../images/pages/service-single/hero.webp"); }
  .single-hero--service-10 { --single-hero-bg-mobile: url("../../images/pages/service-single/hero.webp"); }

  .single-hero__content {
    width: 100%;
    max-width: 100%;
    margin: 0;
  }

  .single-hero h1 {
    width: 100%;
    max-width: 100%;
    margin-bottom: 20px;
    font-size: 48px;
    line-height: normal;
    overflow-wrap: break-word;
  }

  .single-hero__content p {
    margin-bottom: 20px;
    font-size: 28px;
    line-height: normal;
    overflow-wrap: break-word;
  }

  .intro-panel {
    margin-top: -80px;
    padding-left: 20px;
    padding-right: 20px;
  }

  .intro-panel__inner {
    width: 100%;
    min-height: 0;
    padding: 24px;
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 40px), calc(100% - 40px) 100%, 40px 100%, 0 calc(100% - 40px));
  }

  .intro-panel p {
    font-size: 20px;
    line-height: normal;
  }

  .intro-panel p + p {
    margin-top: 28px;
  }

  .switching {
    padding-top: 120px;
  }

  .switching__grid {
    display: block;
  }

  .switching__content h2,
  .section-head h2,
  .faq-section__content h2 {
    font-size: 40px;
    line-height: normal;
  }

  .switching__content > p:not(.section-tag) {
    font-size: 16px;
    line-height: normal;
  }

  .switching__image {
    width: 100vw;
    height: 265px;
    margin: 30px 0 0 calc(50% - 50vw);
    background-position: center;
  }

  .switching__image::after {
    height: 40px;
  }

  .benefits {
    margin-top: 120px;
    padding: 0 0 400px;
    background: url("../../images/pages/service-single/benefits-bg.webp") center bottom/100% 360px no-repeat;
  }

  .benefits__content {
    width: 100%;
  }

  .benefits h2 {
    font-size: 49px;
    line-height: normal;
  }

  .benefits__list {
    gap: 20px;
    margin-top: 20px;
  }

  .benefits__list li {
    width: 100%;
    min-height: 72px;
    padding: 10px 20px 10px 20px;
    font-size: 20px;
    line-height: normal;
  }

  .benefits__list li svg {
    align-self: center;
  }

  .process {
    padding-top: 120px;
  }

  .section-head {
    width: 100%;
    text-align: left;
  }

  .section-head > p:not(.section-tag) {
    font-size: 16px;
    line-height: normal;
    text-align: left;
    margin-bottom: 40px;
  }

  .process__grid {
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 0;
  }

  .step-card {
    width: 100%;
    height: auto;
    min-height: 181px;
    padding: 20px;
  }

  .step-card__title {
    font-size: 23px;
    line-height: normal;
  }

  .step-card__desc {
    font-size: 16px;
    line-height: normal;
  }

  .process__action {
    margin-top: 20px;
  }

  .standards {
    padding-top: 0;
  }

  .standards .section-head > p:not(.section-tag) {
    font-size: 19px;
    line-height: normal;
  }

  .section-tag::after {
    right: -14px;
  }

  .section-head {
    padding-top: 0;
  }
  .standards__grid {
    grid-template-columns: 1fr;
    gap: 20px;
    margin-top: 16px;
  }

  .standard-card,
  .standard-card:nth-child(3),
  .standard-card:nth-child(4),
  .standard-card:nth-child(5),
  .standard-card:nth-child(6) {
    min-height: 0;
    padding: 24px 20px;
  }

  .standard-card h3 {
    font-size: 23px;
    line-height: normal;
  }

  .standard-card p {
    font-size: 19px;
    line-height: normal;
  }

  .faq-section {
    padding-top: 120px;
  }

  .faq-section__grid {
    display: block;
  }

  .faq-section__content {
    padding-left: 0;
  }

  .faq-section__content > p:not(.section-tag) {
    font-size: 16px;
    line-height: normal;
  }

  .faq-section__content .btn {
    margin-top: 20px;
  }

  .faq-list {
    margin-top: 40px;
  }

  .faq-item {
    margin-bottom: 20px;
  }

  .faq-item__question {
    min-height: 88px;
  }

  .faq-item__question-text {
    font-size: 19px;
    line-height: normal;
  }

  .prefooter {
    margin-top: 100px;
    padding: 40px 0;
  }

  .pre-grid {
    grid-template-columns: 1fr;
    gap: 80px;
  }

  .pre-grid > div:last-child {
    margin-top: 0;
  }

  .prefooter h2,
  .pre-grid > div:first-child h2,
  .pre-grid > div:last-child h2 {
    font-size: 33px;
    line-height: normal;
  }

  .pre-grid > div:first-child > p,
  .pre-grid > div:last-child > p {
    font-size: 19px;
    line-height: normal;
  }

  .contact-list {
    gap: 20px;
  }

  .contact-item {
    align-items: center;
  }

  .contact-item--map {
    max-width: none;
  }

  .form {
    width: 100%;
  }

  .form input {
    height: 60px;
  }
}
