@media only screen and (max-width: 1920px) {
    .slider .swiper-slide {
        max-width: calc(100% - 20rem + 24px);
    }

    section.full .section__header {
        max-width: 100%;
    }
}

@media only screen and (max-width: 1700px) {
    nav.menu ul li a {
        font-size: 1.2rem;
    }

    a.link {
        font-size: 1.2rem;
    }
    
    section.full .section__header {
        max-width: 100%;
    }
}

@media only screen and (max-width: 1440px) {
    nav.menu ul li a {
        font-size: 1.2rem;
    }

    a.link {
        font-size: 1.2rem;
        padding: 2px 0;
    }
    
    section.full .section__header {
        max-width: 100%;
    }
    
    nav.menu ul {
        gap: 1.6rem;
    }
    
    a.link span {
        display: none;
    }
    
    a.link:first-child {
        padding-right: 12px;
        border-right: 1px solid hsla(0,0%,100%,.1);
    }
    
    .header__controls {
        gap: 12px;
    }
    
    .model__wrapper {
        padding: 60px 0;
    }
    
    .btns {
        margin-top: 10px;
    }
    
    section.special .swiper-slide .slide__info {
        top: 6rem;
        flex-direction: column;
        gap: 24px;
    }
    
    .subscribe__wrapper {
        height: auto;
    }
    
    img.subscribe__img {
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
    }

    .modal__wrapper {
        max-width: calc(100% - 40px);
    }

    section#spec a.link:first-child {
        border: none;
    }
    
    .left {
        width: 80%;
    }
    
    .left__info a.link {
        font-size: 24px;
    }
    
    .left__info {
        gap: 8px;
    }
    
    p.old {
        font-size: 16px;
    }
    
    .spec__item__element__price {
        gap: 8px;
        font-size: 24px;
    }
    
    .tab {
        padding: 12px 20px;
        font-size: 16px;
    }
    
    button.show-more-btn {
        font-size: 16px;
    }
}

@media only screen and (max-width: 1200px) {
    .slide__info {
        width: calc(100% - 7.2rem);
    }
    
    section.special .swiper-slide .slide__info {
        width: calc(100% - 20rem);
    }
    
    .footer__soc {
        gap: 32px;
    }
    
    .footer__soc a svg {
        width: 28px;
        height: 28px;
    }

    .card-info-number.h1 {
        font-size: 44px;
    }
}

@media only screen and (max-width: 1024px) {
    nav.menu {
        display: none;
    }
    
    .burger {
        display: flex;
        cursor: pointer;
    }
    
    .burger svg path {
        fill: var(--white);
    }
    
    a.link {
        padding-right: 12px;
        border-right: 1px solid hsla(0, 0%, 100%, .1);
    }
    
    .container {
        max-width: 100%;
        padding: 0 2.4rem;
    }
    
    .model__bg source, .model__bg img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    
    .model__bg source {
        display: none;
    }
    
    .model__header {
        justify-content: center;
    }
    
    .model__info {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 20px;
    }
    
    .model__info__content {
        gap: 20px;
        align-items: center;
    }
    
    section.full .section__header {
        padding: 0 2.4rem;
    }
    
    section.full {
        padding: 6rem 0;
    }
    
    .slider .swiper-slide {
        max-width: 100%;
        padding: 0;
        margin: 0 10px;
    }
    
    .slider .swiper-slide::after {
        width: 100%;
        left: 0;
    }
    
    .slide__info {
        flex-direction: column;
        gap: 25px;
    }
    
    .slide__info__content {
        max-width: 100%;
        justify-content: flex-start;
        gap: 100px;
    }
    
    .swiper-slide p.description {
        max-width: 500px;
    }
    
    section.special .swiper-slide .slide__info {
        width: calc(100% - 7.2rem);
    }
    
    section.special .swiper-slide picture {
        display: flex;
        justify-content: center;
    }
    
    section.special .swiper-slide picture source {
        display: none;
    }
    
    section.special .swiper-slide picture img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    
    section.subscribe.full .container {
        max-width: 100%;
        padding: 0 3.6rem;
    }
    
    .subscribe__wrapper {
        height: 530px;
    }
    
    img.subscribe__img {
        max-width: 580px;
        bottom: 0;
    }
    
    .map__info__wrapper {
        max-width: 100%;
        padding: 0 3.6rem;
    }

    .card-info-number.h1 {
        font-size: 44px;
    }
    
    .cards-grid.cards-snap {
        grid-template-columns: repeat(2, 1fr);
    }

    .card-info {
        min-height: 200px;
    }

    .card-info-number.h1 {
        font-size: 32px;
    }

    .modal.modal__nav {
        display: flex;
        transform: translateX(-100%);
        pointer-events: all;
    }

    .modal__nav.active {
        transform: translateX(0);
    }
    
    .modal__nav__wrapper nav.menu {
        display: flex;
        width: 100%;
    }
    
    .modal__nav__wrapper {
        display: flex;
        width: 100%;
        height: 100%;
        background: var(--dark-blue);
        position: relative;
        padding: 80px 16px 16px;
        flex-direction: column;
        gap: 40px;
    }
    
    .modal__close {
        display: flex;
        position: absolute;
        top: 10px;
        left: 10px;
        cursor: pointer;
        transition: all .5s ease;
    }
    
    .modal__close svg path {
        fill: var(--white);
    }
    
    .modal__close svg {
        height: 32px;
        width: 32px;
    }
    
    .modal__nav__wrapper nav.menu ul {
        flex-direction: column;
        gap: 0;
        align-items: flex-start;
        width: 100%;
    }
    
    .modal__nav__wrapper nav.menu ul li {
        width: 100%;
        border-bottom: 1px solid hsla(0,0%,100%,.1);
    }

    .modal__nav__wrapper nav.menu ul li a {
        font-size: 1.4rem;
        font-weight: 500;
        padding-bottom: 1.6rem;
        padding-top: 1.6rem;
        text-transform: none;
        justify-content: space-between;
    }
    
    .modal__nav__wrapper nav.menu ul li a svg {
        transform: rotate(-90deg);
    }
    
    .modal__nav__wrapper nav.menu ul li a svg {
        height: 20px;
        width: 20px;
    }

    .header__info {
        display: none;
    }
    
    .modal__nav__wrapper .header__info {
        display: flex;
        gap: 20px;
    }
}

