:root {
    --cut-size: 160px;
    --cut-size-child: 120px;
    --cut-size-grid: 96px;

    --color-background-primary: #F2F2F2;
    --color-background-accent-special-primary: #141414;
    --color-background-main-tertiary: #9EA0A8;

    --color-background-btn: #141414;

    --color-border-primary: #7C7979;

    --color-text-primary: #2E2E2E;
    --color-text-light: #7C7979;
    --color-text-inverse: #FFFFFF;
    --color-text-blue: #009BE4;
}

/* Regular */
@font-face {
    font-family: 'Inter';
    src: url('../fonts/Inter/Inter-Regular.otf') format('opentype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

/* Bold */
@font-face {
    font-family: 'Inter';
    src: url('../fonts/Inter/Inter-Bold.otf') format('opentype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

/* Italic */
@font-face {
    font-family: 'Inter';
    src: url('../fonts/Inter/Inter-Italic.otf') format('opentype');
    font-weight: 400;
    font-style: italic;
    font-display: swap;
}

/* Bold Italic */
@font-face {
    font-family: 'Inter';
    src: url('../fonts/Inter/Inter-BoldItalic.otf') format('opentype');
    font-weight: 700;
    font-style: italic;
    font-display: swap;
}

/* Montserrat */
@font-face {
    font-family: "Montserrat";
    src: url("../fonts/Montserrat/Montserrat-Medium.ttf");
}

/* Manrope */

@font-face {
    font-family: 'Manrope';
    src: url('/public/fonts/Manrope/Manrope-Bold.eot');
    src: local('Manrope Bold'), local('Manrope-Bold'),
    url('/public/fonts/Manrope/Manrope-Bold.eot?#iefix') format('embedded-opentype'),
    url('/public/fonts/Manrope/Manrope-Bold.woff2') format('woff2'),
    url('/public/fonts/Manrope/Manrope-Bold.woff') format('woff'),
    url('/public/fonts/Manrope/Manrope-Bold.ttf') format('truetype');
    font-weight: bold;
    font-style: normal;
}

@font-face {
    font-family: 'Manrope';
    src: url('/public/fonts/Manrope/Manrope-Semibold.eot');
    src: local('Manrope Semibold'), local('Manrope-Semibold'),
    url('/public/fonts/Manrope/Manrope-Semibold.eot?#iefix') format('embedded-opentype'),
    url('/public/fonts/Manrope/Manrope-Semibold.woff2') format('woff2'),
    url('/public/fonts/Manrope/Manrope-Semibold.woff') format('woff'),
    url('/public/fonts/Manrope/Manrope-Semibold.ttf') format('truetype');
    font-weight: 600;
    font-style: normal;
}

@font-face {
    font-family: 'Manrope';
    src: url('/public/fonts/Manrope/Manrope-Regular.eot');
    src: local('Manrope Regular'), local('Manrope-Regular'),
    url('/public/fonts/Manrope/Manrope-Regular.eot?#iefix') format('embedded-opentype'),
    url('/public/fonts/Manrope/Manrope-Regular.woff2') format('woff2'),
    url('/public/fonts/Manrope/Manrope-Regular.woff') format('woff'),
    url('/public/fonts/Manrope/Manrope-Regular.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Manrope';
    src: url('/public/fonts/Manrope/Manrope-Light.eot');
    src: local('Manrope Light'), local('Manrope-Light'),
    url('/public/fonts/Manrope/Manrope-Light.eot?#iefix') format('embedded-opentype'),
    url('/public/fonts/Manrope/Manrope-Light.woff2') format('woff2'),
    url('/public/fonts/Manrope/Manrope-Light.woff') format('woff'),
    url('/public/fonts/Manrope/Manrope-Light.ttf') format('truetype');
    font-weight: 300;
    font-style: normal;
}

@font-face {
    font-family: 'Manrope';
    src: url('/public/fonts/Manrope/Manrope-Thin.eot');
    src: local('Manrope Thin'), local('Manrope-Thin'),
    url('/public/fonts/Manrope/Manrope-Thin.eot?#iefix') format('embedded-opentype'),
    url('/public/fonts/Manrope/Manrope-Thin.woff2') format('woff2'),
    url('/public/fonts/Manrope/Manrope-Thin.woff') format('woff'),
    url('/public/fonts/Manrope/Manrope-Thin.ttf') format('truetype');
    font-weight: 100;
    font-style: normal;
}

@font-face {
    font-family: 'Manrope';
    src: url('/public/fonts/Manrope/Manrope-Medium.eot');
    src: local('Manrope Medium'), local('Manrope-Medium'),
    url('/public/fonts/Manrope/Manrope-Medium.eot?#iefix') format('embedded-opentype'),
    url('/public/fonts/Manrope/Manrope-Medium.woff2') format('woff2'),
    url('/public/fonts/Manrope/Manrope-Medium.woff') format('woff'),
    url('/public/fonts/Manrope/Manrope-Medium.ttf') format('truetype');
    font-weight: 500;
    font-style: normal;
}

@font-face {
    font-family: 'Manrope';
    src: url('/public/fonts/Manrope/Manrope-ExtraBold.eot');
    src: local('Manrope ExtraBold'), local('Manrope-ExtraBold'),
    url('/public/fonts/Manrope/Manrope-ExtraBold.eot?#iefix') format('embedded-opentype'),
    url('/public/fonts/Manrope/Manrope-ExtraBold.woff2') format('woff2'),
    url('/public/fonts/Manrope/Manrope-ExtraBold.woff') format('woff'),
    url('/public/fonts/Manrope/Manrope-ExtraBold.ttf') format('truetype');
    font-weight: 800;
    font-style: normal;
}

* {
    margin: 0;
    padding: 0;
}

html, body {
    background-color: var(--color-background-accent-special-primary);
    color: var(--color-text-inverse);
}

.grid-container {
    display: flex;
    flex-direction: column;
    gap: 15px;
    flex-wrap: wrap;
}

.dropdown-top-menu {
    display: none;
}

.top-advantages-container-1 {
    margin: 0;
    padding: 0;
    background-image: url("/public/image/headPicture.webp");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top center;
    font-family: Montserrat, sans-serif;
}

.top-advantages-container-2 {
    display: flex;
    justify-content: space-between;
    font-family: Montserrat, serif;
    font-weight: 500;
    align-items: center;
}

.page-header-line {
    display: flex;
    justify-content: space-between;
}

.text-top-menu a {
    color: var(--color-text-inverse);
    text-decoration: none;
}

.button-top-menu {
    color: #2E2E2E;
    font-family: Inter, serif;
    background-color: #F2F2F2;
    font-weight: 400;
}

.container-a, .footer-a {
    background-color: var(--color-background-primary);
    display: flex;
    flex-direction: column;
}

.container-a-a-a > div .text-hover .text-hover-hidden {
    display: none;
    font-weight: 400;
    font-family: Inter, sans-serif;
}

.grid-container-block {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: space-between;
}

.grid-title, .container-a-a-a > div {
    font-weight: 500;
    font-family: Montserrat, sans-serif;
}

.grid-text {
    font-weight: 400;
    font-family: Inter, sans-serif;
    display: flex;
    flex-direction: row;
}

.text-top-menu {
    font-weight: 400;
    display: flex;
    align-items: center;
    font-family: "Inter", serif;
}

.container-a-a-a > div {
    background-color: #14141480;
    flex: 1;
    display: flex;
    align-items: center;
}

.grid-opt {
    background-color: var(--color-background-accent-special-primary);
}

.fl-1 {
    flex: 1;
}

.fl-1 .btn.disabled {
    --bs-btn-disabled-bg: var(--color-background-btn);
    --bs-btn-disabled-border-color: var(--color-background-btn);
}

.grid-1,
.grid-2,
.grid-1-2-1,
.grid-2-1,
.grid-2-2-1,
.grid-1-2,
.grid-flex,
.grid-program,
.grid-program-block-margin,
.group-company, .footer-a-1, .footer-a-2, .footer-a-3, .footer-a-3-2, .footer-a-1-1, .footer-a-1-1-1, .footer-a-1-1-2,
.order-service-type, .modal-content-order-success-1, .footer-a-3-2 > div {
    display: flex;
}

.grid-2-2-1 {
    flex-direction: row;
}

.grid-1-1 {
    background-image: url("/public/image/engineerAndNote.webp");
    background-repeat: no-repeat;
    background-size: cover;
}

.grid-1-2, .grid-program, .grid-program-block-margin, .footer-a-3-2, .footer-a-1-1, .footer-a-1-1-2,
.modal-content-order-success-1 {
    flex-direction: column;
}

.grid-program-background, .grid-apparat-background {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top center;
}

.grid-program-background {
    background-image: url('/public/image/programMetrics.webp');
}

.grid-apparat-background {
    background-image: url('/public/image/programApparate.webp');
}

.grid-vector-pro-context,
.grid-vector-pro-apparat-context,
.group-company .group-company-description,
.footer-a-3-1,
.footer-a-3-2, .footer-menu a, .privacy-policy-context, .order-modal-footer .btn, .order-modal-footer-1,
.order-service-type .btn, .order-modal-body-1, .order-modal-body-2, .order-modal-body-3, .order-modal-body-4,
.order-modal-body-result-services, .order-modal-body-result-contacts, .order-modal-body-result-comment,
.order-modal-body-success-label {
    font-weight: 400;
    font-family: Inter, sans-serif;
}

.footer-a-1-1-2, .footer-a-1-1-3 {
    font-weight: 400;
    font-family: Manrope, sans-serif;
}

.grid-vector-pro-apparat-title, .grid-vector-pro-description, .privacy-policy-title, .order-modal-title {
    font-weight: 500;
    font-family: Montserrat, sans-serif;
}

.grid-begin-title, .group-company .group-company-title {
    font-weight: 600;
    font-family: Montserrat, sans-serif;
}

.grid-program-block-margin {
    justify-content: space-between;
}

.footer-opt {
    color: var(--color-text-primary);
}

.footer-a-3-2 > div > div, .order-modal-private-policy-link {
    border-bottom: 1px var(--color-text-primary) solid;
}

.footer-a-3-2 a, .footer-menu a, .order-modal-private-policy-link {
    text-decoration: none;
    color: var(--color-text-primary);
}

.footer-a-1-1-2, .privacy-policy-context, .order-modal-footer-1, .order-modal-body-1, .order-modal-body-2,
.order-modal-body-success-label, .footer-a-3-1 {
    color: var(--color-text-light);
}

.footer-border {
    height: 1px;
    background-color: var(--color-border-primary);
}

.order-modal-footer .btn {
    width: 100% !important;
    --bs-btn-bg: var(--color-background-btn);
    --bs-btn-border-color: var(--color-background-btn);
}

.order-service-type {
    flex-wrap: wrap;
}

.order-modal-body-result-services, .order-modal-body-result-contacts, .order-modal-body-result-comment {
    font-style: italic;
    margin-top: 12px
}

/* Полная версия */

@media (min-width: 1840px) {
    html, body {
        min-width: 1850px;
    }

    .top-advantages-container-1 {
        height: 1020px;
        font-size: 92px;
        font-weight: 400;
    }

    .top-advantages-container-2 {
        margin: 114px 60px;
        font-size: 44px;
    }

    .page-header-line {
        margin: 60px 36px;
    }

    .top-advantages-container-1 > div {
        margin-left: 48px;
        margin-top: 52px;
    }

    .text-top-menu {
        font-size: 24px;
        column-gap: 32px;
    }

    .button-top-menu {
        width: 244px;
        height: 48px;
        border-radius: 12px;
        font-size: 24px;
        line-height: 32px;
    }

    .container-a-a {
        background-image: url('/public/image/image.png.webp');
        height: 732px;
        margin-top: 16px;
        background-size: cover;
        background-position: top center;
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - var(--cut-size)), calc(100% - var(--cut-size)) 100%, 0 100%);
    }

    .container-a-a .text {
        font-size: 40px;
        font-weight: 600;
        font-family: Montserrat, serif;
        margin: 52px 60px 0 52px;
    }

    .container-a-a .container-a-a-a {
        display: flex;
        gap: 16px;
        margin: 40px 60px;
        /*flex-wrap: wrap;*/
    }

    .container-a-a-a > div {
        height: 540px;
        min-width: 438px;
        justify-content: center;
        font-size: 32px;
    }

    .container-a-a-a > div > div {
        margin: auto 32px;
    }

    .container-a-a-a > div:hover .text-hover {
        margin: 78px 32px !important;
    }

    .container-a-a-a > div:hover {
        background-color: #141414;
        justify-content: unset;
        align-items: unset;
    }

    .container-a-a-a > div .text-hover .text-hover-hidden {
        font-size: 22px;
        margin-top: 28px;
    }

    .container-a-a-a > div .text-hover .text-hover-hidden > div {
        margin-bottom: 12px;
    }

    .container-a-a-a > div:hover .text-hover .text-hover-hidden {
        display: block;
    }

    .container-a-a-a > div:last-child {
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - var(--cut-size-child)), calc(100% - var(--cut-size-child)) 100%, 0 100%);
    }

    .grid-container-block {
        margin: 48px 40px;
        height: 204px;
    }

    .grid-title {
        font-size: 32px;
    }

    .grid-text {
        font-size: 24px;
    }

    .grid-opt {
        height: 300px;
    }

    .grid-1, .grid-2 {
        gap: 16px;
    }

    .grid-1-1 {
        background-position: top center;
    }

    .grid-1-2 {
        gap: 16px;
    }

    .grid-1-2-1 {
        gap: 16px;
    }

    .grid-2-1 {
        flex-direction: row;
        gap: 16px;
    }

    .grid-2-2-1 {
        gap: 16px;
    }

    .cut-size-grid {
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - var(--cut-size-grid)), calc(100% - var(--cut-size-grid)) 100%, 0 100%);
    }

    .grid-begin-title {
        margin: 60px 60px;
        font-size: 40px;
    }

    .bloke-line, .bloke-container {
        margin: 200px 0 80px 60px;
        font-family: Montserrat, sans-serif;
    }

    .bloke-line .bloke-line-1, .bloke-container .bloke-line-1 {
        color: var(--color-text-blue);
        font-size: 80px;
        font-weight: 500;
    }

    .bloke-line .bloke-line-2, .bloke-container .bloke-line-2 {
        font-size: 80px;
        font-weight: 400;
        color: var(--color-text-primary);
    }

    .bloke-line .bloke-line-3, .bloke-container .bloke-line-3 {
        font-size: 80px;
        font-weight: 400;
        /*color: var(--color-text-primary);*/
    }

    .bloke-line .bloke-line-3 span, .bloke-container .bloke-line-3 span {
        color: var(--color-text-blue);
    }

    .grid-program {
        gap: 16px;
        margin-bottom: 16px;
    }


    .grid-program-block {
        height: 520px;
    }

    .grid-vector-pro-description {
        font-size: 32px;
        margin-top: 20px;
    }

    .grid-vector-pro-context {
        font-size: 24px;
    }

    .grid-vector-pro-apparat-title {
        font-size: 32px;
    }

    .grid-vector-pro-apparat-context {
        font-size: 24px;;
    }

    .grid-flex {
        gap: 16px
    }

    .grid-program-block-margin {
        margin: 70px 80px;
        height: 380px;
    }

    .group-company {
        height: 300px;
    }

    .group-company-margin {
        margin: 60px 60px;

    }

    .group-company .group-company-title {
        font-size: 32px;
    }

    .group-company .group-company-description {
        font-size: 24px;
        margin-top: 32px;
    }

    .group-company:hover {
        background-color: var(--color-text-blue);
    }

    .group-company:hover::before, .hover0::before, .hover1::before, .hover2::before {
        content: "";
        height: 1090px;
        width: 1026px;
        background-repeat: no-repeat;
        position: absolute;
        right: 0;
    }

    .hover0, .hover1, .hover2 {
        background-color: var(--color-text-blue);
    }

    .group-company:hover.mockup::before, .hover0::before {
        background-image: url("/public/image/mockup.webp");
        margin-top: -150px;
    }

    .group-company:hover.mockup-1::before, .hover1::before {

        background-image: url("/public/image/mockup1.webp");
        margin-top: -455px;
    }

    .group-company:hover.mockup-2::before, .hover2::before {
        background-image: url("/public/image/mockup2.webp");
        margin-top: -770px;
    }

    .footer-opt {
        height: 623px;
    }

    .footer-a-1 {
        margin: 100px;
    }

    .footer-a-2 {
        margin: 0 100px;
    }

    .footer-a-3 {
        margin: 40px 100px 100px 100px;
        justify-content: space-between;
    }

    .footer-a-3-1 {
        font-size: 20px;
    }

    .footer-a-3-2 {
        justify-content: end;
        font-size: 24px;
    }

    .footer-a-1-1 {
        justify-content: space-between;
    }

    .footer-a-1-1-1 {
        gap: 32px;
        justify-content: end;
    }

    .footer-a-1-1-2 {
        font-size: 16px;
    }

    .footer-a-1-1-3 {
        font-size: 16px;
    }

    .footer-menu a {
        font-size: 24px;
    }

    .text-right {
        text-align: right;
    }

    .p-40 {
        padding: 40px;
    }

    .privacy-policy-title {
        font-size: 32px !important;
    }

    .privacy-policy-context {
        font-size: 24px;
    }

    .order-modal-poster {
        width: 484px;
        height: 914px;
        background-image: url("/public/image/poster.webp");
        background-repeat: no-repeat;
        background-size: cover;
        background-position: top center;
        border-radius: 12px;
    }

    .modal-xxl {
        --bs-modal-width: 1480px;
    }

    .order-modal-footer {
        justify-content: flex-start !important;
        border-top: unset !important;
        gap: 24px;
        margin-top: 40px;
    }

    .order-modal-footer-success {
        --bs-modal-footer-gap: 0;
        margin-bottom: 48px;
    }

    .order-modal-footer .btn {
        font-size: 24px;
        border-radius: 12px;
    }

    .order-modal-footer .btn:hover {
        --bs-btn-hover-bg: var(--color-text-primary);
        --bs-btn-hover-border-color: var(--color-text-primary);
    }

    .order-modal-footer-1 {
        font-size: 20px;
    }

    .order-service-type {
        gap: 12px;
    }

    .order-service-type .btn {
        padding: 8px 16px !important;
        height: 48px;
        border-radius: 12px;
        font-size: 20px;
    }

    .order-form-control {
        /*line-height: 48px !important;*/
        height: 48px !important;
        font-size: 20px !important;
        font-family: Inter, sans-serif;
        border-radius: 12px !important;
    }

    .order-form-control:focus {
        box-shadow: unset !important;
        border-color: var(--color-text-primary);
    }

    .order-modal-title {
        font-size: 32px;
    }

    .order-modal-margin {
        margin: 48px 48px 0 48px;
    }

    .order-modal-header {
        border-bottom: unset !important;
        --bs-modal-header-padding: 0 0;
    }

    .order-modal-body {
        --bs-modal-padding: 0;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        /*height: 765px;*/
        gap: 20px;
    }

    .order-modal-body-1 {
        margin-top: 20px;
        font-size: 24px;
    }

    .order-modal-body-2 {
        font-size: 24px;
    }

    .order-modal-body-3 {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 16px;
        font-size: 20px;
    }

    .order-modal-body-4 {
        display: grid;
        grid-template-columns: 1fr;
        gap: 16px;
        margin-top: 16px;
        font-size: 20px;
    }

    .modal-content-order-success-1 {
        margin: 48px 48px 0 48px;
    }

    .order-modal-body-result {
        border-radius: 12px;
        background-color: #ffffff;
        height: 100%;
        padding: 32px;
        margin-top: 16px;
        margin-bottom: 40px;
    }

    .order-modal-body-result-services, .order-modal-body-result-contacts, .order-modal-body-result-comment {
        font-size: 24px;
    }

    .order-modal-body-success-label {
        font-size: 20px;
    }

    .order-modal-body-success-line {
        height: 1px;
        background-color: #CCC;
        margin: 24px 0
    }

    .order-modal-body-success {
        --bs-modal-padding: 0;
        display: flex;
        flex-direction: column;
    }

    .modal-content-order-success {
        --bs-modal-bg: #EFEFEF;
    }
}

