body {
    --header-height: 3rem
}

.header-fixed .header {
    position: fixed;
    left: 0;
    top: calc(0px - var(--header-height));
    width: 100%;
    z-index: 1000;
    background: #EBEBEB;
    transition: top .15s ease-in
}

.header-visible .header {
    top: 0
}

.header-fixed.header-visible .header {
    top: 0;
    box-shadow: 0 3px 5px #00000029
}

.header-fixed .page {
    padding-top: var(--header-height)
}

@media (width >=1420px) {
    body {
        --header-height: 11.875rem
    }

    .header-fixed .header {
        top: calc(0px - 7rem)
    }
}

.header__nav {
    --wd-nav-link-padding-x: 0;

    flex-wrap: nowrap;
    font-size: 1.125rem;
    font-weight: 600;
    justify-content: space-between;
    flex-grow: 1;
    margin-right: 1.2rem
}

.header__arrow {
    position: absolute;
    left: calc(50vw - 970px);
    top: 0;
    height: 100%
}

@media (width >=1930px) {
    .header__arrow {
        left: 0
    }
}

.header__first-row {
    position: relative;
    padding: .5rem 0;
    background: #02424C
}

.header__first-row .container {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: space-between
}

@media (width >=1420px) {
    .header__first-row {
        padding: .8rem 0;
        background: none
    }
}

.header__second-row {
    display: flex
}

.header__second-row .container {
    display: flex;
    align-items: center;
    padding-top: 1.3rem;
    padding-bottom: 1.3rem
}

.header__contacts {
    display: flex;
    flex-direction: column;
    align-items: flex-end
}

.header__contacts .icon-text_phone {
    font-size: 1.25rem;
    gap: 1.5rem;
    margin-bottom: 1.3rem
}

.header__contacts .address {
    color: #0e0e0e;
    font-size: 1.125rem;
    font-weight: 600;
    line-height: .5
}

.header__social-contacts {
    margin: 0 4.5rem 0 auto;
    gap: 1.7rem
}

.header__social-contacts .icon-text__icon {
    font-size: 1.19rem;
    font-weight: 600;
    line-height: 1
}

.header__social-contacts .icon-text__text {
    gap: 1.5rem
}

.header__form {
    height: 2.8rem;
    align-items: stretch;
    gap: 0
}

.mobile-offcanvas .nav {
    gap: .5rem;
    margin-bottom: 2rem;
    font-weight: 600
}

.mobile-offcanvas .btn__content {
    padding: .75rem 1.5rem
}

.mobile-offcanvas .address {
    font-weight: 600;
    font-size: 1.1rem
}

.mobile-offcanvas__contacts {
    width: 100%;
    gap: .5rem;
    margin-bottom: 2rem;
    justify-content: space-between
}

.mobile-offcanvas__contacts .icon-text__icon {
    font-size: 1.19rem;
    font-weight: 600;
    line-height: 1
}

.mobile-offcanvas__contacts .icon-text__text {
    gap: 1rem
}

.hero {
    margin-top: 1.4rem
}

@media (width >=1420px) {
    .hero {
        margin-top: 3.2rem
    }
}

.hero__btn {
    grid-area: btn;
    width: 100%;
    font-size: 1.206rem;
    font-weight: 600;
    letter-spacing: .05em
}

@media (width >=720px) {
    .hero__btn {
        width: 97%;
        font-size: 1.195rem
    }

    .hero__btn .btn__content {
        padding: 0 2rem 0 0
    }
}

@media (width >=1420px) {
    .hero__btn {
        width: auto;
        font-size: 1.5rem;
        justify-self: start
    }

    .hero__btn .btn__bg {
        height: 6.25rem;
        width: auto
    }
}

@media (width >=720px) {
    .hero__container {
        display: grid;
        grid-template-columns: 50% 50%;
        grid-template-rows: repeat(5, auto);
        grid-template-areas: "title title" "text text" "image image" "blocks blocks" "btn desk";
        align-items: center
    }
}

@media (width >=1420px) {
    .hero__container {
        grid-template: "image bd up up" 2.4rem "image bd title title" auto "image bd text text" auto "image bd blocks blocks" 1fr "image bd btn desk" auto "image bd dn dn" 2.4rem / 28.9rem 3.4rem 33% 1fr
    }
}

.hero__icon-block {
    min-width: 17rem;
    padding-top: 1.8em;
    padding-bottom: 1.8em;
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.625rem
}

.hero__icon-block .icon-block__icon {
    font-size: 1.6875rem
}

@media (width >=720px) {
    .hero__icon-block {
        padding-top: 2.4em;
        padding-bottom: 2.4em;
        flex-shrink: 1;
        flex-basis: 33%;
        min-width: unset;
        font-size: 1rem;
        line-height: 1.29rem
    }

    .hero__icon-block .icon-block__icon {
        font-size: 1.25rem
    }
}

@media (width >=1420px) {
    .hero__icon-block {
        font-size: 1.25rem;
        line-height: 1.625rem
    }

    .hero__icon-block .icon-block__icon {
        font-size: 1.7rem
    }
}

.hero__link-description {
    display: inline-block;
    color: inherit;
    text-decoration: none;
    grid-area: desk;
    margin: 2rem 0;
    font-weight: 500;
    font-size: 1.125rem;
    line-height: 155%
}

.hero__link-description b {
    color: #e30613;
    font-weight: inherit
}

@media (width >=720px) {
    .hero__link-description {
        font-weight: 600;
        font-size: .89rem;
        margin-left: .8rem
    }
}

@media (width >=1420px) {
    .hero__link-description {
        font-size: 1.1rem;
        margin: 0
    }
}

.hero__picture {
    grid-area: image
}

.hero__picture .picture__img {
    margin-bottom: 2.2rem;
    border-radius: .625rem
}

@media (width >=1420px) {
    .hero__picture .picture__img {
        margin: 0;
        border-radius: 1.875rem
    }
}

.hero__scroll {
    display: flex;
    gap: 1rem
}

@media (width >=720px) {
    .hero__scroll {
        grid-area: blocks;
        gap: .85rem;
        margin-bottom: 2rem
    }
}

@media (width >=1420px) {
    .hero__scroll {
        margin: 0 0 3rem
    }
}

.hero__text {
    font-size: 1rem;
    color: #474646;
    font-weight: 500;
    line-height: 150%
}

@media (width >=720px) {
    .hero__text {
        grid-area: text;
        font-size: 1.25rem;
        margin-bottom: 2em
    }
}

@media (width >=1420px) {
    .hero__text {
        font-size: 1.5rem
    }
}

.hero__title {
    font-size: 2.25rem;
    font-weight: 700;
    line-height: 3.5rem
}

@media (width >=720px) {
    .hero__title {
        grid-area: title;
        font-size: 3rem;
        margin-bottom: .5em
    }
}

@media (width >=1420px) {
    .hero__title {
        font-size: 4rem
    }
}

.hero-modal {
    --bs-modal-width: 1015px
}

.hero-modal .btn-close {
    position: absolute;
    right: 1rem;
    top: 1rem
}

.hero-modal__btn {
    margin: 1.5rem 0;
    font-family: var(--bs-body-font-family);
    font-weight: 500;
    letter-spacing: .05em
}

.hero-modal__btn .btn__content {
    justify-content: flex-start
}

@media (width <=1419.99px) {
    .hero-modal__btn {
        width: 100%
    }
}

@media (width >=1420px) {
    .hero-modal__btn {
        width: auto;
        font-size: 1.5rem
    }

    .hero-modal__btn .btn__bg {
        height: 4.375rem;
        width: auto
    }

    .hero-modal__btn .btn__content {
        padding-left: 2.5rem
    }
}

.hero-modal__img {
    width: 15rem;
    margin-right: 1.5rem;
    flex-shrink: 0
}

.hero-modal__img img {
    border-radius: 1.875rem
}

@media (width >=1420px) {
    .hero-modal__img {
        width: 15.7rem;
        margin-right: 3rem
    }
}

.hero-modal__text {
    font-weight: 500;
    line-height: 1.37;
    letter-spacing: .05em
}

.hero-modal__title {
    font-size: 1.5rem;
    font-weight: 700
}

@media (width >=1420px) {
    .hero-modal__title {
        margin-top: 1.5rem;
        font-size: 2.25rem
    }
}

.hero-modal__content {
    background: #FFF;
    border-radius: 1rem;
    padding: 3rem 1rem
}

@media (width >=720px) {
    .hero-modal__content {
        flex-direction: row
    }
}

@media (width >=1420px) {
    .hero-modal__content {
        padding: 3rem 2rem
    }
}

.services {
    padding-top: 5rem;
}

@media (width >=1420px) {
    .services__container {
        display: grid;
        grid-template-columns: 45rem minmax(0, 1fr);
        grid-template-rows: repeat(3, auto) 1fr;
        grid-template-areas: "title title" "text nav" "cards tabs" "order tabs";
        gap: 2rem 4rem;
        align-items: end
    }

    .services_contrast-style .services__container {
        display: grid;
        grid-template-columns: minmax(0, 1fr) 45rem;
        grid-template-areas: "title title" "nav text" "tabs cards" "tabs order";
    }
}

.services__nav {
    grid-area: nav;
    flex-wrap: nowrap;
    margin-bottom: 1.75em;
    font-size: .75rem;
    font-weight: 600
}

.services__nav .btn {
    --wd-btn-border-color: #C4C4C4;

    width: 50%;
    flex-shrink: 1;
    border-radius: .37rem;
    padding: .67em .2em
}

.services_contrast-style .services__nav .btn {
    --wd-btn-active-bg: var(--bs-secondary);
    --wd-btn-active-border-color: var(--bs-secondary);
    --wd-btn-hover-bg: var(--bs-secondary);
    --wd-btn-hover-border-color: var(--bs-secondary);

    font-family: var(--bs-body-font-family);
    font-weight: 600;
}

@media (width >=720px) {
    .services__nav {
        margin-left: 0;
        margin-bottom: 2.5em;
        width: 100%;
        font-size: 1.12rem
    }

    .services__nav .btn {
        padding: .9em .2em
    }
}

