.hero-title-block {
  margin-top: 20px;
}

.title-text {
  margin-top: 40px;
  display: inline-flex;
  align-items: baseline;
  flex-wrap: wrap;
}

.title-text h1 {
  display: inline;
  margin: 0;
}

.title-text h1 svg {
  display: inline-block;
  vertical-align: baseline;
  margin-left: 10px;
  position: relative;
  top: 3px;
}

@media (min-width: 1616px) {
  .hero-title-block {
    left: -46px;
  }

  .hero-title-block h1 {
    font-size: 3rem;
    font-weight: 600;
  }

  .title-text {
    font-size: 58px !important;
    font-weight: 600 !important;
  }

  #header-icon {
    width: 46px;
    height: 46px;
    position: relative;
    top: -1px;
    left: -16px;
  }
}

@media (max-width: 1616px) {
  .hero-title-block h1 {
    font-size: 2.5rem;
    font-weight: 600;
  }

  .title-text {
    font-size: 58px !important;
    font-weight: 600 !important;
  }

  #header-icon {
    width: 38px;
    height: 38px;
    position: relative;
    top: -1px;
    left: -16px;
  }
}

.yandex-benefits-section {
  padding: 0;
}

.testimonials-section {
  padding: 0 !important;
}

@media (max-width: 630px) {
  #header-icon {
    left: -3px;
  }
}

@media (min-width: 968px) {
  .title-text {
    font-size: 54px !important;
    font-weight: 600 !important;
  }
}

@media (max-width: 968px) {
  .title-text {
    margin-top: 20px;
    font-size: 32px !important;
  }
}

@media (min-width: 630px) {
  .title-text {
    font-size: 54px !important;
    font-weight: 600 !important;
  }
}

@media (max-width: 480px) {
  .title-text {
    font-size: 28px !important;
  }
}

.title-text {
  margin-top: 40px;
  display: inline-flex;
  align-items: baseline;
  flex-wrap: wrap;
}

.title-text h1 {
  display: inline;
  margin: 0;
}

.title-text h1 svg {
  display: inline-block;
  vertical-align: baseline;
  margin-left: 10px;
  position: relative;
  top: 3px;
}

@media (min-width: 1312px) and (max-width: 1616px) {
  .yandex-benefits-hero-card {
    height: 608px;
  }
}

/* business improvement section */
.step-card-item.card-05 {
  order: 4;
}

.step-card-item.card-06 {
  order: 5;
}

.step-title-h5.title-05,
.step-title-h5.title-06 {
  height: 40px;
}

@media (min-width: 1120px) {
  .steps-container-grid {
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: thin;
    scrollbar-color: #dcdcdc transparent;
    padding-bottom: 10px;
  }

  .steps-container-grid::-webkit-scrollbar {
    height: 8px;
  }

  .steps-container-grid::-webkit-scrollbar-track {
    background: transparent;
  }

  .steps-container-grid::-webkit-scrollbar-thumb {
    background-color: #dcdcdc;
    border-radius: 4px;
  }

  .steps-container-grid::-webkit-scrollbar-thumb:hover {
    background-color: #c0c0c0;
  }
}

@media (min-width: 1120px) and (max-width: 1616px) {
  .steps-container-grid {
    gap: 90px;
    width: 1100px;
  }
}

@media (min-width: 1616px) {
  .steps-container-grid {
    gap: 107px;
  }
}

@media (max-width: 768px) {
  .step-content-wrapper.content-05,
  .step-content-wrapper.content-06 {
    height: auto;
  }

  .step-description-text.desc-05,
  .step-description-text.desc-06 {
    height: auto;
  }

  .step-title-h5.title-05,
  .step-title-h5.title-06 {
    height: auto;
  }
}

@media (min-width: 768px) and (max-width: 1120px) {
  .step-card-item.card-05,
  .step-card-item.card-06 {
    height: auto;
  }

  .step-content-wrapper.content-05,
  .step-content-wrapper.content-06 {
    height: auto;
  }

  .step-description-text.desc-05,
  .step-description-text.desc-06 {
    height: auto;
  }
}