/* Планшет */

@media (min-width: 1355px) and (max-width: 1839px) {
    html, body {
        min-width: 1360px;
    }

    .logo-medium {
        width: 98px;
    }

    .top-advantages-container-1 {
        height: 900px;
        font-size: 72px;
        font-weight: 400;
    }

    .top-advantages-container-2 {
        margin: 88px 60px;
        font-size: 36px;
    }

    .page-header-line {
        margin: 52px 48px;
    }

    .top-advantages-container-1 > div {
        margin-left: 48px;
        margin-top: 52px;
    }

    .text-top-menu {
        font-size: 20px;
        column-gap: 32px;
    }

    .button-top-menu {
        padding: 8px 20px;
        border-radius: 12px;
        font-size: 20px;
    }

    .container-a-a {
        background-image: url('/public/image/image.png.webp');
        height: 652px;
        margin-top: 16px;
        background-size: cover;
        background-position: top center;
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - var(--cut-size)), calc(100% - var(--cut-size)) 100%, 0 100%);
    }

    .container-a-a .text {
        font-size: 32px;
        font-weight: 600;
        font-family: Montserrat, serif;
        margin: 52px 60px 0 52px;
    }

    .container-a-a .container-a-a-a {
        display: flex;
        gap: 16px;
        margin: 40px 60px;
        flex-wrap: wrap;
    }

    .container-a-a-a > div {
        height: 228px;
        min-width: 438px;
        justify-content: center;
        font-size: 20px;
    }

    .container-a-a-a > div > div {
        margin: auto 32px;
    }

    .container-a-a-a > div:hover .text-hover {
        margin: 28px 32px !important;
    }

    .container-a-a-a > div:hover {
        background-color: #141414;
        justify-content: space-between !important;
        /*justify-content: unset;
        align-items: unset;*/
    }

    .container-a-a-a > div .text-hover .text-hover-hidden {
        font-size: 16px;
        margin-top: 28px;
    }

    .container-a-a-a > div .text-hover .text-hover-hidden > div {
        margin-bottom: 12px;
    }

    .container-a-a-a > div:hover .text-hover .text-hover-hidden {
        display: block;
    }

    .container-a-a-a > div:last-child {
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - var(--cut-size-child)), calc(100% - var(--cut-size-child)) 100%, 0 100%);
    }

    .grid-container-block {
        margin: 48px 40px;
        height: 144px;
    }

    .grid-title {
        font-size: 20px;
    }

    .grid-text {
        font-size: 16px;
    }

    .grid-opt {
        height: 240px;
    }

    .grid-1, .grid-2 {
        gap: 16px;
    }

    .grid-1-1 {
        background-position: top center;
    }

    .grid-1-2 {
        gap: 16px;
    }

    .grid-1-2-1 {
        gap: 16px;
    }

    .grid-2-1 {
        flex-direction: row;
        gap: 16px;
    }

    .grid-2-2-1 {
        gap: 16px;
    }

    .cut-size-grid {
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - var(--cut-size-grid)), calc(100% - var(--cut-size-grid)) 100%, 0 100%);
    }

    .grid-begin-title {
        margin: 60px 60px;
        font-size: 32px;
    }

    .bloke-line {
        margin: 100px 0 40px 60px;
        font-family: Montserrat, sans-serif;
    }

    .bloke-container {
        margin: 80px 0 80px 60px;
        font-family: Montserrat, sans-serif;
    }

    .bloke-line .bloke-line-1 {
        color: var(--color-text-blue);
        font-size: 48px;
        font-weight: 500;
    }

    .bloke-line .bloke-line-2 {
        font-size: 48px;
        font-weight: 400;
        color: var(--color-text-primary);
    }


    .bloke-container .bloke-line-3 {
        font-size: 48px;
        font-weight: 400;
        /*color: var(--color-text-primary);*/
    }

    .bloke-container .bloke-line-3 span {
        color: var(--color-text-blue);
    }

    .grid-program {
        gap: 16px;
        margin-bottom: 16px;
    }

    .grid-program-block {
        height: 420px;
    }

    .grid-vector-pro-description {
        font-size: 20px;
        margin-top: 20px;
    }

    .grid-vector-pro-context {
        font-size: 16px;
    }

    .grid-vector-pro-apparat-title {
        font-size: 20px;
    }

    .grid-vector-pro-apparat-context {
        font-size: 16px;
    }

    .grid-vector-pro-apparat-top {
        /*margin-top: 60px;*/
    }

    .grid-vector-pro-apparat-bottom {
        /*margin-bottom: 25px;*/
    }

    .grid-flex {
        gap: 16px
    }

    .grid-program-block-margin {
        margin: 60px 80px;
        height: 320px;
    }

    .group-company {
        height: 180px;
    }

    .group-company-margin {
        margin: 60px 60px;
        flex-direction: column;
        justify-content: center;
        display: flex;
    }

    .group-company .group-company-title {
        font-size: 20px;
    }

    .group-company .group-company-description {
        font-size: 16px;
        margin-top: 32px;
    }

    .group-company:hover {
        background-color: var(--color-text-blue);
    }

    .group-company:hover::before, .hover0::before, .hover1::before, .hover2::before {
        content: "";
        height: 670px;
        width: 630px;
        background-repeat: no-repeat;
        background-size: cover;
        background-position: top center;
        position: absolute;
        right: 0;
    }

    .hover0, .hover1, .hover2 {
        background-color: var(--color-text-blue);
    }

    .group-company:hover.mockup::before, .hover0::before {
        background-image: url("/public/image/mockup.webp");
        margin-top: -90px;
    }

    .group-company:hover.mockup-1::before, .hover1::before {

        background-image: url("/public/image/mockup1.webp");
        margin-top: -285px;
    }

    .group-company:hover.mockup-2::before, .hover2::before {
        background-image: url("/public/image/mockup2.webp");
        margin-top: -465px;
    }

    .footer-opt {
        height: 462px;
    }

    .footer-a-1 {
        margin: 60px;
    }

    .footer-a-2 {
        margin: 0 60px;
    }

    .footer-a-3 {
        margin: 40px 100px 100px 100px;
        justify-content: space-between;
    }

    .footer-a-3-1 {
        font-size: 16px;
    }

    .footer-a-3-2 {
        justify-content: end;
        font-size: 20px;
    }

    .footer-a-1-1 {
        justify-content: space-between;
    }

    .footer-a-1-1-1 {
        gap: 32px;
        justify-content: end;
    }

    .footer-a-1-1-2 {
        font-size: 14px;
    }

    .footer-a-1-1-3 {
        font-size: 16px;
    }

    .footer-logo {
        height: 150px;
    }

    .footer-menu a {
        font-size: 20px;
    }

    .text-right {
        text-align: right;
    }

    .p-40 {
        padding: 40px;
    }

    .privacy-policy-title {
        font-size: 24px !important;
    }

    .modal-xl {
        --bs-modal-width: 1000px !important;
    }

    .modal-content {
        --bs-modal-border-radius: 20px !important;
    }

    .privacy-policy-context {
        font-size: 20px;
    }

    .order-modal-poster {
        width: 380px;
        height: 706px;
        background-image: url("/public/image/poster.webp");
        background-repeat: no-repeat;
        background-size: cover;
        background-position: top center;
        border-radius: 20px;
    }

    .modal-xxl {
        --bs-modal-width: 1100px;
    }

    .modal-footer {
        margin-top: 24px;
        padding: 0 !important;
    }

    .order-modal-footer {
        justify-content: flex-start !important;
        border-top: unset !important;
        gap: 20px;
    }

    .order-modal-footer-success {
        --bs-modal-footer-gap: 0;
        margin-top: 12px !important;
        margin-bottom: 48px;
    }

    .order-modal-footer .btn {
        font-size: 18px;
        border-radius: 10px;
    }

    .order-modal-footer .btn:hover {
        --bs-btn-hover-bg: var(--color-text-primary);
        --bs-btn-hover-border-color: var(--color-text-primary);
    }

    .order-modal-footer-1 {
        font-size: 16px;
    }

    .order-service-type {
        gap: 12px;
    }

    .order-service-type .btn {
        padding: 6px 12px !important;
        border-radius: 10px;
        font-size: 16px;
    }

    .order-form-control {
        /*line-height: 48px !important;*/
        height: 40px !important;
        font-size: 16px !important;
        font-family: Inter, sans-serif;
        border-radius: 10px !important;
    }

    .order-form-control:focus {
        box-shadow: unset !important;
        border-color: var(--color-text-primary);
    }

    .order-modal-title {
        font-size: 24px;
    }

    .order-modal-margin {
        margin: 40px 32px 0 32px;
    }

    .order-modal-header {
        border-bottom: unset !important;
        --bs-modal-header-padding: 0 0;
    }

    .order-modal-body {
        --bs-modal-padding: 0;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        /*height: calc(100% - 60px);*/
        gap: 8px;
    }

    .order-modal-body-1 {
        margin-top: 20px;
        font-size: 18px;
    }

    .order-modal-body-2 {
        font-size: 18px;
    }

    .order-modal-body-3 {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 16px;
        font-size: 16px;
    }

    .order-modal-body-4 {
        display: grid;
        grid-template-columns: 1fr;
        gap: 16px;
        margin-top: 16px;
        font-size: 16px;
    }

    .modal-content-order-success-1 {
        margin: 32px 32px 0 32px;
    }

    .order-modal-body-result {
        border-radius: 12px;
        background-color: #ffffff;
        height: 100%;
        padding: 32px;
        margin-top: 16px;
        margin-bottom: 0;
    }

    .order-modal-body-result-services, .order-modal-body-result-contacts, .order-modal-body-result-comment {
        font-size: 18px;
    }

    .order-modal-body-success-label {
        font-size: 16px;
    }

    .order-modal-body-success-line {
        height: 1px;
        background-color: #CCC;
        margin: 12px 0
    }

    .order-modal-body-success {
        --bs-modal-padding: 0;
        display: flex;
        flex-direction: column;
    }

    .modal-content-order-success {
        --bs-modal-bg: #EFEFEF;
    }
}