@media (width >=1420px) {
    .services__nav {
        margin: 0;
        font-size: 1rem
    }

    .services__nav .btn {
        padding: 1rem .2em;
        border-radius: .625rem;
        border-width: 2px
    }
}

.services__order {
    grid-area: order;
    padding-top: 1rem;
    padding-bottom: 1rem;
    background: rgb(255 255 255 / 100%);
}

.services__order .title {
    margin-bottom: 0;
    font-size: 1.125rem;
    font-weight: 850;
    font-family: var(--bs-secondary-font-family);
}

@media (width >=576px) {
    .services__order {
        margin-left: 0;
        width: 100%;
        padding: 1rem 3rem
    }
}

@media (width >=720px) {
    .services__order {
        border-radius: 0 0 .7rem .7rem;
        font-size: 2.25rem
    }

    .services__order .title {
        font-size: 2.23rem
    }

    .services__order p {
        font-size: 1.5rem;
        font-weight: 500;
        line-height: 1.5;
    }
}

@media (width >=1420px) {
    .services__order {
        margin-top: 1.5rem;
        padding: 1.9rem 4rem 1.5rem;
    }

    .services_contrast-style .services__order {
        background: rgb(255 255 255 / 70%);
    }
}

.services__text {
    grid-area: text;
    margin-bottom: 1.5em;
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 2.25rem
}

.services__text .icon-text__icon {
    display: none
}

@media (width >=720px) {
    .services__text {
        margin-bottom: 2.5em;
        font-size: 1.25rem;
        line-height: normal
    }
}

@media (width >=1420px) {
    .services__text {
        position: relative;
        margin-bottom: 0;
        font-size: 2.25rem;
        font-weight: 600
    }

    .services__text .icon-text__icon {
        display: block;
        position: absolute;
        left: 101%;
        top: .4em
    }

    .services_contrast-style .icon-text__icon {
        left: unset;
        top: .35em;
        right: 103%;
        transform: rotate(180deg);
    }
}

.services__title {
    grid-area: title;
    margin-bottom: 1.3em
}

.services__title>* {
    display: inline-block
}

.services__title .btn {
    color: inherit;
    width: 1.3em;
    height: 1.3em;
    font-size: .5em;
    flex-shrink: 0;
    display: inline-flex;
    border-radius: 50%
}

@media (width >=1420px) {
    .services__title {
        margin-bottom: 2rem
    }

    .services__title sup {
        top: -.75em
    }
}

.services__btn {
    width: 22em;
    height: 3.42em;
    max-width: 100%;
    font-size: .95rem;
    font-weight: 600;
    letter-spacing: .1em
}

.services__btn .btn__content {
    padding: 0 2em 0 0
}

@media (width >=720px) {
    .services__btn {
        width: 20em;
        margin-top: 1rem;
        font-size: 1.68rem;
        letter-spacing: .05em
    }
}

@media (width >=1420px) {
    .services__btn {
        width: 22em;
        font-size: 1.5rem;
        letter-spacing: .1em
    }
}

.services__tabs {
    grid-area: tabs;
    margin-bottom: 3rem
}

@media (width >=720px) {
    .services__tabs {
        margin-left: 0;
        width: 100%
    }
}

@media (width >=1420px) {
    .services__tabs {
        align-self: stretch;
        margin: 0
    }

    .services__tabs .service-card {
        height: 100%
    }

    .services__tabs .service-card.active {
        display: flex;
        flex-direction: column
    }
}

.services__cards {
    grid-area: cards;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: .8rem;
    margin-bottom: 2rem;
    font-family: var(--bs-secondary-font-family);
    font-weight: 850;
    font-size: .7rem
}

.services__cards .card {
    --bs-card-border-radius: .7rem;
    --bs-card-spacer-x: .7rem;
    --bs-card-cap-bg: var(--bs-primary);
    --bs-card-cap-color: #FFF;

    width: calc(50% - .4rem);
    background: #FFF
}

.services__cards .card__body {
    display: flex;
    flex-direction: column;
    padding-right: 1px;
    padding-top: 5px
}

.services__cards .card-title {
    margin-bottom: 0;
    font-size: 1.25em;
    color: var(--bs-primary)
}

.services__cards .card__img {
    margin: auto;
    max-width: 85%
}

.services__cards .card__footer {
    padding-top: .5rem;
    padding-bottom: .5rem;
    text-align: center
}

@media (width >=720px) {
    .services__cards {
        gap: .8rem 0;
        margin-bottom: 4rem;
        font-size: 1rem
    }

    .services__cards .card {
        width: calc(33% - .4rem)
    }

    .services__cards .card__img {
        max-width: 70%
    }

    .services__cards .card__footer {
        padding-top: .7rem;
        padding-bottom: .7rem
    }
}

@media (width >=1420px) {
    .services__cards,
    .services__cards .card {
        margin: 0
    }
}

.services__nav-arrow {
    position: absolute;
    right: 1rem;
    top: .35em;
    z-index: 3;
    font-size: .5rem;
    color: #fff
}

@media (width >=720px) {
    .services__nav-arrow {
        top: .5em;
        font-size: .75rem
    }
}

.service-card {
    --spacer-x: .7rem;
    --border-radius: .55em;

    display: flex;
    flex-direction: column
}

@media (width >=720px) {
    .service-card {
        --spacer-x: 3rem
    }
}

@media (width >=1420px) {
    .service-card {
        --spacer-x: 2rem
    }
}

.service-card__content {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem 3.5rem;
    font-size: .75rem;
    font-weight: 600
}

.service-card__content b {
    color: #848383
}

.service-card__content p {
    margin-bottom: 0
}

.service-card__content>*:first-child {
    width: 100%
}

@media (width >=720px) {
    .service-card__content {
        gap: .75rem 2.6rem;
        font-size: 1.375rem;
        font-weight: 700
    }
}

@media (width >=1420px) {
    .service-card__content {
        font-size: 1.25rem
    }
}

.service-card__footer {
    background: #FFF;
    padding: .5rem var(--spacer-x) 1.2rem;
    border-radius: 0 0 var(--border-radius) var(--border-radius);
    color: #000;
    font-family: var(--bs-secondary-font-family), sans-serif;
    font-size: .83rem;
    font-weight: 600
}

.service-card__footer b {
    font-size: 1.4em
}

.services_contrast-style .service-card__footer b {
    color: var(--bs-secondary);
}

.service-card__footer p {
    margin-bottom: 0
}

@media (width >=720px) {
    .service-card__footer {
        font-size: 1.6rem;
        padding-bottom: 3rem
    }
}

@media (width >=1420px) {
    .service-card__footer {
        padding-top: 1.5rem;
        padding-bottom: 1.5rem;
        font-size: 1.4rem;
        font-weight: 600;
        line-height: 1.3;
    }
}

.service-card__header {
    border-radius: var(--border-radius) var(--border-radius) 0 0;
    background: var(--bs-primary);
    padding: .3em var(--spacer-x);
    color: #fff;
    font-family: var(--bs-secondary-font-family);
    font-size: 1.12rem;
    font-weight: 700;
    letter-spacing: .05em
}

.services_contrast-style .service-card__header {
    background: var(--bs-secondary);
}

@media (width >=720px) {
    .service-card__header {
        font-size: 2.109rem
    }
}

@media (width >=1420px) {
    .service-card__header {
        font-size: 1.875rem
    }
}

.service-card__top {
    background: #FFF;
    padding: 1em var(--spacer-x);
    font-size: .75rem;
    font-weight: 600;
    justify-content: space-between;
    width: 100%
}

.service-card__top p {
    margin-bottom: .2em
}

.service-card__top .icon-text__icon {
    width: 3.28rem;
    height: 3.28rem
}

@media (width >=720px) {
    .service-card__top {
        font-size: 1.375rem
    }

    .service-card__top .icon-text__icon {
        width: 6rem;
        height: 6rem
    }
}

@media (width >=1420px) {
    .service-card__top {
        font-size: 1.25rem
    }

    .service-card__top .icon-text__icon {
        width: 5.5rem;
        height: 5.5rem
    }
}

.service-card__body {
    flex-grow: 1;
    background: #FAF0EF;
    padding: .5rem var(--spacer-x) .8rem
}

.portfolio__title {
    margin-bottom: 1em
}

.portfolio__slider {
    padding-bottom: 5rem;
}

@media (width <=719.99px) {
    .portfolio__title {
        font-size: 1.5rem;
        line-height: 2.25rem
    }
}

.portfolio__nav {
    margin-bottom: 2rem;
    display: flex
}

.portfolio__nav .btn {
    --wd-btn-color: #4C5159;

    height: 1.7rem;
    flex-shrink: 0;
    font-family: var(--bs-body-font-family);
    font-size: .70rem;
    font-weight: 600;
}

.portfolio__nav .btn__bg {
    height: 100%;
    width: auto
}

@media (width >=720px) {
    .portfolio__nav .btn {
        height: 3.125rem;
        font-size: 1.125rem;
        font-weight: 500;
        letter-spacing: .05em;
    }
}

@media (width >=1420px) {
    .portfolio__nav {
        margin-bottom: 4rem
    }

    .portfolio__nav .btn {
        height: 3.5rem;
        font-size: 1.25rem;
        font-weight: 600
    }
}

.portfolio__tabs {
    padding: 1rem 0 3rem;
    border-radius: .625rem;
    background: #FFF
}

@media (width >=576px) {
    .portfolio__tabs {
        margin-left: 0;
        width: 100%;
        padding: 0;
        background: none
    }
}

.portfolio-item {
    margin-bottom: 3rem
}

@media (width >=1420px) {
    .portfolio-item {
        display: flex;
        gap: 2.4rem
    }

    .portfolio-item_images {
        flex-wrap: wrap;
        gap: 2rem
    }
}

