* {
    margin: 0;
    padding: 0;
    box-sizing: border-box
}

.page__body {
    font-family: Inter, sans-serif;
    font-style: normal;
    font-weight: 500;
    background: #f6f7f8;
    scroll-behavior: smooth
}

.page__title {
    line-height: 140%;
    color: #171a1e
}

.page__title-wrap {
    margin: 0 auto;
    max-width: 1176px;
    padding: 0 24px
}

@media (max-width:650px) {
    .page__title-wrap {
        margin: 0 auto;
        max-width: 1160px;
        padding: 0 16px
    }
}

.page__title_h2 {
    font-size: 36px
}

@media (max-width:650px) {
    .page__title_h2 {
        font-size: 26px
    }
}

.page__title_h3 {
    font-size: 30px
}

@media (max-width:650px) {
    .page__title_h3 {
        font-size: 24px
    }
}

.page__text {
    font-size: 18px;
    line-height: 160%;
    color: #6a6a6a;
    font-weight: 400
}

@media (max-width:650px) {
    .page__text {
        font-size: 16px
    }
}

.page__label {
    color: #171a1e
}

.additional {
    padding: 90px 0 120px
}

@media (max-width:650px) {
    .additional {
        padding: 48px 0
    }
}

.additional__title {
    margin-bottom: 40px
}

@media (max-width:650px) {
    .additional__title {
        margin-bottom: 24px
    }
}

.page-card {
    margin: 0 auto;
    max-width: 1176px;
    padding: 0 24px
}

@media (max-width:650px) {
    .page-card {
        margin: 0 auto;
        max-width: 1160px;
        padding: 0 16px
    }
}

.page-card__image {
    width: 100%;
    object-fit: cover;
    border-radius: 20px 20px 0 0
}

@media (max-width:650px) {
    .page-card__image {
        height: 200px
    }
}

.page-card__wrap {
    display: flex;
    flex-direction: column;
    gap: 30px;
    padding: 50px;
    background: #fff;
    border-radius: 0 0 20px 20px
}

@media (max-width:650px) {
    .page-card__wrap {
        gap: 24px;
        padding: 24px
    }
}

.page-card__button {
    width: 200px;
    height: 50px;
    border-radius: 10px
}

@media (max-width:650px) {
    .page-card__button {
        width: 100%;
        height: 60px
    }
}

.header {
    background: #fff
}

.header__wrap {
    margin: 0 auto;
    max-width: 1176px;
    padding: 0 24px;
    height: 80px;
    display: flex;
    justify-content: space-between;
    align-items: center
}

@media (max-width:650px) {
    .header__wrap {
        margin: 0 auto;
        max-width: 1160px;
        padding: 0 16px;
        height: 70px
    }
}

.header__logo {
    z-index: 1;
    position: relative
}

@media (max-width:650px) {
    .header__menu {
        display: grid;
        position: absolute;
        top: 0;
        right: 0;
        left: 0
    }
}

.logo {
    height: 38px;
    width: 120px;
    margin-top: 6px
}

@media (max-width:650px) {
    .logo {
        height: 38px;
        width: 120px
    }
}

.logo__desc {
    fill: #171a1e
}

.logo__newyear {
    width: 51px;
    height: 50px;
    position: absolute;
    top: -12px;
    left: -25px
}

@media (max-width:650px) {
    .logo__newyear {
        width: 43px;
        height: 42px;
        top: -9px;
        left: -22px
    }
}

.menu__button {
    height: 70px;
    width: 70px;
    padding-right: 16px;
    display: none;
    justify-content: flex-end;
    align-items: center;
    border: none;
    background: transparent;
    justify-self: end
}

@media (max-width:650px) {
    .menu__button {
        display: flex
    }
}

.menu__list {
    display: flex;
    gap: 40px;
    list-style-type: none
}

@media (max-width:650px) {
    .menu__list {
        display: none
    }
}