/* Мобилка 415 */
@media (min-width: 414px) and (max-width: 1354px) {
    :root {
        --cut-size: 64px;
        --cut-size-child: 60px;
        --cut-size-grid: 40px;
    }

    html, body {
        min-width: 415px;
    }

    .logo-medium {
        height: 32px;
    }

    .logo-small {
        height: 32px;
    }

    .top-advantages-container-1 {
        height: 323px;
        font-size: 24px;
        font-weight: 400;
    }

    .top-advantages-container-1 > div {
        height: 96px;
    }

    .top-advantages-container-2 {
        margin: 18px 16px;
        font-size: 14px;
    }

    .page-header-line {
        margin: 17px 16px;
    }

    .top-advantages-container-1 > div {
        margin-left: 16px;
        margin-top: 16px;
    }

    .text-top-menu {
        display: none;
    }

    .dropdown-top-menu {
        display: block;
    }

    .dropdown-top-group {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 16px;
    }

    .button-top-menu {
        padding: 6px 12px;
        border-radius: 8px;
        font-size: 15px;
    }

    .container-a-a {
        background-image: url('/public/image/image.png.webp');
        /*height: 652px;*/
        margin-top: 16px;
        background-size: cover;
        background-position: top center;
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - var(--cut-size)), calc(100% - var(--cut-size)) 100%, 0 100%);
    }

    .container-a-a .text {
        font-size: 16px;
        font-weight: 600;
        font-family: Montserrat, serif;
        margin: 16px 16px 24px 16px;
    }

    .container-a-a .container-a-a-a {
        display: flex;
        gap: 8px;
        margin: 16px 16px;
        flex-wrap: wrap;
    }

    .container-a-a-a > div {
        height: 100px;
        min-width: 383px;
        font-size: 15px;
    }

    .container-a-a-a > div > div {
        margin: 0 16px;
    }

    .container-a-a-a > div:hover {
        height: 200px;
    }

    .container-a-a-a .text-hover {
        display: flex;
        flex-direction: column;
        align-content: space-between;
    }

    .container-a-a-a .text-hover .text-hover-title {
        margin-left: 28px;
    }

    .container-a-a-a .text-hover .text-hover-title::before {
        content: "";
        background-image: url("/public/image/chevronUpSm.svg");
        background-repeat: no-repeat;
        width: 28px;
        height: 28px;
        position: absolute;
        margin-left: -28px;
        margin-top: -5px;
    }

    .container-a-a-a > div:hover .text-hover .text-hover-title::before {
        transform: rotate(180deg);
        margin-top: -3px;
    }

    .container-a-a-a > div:hover .text-hover {
        /*margin: 24px 24px !important;*/
    }

    .container-a-a-a > div:hover {
        background-color: #141414;
        justify-content: space-between !important;
        /*justify-content: unset;
        align-items: unset;*/
    }

    .container-a-a-a > div .text-hover .text-hover-hidden {
        font-size: 13px;
        margin-top: 28px;
    }

    .container-a-a-a > div .text-hover .text-hover-hidden > div {
        /*margin-bottom: 12px;*/
    }

    .container-a-a-a > div:hover .text-hover .text-hover-hidden {
        display: block;
    }

    .container-a-a-a > div:last-child {
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - var(--cut-size-child)), calc(100% - var(--cut-size-child)) 100%, 0 100%);
    }

    .grid-container-block {
        margin: 12px 12px;
        gap: 20px;
    }

    .grid-container {
        gap: 6px;
    }

    .grid-title {
        font-size: 15px;
    }

    .grid-text {
        font-size: 13px;
    }

    .grid-1, .grid-2 {
        gap: 6px;
        flex-direction: column;
    }

    .grid-1-1 {
        background-position: 0 -77px;
        height: 112px;
        flex: unset;
    }

    .grid-1-2 {
        gap: 6px;
    }

    .grid-1-2-1 {
        flex-direction: row;
        gap: 6px;
    }

    .grid-2-1 {
        flex-direction: column;
        gap: 6px;
    }

    .grid-2-2-1 {
        gap: 6px;
    }

    .cut-size-grid {
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - var(--cut-size-grid)), calc(100% - var(--cut-size-grid)) 100%, 0 100%);
    }

    .grid-begin-title {
        margin: 16px 16px;
        font-size: 16px;
    }

    .bloke-line {
        margin: 40px 16px 20px 16px;
        font-family: Montserrat, sans-serif;
    }

    .bloke-container {
        /*margin: 80px 0 80px 60px;*/
        font-family: Montserrat, sans-serif;
    }

    .bloke-line .bloke-line-1 {
        color: var(--color-text-blue);
        font-size: 20px;
        font-weight: 500;
    }

    .bloke-line .bloke-line-2 {
        font-size: 20px;
        font-weight: 400;
        color: var(--color-text-primary);
    }


    .bloke-container .bloke-line-3 {
        font-size: 20px;
        font-weight: 400;
        margin: 36px 16px;
        /*color: var(--color-text-primary);*/
    }

    .bloke-container .bloke-line-3 span {
        color: var(--color-text-blue);
    }

    .grid-program {
        gap: 6px;
        margin-bottom: 16px;
    }

    .grid-program-background {
        height: 226px;
        flex: unset !important;
    }

    .grid-apparat-background {
        height: 226px;
    }

    .grid-program-block {
        /*height: 420px;*/
    }

    .grid-vector-pro-description {
        font-size: 15px;
        margin-top: 20px;
    }

    .grid-vector-pro-context {
        font-size: 13px;
    }

    .grid-vector-pro-apparat-title {
        font-size: 15px;
    }

    .grid-vector-pro-apparat-context {
        font-size: 13px;
    }

    .grid-flex {
        gap: 6px;
        flex-direction: column-reverse;
    }

    .grid-program-block-margin {
        margin: 16px;
        gap: 6px;
    }

    .drop-flex-column-reverse {
        flex-direction: column !important;
    }

    .drop-fl-1 {
        flex: unset !important;
    }

    .group-company {
        height: 160px;
    }

    .group-company-margin {
        margin: 0 16px;
        flex-direction: column;
        justify-content: center;
        display: flex;
        gap: 12px;
    }

    .group-company .group-company-title {
        font-size: 15px;
    }

    .group-company .group-company-description {
        font-size: 13px;
    }

    .group-company:hover {
        background-color: var(--color-text-blue);
    }

    .group-company:hover::before, .hover0::before, .hover1::before, .hover2::before {
        display: none;
    }

    .hover0, .hover1, .hover2 {
        background-color: var(--color-text-blue);
    }

    .footer-a-1 {
        margin: 40px 16px;
        flex-direction: column;
        gap: 40px;
    }

    .footer-a-2 {
        margin: 0 16px;
    }

    .footer-a-3 {
        margin: 20px 16px;
        flex-direction: column;
        gap: 28px;
    }

    .footer-a-3-1 {
        font-size: 16px;
    }

    .footer-a-3-2 {
        justify-content: end;
        font-size: 16px;
    }

    .footer-a-1-1 {
        gap: 28px;
    }

    .footer-a-1-1-1 {
        gap: 32px;
        /*justify-content: end;*/
        flex-direction: column;
    }

    .footer-a-1-1-2 {
        font-size: 14px;
    }

    .footer-a-1-1-3 {
        font-size: 13px;
    }

    .footer-logo {
        height: 80px;
    }

    .footer-menu a {
        font-size: 16px;
    }

    .text-right {
        /*text-align: right;*/
    }

    .p-40 {
        padding: 20px 16px;
    }

    .privacy-policy-title {
        font-size: 15px !important;
    }

    .modal-xl {
        /*--bs-modal-width: 250px !important;*/
    }

    .modal-content {
        --bs-modal-border-radius: 20px !important;
    }

    .privacy-policy-context {
        font-size: 13px;
    }

    .privacy-policy-context p {
        margin-bottom: 3px;
    }

    .order-modal-poster {
        display: none;
    }

    .top-menu-modal-content {
        --bs-modal-bg: var(--color-background-accent-special-primary);
    }

    .top-menu-modal-header {
        --bs-modal-header-padding: 15px 16px;
    }

    .top-menu-body-modal {
        display: flex;
        flex-direction: column;
        gap: 24px;
        align-content: center;
    }

    .top-menu-body-modal > div {
        height: 48px;
        font-size: 16px;
        font-family: Inter, sans-serif;
        font-weight: 400;
        border-bottom: 1px #ccc solid;
    }

    .top-menu-body-modal > div a {
        color: var(--color-text-inverse);
        text-decoration: unset !important;
    }

    .top-menu-body-modal > div.top-menu-modal-line {
        display: flex;
        justify-content: space-between;
    }

    .top-menu-modal-element-center {
        display: flex;
        align-items: center;
    }

    .top-button-body-modal {
        margin-top: 28px;
    }

    .modal-xxl {
        /*--bs-modal-width: 250px;*/
    }

    .modal-header-sm {
        border-bottom: unset !important;
        padding: 0 0 16px 0 !important;
        align-items: start !important;
    }

    .modal-header .btn-close {
        height: 10px;
        width: 10px;
        background-size: 10px 10px;
    }

    .modal-footer {
        margin-top: 24px;
        padding: 0 !important;
        flex-wrap: unset !important;
    }

    .order-modal-footer {
        justify-content: flex-start !important;
        border-top: unset !important;
        gap: 16px;
        flex-direction: column;
    }

    .order-modal-footer > div {
        width: 100%;
    }

    .order-modal-footer-success {
        --bs-modal-footer-gap: 0;
        margin-top: 12px !important;
        /*margin-bottom: 48px;*/
    }

    .order-modal-footer .btn {
        font-size: 15px;
        border-radius: 8px;
    }

    .order-modal-footer .btn:hover {
        --bs-btn-hover-bg: var(--color-text-primary);
        --bs-btn-hover-border-color: var(--color-text-primary);
    }

    .modal-dialog-scrollable .modal-body {
        overflow-y: scroll !important;
    }

    .order-modal-footer-1 {
        font-size: 14px;
        text-align: center;
    }

    .order-service-type {
        gap: 8px;
    }

    .order-service-type .btn {
        padding: 4px 8px !important;
        border-radius: 8px;
        font-size: 14px;
    }

    .order-form-control {
        /*line-height: 48px !important;*/
        height: 36px !important;
        font-size: 14px !important;
        font-family: Inter, sans-serif;
        border-radius: 10px !important;
    }

    .order-form-control:focus {
        box-shadow: unset !important;
        border-color: var(--color-text-primary);
    }

    .order-modal-title {
        font-size: 15px;
    }

    .order-modal-margin {
        margin: 20px 16px;
    }

    .order-modal-header {
        border-bottom: unset !important;
        --bs-modal-header-padding: 0 0;
    }

    .order-modal-body {
        --bs-modal-padding: 0;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        /*height: calc(100vh - 100px);*/
        gap: 8px;
        overflow-y: auto;
    }

    .order-modal-body-1 {
        margin-top: 20px;
        font-size: 13px;
    }

    .order-modal-body-2 {
        font-size: 13px;
    }

    .order-modal-body-3 {
        display: grid;
        grid-template-columns: 1fr;
        gap: 8px;
        font-size: 13px;
    }

    .order-modal-body-4 {
        display: grid;
        grid-template-columns: 1fr;
        gap: 8px;
        margin-top: 16px;
        font-size: 13px;
    }

    .modal-content-order-success-1 {
        margin: 20px 16px;
    }

    .order-modal-body-result {
        border-radius: 12px;
        background-color: #ffffff;
        height: 100%;
        padding: 12px;
        margin-top: 16px;
        margin-bottom: 0;
    }

    .order-modal-body-result-services, .order-modal-body-result-contacts, .order-modal-body-result-comment {
        font-size: 13px;
    }

    .order-modal-body-success-label {
        font-size: 14px;
    }

    .order-modal-body-success-line {
        height: 1px;
        background-color: #CCC;
        margin: 12px 0
    }

    .order-modal-body-success {
        --bs-modal-padding: 0;
        display: flex;
        flex-direction: column;
    }

    .modal-content-order-success {
        --bs-modal-bg: #EFEFEF;
    }
}