.portfolio-item__slider {
    --padding-right: 20%;
    --swiper-pagination-bottom: 2rem;
    --swiper-pagination-top: 2rem;
    --swiper-pagination-bullet-width: 2rem;
    --swiper-pagination-bullet-height: .5rem;
    --swiper-pagination-bullet-border-radius: .125rem;
    --swiper-pagination-color: #FCFAFA;
    --swiper-pagination-bullet-inactive-color: #FFF;
    --swiper-pagination-bullet-inactive-opacity: .47;

    margin-bottom: 1.8rem;
    height: 12rem;
    cursor: pointer
}

.portfolio-item__slider .swiper-pagination {
    display: none
}

.portfolio-item .swiper-pagination-bullet {
    position: relative;
    flex-grow: 1;
    min-width: 13.3%;
    height: 100%;
    background: none;
    border: none
}

.portfolio-item .swiper-pagination-bullet::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: var(--swiper-pagination-bullet-height);
    border-radius: var(--swiper-pagination-bullet-border-radius);
    background-color: var(--swiper-pagination-bullet-inactive-color);
    opacity: var(--swiper-pagination-bullet-inactive-opacity)
}

.portfolio-item .swiper-pagination-bullet-active::after {
    background-color: var(--swiper-pagination-color);
    opacity: 1
}

.portfolio-item__slider img {
    border-radius: .4rem
}

.portfolio-item__body {
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.125rem;
    letter-spacing: .05em
}

.portfolio-item_images .portfolio-item__body {
    display: none; 
}

.portfolio-item__body p {
    margin-bottom: 2em
}

.portfolio-item__body .swiper-slide {
    width: 40%;
    flex-grow: 1;
    height: 10rem;
    cursor: zoom-in;
}

.portfolio-item__body img {
    border-radius: .4rem;
}

.portfolio-item__date {
    margin-bottom: 1em;
    color: #848383;
    font-family: ;
    font-size: 1.125rem;
    font-weight: 500;
    letter-spacing: .05em
}

.portfolio-item__title {
    margin-bottom: 1em;
    font-family: var(--bs-secondary-font-family);
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: .05em
}

.portfolio-item_images .portfolio-item__title {
    width: 100%;
}

.portfolio-item__total {
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.125rem;
    letter-spacing: .05em
}

.portfolio-item__total p {
    margin-bottom: 0
}


@media (width >=720px) {
    .portfolio-item__slider {
        margin-bottom: 3rem;
        height: 21rem
    }

    .portfolio-item__slider img {
        border-radius: .625rem
    }

    .portfolio-item__body {
        padding-top: 1.5rem;
        font-size: 1rem;
        font-weight: 500;
        line-height: 1.375rem
    }

    .portfolio-item__title {
        font-size: 1.5rem;
        margin-bottom: .7em
    }

    .portfolio-item__date {
        margin-bottom: 1.5em
    }

    .portfolio-item__total {
        font-size: 1.125rem;
        line-height: 1.625rem
    }
}

@media (width >=1420px) {
    .portfolio-item__slider {
        margin: 0;
        overflow: hidden;
        flex-shrink: 0;
        width: 45rem;
        height: 29rem
    }

    .portfolio-item__slider img {
        border-radius: .9375rem
    }

    .portfolio-item__slider .swiper-pagination {
        display: flex;
        padding: 0 2rem;
        gap: 1.3rem;
        overflow: hidden
    }

    .portfolio-item_images .portfolio-item__body {
        display: flex;
        gap: 2rem;
        flex-wrap: wrap;
        width: 10rem;
        flex-grow: 1;
    }

    .portfolio-item__body .swiper-slide {
        height: 13.5rem
    }

    .portfolio-item_images .portfolio-item__title {
        margin-bottom: -0.5rem;
    }
}


.testimonials {
    margin: 2rem 0 5rem;
    padding-top: 3rem;
}

.testimonials__form {
    flex-direction: column;
    font-size: 1.125rem
}

.testimonials__form .btn {
    font-family: var(--bs-body-font-family);
    font-size: inherit;
    font-weight: 600;
    letter-spacing: .05em
}

.testimonials__form .btn__content {
    padding: 0 2em 0 0
}

.testimonials__form .form-control__input {
    --wd-input-border-color: #FFF;

    padding: 1.16em;
    border-radius: .7em;
    font-size: inherit;
    font-weight: 500;
    letter-spacing: .05em
}

@media (width >=720px) {
    .testimonials__form {
        flex-flow: row wrap;
        font-size: .8rem
    }

    .testimonials__form .form-control__input {
        padding: .65em 2em;
        border-radius: .45em
    }

    .testimonials__form .btn {
        height: 2.9em
    }

    .testimonials__form .btn__content {
        padding: 0 0 0 1em
    }

    .testimonials__form .btn__bg {
        width: auto;
        height: 100%
    }
}

@media (width >=1420px) {
    .testimonials {
        margin: 6rem 0 8rem;
    }

    .testimonials__form {
        justify-content: space-between;
        font-size: 1.5rem;
        gap: 1.5rem .5rem
    }

    .testimonials__form .form-control__input {
        padding: 1em 3em;
        border-radius: .45em
    }

    .testimonials__form .btn {
        height: 3.5em
    }
}

.testimonials__tabs {
    margin-bottom: 3.57rem
}

.testimonials__nav {
    --wd-nav-link-color: #4C5159;
    --wd-nav-link-padding-x: 0;

    gap: .2em;
    color: #4c5159;
    font-family: var(--bs-secondary-font-family);
    font-size: 1.1rem;
    font-weight: 500
}

@media (width >=720px) {
    .testimonials__nav {
        font-size: 1.5rem
    }
}

@media (width >=1420px) {
    .testimonials__nav {
        margin-bottom: 2rem;
        font-size: 2.25rem
    }
}

.testimonials__video-slider {
    padding: 1rem 0
}

@media (width >=1420px) {
    .testimonials__video-slider .video {
        --wd-video-border-radius: .9375rem;

        width: 36rem
    }
}

.testimonials__letter-slider {
    --bs-aspect-ratio: 130%;

    padding: 1rem 0
}

.inclusive {
    padding: 3rem 0;
    background: url("/assets/a1-4f74ae4b.webp") 50% / cover no-repeat, #02424C93
}

@media (width >=720px) and (width <=1419.99px) {
    .inclusive {
        padding: 6.5rem 0 4rem
    }
}

@media (width >=1420px) {
    .inclusive {
        padding: 9rem 0 8rem
    }
}

.inclusive__title {
    margin-bottom: 2rem;
    color: #fff
}

@media (width <=575.99px) {
    .inclusive__title {
        font-size: 2.1875rem
    }
}

@media (width >=720px) {
    .inclusive__title {
        margin-bottom: 4rem
    }
}

@media (width >=1420px) {
    .inclusive__title {
        margin-bottom: 7rem
    }
}

.inclusive__block-list {
    list-style-type: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    color: #000;
    font-family: var(--bs-secondary-font-family);
    font-size: 1.25rem;
    font-weight: 500;
    line-height: 1.5
}

.inclusive__block-list li {
    display: flex;
    width: 100%;
    height: 9.2rem;
    padding: 2.7rem 1.9rem;
    border-radius: .82rem;
    background: rgb(255 255 255 / 76%);
    box-shadow: 0 0 7px #00000026;
    text-decoration: underline;
    cursor: pointer
}

.inclusive__block-list li::before {
    content: "";
    display: inline-block;
    width: .65em;
    height: .65em;
    flex-shrink: 0;
    margin: .45em 1rem 0 0;
    border-radius: 50%;
    background: var(--bs-secondary)
}

@media (width >=720px) {
    .inclusive__block-list li {
        width: 45%;
        flex-grow: 1
    }
}

@media (width >=1420px) {
    .inclusive__block-list {
        font-size: 1.5rem
    }

    .inclusive__block-list li {
        height: 10.6rem;
        padding-left: 2.5rem;
        text-decoration: none;
        transition: all .15s
    }

    .inclusive__block-list li:hover {
        color: var(--bs-secondary);
        box-shadow: 0 5px 7px #00000059
    }
}

.inclusive__bottom {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    margin-top: 3rem
}

.inclusive__bottom>* {
    flex-basis: 40%;
    flex-grow: 1
}

@media (width >=720px) {
    .inclusive__bottom {
        flex-wrap: nowrap;
        justify-content: space-between
    }

    .inclusive__bottom>* {
        flex-basis: 8em;
        flex-grow: 0
    }
}

@media (width >=1420px) {
    .inclusive__bottom {
        margin-top: 7rem
    }

    .inclusive__bottom>* {
        flex-basis: 15em
    }
}

.inclusive__img {
    margin: 2rem 0 3rem
}

.inclusive__img .img {
    border-radius: 50%;
    border: 4.571px solid #E5E5E5
}

@media (width >=720px) and (width <=1419.99px) {
    .inclusive__img {
        display: none
    }
}

@media (width >=1420px) {
    .inclusive__img {
        width: 33.69rem;
        margin: 0 3rem 0 0;
        border-width: 7px;
        flex-shrink: 0
    }
}

.inclusive__number-description {
    color: #fff;
    font-weight: 600;
    line-height: 1.4
}

@media (width >=720px) {
    .inclusive__number-description {
        font-size: .875rem
    }
}

@media (width >=1420px) {
    .inclusive__number-description {
        font-size: 1.5rem
    }
}

.inclusive__number-title {
    color: #ffffffb3;
    font-family: var(--bs-secondary-font-family);
    font-size: 2.8125rem;
    font-weight: 700
}

@media (width >=720px) {
    .inclusive__number-title {
        font-size: 2.25rem
    }
}

@media (width >=1420px) {
    .inclusive__number-title {
        font-size: 4.5rem
    }
}

@media (width >=1420px) {
    .inclusive__row {
        display: flex
    }
}

.service-modal {
    --bs-modal-width: 1400px;
    --bs-modal-bg: #fff
}

.service-modal .btn-close {
    position: absolute;
    right: 1rem;
    top: 1rem
}

.service-modal .modal-content {
    padding: 2rem 1rem
}