.menu__list_open {
    display: flex;
    gap: 40px;
    list-style-type: none
}

@media (max-width:650px) {
    .menu__list_open {
        flex-direction: column;
        align-items: flex-end;
        gap: 32px;
        padding: 32px 16px;
        background: #fff;
        border-top: 1px solid #f6f7f8;
        box-shadow: 0 8px 24px rgba(8, 33, 63, .05)
    }
}

.menu__link {
    transition: color .2s ease;
    text-transform: uppercase;
    color: #171a1e
}

@media (max-width:650px) {
    .menu__link {
        font-size: 18px
    }
}

.menu__link:hover {
    color: #0073d8
}

.main__bg-wrap {
    display: grid;
    gap: 120px 0;
    padding-top: 120px;
    padding-bottom: 120px
}

@media (max-width:650px) {
    .main__bg-wrap {
        gap: 48px 0;
        padding-top: 48px;
        padding-bottom: 48px
    }
}

.main__additional {
    display: grid;
    gap: 90px 0
}

@media (max-width:650px) {
    .main__additional {
        gap: 48px 0
    }
}

.offer {
    display: flex;
    align-items: center;
    height: 700px;
    background: url(main_bg.2d62d9c7.jpg) no-repeat 50%
}

@media (max-width:650px) {
    .offer {
        margin: 16px;
        border-radius: 20px;
        height: 600px;
        background: url(main_bg_mobile.3c1ced50.jpg) no-repeat 50%
    }
}

.offer__wrap {
    margin: 0 auto;
    max-width: 1176px;
    padding: 0 24px;
    width: 100%
}

@media (max-width:650px) {
    .offer__wrap {
        margin: 0 auto;
        max-width: 1160px;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        height: 100%;
        padding: 16px
    }
}

.offer__title {
    max-width: 650px;
    font-size: 48px;
    margin-bottom: 30px
}

@media (max-width:650px) {
    .offer__title {
        font-size: 24px;
        margin-bottom: 16px
    }
}

.offer__subtitle {
    font-size: 24px;
    line-height: 160%;
    margin-bottom: 60px;
    color: #6a6a6a
}

@media (max-width:650px) {
    .offer__subtitle {
        font-size: 16px
    }
}

.offer__button {
    height: 60px;
    width: 230px;
    border-radius: 10px
}

@media (max-width:650px) {
    .offer__button {
        width: 100%
    }
}

.statistic {
    max-width: 1176px;
    padding: 0 24px;
    width: 100%;
    margin: -95px auto 0
}

@media (max-width:650px) {
    .statistic {
        margin: 0 auto;
        max-width: 1160px;
        padding: 0 16px
    }
}

.statistic__inner {
    display: flex;
    justify-content: space-between;
    gap: 24px;
    border-radius: 20px;
    padding: 50px;
    background: #fff
}

@media (max-width:730px) {
    .statistic__inner {
        flex-direction: column;
        gap: 30px;
        padding: 24px
    }
}

.statistic__numbers {
    font-weight: 600;
    font-size: 48px;
    color: #171a1e
}

@media (max-width:950px) {
    .statistic__numbers {
        font-size: 40px
    }
}

@media (max-width:850px) {
    .statistic__numbers {
        font-size: 36px
    }
}

.statistic__label {
    font-size: 30px
}

@media (max-width:950px) {
    .statistic__label {
        font-size: 24px
    }
}

@media (max-width:850px) {
    .statistic__label {
        font-size: 18px
    }
}

@media (max-width:730px) {
    .statistic__label {
        font-size: 24px
    }
}

.statistic__descriptor {
    font-size: 18px;
    color: #6a6a6a;
    margin-top: 8px
}

@media (max-width:850px) {
    .statistic__descriptor {
        font-size: 16px;
        margin-top: 6px
    }
}

.servises {
    width: 100%;
    margin: 0 auto;
    max-width: 1176px;
    padding: 0 24px
}

