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

    .project-single-page {
        padding-top: 8px;
    }

    .project-single-page__shell {
        width: 100%;
    }

    .project-hero {
        grid-template-columns: 1fr;
        justify-content: start;
        gap: 40px;
        padding-top: 0;
        flex-direction: column;
        padding-right: 0;
    }

    .project-hero__content,
    .project-story__head,
    .project-cta__content,
    .related-projects__intro {
        width: 100%;
    }

    .project-hero__content {
        padding-top: 0;
        gap: 20px;
        flex: initial;
    }

    .project-hero__title {
        width: 100%;
        margin: 0;
        font-size: 40px;
        line-height: normal;
    }

    .project-hero__meta {
        gap: 20px;
        margin: 0;
        font-size: 16px;
    }

    .project-meta-item {
        gap: 10px;
    }

    .project-meta-item svg {
        width: 40px;
        height: 40px;
    }

    .project-hero__desc {
        width: 100%;
        font-size: 16px;
        line-height: normal;
    }

    .project-hero__desc p + p {
        margin-top: 15px;
    }

    .btn-primary {
        min-width: auto;
    }

    .project-hero__visual {
        width: 100%;
        height: 534px;
        margin-left: auto;
        margin-right: auto;
    }

    .project-hero__play {
        width: 50px;
        height: 50px;
    }

    .project-story {
        align-items: flex-start;
        width: 100vw;
        margin-left: calc(50% - 50vw);
        padding-top: 120px;
        padding-left: 0;
        overflow: hidden;
    }

    .project-story__head {
        align-items: flex-start;
        padding-left: 20px;
        padding-right: 20px;
    }

    .section-label--center {
        align-self: flex-start;
    }

    .project-story__title {
        width: 100%;
        margin: 20px 0;
        text-align: left;
        font-size: 40px;
        line-height: normal;
    }

    .project-story__desc {
        width: 100%;
        text-align: left;
        font-size: 16px;
        line-height: normal;
    }

    .project-story__track {
        display: flex;
        gap: 10px;
        width: 100%;
        max-width: none;
        padding-top: 40px;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .project-story__track::-webkit-scrollbar {
        display: none;
    }

    .project-story__track .story-card:first-child {
        margin-left: 20px;
    }

    .project-story__track .story-card:last-child {
        margin-right: 20px;
    }

    .project-story__track-scrollbar {
        display: block;
        width: calc(100vw - 40px);
        height: 3px;
        margin: 5px 20px 0;
        background: var(--second-bg);
        overflow: hidden;
    }

    .project-story__track-scrollbar-thumb {
        display: block;
        height: 100%;
        background: var(--accent);
        transform: translateX(0);
        will-change: transform;
    }

    .story-card {
        width: 280px;
        height: 384px;
        flex-shrink: 0;
    }

    .story-card__badge {
        height: 50px;
        padding: 0 20px;
        font-size: 16px;
    }

    .project-story__progress {
        position: relative;
        display: block;
        width: 100%;
        height: 2px;
        margin-top: 38px;
        background: var(--second-bg);
    }

    .project-story__progress-active {
        position: absolute;
        left: 0;
        top: 0;
        width: 80px;
        height: 2px;
        background: var(--accent);
    }

    .project-single-page .section-get-started {
        padding-left: 0;
        padding-right: 0;
        margin-top: 120px;
    }

    .project-single-page .section-get-started > .container {
        width: 100%;
        padding-left: 0;
        padding-right: 0;
    }

    .project-cta {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .project-cta__visual {
        order: -1;
        height: 240px;
    }

    .project-cta__visual img {
        object-position: center;
    }

    .project-cta__content {
        padding: 30px 24px 40px;
    }

    .project-cta__content::after {
        display: none;
    }

    .project-cta__tag {
        height: 40px;
        padding: 10px 15px 10px 15px;
        font-size: 16px;
    }

    .project-cta__tag::after {
        right: -15px;
        width: 15px;
    }

    .project-cta__title {
        width: 272px;
        margin: 20px 0;
        font-size: 33px;
        line-height: normal;
    }

    .project-cta__desc,
    .project-cta__form,
    .project-cta__privacy {
        width: 272px;
    }

    .project-cta__desc {
        font-size: 19px;
        line-height: normal;
    }

    .project-cta__field input {
        height: 50px;
        padding: 15px 0;
    }

    .project-cta__field textarea {
        height: 72px;
        padding: 15px 0;
    }

    .project-cta__row {
        flex-direction: column;
        gap: 0;
    }

    .btn-dark {
        align-self: flex-start;
        min-width: 178px;
    }

    .related-projects {
        display: block;
        padding-top: 100px;
        padding-bottom: 120px;
    }

    .related-projects__intro {
        gap: 20px;
    }

    .related-projects__tag {
        min-height: 21px;
        padding: 2px 2px 2px 5px;
        border-left-width: 2px;
        font-size: 13px;
        font-weight: 400;
    }

    .related-projects__tag::after {
        right: -5px;
        width: 5px;
    }

    .related-projects__title {
        width: 100%;
        font-size: 40px;
        line-height: normal;
    }

    .related-projects__desc {
        font-size: 16px;
        line-height: normal;
    }

    .related-projects__back {
        margin-top: 20px;
    }

    .related-projects__back-left,
    .related-projects__back-right {
        width: 14px;
        height: 40px;
    }

    .related-projects__back-center {
        min-width: 180px;
        height: 40px;
        padding: 10px 16px;
        font-size: 16px;
    }

    .related-projects__cards {
        width: 100%;
        margin-top: 40px;
        overflow: hidden;
    }

    .related-projects__cards .swiper-slide {
        width: 100%;
    }

    .related-projects__intro .project-pagination-wrapper {
        display: none;
    }

    .project-pagination--mobile {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        width: 100%;
        height: auto;
        margin: 20px auto 0;
        row-gap: 10px;
    }

    .project-pagination--mobile .project-pagination__bullets {
        flex-wrap: wrap;
        justify-content: center;
        min-width: 0;
    }

    .project-pagination--mobile .project-pagination__arrows {
        display: flex;
        flex: 0 0 auto;
        gap: 12px;
    }

    .project-card {
        width: 100%;
        flex-shrink: 0;
        min-height: 415px;
    }

    .project-card__image-wrap {
        height: 240px;
    }

    .project-card__content {
        margin-top: -28px;
        padding: 20px 20px 24px;
        clip-path: polygon(0 0, 100% 28px, 100% 100%, 0 100%);
    }

    .project-card__title {
        font-size: 28px;
        line-height: normal;
    }

    .project-card__meta {
        font-size: 16px;
    }

    .project-pagination {
        padding: 0;
    }

    .footer {
        flex-direction: column;
        align-items: flex-start;
        gap: 40px;
        margin-top: 0;
        padding: 40px 20px;
    }

    .footer__left {
        width: 100%;
        height: auto;
        gap: 20px;
    }

    .footer__logo {
        width: 145px;
        height: 100px;
    }

    .footer__links {
        flex-direction: column;
        gap: 30px;
    }

    .footer__contact .footer__col-title {
        margin-bottom: 20px;
    }

    .footer__contact-inner {
        width: 100%;
    }

    .footer__phone {
        font-size: 28px;
    }

    .footer__email {
        font-size: 19px;
    }
}
