* {
    padding: 0;
    margin: 0;
    box-sizing: border-box;
    font-family: 'Poppins', sans-serif;
    text-decoration: none;
    list-style: none;
}

a {
    text-decoration: none;
    color: rgb(34, 34, 34) !important;
}

html {
    scroll-behavior: smooth;
}

#why {
    scroll-margin-top: 120px;
}

#services {
    scroll-margin-top: 50px;
}

#form {
    scroll-margin-top: 60px;
}

#form a {
    color: rgb(230, 230, 230) !important;
}

.container {
    /* max-width: 1850px;

    padding: 0 50px; */
}



header {
    position: fixed;
    width: 100%;
    background-color: white;
    border-bottom: 1px solid #E5E5E5;
    z-index: 999;
    /* padding: 0 50px; */
}

.container {
    max-width: 1350px;
    margin: 0 auto;
}

.header_row_1 {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;

    border-bottom: 1px solid #E5E5E5;
    background-color: #2c4168;
    background-color: #01195c;
    background-color: #1e1e1e;
    font-weight: 300;


    padding: 2px 50px 2px 50px;


}

.row_1_flex {
    display: flex;
    gap: 30px;
    align-items: center;
}

.time {
    font-weight: 300;
    font-size: 13px;
    line-height: 24px;
    color: #ffffff !important;
    display: flex;
    align-items: center;
    gap: 6px;
    position: relative;
    top: 2px;
}

.header_row_contacts {
    display: flex;
    column-gap: 20px;
    position: relative;
    top: -2px
}

.header_row_contacts_item {
    font-weight: 500;
    font-size: 13px;
    line-height: 24px;
    color: #ffffff !important;
    display: flex;
    align-items: center;
    gap: 6px;
    position: relative;
    top: 2px;
}

.header_row_contacts_item img {
    width: 13px;
}

.header_socials {
    display: flex;
    column-gap: 20px;
    position: relative;
    top: 1px;
}

.header_socials_item img {
    width: 15px;
}

.header_row_2 {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 2px 50px;
}

.header_logo {
    font-weight: 300;
    text-align: center;
    color: #000000;
    color: #e58900;
    color: #FF6B01;
}

.header_logo p {
    font-size: 12px;
    font-weight: 400;
    color: #000000;
}

.header_logo span {
    position: relative;
    top: -4px;
    left: -4px;
}

.header_logo img {
    width: 145px;

}

.header_menu nav {
    display: flex;
    gap: 25px;
}

.header_menu nav a {
    font-size: 15px;
    font-weight: 400;
    text-transform: uppercase;
}

.header_btn {
    font-weight: 300;
    font-size: 14px;
    line-height: 24px;
    color: #000000;
    padding: 4px 34px;


    background-color: #2c487c;
    background-color: #2a406c;
    background-color: #e7a900;
    background-color: #FF6B01;
    background-color: #f9bf00;
    color: white;
}




.main_content {
    position: relative;
    height: 90vh;
    width: 100%;
    overflow: hidden;
    display: flex;

    align-items: center;
    position: relative;


}

.main_content video {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    width: 100%;
    height: 100vh;
    object-fit: cover;
    filter: brightness(0.5);
}

.main_content_text {


    color: white;
    width: 790px;
    padding: 40px 30px;
    margin-left: 50px;
    font-size: 42px;
    font-weight: 600;
    line-height: 50px;
    z-index: 99;

}

.main_content_low_text {
    margin-top: 20px;
    font-size: 20px;
    line-height: 28px;

    /* color: #a4000b; */
}

.main_content_low_text span {
    color: #e48c00;
    color: #e48c00;
    font-weight: 800;
    font-size: 24px;
}

.main_content_low_text li {
    color: rgb(237, 237, 237);
}

.title_row {
    padding: 80px 0 20px 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-weight: 300;
    font-size: 20px;
    border-bottom: 1px solid #a0a0a0;
}