.service-modal .swiper-button {
    margin-right: 1rem;
    height: 2rem;
    width: auto;
    transition: transform .15s ease-in
}

.service-modal .btn {
    margin-top: 1rem;
    padding: 0 4rem;
    margin-left: auto;
    height: 3rem
}

.service-modal .swiper-button:hover {
    transform: scale(1.15)
}

.service-modal .swiper-button svg {
    height: 100%;
    width: auto
}

@media (width >=1420px) {
    .service-modal .swiper-button {
        margin-right: 4rem;
        height: 3rem
    }

    .service-modal .modal-content {
        padding: 2rem 4rem
    }
}

@media (width >=1420px) {
    .service-modal__container {
        display: grid;
        grid-template: "desc image" 0fr "content image" / 60% 40%
    }

    .service-modal__container_single {
        display: block;
    }
}

.service-modal__content {
    grid-area: content;
    font-size: 16px;
    line-height: 1.5
}

.service-modal__content p {
    margin: 14px 0
}

.service-modal__content h4 {
    margin: 1.33em 0
}

.service-modal__content h5 {
    margin: 1.67em 0
}

.service-modal__content ul {
    margin: 14px 0;
    list-style-type: none;
    padding: 0
}

.service-modal__content ul li {
    position: relative;
    margin-bottom: 9px;
    padding-left: 20px
}

.service-modal__content ul li::before {
    content: "";
    position: absolute;
    top: .5em;
    left: 0;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: var(--bs-secondary)
}

.service-modal__content ol {
    margin: 14px 0;
    padding-left: 1.3em
}

.service-modal__content .nav {
    margin-bottom: 1rem;
    gap: 0;
    flex-wrap: nowrap
}

.service-modal__content .nav__link {
    text-transform: uppercase;
    flex-shrink: 0
}

@media (width >=1420px) {
    .service-modal__content p,
    .service-modal__content ul,
    .service-modal__content ol {
        margin: 28px 0
    }

    .service-modal__content .nav {
        overflow: visible
    }
}

.service-modal__description {
    grid-area: desc;
    margin-bottom: 20px;
    font-weight: 400;
    font-size: 16px;
    line-height: 1.45
}

@media (width >=1420px) {
    .service-modal__description {
        font-weight: 400;
        font-size: 18px
    }
}

.service-modal__image {
    grid-area: image;
    display: none
}

@media (width >=1420px) {
    .service-modal__image {
        display: block;
        text-align: center;
        padding-left: 20px
    }

    .service-modal__image img {
        position: sticky;
        top: 0;
        height: calc(100vh - var(--bs-modal-margin) * 2 - 14rem);
        width: auto;
        max-width: 80%
    }
}

.order {
    padding: 4rem 0 8rem;
    background: url("/assets/ai-2-0ea93e7a.webp") 50% / cover no-repeat, var(--bs-secondary);
    color: #fff
}

@media (width >=720px) {
    .order {
        padding: 3rem 0 6rem
    }
}

@media (width >=1420px) {
    .order {
        padding: 5rem 0 10rem
    }
}

.order__form {
    --wd-input-border-color: #FFF;
    --wd-input-color: #FFF;
    --wd-input-placeholder-color: #FFFA;
    --wd-input-focus-color: #FFF;
    --wd-input-focus-border-color: #FFF;
    --bs-link-color-rgb: 255, 255, 255;

    flex-direction: column;
    font-size: 1.25rem;
    font-weight: 500
}

.order__form .form-control__input {
    padding: 1em 0
}

.order__form .btn {
    --wd-btn-bg: #FF9C95;

    width: 100%;
    margin-top: 1.5rem;
    border-radius: 0;
    font-size: 1.5rem;
    font-weight: 600;
    font-family: var(--bs-body-font-family);
    letter-spacing: .05em
}

.order__form .btn__content {
    padding: .75rem
}

@media (width >=720px) {
    .order__form {
        font-size: .875rem;
        flex-flow: row wrap
    }

    .order__form .form-control {
        width: 50%;
        flex-grow: 1
    }

    .order__form .btn {
        margin-top: 1rem;
        font-size: 1rem
    }
}

@media (width >=1420px) {
    .order__form,
    .order__form .btn {
        font-size: 1.5rem;
        font-weight: 600
    }
}

.order__text {
    margin-bottom: .5em;
    font-family: var(--bs-secondary-font-family);
    font-size: 1.75rem;
    font-weight: 700
}

@media (width >=720px) {
    .order__text {
        margin-bottom: 1.3em;
        font-size: 1.25rem;
        font-weight: 500
    }
}

@media (width >=1420px) {
    .order__text {
        font-size: 2.25rem;
        margin-bottom: 1em
    }
}

.order__title {
    margin-bottom: .6em;
    font-weight: 900;
    font-size: 2.25rem
}

@media (width >=720px) {
    .order__title {
        margin-bottom: .3em
    }
}

@media (width >=1420px) {
    .order__title {
        font-size: 4rem
    }
}

@media (width >=1420px) {
    .order__container {
        max-width: 1190px
    }
}

.order__file .form-control__text {
    padding: 1em 0;
    width: 100%;
    display: flex;
    justify-content: space-between
}

.order__file svg {
    height: 1.5em;
    width: auto;
    flex-shrink: 0
}

@media (width >=720px) {
    .order__file.form-control {
        width: 13em;
        flex-grow: 0
    }
}

.order_modal {
    --bs-modal-width: 100%;

    padding: 3rem 0
}

.order_modal .modal-content {
    background: none;
    border: none
}

.order_modal .order__container {
    position: relative
}

.order_modal .btn-close {
    --wd-btn-close-color: currentcolor;

    position: absolute;
    right: .5em;
    top: -2.5em;
    width: 2em;
    height: 2em;
    background-size: 2em
}

@media (width <=575.99px) {
    .order_modal .order__text {
        font-size: 1.2rem
    }
}