@media only screen and (max-width: 768px) {
    h1.title {
        font-size: 2.2rem;
        font-weight: 500;
        line-height: 2.6rem;
    }
    
    section.hero .container {
        justify-content: flex-end;
    }
    
    .hero__content {
        height: auto;
        gap: 16px;
        padding-bottom: 40px;
    }
    
    .container {
        padding: 0 1.6rem;
    }
    
    .model__header img {
        height: 32px;
    }
    
    .model__wrapper {
        padding: 40px 0;
    }
    
    .model__info__slug {
        font-size: 20px;
        line-height: 1.2;
    }
    
    .model__info {
        gap: 16px;
    }
    
    .model__info__content {
        gap: 16px;
    }
    
    p.price {
        font-size: 2rem;
        line-height: 2.4rem;
    }
    
    p.credit {
        font-size: 1.6rem;
        line-height: 1.9rem;
    }
    
    .btns {
        flex-direction: column;
        margin: 0;
        gap: 10px;
    }
    
    section.full {
        padding: 0;
    }
    
    section.full .section__header {
        display: none;
    }
    
    h3.slide__title {
        font-size: 2rem;
        line-height: 2.4rem;
    }
    
    .slide__info {
        align-items: center;
        gap: 15px;
        text-align: center;
        bottom: 6rem;
        width: calc(100% - 32px);
        left: 16px;
    }
    
    .slide__info__content {
        flex-direction: column;
        gap: 15px;
        align-items: center;
    }
    
    .slide__info__content button {
        width: 312px;
    }
    
    section.full .section__footer {
        position: absolute;
        z-index: 2;
    }
    
    .slider .swiper-slide {
        height: 50rem;
        margin: 0;
    }
    
    .swiper-slide p.description {
        max-width: 100%;
    }
    
    section.full .section__footer .arrow {
        display: none;
    }
    
    section.full .section__footer span.swiper-pagination-bullet {
        flex: 1;
    }
    
    section.full .section__footer {
        bottom: 25px;
        padding: 0 24px;
    }
    
    section.special .swiper-slide .slide__info h3.slide__title {
        font-size: 2rem;
        line-height: 2.4rem;
    }
    
    section.special .swiper-slide .slide__info {
        gap: 24px;
        width: calc(100% - 32px);
    }
    
    section.special .swiper-slide .slide__info .slide__info__content {
        gap: 24px;
    }
    
    section.special .swiper-slide .slide__info .slide__info__content .btn {
        width: 312px;
    }
    
    .slider__nav {
        max-width: 400px;
        width: 100% !important;
    }
    
    span.swiper-pagination-bullet.swiper-pagination-bullet-active {
        width: auto;
        flex: 1;
    }
    
    span.swiper-pagination-bullet {
        width: auto;
        flex: 1;
    }
    
    section.special .slider__controls .arrow {
        display: none;
    }
    
    section.news h4 {
        font-size: 1.6rem;
        line-height: 1.9rem;
    }
    
    section.news .slide__info {
        align-items: flex-start;
        text-align: left;
    }
    
    h2.section__title {
        font-size: 2rem;
        line-height: 2.4rem;
    }
    
    img.subscribe__img {
        position: inherit;
        order: 3;
        transform: none;
        left: auto;
        padding-top: 4rem;
    }
    
    .subscribe__wrapper {
        flex-direction: column;
        height: auto;
        align-items: center;
        text-align: center;
        gap: 1.6rem;
    }
    
    .subscribe__wrapper h2.section__title {
        order: 1;
    }
    
    .subscribe__controls {
        order: 2;
        align-items: center;
        gap: 1.6rem;
        width: 100%;
    }
    
    .soc {
        gap: 0.8rem;
    }
    
    section.subscribe.full .container {
        padding: 0 16px;
    }
    
    .subscribe__controls .btn {
        width: 100%;
    }
    
    .map__info__wrapper {
        padding: 16px;
    }
    
    div#map {
        align-items: flex-start;
    }

    .cards-grid.cards-snap {
        grid-template-columns: repeat(1, 1fr);
        gap: 10px;
        margin-bottom: 20px;
        padding-right: 10px;
    }
    
    .modal__wrapper {
        max-height: 80vh;
        /* overflow-y: scroll; */
        padding: 40px 12px 12px;
    }
    
    .modal__detail .modal__close {
        right: 3px;
        top: 3px;
        left: auto;
    }

    .dongfeng {
        position: initial;
        height: 550px;
        left: 0;
        max-width: 100%;
    }

    #map > ymaps {
        height: 500px !important;
    }

    .qr {
        max-width: calc(100% - 20px);
        flex-direction: column;
        align-items: center;
        text-align: center;
    }
    
    .qr__info {
        gap: 10px;
    }
    
    .qr__items {
        gap: 0;
    }

    .left {
        width: 100%;
        flex-direction: column;
    }
    
    .spec__item__element {
        flex-direction: column;
        gap: 20px;
    }
    
    .slider__wrapper {
        width: 100%;
    }
    
    .left .swiper {
        max-width: 100%;
        height: auto;
    }
    
    .left__info {
        width: 100%;
    }
    
    .spec__item__element__price {
        width: 100%;
        align-items: flex-start;
    }
}