@media (min-width: 1120px) and (max-width: 1616px) {
  .step-title-h5.title-05,
  .step-title-h5.title-06 {
    height: 34px;
  }
}

@media (min-width: 1120px) {
  .business-improvement-section {
    overflow: hidden;
  }

  .business-improvement-frame {
    overflow: hidden;
    height: 490px;
  }

  .steps-container-grid {
    width: 100vw;
    max-width: none;
    margin-left: calc(-50vw + 50%);
    padding-left: calc(50vw - 50%);
    padding-right: calc(50vw - 50%);
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding-bottom: 10px;
  }

  .steps-container-grid::-webkit-scrollbar {
    display: none;
  }
}

@media (min-width: 1120px) and (max-width: 1616px) {
  .business-improvement-frame .divider-line {
    width: 1250px;
    left: 11px;
    top: 361px;
  }

  .process-header-wrapper {
    gap: 17px;
    width: 1100px;
    height: 221px;
  }

  .main-title-h1 {
    width: 1100px;
    height: 124px;
  }

  .business-improvement-section {
    padding: 90px 0;
  }

  .header-text-container {
    gap: 364px;
    width: 1100px;
    height: 80px;
  }

  .blue-badge svg:nth-child(1) {
    margin-right: -8px;
  }

  .description-text-large {
    width: 567px;
    height: 80px;
    font-size: 22px;
  }

  .steps-container-grid {
    gap: 90px;
    top: 261px;
    position: absolute;
    left: 0;
  }

  .step-card-item {
    gap: 25px;
    width: 214px;
  }

  .step-heading-wrapper {
    gap: 17px;
    width: 214px;
    height: 64px;
  }

  .number-badge-circle {
    padding: 16px 13px;
    width: 65px;
    height: 64px;
    border-radius: 32px;
  }

  .badge-number-text {
    width: 19px;
    height: 17px;
    font-size: 17px;
  }

  .step-title-h5 {
    width: 136px;
    font-size: 18px;
  }

  .step-title-h5.title-01 {
    height: 17px;
  }

  .step-title-h5.title-02,
  .step-title-h5.title-03,
  .step-title-h5.title-04,
  .step-title-h5.title-05,
  .step-title-h5.title-06 {
    height: 34px;
  }

  .step-content-wrapper {
    gap: 29px;
    width: 214px;
  }

  .ellipse-indicator-container {
    width: 22px;
    height: 22px;
    border-radius: 11px;
    margin-top: 2px;
  }

  .ellipse-dot {
    width: 13px;
    height: 13px;
  }

  .step-description-text {
    width: 214px;
    font-size: 14px;
  }
}

@media (min-width: 1616px) {
  .business-improvement-section {
    padding: 110px 0;
  }

  .steps-container-grid {
    gap: 107px;
    position: absolute;
    left: 0;
    top: 312px;
  }

  .business-improvement-frame .divider-line {
    left: 4px;
    top: 446px;
    width: 1580px;
  }

  .business-improvement-frame {
    height: 610px;
  }
}

.onetimeservices-cards-grid-container {
  grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 768px) {
  .steps-container-grid::before {
    content: '';
    position: absolute;
    width: calc(230px * 6 + 24px * 7);
    height: 0px;
    left: 2.1rem;
    bottom: 167px;
    border: 1.5px solid #dcdcdc;
    pointer-events: none;
    z-index: 0;
  }
}

@media (min-width: 768px) and (max-width: 1120px) {
  .steps-container-grid::before {
    content: '';
    position: absolute;
    width: calc(280px * 6 + 24px * 3);
    height: 0px;
    left: 2.1rem;
    bottom: 187px;
    border: 1.5px solid #dcdcdc;
    pointer-events: none;
    z-index: 0;
  }
}

@media (min-width: 1616px) {
  .is-margin {
    padding: 110px 0;
  }

  .is-bottom-margin {
    padding: 0 0 110px 0;
  }
}

@media (max-width: 1616px) {
  .is-margin {
    padding: 90px 0;
  }

  .is-botttom-margin {
    padding: 0 0 90px 0;
  }
}