.why {
    padding: 5.8rem 0 9rem;
    background: url("/assets/ai-2-0ea93e7a.webp") 70% no-repeat, linear-gradient(360deg, #0E0E0E 0%, #0E0E0E .01%, rgb(14 14 14 / 78%) 61.95%, rgb(14 14 14 / 55%) 100%);
    color: #fff
}

@media (width >=720px) {
    .why {
        background: url("/assets/ai-2-0ea93e7a.webp") 50% / cover no-repeat, linear-gradient(270deg, #0E0E0E 0%, #0E0E0E .01%, rgb(14 14 14 / 78%) 61.95%, rgb(14 14 14 / 0%) 100%), url("/assets/rectangle-780-7989c6ba.webp") 50% / cover no-repeat;
        padding: 5.8rem 0
    }
}

@media (width >=1420px) {
    .why {
        padding: 8rem 0 14rem
    }
}

@media (width >=1420px) {
    .why__container {
        padding-left: 23em
    }
}

.why__list {
    display: flex;
    flex-wrap: wrap;
    gap: 2.4em;
    margin: 0;
    padding: 0;
    list-style-type: none;
    color: #fffcfc;
    font-size: 1.125rem;
    font-weight: 600;
    line-height: 1.5rem
}

.why__list .icon-text {
    width: 100%
}

.why__list .icon-text__icon {
    width: 2.5em;
    margin-right: 1.5em
}

@media (width >=720px) {
    .why__list {
        gap: 1.3em;
        font-size: 1rem;
        font-weight: 400;
        line-height: 1.45rem
    }

    .why__list .icon-text {
        width: 40%;
        max-width: 50%;
        flex-grow: 1
    }

    .why__list .icon-text__icon {
        flex-shrink: 0;
        width: 2.2em;
        margin-right: 1.5em
    }
}

@media (width >=1420px) {
    .why__list {
        gap: 1.5em 3em;
        font-size: 1.5rem;
        font-weight: 600;
        line-height: 2.25rem
    }
}

.why__title {
    max-width: 8em;
    margin-bottom: 1em
}

@media (width >=720px) {
    .why__title {
        max-width: none;
        margin-bottom: 1.2em
    }
}

.job-plan__row {
    padding: 3rem 0 0;
    display: flex
}

.job-plan__card {
    position: relative;
    z-index: 1;
    width: 18rem;
    height: 11.2rem;
    flex-shrink: 0;
    padding: 2.35rem 1rem 0 1.9rem
}

.job-plan_centered .job-plan__card  {
    text-align: center;
}

.job-plan_low .job-plan__card {
    padding-top: 1.5rem;
    height: 8rem;
}

.job-plan__card-bg {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: auto;
    z-index: -1
}

.job-plan__card-position {
    position: absolute;
    width: 2em;
    height: 2em;
    left: 1.6em;
    top: -1em;
    display: flex;
    align-items: center;
    justify-content: center;
    border: .1em solid #FFF;
    border-radius: 50%;
    background: #EBEBEB;
    color: #02424c;
    font-family: var(--bs-secondary-font-family);
    font-size: 1.25rem;
    font-weight: 700
}

.job-plan__card-text {
    color: #474646;
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.333
}

.job-plan__card-title {
    color: #02424c;
    font-size: 1.25rem;
    font-weight: 700
}

@media (width >=720px) {
    .job-plan__row {
        padding: 3.5rem 0 0;
    }

    .job-plan__card {
        width: 19.65rem;
        height: 11.8rem;
        flex-shrink: 0;
        padding: 2.75rem 1.3rem 0 2.25rem
    }

    .job-plan_low .job-plan__card {
        padding-top: 2rem;
        height: 9rem;
    }

    .job-plan__card-position {
        font-size: 1.5rem
    }

    .job-plan__card-text {
        font-weight: 500;
        line-height: 1.24
    }

    .job-plan__card-title {
        font-size: 1.5rem;
        line-height: 1.1
    }

    .job-plan_4-column .job-plan__card-title {
        font-size: 1.2rem;
        line-height: 1.375
    }
}

@media (width >=1420px) {
    .job-plan__row {
        padding: 7rem 0 0;
        flex-wrap: wrap;
        gap: 4rem 0;
        overflow: initial !important;
    }

    .job-plan_low .job-plan__row {
        gap: 2rem 0
    }

    .job-plan__card {
        padding: 4rem 3rem 0 3.3rem;
        width: 33.33%;
        height: 17.39rem;
        flex-shrink: 0
    }

    .job-plan_4-column .job-plan__card {
        padding: 4rem 2.3rem 0 2.5rem;
        width: 25%;
        height: 14rem;
    }

    .job-plan_low .job-plan__card {
        padding-top: 2.5rem;
        height: 13rem;
    }

    .job-plan__card-position {
        font-size: 2.25rem
    }

    .job-plan__card-text {
        font-size: 1rem;
        line-height: 1.375
    }

    .job-plan__card-title {
        font-size: 2.25rem
    }

    .job-plan_4-column .job-plan__card-title {
        font-size: 1.5rem;
    }
}


.about {
    margin-bottom: 2rem
}

@media (width >=1420px) {
    .about {
        margin-bottom: 4rem
    }
}

.about__btn {
    grid-area: btn;
    width: 100%;
    font-family: var(--bs-body-font-family);
    font-size: 1.125rem;
    font-weight: 600;
    letter-spacing: .05em;
    text-align: left
}

.about__btn .btn__content {
    padding: 0 3rem 0 2rem
}

@media (width >=1420px) {
    .about__btn {
        width: 38rem;
        font-size: 1.5rem
    }
}

.about__certs {
    grid-area: certs;
    margin: 3rem 0;
    margin-left: calc(0px - var(--outer-space));
    width: calc(100% + var(--outer-space));
    padding: 0 var(--outer-space)
}

@media (width >=720px) {
    .about__certs {
        margin: 0;
        padding: 0;
        padding-right: var(--outer-space);
        width: calc(100% + var(--outer-space))
    }
}

@media (width >=1420px) {
    .about__certs {
        margin: 2rem 0
    }
}

@media (width >=720px) {
    .about__container {
        display: grid;
        grid-template: "title title" "img text" "img certs" 1fr "img btn" / 16.875rem minmax(0, 1fr);
        gap: 1.25rem
    }
}

@media (width >=1420px) {
    .about__container {
        gap: 1rem 3.7rem;
        grid-template: "img title" "img text" "img certs" "img btn" / 32rem minmax(0, 1fr)
    }
}

.about__img {
    grid-area: img;
    width: 100%;
    height: 24rem;
    margin-bottom: 2rem;
    overflow: hidden;
    border-radius: .625rem
}

@media (width >=720px) {
    .about__img {
        border-radius: .87rem;
        height: 100%
    }
}

.about__text {
    grid-area: text;
    color: #474646;
    font-size: .875rem;
    font-weight: 600;
    line-height: 1.3
}

@media (width >=720px) {
    .about__text {
        font-weight: 400
    }
}

@media (width >=1420px) {
    .about__text {
        font-size: 1.125rem;
        font-weight: 500
    }
}

.about__title {
    grid-area: title;
    max-width: 7em;
    margin-bottom: 1em
}

@media (width >=720px) {
    .about__title {
        max-width: none;
        margin-bottom: .3em
    }
}

@media (width >=1420px) {
    .about__title {
        margin-bottom: 0
    }
}

@media (width >=1420px) {
    .team {
        padding-top: 2rem
    }
}

.team__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem
}

@media (width >=1420px) {
    .team__header {
        margin-bottom: 4rem
    }
}

.team__name {
    margin-bottom: 0;
    font-family: var(--bs-secondary-font-family);
    font-size: .875rem;
    font-weight: 700
}

@media (width >=720px) {
    .team__name {
        font-size: 1.5rem
    }
}

@media (width >=1420px) {
    .team__name {
        font-size: 1.7rem
    }
}

.team__position {
    color: #474646;
    font-size: .625rem;
    font-weight: 600
}

@media (width >=720px) {
    .team__position {
        font-size: 1rem;
        font-weight: 400
    }
}

@media (width >=1420px) {
    .team__position {
        font-size: 1.12rem
    }
}

.team__slider .swiper-slide {
    display: flex;
    flex-direction: column
}

.team__img {
    height: 9rem;
    margin-bottom: .3rem
}

.team__img img {
    border-radius: .32rem
}

@media (width >=720px) {
    .team__img {
        height: 16rem
    }

    .team__img img {
        border-radius: .55rem
    }
}

@media (width >=1420px) {
    .team__img {
        height: 20rem
    }

    .team__img img {
        border-radius: .7rem
    }
}

.all-inclusive__header {
    margin-bottom: 2rem;
    font-size: 1.375rem;
    font-weight: 600
}

.all-inclusive__header a {
    text-decoration: none
}

@media (width >=720px) {
    .all-inclusive__header {
        margin-bottom: 3rem;
        font-size: 2.25rem;
        font-weight: 500
    }
}

@media (width >=1420px) {
    .all-inclusive__header {
        font-size: 3rem;
        font-weight: 600
    }
}

.all-inclusive__slide-bg {
    display: none
}

@media (width >=720px) {
    .all-inclusive__slide-bg {
        grid-area: a;
        display: block
    }
}

.all-inclusive__slide-body {
    grid-area: a;
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.33
}

.all-inclusive__slide-body ul {
    padding-left: 1.4em
}

@media (width >=720px) {
    .all-inclusive__slide-body {
        padding: 3rem 3rem 0 6rem;
        font-size: 1rem;
        font-weight: 400
    }
}

@media (width >=1420px) {
    .all-inclusive__slide-body {
        padding: 3rem 7rem 0 9rem;
        font-size: 1.125rem;
        font-weight: 600
    }
}

.all-inclusive__slide-title {
    font-size: 1.125rem;
    font-weight: 700
}

@media (width >=720px) {
    .all-inclusive__slide-title {
        font-size: 1.5rem
    }
}

@media (width >=1420px) {
    .all-inclusive__slide-title {
        font-size: 2.25rem
    }
}

.all-inclusive__slider {
    padding-bottom: 5rem
}

.all-inclusive__slider .swiper-wrapper {
    align-items: stretch
}

@media (width >=1420px) {
    .all-inclusive__slider {
        padding-bottom: 0;
        margin-bottom: 5rem
    }
}

@media (width <=575.99px) {
    .all-inclusive__title {
        font-size: 1.5rem
    }
}

@media (width >=720px) {
    .all-inclusive__title {
        margin-bottom: .5em
    }
}

@media (width >=1420px) {
    .all-inclusive__title {
        display: inline
    }
}

.all-inclusive__slide {
    border-radius: .625rem;
    background: #02424C;
    padding: 1.2rem;
    color: #fff;
    height: auto
}

@media (width >=720px) {
    .all-inclusive__slide {
        background: none;
        border-radius: 0;
        padding: 0;
        display: grid;
        grid-template: "a";
        height: 100%
    }
}

@media (width >=1420px) {
    .all-inclusive__video {
        height: 40.5rem
    }
}

.all-inclusive__nav-arrow {
    opacity: 0;
    position: relative;
    width: 100%;
    color: var(--bs-secondary);
    display: flex;
    justify-content: space-between;
    font-size: 1rem
}

.all-inclusive__slider:hover .all-inclusive__nav-arrow {
    opacity: 1
}

.all-inclusive__nav-arrow .swiper-button {
    position: absolute;
    z-index: 20;
    top: 16rem;
    opacity: .7;
    transition: all .15s
}

.all-inclusive__nav-arrow .swiper-button:hover {
    transform: scale(1.1);
    opacity: 1
}

.all-inclusive__nav-arrow .swiper-button-prev {
    left: 0
}

.all-inclusive__nav-arrow .swiper-button-next {
    right: 0
}

@media (width >=720px) {
    .all-inclusive__nav-arrow .swiper-button {
        top: 5.5rem
    }
}

@media (width >=1420px) {
    .all-inclusive__nav-arrow {
        font-size: 1.5rem
    }

    .all-inclusive__nav-arrow .swiper-button {
        top: 9rem
    }
}

.contract {
    margin-bottom: 5rem;
    margin-top: 4rem;
    padding-bottom: 2rem;
    border-radius: .625rem;
    background: #FFF
}

@media (width >=720px) {
    .contract {
        border-radius: 0;
        background: none
    }
}

.contract__btn {
    grid-area: btn;
    width: 100%;
    font-size: 1.125rem;
    font-weight: 600;
    font-family: var(--bs-body-font-family);
    letter-spacing: .05em
}

@media (width >=720px) {
    .contract__btn {
        font-size: 1.5rem;
        font-weight: 500
    }
}

@media (width >=1420px) {
    .contract__btn {
        width: 38rem;
        font-weight: 600
    }
}

@media (width >=720px) {
    .contract__container {
        display: grid;
        grid-template: "img title" "text text" "btn btn" / 13rem 1fr;
        gap: 1rem 1.5rem;
        align-items: center
    }
}

@media (width >=1420px) {
    .contract__container {
        grid-template: "img a" 1fr "img title" "img text" "img btn" "img b" 1fr / 28rem 1fr
    }
}

.contract__img {
    grid-area: img;
    width: 10rem;
    margin: 0 auto 2rem
}

@media (width >=720px) {
    .contract__img {
        width: 100%;
        margin: 0
    }
}

.contract__text {
    grid-area: text;
    margin-bottom: 3rem;
    font-size: 1.125rem;
    font-weight: 500;
    line-height: 1.3
}

@media (width >=720px) {
    .contract__text {
        font-size: 1.5rem;
        font-weight: 400
    }
}

@media (width >=1420px) {
    .contract__text {
        margin: 1rem 0;
        font-weight: 600
    }
}

.contract__title {
    grid-area: title;
    margin-bottom: .5em;
    line-height: 1.2
}

@media (width >=1420px) {
    .contract__title {
        margin: 0
    }
}

.equipment {
    padding: 4rem 0 8rem;
    background: url("/assets/ai-2-0ea93e7a.webp") 70% no-repeat, #02424C;
    color: #fff;
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.5
}

@media (width >=720px) {
    .equipment {
        padding: 2rem 0 12rem;
        line-height: 1.37;
        font-weight: 400
    }
}

@media (width >=1420px) {
    .equipment {
        padding: 12rem 0;
        font-size: 1.5rem;
        font-weight: 600;
        line-height: 1.5
    }
}

.equipment__btn {
    --wd-btn-color: #FFF;
    --wd-btn-border-color: #FFF;
    --wd-btn-hover-color: var(--bs-secondary);
    --wd-btn-hover-border-color: var(--bs-secondary);

    width: 16.75rem;
    margin: 1rem 0 2rem;
    font-family: var(--bs-body-font-family);
    font-weight: 600;
    letter-spacing: .05em
}

@media (width >=720px) {
    .equipment__btn {
        margin: 0 0 2rem
    }
}

@media (width >=1420px) {
    .equipment__btn {
        width: 23.125rem;
        font-size: 1.5rem;
        margin: 0
    }
}

.equipment__cert {
    width: 9rem;
    height: 11.4rem;
    flex-shrink: 0
}

@media (width >=720px) {
    .equipment__cert {
        height: 12.75rem;
        width: 22%;
        flex-grow: 1
    }
}

@media (width >=1420px) {
    .equipment__cert {
        height: 16.875rem
    }
}

.equipment__certs {
    grid-area: certs;
    width: 100%;
    display: flex;
    gap: .8rem
}

@media (width >=720px) {
    .equipment__certs {
        gap: 1rem
    }
}

@media (width >=1420px) {
    .equipment__certs {
        gap: 1.25rem
    }
}

@media (width >=720px) {
    .equipment__container {
        display: grid;
        grid-template: "title title" "img text-1" "img btn" "text-2 text-2" "certs certs" "text-3 text-3" / 14rem 1fr;
        gap: 0 4rem
    }
}

@media (width >=1420px) {
    .equipment__container {
        grid-template: "title title title" "text-1 text-1 btn" "text-2 text-2 text-2" "img certs certs" "text-3 text-3 text-3" / 28rem 1fr 31rem;
        gap: 0 2rem;
        align-items: center
    }
}

.equipment__img {
    grid-area: img;
    max-width: 20.1875rem;
    margin-bottom: 1.5rem
}

@media (width >=720px) {
    .equipment__img {
        max-width: none
    }
}

@media (width >=1420px) {
    .equipment__img {
        max-width: 23rem;
        margin: auto 0
    }
}

.equipment__list {
    display: flex;
    flex-wrap: wrap;
    margin: -6rem 0 0;
    padding: 0;
    list-style-type: none;
    gap: 1.25rem
}

.equipment__list .icon-text {
    width: 100%;
    min-height: 11.25rem;
    flex-direction: column;
    flex-shrink: 0;
    padding: 1.25rem 2rem;
    gap: .7rem;
    border-radius: .4rem;
    background: #FFF;
    color: #0e0e0e;
    text-align: center;
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.25rem
}

.equipment__list .icon-text__icon {
    height: 3rem;
    width: auto
}

@media (width >=720px) {
    .equipment__list {
        gap: .6rem;
        margin: -8rem 0 0
    }

    .equipment__list .icon-text {
        width: 40%;
        flex-grow: 1;
        min-height: 9.47rem;
        flex-direction: row;
        gap: 1.5rem;
        padding: 1.25rem;
        text-align: left;
        font-size: .62rem;
        font-weight: 500;
        line-height: 1.5
    }

    .equipment__list .icon-text__icon {
        height: 2rem
    }
}

@media (width >=1420px) {
    .equipment__list {
        margin: -4rem 0 0
    }

    .equipment__list .icon-text {
        height: 18.8125rem;
        padding: 3rem 5rem 3rem 3rem;
        gap: 2rem;
        border-radius: .9375rem;
        font-size: 1.25rem;
        font-weight: 600
    }

    .equipment__list .icon-text__icon {
        height: 5rem
    }
}

.equipment__text-1 {
    grid-area: text-1
}

@media (width >=1420px) {
    .equipment__text-1 {
        margin-bottom: 0
    }
}

.equipment__text-2 {
    grid-area: text-2;
    margin-bottom: 2.5rem
}

@media (width >=1420px) {
    .equipment__text-2 {
        margin: 1rem 0 5rem
    }
}

.equipment__text-3 {
    grid-area: text-3;
    margin-top: 2em
}

.equipment__title {
    grid-area: title;
    margin-bottom: 1em
}

@media (width >=720px) and (width <=1419.99px) {
    .equipment__title {
        font-size: 2.375rem
    }
}

@media (width >=1420px) {
    .equipment__title {
        margin-bottom: 2rem
    }
}

.suppliers {
    margin: 3rem 0
}

.suppliers_auto {
    cursor: default
}

.suppliers_auto .swiper-wrapper {
    transition-timing-function: linear
}

@media (width >=1420px) {
    .suppliers {
        margin: 7rem 0
    }
}

.faq__item-body {
    margin: 1.125rem 0 1.875rem;
    color: #474646;
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.5
}

@media (width >=720px) {
    .faq__item-body {
        font-size: 1.125rem;
        font-weight: 400;
        line-height: 1.33
    }
}

@media (width >=1420px) {
    .faq__item-body {
        margin: 1.875rem 0;
        font-weight: 600
    }
}

.faq__item-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    cursor: pointer
}