@media (max-width:650px) {
    .servises {
        margin: 0 auto;
        max-width: 1160px;
        padding: 0 16px
    }
}

.servises__wrap {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    margin-top: 50px
}

@media (max-width:800px) {
    .servises__wrap {
        grid-template-columns: 1fr
    }
}

@media (max-width:650px) {
    .servises__wrap {
        grid-template-columns: 1fr;
        margin-top: 24px
    }
}

.servises-card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 100%;
    min-height: 260px;
    padding: 40px 40px 30px;
    background: #fff;
    border-radius: 20px;
    position: relative;
    overflow: hidden
}

@media (max-width:650px) {
    .servises-card {
        padding: 24px
    }
}

.servises-card .tiger {
    position: absolute;
    height: 70px;
    width: 98px;
    bottom: -70px;
    right: 36px;
    opacity: 0;
    transition: all .4s ease
}

.servises-card__icon {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 70px;
    height: 70px;
    background: #fff;
    border-radius: 20px;
    box-shadow: 0 6px 24px rgba(0, 0, 0, .06);
    transition: all .4s ease
}

.servises-card__icon svg path {
    fill: #171a1e;
    transition: all .2s ease
}

@media (max-width:650px) {
    .servises-card__icon {
        grid-row: 1
    }
}

.servises-card__title {
    font-size: 24px;
    line-height: 140%;
    color: #171a1e;
    max-width: 100%
}

.servises-card__link {
    font-size: 16px;
    line-height: 19px;
    color: #a1a1a1;
    transition: all .2s ease
}

.servises-card:hover .servises-card__icon {
    background: #0073d8;
    box-shadow: none
}

.servises-card:hover .servises-card__icon svg path {
    fill: #fff
}

.servises-card:hover .servises-card__link {
    color: #0073d8
}

.servises-card:hover .tiger {
    bottom: 0;
    opacity: 1
}

.servises-card__inner {
    display: grid;
    grid-template-columns: 1fr min-content;
    gap: 24px
}

@media (max-width:650px) {
    .servises-card__inner {
        grid-template-columns: 1fr
    }
}

.city {
    margin: 0 auto;
    max-width: 1176px;
    padding: 0 24px;
    width: 100%
}

@media (max-width:650px) {
    .city {
        margin: 0 auto;
        max-width: 1160px;
        padding: 0 16px
    }
}

.city .city__grid {
    display: grid;
    grid-template-columns: 1fr min-content;
    gap: 50px;
    margin-top: 50px
}

@media (max-width:1000px) {
    .city .city__grid {
        grid-template-columns: 1fr;
        gap: 0
    }
}

@media (max-width:650px) {
    .city .city__grid {
        margin-top: 24px
    }
}

.city .city-list {
    max-height: 590px;
    background: #fff;
    border-radius: 20px;
    padding: 16px;
    overflow-y: auto
}

@media (max-width:1000px) {
    .city .city-list {
        overflow-y: visible;
        max-height: 100%
    }
}

@media (max-width:650px) {
    .city .city-list {
        padding: 0
    }
}

.city .city-list__card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    border-radius: 10px;
    cursor: pointer
}

.city .city-list__card:hover {
    background: #f4f4f5
}

@media (max-width:650px) {
    .city .city-list__card:hover {
        background: #fff
    }
}

.city .city-list__title {
    font-weight: 600;
    font-size: 24px;
    color: #171a1e
}

@media (max-width:650px) {
    .city .city-list__title {
        font-size: 21px
    }
}

@media (max-width:350px) {
    .city .city-list__title {
        font-size: 18px
    }
}

.city .city-list__count {
    font-size: 14px;
    color: #6a6a6a;
    margin-top: 6px
}

.city .city-list__flag {
    width: 44px;
    height: 56px
}

.city .city-map__image {
    max-height: 590px
}