.services h2 {
    font-size: 16px;
    color: #1e1e1e;
    font-weight: 300;
    padding-top: 4px;
    font-size: 22px;
}

.services hr {
    height: 1px;
    background-color: rgb(215, 215, 215);
    text-align: center;
    width: 15%;

}

.container {
    padding: 0 50px;
    max-width: 1450px;
    margin: 0 auto;
}

@media (max-width: 1600px) {
    .container {
        padding-left: 100px;
        padding-right: 100px;
    }
}

/* services start */

.services_row {
    display: flex;
    gap: 20px;
    justify-content: space-between;
    margin-top: 50px;
    align-items: center;
}

.services_item {
    display: block;
    width: 33%;
    position: relative;
    background-color: #fff;

}

@media (min-width:1024px) {
    .services_item:hover img {
        transform: scale(1.1);

    }
}

.services_item__img {
    overflow: hidden;
    height: 300px;
}

.services_item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: all 0.7s;
}


/* animation */
.services_item.item-1 {
    z-index: 3;
}

.services_item.item-2 {
    transform: translateX(-100%);
    z-index: 2;
    opacity: 0;
    transition: opacity 0.2s, transform 0.6s;
}

.services_item.item-3 {
    transform: translateX(-100%);
    z-index: 1;
    opacity: 0;
    transition: opacity 0.2s, transform 0.6s;
}

.services_item.el-show {
    transform: translateX(0);
    opacity: 1;
}

/* services end */


.section-form {
    position: relative;
    /* background-color: rgba(0, 0, 0, 0.102); */
    padding: 30px 0;
    overflow: hidden;
}

.section-form__bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 0;
    background-image: url('../img/bb.jpg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

@media (min-width: 1025px) {
    .parallax {
        background-attachment: fixed;
    }
}

@media (min-width: 1024px) {
    .parallax {
        background-attachment: fixed;
    }
}

.section-form__container {
    position: relative;
    display: flex;
    justify-content: center;
}



.el-anim-left.el-show,
.el-anim-right.el-show {
    opacity: 1;
    transform: translate(0);
    transition-duration: .5s;
}

.section-form__content {
    width: 100%;
    max-width: 500px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding-right: 60px;
    color: white;
}

.el-anim-left.el-show,
.el-anim-right.el-show {
    opacity: 1;
    transform: translate(0);
    transition-duration: .5s;
}


.form {
    width: 100%;
    max-width: 500px;
    position: relative;
    padding-left: 60px;
    border-left: 1px solid rgba(255, 255, 255, 0.548);
}

.el-anim-right {
    opacity: 0;
    transform: translate(20%);
    transition-duration: transform .5s;
}

.section-form__title {
    margin-bottom: 30px;
}

.h1 {
    font-size: 42px;
    font-weight: 400;
    line-height: 1.3;
}

.section-form__office {
    display: flex;
    flex-direction: column;
    gap: 20px;
    color: #ffffffc2;
}

.section-form__office-item {
    display: flex;
    align-items: center;
    gap: 10px;
}

.section-form__office-icon {
    width: 30px;
    height: 30px;
    fill: #ffffffc2;
    stroke: #ffffffc2;
}

svg {
    width: 100%;
    height: 100%;
}

.section-form__bg:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #000000c7;
}

.form__box input {
    background-color: transparent;
    padding: 14px 10px;
    font-size: 22px;
    font-weight: 300;
    border-bottom: 1px solid rgba(255, 255, 255, 0.548);
    width: 100%;
    color: white;
}

.form__error {
    position: absolute;
    top: calc(100% + 3px);
    color: #ff2f2f;
    display: none;
}

.choose-social__title {
    font-size: 18px;
    margin-bottom: 10px;
    color: rgba(255, 255, 255, 0.548);
}

.form__box {
    margin-bottom: 30px;
    position: relative;
}

.choose-social__item {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
}