@media (width >=1420px) {
    .faq__item-header {
        align-items: center
    }
}

.faq__item-icon {
    width: 2rem;
    height: 2rem;
    flex-shrink: 0;
    fill: var(--bs-primary)
}

.faq__item-icon .bg,
.faq__item-header[aria-expanded="true"] .vertical {
    display: none
}

@media (width >=720px) {
    .faq__item-icon {
        width: 2.8125rem;
        height: 2.8125rem;
        margin-left: 2rem;
        fill: #fff
    }

    .faq__item-icon .bg {
        display: block;
        fill: var(--bs-primary)
    }
}

.faq__item-title {
    font-weight: 600;
    line-height: 1.37;
    font-size: 1rem
}

@media (width >=720px) {
    .faq__item-title {
        font-size: 1.25rem;
        font-weight: 500;
        line-height: normal
    }
}

@media (width >=1420px) {
    .faq__item-title {
        font-size: 1.5rem;
        font-weight: 600
    }
}

.faq__item {
    padding: 1rem 0;
    background: #FFF;
    margin-bottom: 1rem
}

@media (width >=720px) {
    .faq__item {
        padding: 2rem 0
    }
}

@media (width >=1420px) {
    .faq__item {
        padding: 1.4rem 1.4rem 1.4rem 6rem;
        border-radius: .9375rem
    }
}

.faq__title {
    margin-bottom: 1.2em
}

.faq__title em {
    color: #848383;
    font-style: normal
}

.cta__card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 18rem;
    flex-shrink: 0;
    padding: 2rem 1rem 2rem 2rem;
    border-radius: .7em;
    background: var(--bs-primary);
    color: #fff;
    font-family: var(--bs-secondary-font-family);
    font-size: .875rem;
    font-weight: 500;
    line-height: 1.3
}

@media (width >=720px) {
    .cta__card {
        width: 28rem;
        padding: 3rem;
        font-size: 1.25rem
    }
}

@media (width >=1420px) {
    .cta__card {
        width: 28%;
        flex-grow: 1
    }
}

.cta__row {
    display: flex;
    justify-content: space-between;
    gap: 1rem
}

@media (width >=720px) {
    .cta__row {
        gap: 1.25rem
    }
}

.cta__title {
    margin-bottom: 0
}

@media (width <=1419.99px) {
    .cta__title {
        font-size: 2.25rem
    }
}

.cta__text {
    color: #848383;
    margin-bottom: 1.2em
}

@media (width <=1419.99px) {
    .cta__text {
        font-size: 2.25rem
    }
}

@media (width >=720px) {
    .cta__text {
        color: inherit;
        margin-bottom: 2em
    }
}

@media (width >=1420px) {
    .cta__text {
        margin-bottom: 1em
    }
}

.cta__btn {
    width: 100%;
    font-family: var(--bs-body-font-family);
    font-size: .875rem;
    font-weight: 600;
    letter-spacing: .05em
}

.cta__btn .btn__content {
    gap: .7em;
    fill: currentcolor;
    stroke: currentcolor
}

@media (width >=720px) {
    .cta__btn {
        margin-top: 2rem;
        font-size: 1.25rem;
        font-weight: 400;
        width: 20rem
    }
}

@media (width >=1420px) {
    .cta__btn {
        margin-top: 1rem
    }
}

.contacts__address {
    margin-bottom: 1.3rem
}

@media (width >=720px) {
    .contacts__address {
        margin-bottom: 3rem
    }
}

@media (width >=1420px) {
    .contacts__address {
        margin-bottom: .5rem
    }
}

.contacts__info {
    grid-area: info;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    color: #000;
    font-weight: 600;
    line-height: 1.5
}

@media (width >=720px) {
    .contacts__info {
        font-size: 1.125rem;
        font-weight: 400;
        line-height: 1.33
    }
}

@media (width >=1420px) {
    .contacts__info {
        font-weight: 600
    }
}

.contacts__map {
    grid-area: map;
    height: 15rem;
    overflow: hidden;
    margin-bottom: 2.5rem
}

.contacts__map.full-width-xs-md {
    padding: 0
}

@media (width >=720px) {
    .contacts__map {
        height: 25rem
    }
}

@media (width >=1420px) {
    .contacts__map {
        height: 39rem;
        width: 100%;
        margin: 0;
        border-radius: 1.171rem
    }
}

.contacts__text {
    grid-area: text;
    margin-bottom: 2em;
    color: #4c5159;
    font-size: 1.5rem;
    line-height: 1.5
}

@media (width >=1420px) {
    .contacts__text {
        font-weight: 600
    }
}

.contacts__title {
    grid-area: title
}

@media (width <=1419.99px) {
    .contacts__title {
        font-size: 2.25rem;
        margin-bottom: .5em
    }
}

.contacts__worktime {
    margin-bottom: 2.3rem
}