/* Мобилка 360 */
@media (max-width: 413px) {
    :root {
        --cut-size: 64px;
        --cut-size-child: 52px;
        --cut-size-grid: 40px;
    }

    html, body {
        min-width: 360px;
    }

    .logo-medium {
        height: 32px;
    }

    .logo-small {
        height: 32px;
    }

    .top-advantages-container-1 {
        height: 270px;
        font-size: 20px;
        font-weight: 400;
    }

    .top-advantages-container-1 > div {
        height: 96px;
    }

    .top-advantages-container-2 {
        margin: 18px 16px;
        font-size: 14px;
    }

    .page-header-line {
        margin: 17px 16px;
    }

    .top-advantages-container-1 > div {
        margin-left: 16px;
        margin-top: 16px;
    }

    .text-top-menu {
        display: none;
    }

    .dropdown-top-menu {
        display: block;
    }

    .dropdown-top-group {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 16px;
    }

    .button-top-menu {
        padding: 6px 12px;
        border-radius: 8px;
        font-size: 14px;
    }

    .container-a-a {
        background-image: url('/public/image/image.png.webp');
        /*height: 652px;*/
        margin-top: 8px;
        background-size: cover;
        background-position: top center;
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - var(--cut-size)), calc(100% - var(--cut-size)) 100%, 0 100%);
    }

    .container-a-a .text {
        font-size: 14px;
        font-weight: 600;
        font-family: Montserrat, serif;
        margin: 16px 16px 8px 16px;
    }

    .container-a-a .container-a-a-a {
        display: flex;
        gap: 8px;
        margin: 16px 16px;
        flex-wrap: wrap;
    }

    .container-a-a-a > div {
        height: 100px;
        min-width: 328px;
        font-size: 14px;
    }

    .container-a-a-a > div > div {
        margin: 0 16px;
    }

    .container-a-a-a > div:hover {
        height: 200px;
    }

    .container-a-a-a > div:hover:nth-last-child(1),
    .container-a-a-a > div:hover:nth-last-child(2),
    .container-a-a-a > div:hover:nth-last-child(3)
    {
        height: 250px !important;
    }

    .container-a-a-a .text-hover {
        display: flex;
        flex-direction: column;
        align-content: space-between;
    }

    .container-a-a-a .text-hover .text-hover-title {
        margin-left: 28px;
    }

    .container-a-a-a .text-hover .text-hover-title::before {
        content: "";
        background-image: url("/public/image/chevronUpSm.svg");
        background-repeat: no-repeat;
        width: 28px;
        height: 28px;
        position: absolute;
        margin-left: -28px;
        margin-top: -5px;
    }

    .container-a-a-a > div:hover .text-hover .text-hover-title::before {
        transform: rotate(180deg);
        margin-top: -3px;
    }

    .container-a-a-a > div:hover .text-hover {
        /*margin: 24px 24px !important;*/
    }

    .container-a-a-a > div:hover {
        background-color: #141414;
        justify-content: space-between !important;
        /*justify-content: unset;
        align-items: unset;*/
    }

    .container-a-a-a > div .text-hover .text-hover-hidden {
        font-size: 13px;
        margin-top: 28px;
    }

    .container-a-a-a > div .text-hover .text-hover-hidden > div {
        /*margin-bottom: 12px;*/
    }

    .container-a-a-a > div:hover .text-hover .text-hover-hidden {
        display: block;
    }

    .container-a-a-a > div:last-child {
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - var(--cut-size-child)), calc(100% - var(--cut-size-child)) 100%, 0 100%);
    }

    .grid-container-block {
        margin: 12px 12px;
        gap: 20px;
    }

    .grid-title {
        font-size: 14px;
    }

    .grid-text {
        font-size: 12px;
    }

    .grid-1, .grid-2 {
        gap: 6px;
        flex-direction: column;
    }

    .grid-1-1 {
        background-position: 0 -25px;
        height: 112px;
        flex: unset;
    }

    .grid-1-2 {
        gap: 6px;
    }

    .grid-1-2-1 {
        flex-direction: row;
        gap: 6px;
    }

    .grid-2-1 {
        flex-direction: column;
        gap: 6px;
    }

    .grid-2-2-1 {
        gap: 6px;
    }

    .cut-size-grid {
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - var(--cut-size-grid)), calc(100% - var(--cut-size-grid)) 100%, 0 100%);
    }

    .grid-begin-title {
        margin: 16px 16px;
        font-size: 16px;
    }

    .bloke-line {
        margin: 40px 16px 20px 16px;
        font-family: Montserrat, sans-serif;
    }

    .bloke-container {
        /*margin: 80px 0 80px 60px;*/
        font-family: Montserrat, sans-serif;
    }

    .bloke-line .bloke-line-1 {
        color: var(--color-text-blue);
        font-size: 20px;
        font-weight: 500;
    }

    .bloke-line .bloke-line-2 {
        font-size: 20px;
        font-weight: 400;
        color: var(--color-text-primary);
    }


    .bloke-container .bloke-line-3 {
        font-size: 20px;
        font-weight: 400;
        margin: 36px 16px;
        /*color: var(--color-text-primary);*/
    }

    .bloke-container .bloke-line-3 span {
        color: var(--color-text-blue);
    }

    .grid-program {
        gap: 8px;
        margin-bottom: 12px;
    }

    .grid-program-background {
        height: 226px;
        flex: unset !important;
    }

    .grid-apparat-background {
        height: 226px;
    }

    .grid-program-block {
        /*height: 420px;*/
    }

    .grid-vector-pro-description {
        font-size: 14px;
        margin-top: 20px;
    }

    .grid-vector-pro-context {
        font-size: 12px;
    }

    .grid-vector-pro-apparat-title {
        font-size: 14px;
    }

    .grid-vector-pro-apparat-context {
        font-size: 12px;
    }

    .grid-flex {
        gap: 8px;
        flex-direction: column-reverse;
    }

    .grid-container {
        gap: 6px;
    }

    .grid-program-block-margin {
        margin: 16px;
        gap: 20px;
    }

    .drop-flex-column-reverse {
        flex-direction: column !important;
    }

    .drop-fl-1 {
        flex: unset !important;
    }

    .group-company {
        height: 160px;
    }

    .group-company-margin {
        margin: 0 16px;
        flex-direction: column;
        justify-content: center;
        display: flex;
        gap: 12px;
    }

    .group-company .group-company-title {
        font-size: 14px;
    }

    .group-company .group-company-description {
        font-size: 16px;
    }

    .group-company:hover {
        background-color: var(--color-text-blue);
    }

    .group-company:hover::before, .hover0::before, .hover1::before, .hover2::before {
        display: none;
    }

    .hover0, .hover1, .hover2 {
        background-color: var(--color-text-blue);
    }

    .footer-opt {
        color: var(--color-text-primary);
    }

    .footer-a-1 {
        margin: 40px 16px;
        flex-direction: column;
        gap: 40px;
    }

    .footer-a-2 {
        margin: 0 16px;
    }

    .footer-a-3 {
        margin: 16px 16px 40px 16px;
        flex-direction: column;
        gap: 28px;
    }

    .footer-a-3-1 {
        font-size: 15px;
    }

    .footer-a-3-2 {
        justify-content: end;
        font-size: 15px;
    }

    .footer-a-1-1 {
        gap: 28px;
    }

    .footer-a-1-1-1 {
        gap: 32px;
        flex-direction: column;
    }

    .footer-a-1-1-2 {
        font-size: 13px;
    }

    .footer-a-1-1-3 {
        font-size: 12px;
    }

    .footer-logo {
        height: 70px;
    }

    .footer-menu a {
        font-size: 15px;
    }

    .text-right {
        /*text-align: right;*/
    }

    .p-40 {
        padding: 16px 16px;
    }

    .privacy-policy-title {
        font-size: 14px !important;
    }

    .modal-xl {
        /*--bs-modal-width: 250px !important;*/
    }

    .modal-header-sm {
        border-bottom: unset !important;
        padding: 0 0 16px 0 !important;
        align-items: start !important;
    }

    .modal-header .btn-close {
        height: 10px;
        width: 10px;
        background-size: 10px 10px;
    }

    .modal-content {
        --bs-modal-border-radius: 20px !important;
    }

    .privacy-policy-context {
        font-size: 12px;
        --bs-modal-padding: 0;
    }

    .privacy-policy-context p {
        margin-bottom: 3px;
    }

    .order-modal-poster {
        display: none;
    }

    .top-menu-modal-content {
        --bs-modal-bg: var(--color-background-accent-special-primary);
    }

    .top-menu-modal-header {
        --bs-modal-header-padding: 15px 16px;
    }

    .top-menu-body-modal {
        display: flex;
        flex-direction: column;
        gap: 24px;
        align-content: center;
    }

    .top-menu-body-modal > div {
        height: 48px;
        font-size: 16px;
        font-family: Inter, sans-serif;
        font-weight: 400;
        border-bottom: 1px #ccc solid;
    }

    .top-menu-body-modal > div a {
        color: var(--color-text-inverse);
        text-decoration: unset !important;
    }

    .top-menu-body-modal > div.top-menu-modal-line {
        display: flex;
        justify-content: space-between;
    }

    .top-menu-modal-element-center {
        display: flex;
        align-items: center;
    }

    .top-button-body-modal {
        margin-top: 28px;
    }

    .modal-xxl {
        /*--bs-modal-width: 250px;*/
    }

    .modal-footer {
        margin-top: 24px;
        padding: 0 !important;
        flex-wrap: unset !important;
    }

    .order-modal-footer {
        justify-content: flex-start !important;
        border-top: unset !important;
        gap: 16px;
        flex-direction: column;
    }

    .order-modal-footer > div {
        width: 100%;
    }

    .order-modal-footer-success {
        --bs-modal-footer-gap: 0;
        margin-top: 16px !important;
    }

    .order-modal-footer .btn {
        font-size: 14px;
        border-radius: 8px;
    }

    .order-modal-footer .btn:hover {
        --bs-btn-hover-bg: var(--color-text-primary);
        --bs-btn-hover-border-color: var(--color-text-primary);
    }

    .modal-dialog-scrollable .modal-body {
        overflow-y: scroll !important;
    }

    .order-modal-footer-1 {
        font-size: 13px;
        text-align: center;
    }

    .order-service-type {
        gap: 8px;
    }

    .modal-content {
        --bs-modal-border-radius: 12px;
    }

    .order-service-type .btn {
        padding: 4px 8px !important;
        border-radius: 8px;
        font-size: 12px;
    }

    .order-form-control {
        /*line-height: 48px !important;*/
        height: 36px !important;
        font-size: 12px !important;
        font-family: Inter, sans-serif;
        border-radius: 10px !important;
    }

    .order-form-control:focus {
        box-shadow: unset !important;
        border-color: var(--color-text-primary);
    }

    .order-modal-title {
        font-size: 14px;
    }

    .order-modal-margin {
        margin: 20px 16px;
    }

    .order-modal-header {
        border-bottom: unset !important;
        --bs-modal-header-padding: 0 0;
    }

    .order-modal-body {
        --bs-modal-padding: 0;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        /*height: calc(100vh - 100px);*/
        gap: 6px;
        overflow-y: auto;
    }

    .order-modal-body-1 {
        margin-top: 0;
        font-size: 12px;
    }

    .order-modal-body-2 {
        font-size: 12px;
    }

    .order-modal-body-3 {
        display: grid;
        grid-template-columns: 1fr;
        gap: 6px;
        font-size: 13px;
    }

    .order-modal-body-4 {
        display: grid;
        grid-template-columns: 1fr;
        gap: 16px;
        margin-top: 16px;
        font-size: 13px;
    }

    .modal-content-order-success-1 {
        margin: 20px 16px;
    }

    .order-modal-body-result {
        border-radius: 12px;
        background-color: #ffffff;
        height: 100%;
        padding: 12px;
        margin-top: 16px;
        margin-bottom: 0;
    }

    .order-modal-body-result-services, .order-modal-body-result-contacts, .order-modal-body-result-comment {
        font-size: 13px;
    }

    .order-modal-body-success-label {
        font-size: 12px;
    }

    .order-modal-body-success-line {
        height: 1px;
        background-color: #CCC;
        margin: 12px 0
    }

    .order-modal-body-success {
        --bs-modal-padding: 0;
        display: flex;
        flex-direction: column;
    }

    .modal-content-order-success {
        --bs-modal-bg: #EFEFEF;
    }
}