.choose-social__item span {
    color: rgb(214, 214, 214);
}

.choose-social__item input:checked+.check-box {
    background-color: #e7a900;

}

.choose-social__item .check-box {
    width: 20px;
    height: 20px;
    border: 1px solid rgba(255, 255, 255, 0.548);
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.choose-social__items {
    border: 1px solid rgba(255, 255, 255, 0.548);
    border-radius: 20px;
    padding: 10px 20px;
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.form__submit {
    width: 100%;
}

.btn-white {
    background-color: transparent;
    border: 1px solid white;
    color: white;
}

.btn,
.btn-white {
    display: block;
    padding: 10px 40px;

    font-weight: 300;
    font-size: 16px;
    min-width: 120px;
    transition: all .2s;
}


:root {
    --orange: #f9bf00;
    --dark: #121212;
    --white: #fff;
    --font: 'Inter', sans-serif;

}


.container {
    max-width: 1200px;
    margin: 60px auto;
    padding: 0 20px;
}

/* grid start */

.grid {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 40px;
    align-items: center;
}

.image-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto auto;
    gap: 10px;
}

.image-item {
    position: relative;
    overflow: hidden;
    height: 210px;
}

.image-item p {
    position: absolute;
    top: 33%;
    left: 0;
    right: 0;

    color: #fff;
    font-weight: 600;
    text-align: center;
    padding: 20px;
    font-size: 18px;
}

.a-big {
    top: 21% !important;
}

.image-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 2px;
}

.image-item.large {
    grid-column: 1 / 2;
    grid-row: 1 / 2;
}

.orange-box {
    background: var(--orange);
    padding: 30px 20px;
    color: var(--white);
    display: flex;
    flex-direction: column;
    justify-content: center;
    border-radius: 2px;
}

.orange-box h2 {
    font-size: 1.4rem;
    margin-bottom: 10px;
    font-weight: 700;
}

.orange-box p {
    font-size: 0.95rem;
    opacity: 0.9;
    color: #323232;
}

/* animations */

.image-item-1 {
    position: relative;
    z-index: 4;
}

.image-item-2 {
    transform: translateX(-100%);
    opacity: 0;
    transition: opacity 0.2s, transform 1s;
}

.image-item-3 {
    transform: translateY(-100%);
    opacity: 0;
    transition: opacity 0.2s, transform 1s;
}

.image-item-4 {
    transform: translateX(-100%) translateY(-100%);
    opacity: 0;
    transition: opacity 0.2s, transform 1s;
}


.image-item-2.el-show,
.image-item-3.el-show,
.image-item-4.el-show {
    transform: translateX(0) translateY(0);
    opacity: 1;
}

/* grid end */


/* Right section */
.welcome-box {
    position: relative;
    background: var(--white);

    color: var(--dark);
    padding: 50px 40px;
    border-radius: 2px;
    background-color: #181818;
    color: white;
}

.welcome-box::before {
    content: '';
    position: absolute;
    top: -15px;
    right: -15px;
    width: 100%;
    height: 100%;
    background: var(--orange);
    z-index: -1;
    border-radius: 2px;
}

.welcome-content h1 {
    color: var(--orange);
    font-size: 2rem;
    margin-bottom: 20px;

}

.welcome-content p {
    margin-bottom: 15px;
    font-size: 0.95rem;
}

.a_big {
    color: rgb(216, 216, 216);
}

.credit {
    font-size: 0.85rem;
}

.credit a {
    color: var(--orange);
    text-decoration: none;
}

.btn {
    margin-top: 20px;
    background: var(--orange);
    color: var(--white);
    padding: 12px 24px;
    border: none;
    font-weight: 600;
    border-radius: 2px;
    cursor: pointer;
    transition: background 0.3s;
}

.btn:hover {
    background: #c84f1c;
}

/* Responsive */
@media (max-width: 900px) {
    .grid {
        grid-template-columns: 1fr;
    }

    .welcome-box {
        margin-top: 30px;
    }
}