@media (max-width: 968px) {
  .is-margin {
    padding: 70px 0;
  }

  .is-bottom-margin {
    padding: 0 0 70px 0;
  }

  .hero-development-section {
    padding-bottom: 0;
  }
}

.overload-graphic {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 48px;
  width: 429px;
  height: 47px;
}

.overload-badge {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  height: 47px;
  flex: none;
  flex-grow: 0;
}

.overload-badge-price {
  width: 185px;
}

.overload-badge-timeline {
  width: 196px;
}

.overload-badge-icon {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  padding: 5px 6px;
  width: 47px;
  height: 47px;
  background: #ffffff;
  border-radius: 38.5px;
  flex-shrink: 0;
}

.overload-badge-icon svg {
  width: 36px;
  height: 36px;
}

.stack-card {
  min-height: 300px;
}

.overload-badge-text {
  font-family: 'Roboto', sans-serif;
  font-style: normal;
  font-weight: 700;
  font-size: 18px;
  line-height: 100%;
  color: #ffffff;
  white-space: nowrap;
}

@media (min-width: 1616px) {
  .overload-card {
    height: 800px;
  }

  .overload-image {
    height: 80%;
    right: 50px;
  }

  .overload-title {
    font-size: 38px;
  }

  .overload-graphic {
    margin-bottom: -10px;
  }
}

@media (max-width: 1616px) {
  .overload-card {
    height: 680px;
  }

  .overload-title {
    font-size: 30px;
  }

  .overload-image {
    height: 75%;
    right: 40px;
  }

  .overload-badge-text {
    font-size: 16px;
  }

  .stack-card {
    min-height: 270px;
  }
}

@media (max-width: 968px) {
  .overload-card {
    height: auto;
    flex-direction: column;
  }

  .overload-image {
    position: static;
    width: 210px;
    max-height: none;
    height: 210px;
    height: auto;
    display: block;
  }

  .overload-content {
    width: 100%;
  }

  .overload-title {
    max-width: 100%;
  }

  .overload-list-item {
    width: 100%;
  }

  .overload-graphic {
    gap: 0;
    width: 100%;
  }

  .overload-buttons {
    flex-direction: row;
    width: 100%;
  }

  .overload-btn-primary,
  .overload-btn-outline {
    width: 100%;
  }

  .overload-content {
    padding: 40px 20px;
  }

  .is-margin-top {
    padding-top: 70px;
  }
}

.overload-list-text {
  font-weight: 500;
}

@media (max-width: 520px) {
  .overload-badge-text {
    font-size: 15px;
  }

  .overload-title {
    font-size: 21px;
  }
}

@media (max-width: 428px) {
  .overload-graphic {
    flex-direction: column;
    align-items: flex-start;
    height: 102px;
    gap: 12px;
  }

  .overload-buttons {
    flex-direction: column;
  }
}

@media (min-width: 1616px) {
  .yandex-benefits-hero-card {
    height: 838px;
  }

  .title-text h1 {
    margin-top: -30px;
  }

  .hero-development-description-text {
    width: 673px;
    top: 176px;
    font-size: 22px;
  }

  .is-margin-top {
    padding-top: 110px;
  }
}

@media (max-width: 1616px) and (min-width: 968px) {
  .yandex-benefits-hero-card {
    height: 766px;
  }

  .title-text h1 {
    margin-top: -40px;
  }

  .hero-development-description-text {
    top: 136px;
    font-size: 22px;
  }

  .is-margin-top {
    padding-top: 90px;
  }
}

@media (max-width: 720px) {
  .pricing-tariffs-section {
    padding-bottom: 70px;
  }
}

@media (max-width: 768px) {
  .hero-title-block h1 {
    font-size: 32px !important;
  }

  #header-icon {
    margin-left: -2px;
    width: 32px;
    left: 0;
  }
}

@media (max-width: 630px) {
  .hero-title-block h1 {
    line-height: 110%;
  }
}

@media (max-width: 630px) {
  .hero-title-block {
    margin-top: 5px;
  }
}