@media (max-width:1000px) {
    .city .city-map__image {
        display: none
    }
}

.speech {
    margin: 0 auto;
    max-width: 1176px;
    padding: 0 24px;
    width: 100%
}

@media (max-width:650px) {
    .speech {
        margin: 0 auto;
        max-width: 1160px;
        padding: 0 16px
    }
}

.speech__grid {
    display: grid;
    grid-template-columns: 1fr min-content;
    background: #fff;
    border-radius: 20px;
    justify-items: center
}

@media (max-width:1050px) {
    .speech__grid {
        grid-template-columns: 1fr
    }
}

.speech__image {
    max-width: 470px;
    object-fit: cover;
    border-radius: 20px
}

@media (max-width:1050px) {
    .speech__image {
        width: 100%
    }
}

.speech__title {
    margin-bottom: 20px
}

.speech__text {
    margin-bottom: 24px
}

.speech__wrap {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 50px
}

@media (max-width:650px) {
    .speech__wrap {
        padding: 24px
    }
}

.sign {
    display: flex;
    justify-content: space-between;
    align-items: center
}

.sign .sign__wrap {
    display: flex;
    flex-direction: column;
    gap: 6px
}

.sign .sign__title {
    font-size: 18px;
    color: #171a1e
}

.sign .sign__image {
    width: 173px
}

@media (max-width:650px) {
    .sign .sign__image {
        width: 100px
    }
}

.form {
    margin: 0 auto;
    max-width: 1176px;
    padding: 0 24px;
    width: 100%
}

@media (max-width:650px) {
    .form {
        margin: 0 auto;
        max-width: 1160px;
        padding: 0 16px
    }
}

.form__wrap {
    padding: 50px;
    border-radius: 20px;
    background: #fff
}

@media (max-width:650px) {
    .form__wrap {
        padding: 24px
    }
}

.form__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px 24px
}

@media (max-width:900px) {
    .form__grid {
        grid-template-columns: repeat(2, 1fr)
    }
}

@media (max-width:650px) {
    .form__grid {
        grid-template-columns: 1fr
    }
}

.form__title {
    margin-bottom: 20px
}

.form__text {
    margin-bottom: 60px
}

@media (max-width:650px) {
    .form__text {
        margin-bottom: 46px
    }
}

.form__cell_one {
    grid-column: span 1
}

.form__cell_two {
    min-height: 60px;
    display: flex;
    align-items: center;
    grid-column: span 2
}

@media (max-width:900px) {
    .form__cell_two {
        grid-column: span 1;
        grid-row: 4
    }
}

@media (max-width:650px) {
    .form__cell_two {
        grid-column: span 1;
        grid-row: 7
    }
}

.form__label {
    font-size: 14px;
    color: #707070;
    margin-bottom: 10px
}

.form__input,
.form__select {
    width: 100%;
    height: 60px;
    font-size: 16px;
    color: #171a1e;
    padding: 0 20px;
    border: 1px solid #d1d1d1;
    border-radius: 10px
}

.form__checkbox,
.form__select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none
}

.form__checkbox {
    position: absolute
}

.form__checkbox_input {
    position: absolute;
    width: 32px;
    height: 32px;
    margin-left: -42px;
    border-radius: 10px;
    background-color: #0073d8
}

.form__checkbox:checked+.form__checkbox_input {
    background: url(ok.31239a9e.svg) 50% no-repeat #0073d8
}

.form__label_checkbox {
    margin: 0
}

.form__button {
    font-size: 16px;
    width: 100%;
    height: 60px;
    border-radius: 10px;
    align-self: end
}

@media (max-width:650px) {
    .form__button {
        margin-top: 20px
    }
}

.form__link {
    color: #0073d8
}

.label__wrap {
    display: flex;
    align-items: center;
    cursor: pointer;
    padding-left: 42px
}