.h2 {
    text-align: center;
    font-size: 40px;
    font-weight: 300;
    padding-bottom: 40px;
}



.footer {
    padding-top: 30px;
    padding-bottom: 30px;
    background-color: rgb(18, 18, 18);
    color: white;
}

.footer__social img {
    width: 20px;

}

.ml {
    display: flex;
    align-items: center;
    gap: 5px
}

.footer_flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 5px;
}

.footer__time {
    padding-top: 30px;
    color: rgb(211, 211, 211);
    font-size: 14px;
    color: #e7a900 !important;
}

.footer__time p {
    color: rgb(211, 211, 211);
    margin-bottom: 6px;
    font-size: 16px;

}

.footer_contacts {
    display: flex !important;
    align-items: center;
    gap: 25px;
}

.footer_contacts a {
    display: block;
    margin: 6px 0;
}

.footer_contacts img {
    width: 20px;
    margin-right: 6px;
    display: block;
}

.footer a {
    color: rgb(211, 211, 211) !important
}

.footer p {
    color: rgb(211, 211, 211);
}

.footer__top {
    display: flex;
    align-items: center;
    gap: 20px;
    justify-content: space-between;
    flex-wrap: wrap;
    padding-bottom: 40px;
    border-bottom: 1px solid white;
    margin-bottom: 40px;
}

.footer__bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.footer__left {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.footer__social {

    display: flex;
}

.footer__social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    margin-left: 10px;
    fill: white;
}

.footer__nav {
    display: flex;
    gap: 40px;
    font-size: 20px;
    align-items: center;
}

.footer__nav li button {
    background: none;
    border: none;
    color: white;
    cursor: pointer;
    background-color: #e7a900;
    padding: 8px 20px;
}

.footer__logo {
    display: flex;
    align-items: center;

    gap: 10px;
}

.footer__logo img {
    width: 120px;
}







/* услуга */
.hero {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 20px;
    margin-top: 100px;
}

.text-content {
    flex: 1;
    padding-right: 20px;
}

.text-content p {
    color: #666;

    width: 90%;
}

.hero h1 {
    font-size: 48px;
    font-weight: 700;
    color: #333;
    margin-bottom: 20px;
}

p,
li {
    font-size: 18px;
    color: #666;
}

.image-content {
    flex: 1;
    position: relative;
}

.image-content:before {
    width: 174px;
    height: 174px;
    border-top: 15px solid #f9bf00;

    border-left: 15px solid #f9bf00;
    content: "";
    position: absolute;
    top: -15px;
    left: -15px;
}

.image-content::after {
    width: 174px;
    height: 174px;
    border-bottom: 15px solid #f9bf00;

    border-right: 15px solid #f9bf00;
    content: "";
    position: absolute;
    bottom: -10px;
    right: -15px;
}



.image-content img {
    max-width: 100%;
    height: auto;
}

.service_btn {
    background-color: #f9bf00;
    background-color: #000000;
    color: white !important;
    color: white;
    padding: 10px 30px;
    margin-top: 30px;
    display: block;
    width: 300px;
    text-align: center;
}

.services_advantages_wrap {
    display: flex;
    gap: 50px;
    align-items: center;
    justify-content: space-around;
}

.services_advantages_text {
    width: 60%;
}

.services_advantages_text p {
    padding-bottom: 20px;
    text-indent: 15px;
}

.services_advantages_text ul {

    padding: 10px 20px 30px 20px;

}

.services_advantages_text li {
    list-style: disc;
    padding-bottom: 8px;
    font-size: 16px;
}

.services_advantages_text h2 {
    border-bottom: 1px solid rgb(157, 157, 157);
    padding-bottom: 10px;
    width: 95%;
    margin-bottom: 20px;
    font-size: 35px;
    margin-top: 40px;
    color: #333;
}