@media (width >=720px) {
    .contacts__worktime {
        margin-bottom: 1.5rem
    }
}

@media (width >=1420px) {
    .contacts__worktime {
        margin-bottom: .5rem
    }
}

.contacts__btn {
    width: 100%;
    padding: .3rem 2rem;
    gap: 1rem;
    justify-content: flex-start;
    border-radius: .8rem;
    font-family: var(--bs-secondary-font-family);
    font-size: 1rem;
    font-weight: 600
}

.contacts__btn .icon-text__icon {
    width: 2.2em;
    height: 2.2em
}

@media (width >=720px) {
    .contacts__btn {
        padding: .5rem 2rem .5rem 27%;
        gap: 3rem;
        font-size: 1.125rem;
        font-weight: 400
    }
}

@media (width >=1420px) {
    .contacts__btn {
        font-weight: 600;
        padding-left: 2rem;
        gap: 4rem
    }
}

.contacts__link {
    gap: 1rem;
    margin-bottom: 1rem;
    color: #474646;
    font-weight: 600;
    text-decoration: none
}

.contacts__link .icon-text__icon {
    width: 2rem
}

@media (width >=720px) {
    .contacts__link {
        font-size: 1.125rem;
        font-weight: 400;
        margin-bottom: 1.5rem
    }
}

@media (width >=1420px) {
    .contacts__link {
        font-weight: 600;
        margin-bottom: .5rem
    }
}

.contacts__phone {
    margin-bottom: 1rem;
    font-size: 1.23rem;
    font-weight: 600;
    letter-spacing: .05em
}

@media (width >=1420px) {
    .contacts__phone {
        margin-bottom: 1rem
    }
}

.contacts__btn-block {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1.5rem
}

@media (width >=720px) {
    .contacts__btn-block {
        margin-top: 3rem;
        gap: 1.7rem
    }
}

@media (width >=1420px) {
    .contacts__btn-block {
        margin: 0;
        gap: 1rem
    }
}

@media (width >=1420px) {
    .contacts__container {
        display: grid;
        grid-template: "title title" "text text" "map info" / 1fr 28.7rem;
        gap: 0 2rem
    }
}

.bg-container {
    padding: 1px 0;
    background: url("/assets/layer-2-fa0fee50.svg") 0 0 no-repeat, url("/assets/layer-2-fa0fee50.svg") 100% 100% no-repeat
}

.footer {
    --bs-link-color-rgb: 255, 255, 255;
    --bs-link-color-hover-rgb: var(--bs-secondary-rgb);
    --wd-nav-link-color: #FFF;
    --wd-nav-link-hover-color: var(--bs-secondary);

    margin-top: 5rem;
    padding: 6rem 0 4rem;
    background: url("/assets/ai-2-0ea93e7a.webp") 100% 100% no-repeat, #02424C;
    color: #fff
}

@media (width >=720px) {
    .footer {
        padding: 4rem 0
    }
}

@media (width >=1420px) {
    .footer {
        padding: 6rem 0
    }
}

.footer__company-info {
    grid-area: info;
    color: #fffc;
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.5
}

.footer__company-info p {
    font-size: 1.125rem
}

.footer__company-info ul {
    list-style-type: none;
    padding: 0;
    margin: 0
}

@media (width >=720px) {
    .footer__company-info {
        font-size: 1.125rem;
        font-weight: 500
    }
}

@media (width >=1420px) {
    .footer__company-info {
        margin-bottom: -4rem
    }

    .footer__company-info ul {
        margin-bottom: 1em
    }
}

.footer__nav {
    grid-area: nav;
    margin: 1rem 0;
    display: flex;
    font-weight: 600
}

.footer__nav .nav__link {
    padding: 0
}

.footer__nav>*:not(:last-child) {
    display: none
}

@media (width >=720px) {
    .footer__nav {
        --wd-nav-link-padding-x: 0;

        font-size: 1.125rem;
        font-weight: 500
    }

    .footer__nav>*:not(:last-child) {
        display: inline
    }
}

@media (width >=1420px) {
    .footer__nav {
        margin-top: -2rem;
        font-weight: 600;
        gap: 3rem
    }
}

.footer__order-btn {
    width: 100%;
    font-family: var(--bs-body-font-family);
    font-size: .875rem;
    font-weight: 600;
    letter-spacing: .05em
}

.footer__order-btn .btn__content {
    padding: 0 3rem 0 0
}

@media (width >=720px) {
    .footer__order-btn {
        max-width: 35rem;
        font-size: 1.3rem;
        font-weight: 500
    }
}

.footer__order-text {
    color: #f45b50;
    font-weight: 600
}

@media (width >=720px) {
    .footer__order-text {
        margin-bottom: 2rem;
        font-size: 1.5rem;
        font-weight: 500
    }
}

@media (width >=1420px) {
    .footer__order-text {
        font-size: 1.125rem;
        font-weight: 600
    }
}

.footer__order-title {
    margin-bottom: 0;
    max-width: 12em;
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1.4
}

@media (width >=720px) {
    .footer__order-title {
        max-width: unset;
        font-size: 1.875rem;
        font-weight: 700
    }
}

.footer__order {
    grid-area: order;
    margin: 1.5rem 0 3rem;
    padding: 1.6rem 1rem;
    border-radius: .4rem;
    background: url("/assets/layer-2-fa0fee50.svg") 50% no-repeat, #DFDFDF;
    color: var(--bs-body-color)
}

@media (width >=720px) {
    .footer__order {
        padding: 2rem 0 3rem 3rem;
        margin: 0
    }
}

@media (width >=1420px) {
    .footer__order {
        padding: 3rem 1rem 2rem 6rem
    }
}

.footer__phone {
    grid-area: phone;
    margin: 2rem 0 1.5rem;
    font-size: 1.25rem;
    letter-spacing: .05em
}

.footer__phone .icon-text__icon {
    display: none
}

.footer__phone .icon-text__text {
    gap: 1rem
}

.footer__phone a {
    text-decoration: none
}

.footer__phone a:last-child {
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: normal
}

@media (width >=720px) {
    .footer__phone {
        margin: 0;
        color: #fff
    }

    .footer__phone .icon-text__icon {
        display: block
    }

    .footer__phone .icon-text__text {
        align-items: flex-end;
        gap: 0
    }
}

@media (width >=1420px) {
    .footer__phone {
        align-items: flex-start;
        justify-self: end;
        font-size: 1.45rem
    }

    .footer__phone a {
        margin: 0
    }

    .footer__phone a:last-child {
        font-size: 1.125rem;
        font-weight: 400
    }
}

.footer__privacy-link {
    grid-area: privacy;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
}

.footer__privacy-link a {
    text-decoration: none
    
}

@media (width >=720px) {
    .footer__privacy-link {
        display: none;
        font-size: 1.125rem;
        font-weight: 500
    }
}

@media (width >=1420px) {
    .footer__privacy-link {
        display: inline-flex;
        flex-direction: row;
        gap: 2rem;
        justify-self: start
    }
}

.footer__site-name {
    grid-area: logo;
    gap: .75rem
}

.footer__site-name .icon-text__icon {
    width: 4.5rem;
    height: 4.5rem
}

.footer__site-name .site-name__title {
    margin-bottom: .3em;
    font-size: 1.44rem;
    font-weight: 900;
    letter-spacing: .05em
}

.footer__site-name .site-name__subtitle {
    font-size: 1.19rem;
    font-weight: 600
}

@media (width >=720px) {
    .footer__site-name {
        gap: 1rem;
        margin-bottom: 0
    }
}

@media (width >=720px) {
    .footer__container {
        display: grid;
        grid-template: "logo phone" "order order" "nav nav" "info info" / 1fr auto;
        gap: 4rem 0
    }
}

@media (width >=1420px) {
    .footer__container {
        grid-template: "logo phone" "info order" "privacy order" "nav nav" / 1fr 50rem;
        gap: 4rem 0
    }
}

.consult-modal {
    --bs-modal-width: 1024px
}

.consult-modal .modal-content {
    padding: 2rem 1rem
}

.consult-modal .btn-close {
    position: absolute;
    right: 1rem;
    top: 1rem
}

@media (width >=720px) {
    .consult-modal .modal-content {
        padding: 2rem 4rem
    }
}

@media (width >=1420px) {
    .consult-modal .modal-content {
        padding: 5rem 6rem 5rem 16rem
    }
}

.consult-modal__form {
    --wd-input-bg: #E2DFDF;
    --wd-input-padding-x: 1rem;

    margin-top: 2rem;
    flex-wrap: wrap;
    font-size: 1.2rem
}

.consult-modal__form .form-control {
    width: 100%;
    flex-grow: 1
}

.consult-modal__form .form-control__input {
    border-radius: .7rem;
    padding: 1em 1.5em
}

.consult-modal__form .btn {
    width: 100%;
    flex-grow: 1;
    border-radius: .7rem;
    font-family: var(--bs-body-font-family);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: .05em
}

.consult-modal__form .btn__content {
    padding: 1.5rem 2rem
}

@media (width >=720px) {
    .consult-modal__form .form-control {
        width: 35%
    }

    .consult-modal__form .btn {
        font-size: 1.5rem
    }

    .consult-modal__form .btn:nth-child(2) {
        width: 35%
    }
}

.consult-modal__text {
    color: #474646;
    font-size: 1.2rem;
    font-weight: 500
}

@media (width >=1420px) {
    .consult-modal__text {
        font-size: 1.5rem
    }
}

.consult-modal__title {
    font-size: 1.7rem;
    font-weight: 700;
    line-height: 1
}

@media (width >=720px) {
    .consult-modal__title {
        line-height: normal
    }
}

@media (width >=1420px) {
    .consult-modal__title {
        font-size: 2.25rem
    }
}

.consult-modal__img {
    position: absolute;
    left: 1rem;
    top: 5rem;
    width: 12.3125rem;
    height: 12.3125rem
}

.fair-modal {
    --bs-modal-width: 87.5rem
}