.cases {
    background: #fff;
    padding-top: 90px;
    padding-bottom: 120px;
    overflow: hidden
}

@media (max-width:650px) {
    .cases {
        padding-top: 48px;
        padding-bottom: 48px
    }
}

.cases__wrap {
    position: relative;
    margin: 0 auto;
    max-width: 1176px;
    padding: 0 24px
}

@media (max-width:650px) {
    .cases__wrap {
        margin: 0 auto;
        max-width: 1160px;
        padding: 0 16px
    }
}

.cases__title {
    margin-bottom: 50px
}

@media (max-width:650px) {
    .cases__title {
        margin-bottom: 24px
    }
}

.cases__button {
    position: absolute;
    top: 50%;
    width: 36px;
    height: 36px;
    border-radius: 100%;
    cursor: pointer;
    z-index: 10;
    transition: all .2s ease
}

@media (max-width:650px) {
    .cases__button {
        display: none
    }
}

.cases__button_next {
    background: url(slider-button_primary.ca7f2948.svg) no-repeat 50% #fff;
    left: -36px;
    box-shadow: 0 10px 20px rgba(0, 0, 0, .13)
}

@media (max-width:1250px) {
    .cases__button_next {
        left: 48px;
        top: 40%;
        box-shadow: 0 10px 20px rgba(0, 0, 0, .5)
    }
}

.cases__button_next:hover {
    box-shadow: 0 10px 20px rgba(0, 0, 0, .2)
}

.cases__button_prev {
    background: url(slider-button_primary.ca7f2948.svg) no-repeat 50% #fff;
    transform: rotate(-180deg);
    right: -36px;
    box-shadow: 0 -10px 20px rgba(0, 0, 0, .13)
}

@media (max-width:1250px) {
    .cases__button_prev {
        right: 48px;
        top: 40%;
        box-shadow: 0 -10px 20px rgba(0, 0, 0, .5)
    }
}

.cases__button_prev:hover {
    box-shadow: 0 -10px 20px rgba(0, 0, 0, .2)
}

.case-card {
    border: 1px solid #f0f0f0;
    border-radius: 20px
}

.case-card__image {
    border-radius: 20px 20px 0 0;
    width: 100%;
    height: 340px;
    object-fit: cover
}

.case-card__wrap {
    display: grid;
    grid-template-columns: min-content 1fr;
    align-items: center;
    gap: 12px
}

.case-card__content {
    padding: 24px
}

.case-card__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    margin-bottom: 30px
}

.case-card__icon {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 50px;
    height: 50px;
    background: #f0f0f0;
    border-radius: 10px
}

.case-card__label {
    font-size: 14px;
    color: #707070
}

.case-card__title {
    font-weight: 600;
    font-size: 21px;
    color: #171a1e;
    margin-bottom: 14px
}

.case-card__desc {
    font-size: 16px;
    line-height: 160%;
    color: #707070;
    margin-bottom: 10px
}

.case-card__years {
    font-size: 12px;
    color: #b5b5b5
}

.swiper {
    max-width: 1128px
}

.articles {
    background: #fff;
    padding-top: 90px;
    padding-bottom: 120px
}

@media (max-width:650px) {
    .articles {
        padding-top: 48px;
        padding-bottom: 48px
    }
}

.articles__wrap {
    margin: 0 auto;
    max-width: 1176px;
    padding: 0 24px
}

@media (max-width:650px) {
    .articles__wrap {
        margin: 0 auto;
        max-width: 1160px;
        padding: 0 16px
    }
}

.articles__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin-top: 50px
}

@media (max-width:900px) {
    .articles__grid {
        grid-template-columns: 1fr;
        margin-top: 24px;
        gap: 48px
    }
}

.articles__card {
    text-decoration: none
}

.articles__image {
    width: 100%;
    height: 240px;
    object-fit: cover;
    border-radius: 20px;
    margin-bottom: 30px
}