.services_advantages_flex {
    position: sticky;
    height: 100%;
    top: 220px;

}

.services_advantages_number {
    font-size: 25px;
    font-weight: bold;
    background-color: black;
    width: 60px;
    height: 60px;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
}

.services_advantages_item {
    display: flex;
    gap: 20px;
    margin-bottom: 20px;
    align-items: center;
}

/* Общий контейнер для портфолио */
.portfolio {
    display: grid;
    /* Используем Grid Layout */
    grid-template-columns: repeat(3, 1fr);
    /* Создаем 3 колонки одинаковой ширины (1fr - 1 fraction) */
    grid-template-rows: repeat(2, auto);
    /* Адаптивная сетка: минимум 300px, максимум 1fr */
    gap: 20px;

}

.portfolio_h2 {
    padding-top: 20px;
    border-bottom: 1px solid rgb(157, 157, 157);
    padding-bottom: 10px;
    width: 95%;
    margin-bottom: 20px;
    font-size: 35px;
    margin-top: 40px;
    color: #333;
}

/* Элемент портфолио (изображение и текст) */
.portfolio_item {
    display: flex;

    flex-direction: column;

    border: 1px solid #ddd;

    padding-bottom: 10px;

    text-align: center;



}

/* Стиль для изображений */
.portfolio_item img {
    width: 100%;
    height: auto;
    margin-bottom: 10px;
    display: block;
    height: 200px;
    object-fit: contain;

}


.portfolio_item p {
    font-size: 14px;
    /* Размер шрифта */
    color: #333;
    /* Цвет текста */
}

/* конец услуги */

.portfolio-wrap h1 {
    text-align: center;
    font-size: 42px;
    font-weight: 600;
    color: #2d2d2d;
}



.portfolio_grid {
    display: grid;
    /* Включаем grid layout */
    grid-template-columns: repeat(3, 1fr);
    /* Создаем 3 колонки одинаковой ширины (1fr - 1 fraction) */
    grid-template-rows: repeat(2, auto);
    /*  Создаем 2 строки, высота определяется автоматически (auto) */
    grid-gap: 10px;
    /*  Отступ между элементами сетки 10 пикселей */
    width: 100%;
    /*  Занимаем всю доступную ширину родительского контейнера */

    margin: 0 auto;
    /*  Центрируем сетку по горизонтали */
}

/*
  Стили для отдельных элементов сетки.
*/
.grid_item {
    position: relative;
    display: block;
    width: 100%;
    /*  Ширина элемента сетки равна ширине родительского элемента (grid_item) */
    height: 100%;
    /*  Высота элемента сетки равна высоте родительского элемента (grid_item) */
}

.grid_item p {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 10px;
    background-color: rgba(0, 0, 0, 0.7);
    color: #fff;
    font-size: 14px;
    text-align: center;
}

/*
  Стили для изображений внутри элементов сетки.
  Регулируем размеры изображений, чтобы они хорошо вписывались в ячейки сетки.
*/
.grid_item img {
    width: 100%;
    /*  Ширина изображения равна ширине родительского элемента (grid_item) */
    height: 200px;
    /*  Высота изображения масштабируется автоматически, сохраняя пропорции */
    display: block;
    /* Убирает лишние отступы под изображением, которые могут возникать. */
    object-fit: cover;
    /* Заполняет контейнер, обрезая, если нужно */
    /* aspect-ratio: 1 / 1; Сохраняет пропорции 1:1 во избежание искажений */
}

/* Адаптивность (медиа-запрос для экранов меньшего размера) */
@media (max-width: 768px) {
    .portfolio_grid {
        grid-template-columns: repeat(2, 1fr);
        /* Переключаемся на две колонки */
    }
}


.low_about {
    width: 500px;
    font-size: 14px;
    margin: 0 auto;
    margin-top: 20px;
    margin-bottom: 20px;
}