.fair-modal .modal-content {
    padding: 1.5rem .75rem;
    font-size: .9rem;
    line-height: 1.3
}

.fair-modal .btn-close {
    position: absolute;
    right: 1rem;
    top: 1rem
}

.fair-modal ul {
    padding: 0;
    list-style-type: none
}

.fair-modal li {
    margin-bottom: .5em;
    display: flex;
    align-items: center;
    gap: .5em
}

.fair-modal li::before {
    content: "";
    display: inline-block;
    width: .65em;
    height: .65em;
    flex-shrink: 0;
    border-radius: 50%;
    background: currentcolor
}

.fair-modal li:first-child::before {
    display: none
}

@media (width >=720px) {
    .fair-modal {
        --bs-modal-margin: 0
    }

    .fair-modal .modal-content {
        padding: 1.5rem .75rem;
        text-align: left
    }

    .fair-modal li {
        margin-bottom: 1em;
        flex-direction: row;
        gap: 1em
    }

    .fair-modal li:first-child::before {
        display: inline-block
    }
}

@media (width >=1420px) {
    .fair-modal .modal-content {
        padding: 3rem;
        font-size: 1.25rem
    }

    .fair-modal .btn-close {
        right: 3rem;
        top: 3rem
    }
}

.fair-modal__text {
    margin-bottom: 1.33em;
    font-family: var(--bs-secondary-font-family)
}

@media (width >=720px) {
    .fair-modal__text {
        font-size: 1rem
    }
}

@media (width >=1420px) {
    .fair-modal__text {
        font-size: 1.75rem;
        font-weight: 700
    }
}

@media (width >=1420px) {
    .fair-modal__title {
        font-size: 3rem
    }
}

.fair-modal__btn {
    margin: 1em auto 0;
    font-family: var(--bs-body-font-family);
    font-weight: 500;
    letter-spacing: .05em
}

@media (width >=720px) {
    .fair-modal__btn {
        width: 32rem
    }
}

.coockie-modal {
    --bs-offcanvas-height: auto
}

.coockie-modal .modal-dialog {
    align-items: flex-end
}

.coockie-modal__container {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem
}

@media (width >=1420px) {
    .coockie-modal__container {
        flex-wrap: nowrap;
        padding: 0 12rem
    }
}

.coockie-modal__btn {
    width: 45%
}

@media (width >=1420px) {
    .coockie-modal__btn {
        width: 20em
    }
}

.page-404 {
    background: #FFF
}

.page-404__container {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 5rem
}

.page-404__container .btn {
    width: 100%;
    font-family: var(--bs-body-font-family);
    font-weight: 600;
    letter-spacing: .05em
}

@media (width >=720px) {
    .page-404__container {
        width: 25rem;
        font-size: 1.15rem
    }

    .page-404__container .img {
        width: 30rem
    }
}

@media (width >=1420px) {
    .page-404__container {
        font-size: 1.5rem
    }

    .page-404__container .img {
        width: 53rem
    }

    .page-404__container .btn {
        width: 38rem;
        font-size: 1.5rem
    }
}

.page-thank {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5rem;
    margin: 4rem auto
}

.page-thank__back {
    font-size: 2rem;
    width: 15em;
    max-width: 100%
}

.gift {
    background: #FEFEFE;
    position: relative;
    padding-bottom: 5rem;
}

.gift__arrow {
    width: 100%;
    filter: drop-shadow(0 4px 4px rgb(0 0 0 / 25%));
}

.gift__title {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    color: #F5F5F5;
    margin-top: 1em;
    font-size: 4.3vw;
    font-weight: 900;
}

.gift__title .icon-text__icon {
    height: 2.5em;
}

.gift__content-title {
    color: #000;
}

.gift__content-subtitle {
    font-size: 1.1em;
    font-weight: 600;
}

.gift__content-arrow {
    display: none;
}

.gift__content ul {
    padding-left: 1em;
}

.gift__content>ul {
    margin-top: 2rem;
}

.gift__content ul ul{
    padding-left: 0;
    list-style-type: none;
}

.gift__list-title {
    --bs-link-color-rgb: 14, 14, 14;

    font-weight: 500;
}

.gift__list-title:not(a) {
    color: #0E0E0E;
}

.gift__content li {
    margin-bottom: 0.7em;
}

.gift__btn {
    width: 100%;
    max-width: 27rem;
    margin-top: 2rem;
}

.gift__btn .btn__content {
    gap: 0.3em;
}

@media (width >=720px) {
    .gift__list-title {
        font-size: 1.5rem;
    }

    .gift__content-title {
        font-size: 2.4rem;
    }

    .gift__btn {
        font-size: 1.5rem;
    }
}

@media (width >=1420px) {
    .gift {
        margin-top: 10rem;
    }

    .gift__title {
        font-size: 2.1vw;
    }

    .gift__container {
        display: flex;
        flex-direction: row-reverse;
        gap: 1.5rem;
        margin-top: 5rem;
    }

    .gift__content {
        position: relative;
        width: 55%;
        flex-shrink: 0;
        color: #5F5F5F;
        font-size: 1.125rem;
    }

    .gift__slider {
        width: calc(45% - 1.5rem);
    }

    .gift__content-arrow {
        display: block;
        position: absolute;
        left: -90px;
        top: 90px;
        fill: var(--bs-secondary);
        width: 80px;
    }

    .gift__content-title {
        font-size: 2.5rem;
    }


    .gift__btn {
        width: 29rem;
    }

    .gift__btn .btn__content {
        flex-direction: column;
        align-items: flex-start;
        padding-left: 5.5rem;
        gap: 0;
    }

    .gift__btn .btn__content span:last-child {
        font-weight: 700;
    }
}

.gift-modal {
    --bs-modal-width: 88rem;
}

.gift-modal .btn-close {
    position: absolute;
    right: 1rem;
    top: 1rem
}

.gift-modal .modal-content {
    padding: 2rem 1rem;
}

.gift-modal__title {
    margin: 2em 0 1em;
    color: var(--bs-primary);
    font-size: 1.1em;
}

@media (width >=720px) {
    .gift-modal__title {
        font-size: 1.4em;
    }
}

@media (width >=1420px) {
    .gift-modal .modal-content {
        padding: 5rem 15rem;
    }
}

.sale {
    padding: 4rem 0;
    background: url("/assets/sale-bg-sm.jpg") 50% / cover no-repeat
}

.sale__title {
    color: var(--bs-primary);
    font-weight: 700;
    margin-bottom: 0.5em;
}

.sale__content {
    position: relative;
}

.sale p {
    font-weight: 600;
    line-height: 1.5;
    margin-bottom: 1em;
}

.sale .text-secondary {
    font-size: 1.33em;
}

.sale__price {
    position: absolute;
    left: 14rem;
    top: 1rem;
    color: #FFF;
    font-size: 1rem;
    font-weight: 900;
}

.sale__price svg {
    width: 6em;
    height: 6em;
}

.sale__price span {
    position: absolute;
    left: 0.1em;
    top: 2.4em;
    width: 100%;
    display: flex;
    justify-content: center;
    transform: rotate(-18deg);
}

.sale__old-price {
    position: absolute;
    left: 18rem;
    top: 5.4rem;
    color: #000;
    font-weight: 600;
}

.sale__price-line {
    position: absolute;
    width: 127%;
    height: 2px;
    top: 50%;
    left: -20%;
    background: var(--bs-secondary);
    transform: rotate(-37deg);
}

.sale__btn {
    width: 100%;
    max-width: 27rem;
    font-size: 1.5rem;
    font-weight: 600;
}

@media (width >=720px) {
    .sale {
        padding: 10rem 0;
    }

    .sale__title {
        margin-bottom: 0.2em;
        font-size: 6.25rem;
    }

    .sale p {
        font-size: 2rem;
        font-weight: 600;
    }

    .sale .text-small {
        font-size: 1.5rem;
    }

    .sale__price {
        font-size: 2.25rem;
        left: 27rem;
    }

    .sale__btn {
        max-width: 35rem;
        margin-top: 2rem;
        font-size: 1.5rem;
        font-weight: 600;
        letter-spacing: 0.05em;
    }

    .sale__old-price {
        left: 34rem;
        top: 14.4rem;
        font-size: 2rem;
    }
}

@media (width >=1420px) {
    .sale {
        padding: 14rem 0;
        background: url("/assets/sale-bg.jpg") 50% / cover no-repeat
    }

    .sale__content {
        margin-left: 42%;
    }

    .sale__old-price {
        left: 42rem;
        top: 11.4rem;
    }
}

.vacancy-modal {
    --bs-modal-width: 1600px
}

.vacancy-modal .btn-close {
    position: absolute;
    right: 1rem;
    top: 1rem
}

.vacancy-modal__content {
    background: #FFF;
    border-radius: 1rem;
    padding: 3rem 1rem
}

@media (width >=720px) {
    .vacancy-modal__content {
        padding: 4rem 5rem;
        flex-direction: row;
    }
}

@media (width >=1420px) {
}

.vacancy-modal__img {
    width: 15rem;
    margin-right: 1.5rem;
    flex-shrink: 0
}

.vacancy-modal__img img {
    border-radius: 1.2rem
}

.vacancy-modal__title {
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.22;
}

.vacancy-modal__text {
    line-height: 1.22;
}

.vacancy-modal__text .icon-text {
    gap: 1em;
}

.vacancy-modal__text .icon-text__text {
    font-weight: 600;
}

.vacancy-modal__text ul {
    padding-left: 1.5rem;
    margin: 1em 0 2em;
}

@media (width >=720px) {
    .vacancy-modal__text .icon-text__text {
        flex-direction: row;
        gap: 0.5em;
    }
}

@media (width >=1420px) {
    .vacancy-modal__title {
        font-size: 1.25rem;
        font-weight: 700;
        margin: 1rem 0 2rem;
    }
    .vacancy-modal__text {
        font-size: 1.125rem;
        line-height: 1.22;
    }
    .vacancy-modal__img {
        width: 35rem;
        margin-right: 5rem
    }
}