@media (max-width:650px) {
    .articles__image {
        margin-bottom: 24px
    }
}

.articles__title {
    font-size: 24px;
    line-height: 140%;
    color: #171a1e;
    margin-bottom: 10px
}

.articles__subtitle {
    font-size: 16px;
    line-height: 160%;
    color: #6a6a6a
}

.article {
    margin: 0 auto;
    max-width: 1176px;
    padding: 0 24px
}

@media (max-width:650px) {
    .article {
        margin: 0 auto;
        max-width: 1160px;
        padding: 0 16px
    }
}

.article__wrap {
    background: #fff;
    border-radius: 20px;
    padding: 50px;
    margin: 50px 0 120px
}

@media (max-width:650px) {
    .article__wrap {
        padding: 16px;
        margin: 16px 0 50px
    }
}

.article__paragraph {
    color: #353535;
    margin-bottom: 20px
}

.article__title_h1 {
    font-size: 36px;
    margin-bottom: 40px
}

@media (max-width:650px) {
    .article__title_h1 {
        font-size: 30px
    }
}

.article__title_h2 {
    font-size: 24px;
    margin: 50px 0 20px
}

.article__image {
    width: 100%;
    max-width: 680px;
    border-radius: 10px;
    margin-top: 30px
}

.article__main-image {
    width: 100%;
    border-radius: 10px;
    margin-bottom: 40px
}

.contact {
    width: 100%;
    margin: 0 auto;
    max-width: 1176px;
    padding: 0 24px
}

@media (max-width:650px) {
    .contact {
        margin: 0 auto;
        max-width: 1160px;
        padding: 0 16px
    }
}

.contact__wrap {
    display: flex;
    flex-direction: column;
    gap: 40px;
    background: #fff;
    border-radius: 20px;
    padding: 50px
}

@media (max-width:650px) {
    .contact__wrap {
        padding: 24px
    }
}

.contact__inner {
    display: flex;
    flex-direction: column;
    gap: 6px
}

.contact__label {
    font-weight: 500;
    font-size: 18px;
    color: #707070
}

.contact__text {
    font-weight: 600;
    font-size: 24px;
    color: #171a1e;
    text-decoration: none
}

.footer {
    background: #171a1e
}

.footer__wrap {
    margin: 0 auto;
    max-width: 1176px;
    padding: 0 24px
}

@media (max-width:650px) {
    .footer__wrap {
        margin: 0 auto;
        max-width: 1160px;
        padding: 0 16px
    }
}

.footer__inner {
    height: 80px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 40px
}

.footer__logo .logo__desc {
    fill: #fff
}

.footer__menu .menu__link {
    color: #fff;
    text-decoration: none
}

.footer__inn {
    font-size: 16px;
    color: #6a6a6a
}

.footer__bottom {
    display: flex;
    justify-content: space-between;
    margin-top: 40px;
    padding: 30px 0;
    border-top: 1px solid #2e3134
}

@media (max-width:650px) {
    .footer__bottom {
        flex-direction: column;
        gap: 8px
    }
}

.footer__copyright {
    font-size: 11px;
    color: #6a6a6a
}

.popup {
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    background-color: rgba(23, 26, 30, .6);
    display: none
}

.popup_open {
    display: block
}

.popup__wrap {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center
}

@media (max-width:650px) {
    .popup__wrap {
        padding: 16px
    }
}

.popup__card {
    width: 500px;
    background: #fff;
    border-radius: 20px;
    padding: 50px
}

@media (max-width:650px) {
    .popup__card {
        width: 100%;
        padding: 24px
    }
}

.popup__title {
    margin-bottom: 20px
}

.button {
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    color: #fff;
    background: #0073d8;
    border: none;
    font-family: inherit;
    text-decoration: none;
    transition: background .2s ease
}

.button:hover {
    background: #318dde
}

.link {
    text-decoration: none
}

.whitespace {
    white-space: nowrap
}