.port_btn {
    width: 300px;
    margin-top: 60px;
    background-color: #121212 !important;
}

/* link-arrow start */
.link-arrow {
    display: flex;
    align-items: center;
    gap: 10px;

}

.link-arrow img {
    width: 30px;
    transition: all 0.2s;
    object-fit: contain;
}

@media (min-width:1024px) {
    .link-arrow:hover img {
        transform: translateX(6px);
    }
}

/* link-arrow end */


/* partners start */
.partners {
    padding: 60px 0;
}

.partners h2 {
    margin-top: 0;
    margin-bottom: 20px;
}

.partners-el {
    height: 100px;
}

.partners-el img {
    width: 300px;
    height: 100%;
    object-fit: contain;
}

.marquee {
    position: relative;
    display: flex;
    align-items: flex-end;
    z-index: 5;
    overflow: hidden;
}

.marquee__wrap {
    position: relative;
    display: flex;
    gap: 0;
    z-index: 5;
    text-transform: uppercase;
    flex-wrap: nowrap;
    padding: 12px 0;
}

.marquee__wrap-group {
    flex: none;
    white-space: nowrap;
    display: inline-flex;
    gap: 80px;
    animation: line 120s 0s linear infinite;
    padding-left: 80px;
}


@keyframes line {
    0% {
        transform: translate3d(0, 0, 0);
    }

    100% {
        transform: translate3d(-100%, 0, 0);
    }
}




.mobile_none {
    display: block
}

/* partners end */
.mobile_header {
    display: none;
}

nav {
    display: none;
}

.reviews {
    background-color: #e4e4e4;
    padding: 30px 0 30px 0;
    position: relative;
    width: 90%;
    margin: 1px auto;
}

.reviews:before {
    position: absolute;
    content: "";
    width: 174px;
    height: 174px;
    border-top: 20px solid #e7a900;
    border-left: 20px solid #e7a900;
    top: -20px;
    left: -20px;
}

.reviews:after {
    position: absolute;
    content: "";
    width: 174px;
    height: 174px;
    border-bottom: 20px solid #e7a900;
    border-right: 20px solid #e7a900;
    bottom: -20px;
    right: -20px;
}

.reviews h2 {
    text-align: center;
    font-size: 40px;
    font-weight: 300;
    padding-bottom: 40px;
}

.swiper {
    width: 100%;
    height: 300px;
    margin: 0;
    /* Убираем внешние отступы */
    padding: 0;
    /* Убираем внутренние отступы */
}

.swiper-wrapper {
    width: 100%;
    height: 100%;
    display: flex;
    /* Убедитесь, что это flex контейнер */
    margin: 0;
    padding: 0;
}

.swiper-slide {
    text-align: center;
    font-size: 18px;
    background: none !important;

    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    width: auto;
    /* Важно!  Позволяет Swiper'у управлять шириной */
    margin: 0;
    padding: 0;

    margin: 0 10px;
}

.swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;

}

/* Общие стили для слайдера (как в предыдущем примере) */
.swiper {
    width: 90%;
    height: 340px;
}

.swiper-slide {
    text-align: center;
    font-size: 18px;
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    /* Добавляем курсор для кликабельности */
}

.swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Для Chrome, Safari и Edge */
.swiper::-webkit-scrollbar {
    width: 0;
    /* Задайте 0 для ширины как по горизонтали, так и по вертикали */
    height: 0;
}

/* Для Firefox */
.swiper {
    scrollbar-width: none;
    /* Скрывает полосу прокрутки */
}

/* Для IE и Edge (если требуется) */
.swiper {
    -ms-overflow-style: none;
    /* Устаревшее, но может потребоваться для старых версий IE */
}

.swiper {
    overflow: auto;
    /* Разрешаем прокрутку контента */
}


.about_title {
    color: rgb(18, 18, 18);
    padding-top: 90px;
    text-align: center;
    font-size: 160px;
}