@media only screen and (max-width: 540px) {
    footer .container {
        flex-direction: column;
        gap: 3rem;
    }
    
    nav.footer__nav {
        justify-content: flex-start;
    }

    section.news .slider .swiper-slide {
        height: auto;
        min-height: 300px;
    }
    
    section.news .slide__info {
        bottom: auto;
        top: 16px;
        flex-direction: column-reverse;
        gap: 10px;
    }
    
    span.date {
        font-size: 12px;
    }
    
    .slider .swiper-slide::after {
        background: linear-gradient(0deg, #051c2ced 0%, #051c2c38 15%, transparent, #051c2cc4 80%);
    }

    .slider .swiper-slide {
        height: 100vh;
        margin: 0;
    }

    .slider__nav {
        max-width: 100%;
    }
    
    .swiper-slide .slide__info, section.special .swiper-slide .slide__info {
        bottom: 6rem;
        top: auto;
    }

    .map__info__wrapper {
        position: absolute;
        padding: 0;
        bottom: 0;
    }
    
    div#map {
        height: auto;
        overflow: hidden;
        flex-direction: column;
    }
    
    .map__info {
        max-width: 100%;
        width: 100%;
        border-radius: 0;
    }

    section.special .slider__controls {
        padding: 0 24px;
        bottom: 25px;
    }

    .modal__detail__wrapper {
        padding-bottom: 20px;
        overflow-y: scroll;
    }
    
    .card-info-number.h1 {
        font-size: 44px;
    }

    .modal__call .modal__wrapper {
        max-width: calc(100% - 32px);
    }
    
    label.checkbox__label {
        font-size: 12px;
        line-height: 1.2;
    }
    
    .checkbox-item input {
        width: 16px;
        height: 16px;
    }
    
    .contact__form__wrapper {
        gap: 1.6rem;
    }
    
    .modal__contact__form {
        gap: 3.2rem;
    }

    .spec__item {
        padding: 10px;
    }
    
    .left__info {
        gap: 0;
    }
    
    .spec__item__element__price {
        gap: 4px;
    }
    
    .left__info a.link {
        font-size: 20px;
    }
    
    p.subtitle {
        font-size: 14px;
    }
    
    .slider__wrapper {
        gap: 10px;
    }

    a.logo img {
        max-width: 120px;
        max-height: 20px;
    }
    
    a.logo img:last-child {
        max-height: 16px;
    }
}