.about_text {
    padding: 10px 50px 30px 50px;
    background-color: white;
}

.about_text p {
    padding-bottom: 10px;
    color: rgb(59, 59, 59);
    font-size: 20px;
}

.dr_flex {
    display: flex;
    align-items: center;
    gap: 5px;
    margin-bottom: 4px;
}

.dr_flex a {
    margin-bottom: 5px !important;
    padding: 0 !important;
}

.dr_time {
    display: block;
    color: black;
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    margin-bottom: 10px;
    font-weight: 600;
    text-align: center;
    font-size: 13px;
    font-weight: 300;
    text-align: start;
}

@media (max-width: 920px) {
    .mobile_header_logo {
        padding-right: 4px;
        border-right: 1px solid #c1c1c1;
    }

    .mobile_header_logo img {
        width: 60px;


    }

    .desctop_header {
        display: none;
    }

    .mobile_header {
        background-color: #f0f0f0;
        padding: 10px;
        display: flex;
        justify-content: space-between;
        /* Размещает элементы по краям */
        align-items: center;
    }



    .logo {
        font-size: 20px;
    }

    /* Скрываем навигацию по умолчанию */

    /* Стили для мобильной версии */
    #mobile_menu {
        padding: 50px 20px;
    }

    #mobile_menu a {
        display: block;
        color: black;
        font-size: 14px;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 4px;
        margin-bottom: 10px;
        padding: 6px 10px;
        font-weight: 600;
        text-align: center;

    }

    #mobile_menu ul {
        display: flex;
        flex-direction: column;
        gap: 5px;

        justify-content: center;
    }

    .contacts_logo {
        text-align: center;
    }

    .contacts_logo p {
        font-size: 13px;
    }

    .contacts_logo img {
        width: 100px;
        margin-bottom: 6px;

    }

    .contacts_logo p {
        margin-bottom: 10px;
    }

    .contacts_grid {}

    .contacts_box {
        padding: 10px 20px;
        margin-top: 30px;
        border: 1px solid rgb(207, 207, 207);
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
    }

    .contacts_mobile {
        display: flex;
        flex-direction: column;
        justify-content: start;
        align-items: start;
    }

    .contacts_mobile a {
        padding: 1px !important;
    }

    .contacts_mobile img {
        width: 20px;
        margin-right: 4px;
    }

    nav {
        display: block;
        position: fixed;
        top: 0;
        right: 0;
        width: 250px;
        height: 100vh;
        background-color: white;
        padding: 20px;
        box-shadow: -2px 0 5px rgba(0, 0, 0, 0.2);
        transform: translateX(100%);
        /* Скрываем меню за правым краем */
        transition: transform 0.3s ease-in-out;
    }

    nav.open {
        transform: translateX(0);
        /* Показываем меню */
    }


    .menu-button {
        cursor: pointer;
        font-size: 30px;
    }

    .mobile_header_contacts {
        display: flex;
        gap: 20px;
        justify-content: space-between;
        align-items: center;
    }

    .mobile_header_contacts a {
        display: block;
        color: black;
        font-size: 13px;
        display: flex;
        align-items: center;
        font-weight: 400;
        gap: 6px;
    }

    .mobile_none {
        display: none;
    }

    .mobile_header_btn {
        background-color: #211d6f;
        color: white;
        padding: 8px 20px;
        font-size: 12px;
    }

    .mobile_header_contacts a:last-child {
        margin-top: 4px;
    }

    .mobile_header_contacts img {
        width: 20px;


    }

    .close-button {
        cursor: pointer;
        font-size: 24px;
        position: absolute;
        top: 10px;
        right: 10px;
    }

    .main_content {
        height: 65vh !important;
    }

    .main_content_text {
        padding: 40px 20px 40px 20px !important;
        margin-left: 0px;
        font-size: 28px;
        line-height: normal;
        margin-top: 5vh;
    }

    .services_row {
        flex-direction: column;
    }

    .services_item {
        width: auto
    }

    .services_item.item-2 {
        transform: translateX(-100%);
        transform: none;
        ;
        z-index: 2;
        opacity: 0;
        transition: none;
    }

    .services_item.item-3 {
        transform: translateX(-100%);
        transform: none;
        ;
        z-index: 2;
        opacity: 0;
        transition: none;
    }

    .services_item.el-show {
        transform: translateX(0);
        opacity: 1;
    }

    .image-item,
    .orange-box {
        min-height: 280px;
        width: 46vw !important;
    }

    .image-item__text {
        font-size: 15px;
    }

    .orange-box h2 {
        font-size: 18px;
    }

    .image-item p {
        font-size: 17px;
    }

    .marquee__wrap-group {
        gap: 30px;
    }

    .partners-el img {
        width: 100px;
    }

    .section-form__container {
        flex-direction: column !important;
        gap: 20px;
    }

    .form {
        border-left: none !important;
        padding-left: 0px !important;
        padding-top: 40px;
    }

    .footer__right {
        display: none;
    }

    .hero {
        display: block;
        padding: 0;
        margin: 0;

    }

    .pt-100 {
        padding-top: 1010px !important;
    }

    .container {
        padding: 0 20px;
        margin: 0;

    }

    .text-content {
        padding-right: 0;
        padding-top: 90px !important;
    }

    .services_advantages_wrap {
        flex-direction: column;
        gap: 20px;
        padding: 0
    }

    .text-content h1 {
        font-size: 33px;
    }

    .service_btn {
        margin-bottom: 50px;
    }

    .services_advantages_text {
        width: 100%;
        margin-bottom: 30px;
    }

    .portfolio_h2 {
        padding: 10px 0 20px 0;
    }

    .content {
        padding: 50px 1px !important;

    }

    .container {
        gap: 0px !important;
        padding: 10px !important;
    }

    .content h1 {
        padding-top: 80px;
        padding-bottom: 50px;
    }

    .wrp {
        padding: 0 14px;
    }

    .left-card {
        gap: 0px !important;
        flex-direction: column-reverse !important;

    }

    .contact-row {
        flex-direction: column;
        gap: 20px !important;
    }

    .sidebar {
        flex-direction: row !important;
        width: auto !important;
        padding: 20px 0 !important;
    }

    .contact-info {
        gap: 20px !important;
    }

    .portfolio-wrap h1 {
        padding-top: 140px !important;
    }

    .low_about {
        width: 100% !important;
    }

    .reviews {
        margin-bottom: 100px;
        margin-top: 20px;
        padding: 20px 0 !important;

    }

    .section-form {
        margin-bottom: 60px !important;
        padding-bottom: 40px !important;
    }

    .about {}

    .about_title {
        background-color: #181818;
        padding: 140px 0 40px 0;
        margin-bottom: 50px;
    }

    .about_title h1 {
        font-size: 90px;
        padding-bottom: 40px;
        font-weight: 800;
        color: white;
    }

    .about_text p {
        padding: 0 20px 20px 20px;
    }

    .port_btn {
        margin-bottom: 80px;
    }

    .section-form {
        padding: 40px 20px !important;
    }

    .swiper {

        height: 440px !important;
    }

    .choose-social__item span {
        font-size: 11px !important;
    }

    .footer__social {

        gap: 4px;
    }

    .footer__bottom {
        flex-direction: column-reverse !important;
        gap: 20px !important;
        text-align: center !important
    }

}

@media (max-width: 380px) {
    .main_content {
        height: 80vh !important;
    }

    .title_row {
        padding: 60px 0 20px 0;
    }

    .mobile_header_logo img {
        width: 50px;
    }

    .mobile_header_logo {
        border-right: none;
    }

    .mobile_header_contacts {
        gap: 10px;
    }

    .mobile_header_contacts img {
        width: 15px;
    }

}
