/*!
Theme Name: Redline agency Theme
Author: Redline agency Theme
Version: 1.0.0
*/
 
@font-face {
  font-display: swap; 
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  src: url('fonts/montserrat-v30-cyrillic_latin-regular.woff2') format('woff2'); 
} 
@font-face {
  font-display: swap; 
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  src: url('fonts/montserrat-v30-cyrillic_latin-500.woff2') format('woff2'); 
} 
@font-face {
  font-display: swap; 
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  src: url('fonts/montserrat-v30-cyrillic_latin-600.woff2') format('woff2'); 
} 
@font-face {
  font-display: swap; 
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  src: url('fonts/montserrat-v30-cyrillic_latin-700.woff2') format('woff2'); 
} 
@font-face {
  font-display: swap; 
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  src: url('fonts/montserrat-v30-cyrillic_latin-800.woff2') format('woff2'); 
} 
@font-face {
  font-display: swap; 
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  src: url('fonts/montserrat-v30-cyrillic_latin-900.woff2') format('woff2'); 
}


@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Mulish';
  font-style: normal;
  font-weight: 900;
  src: url('fonts/mulish-v17-cyrillic_latin-900.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

:root {
    --main-color:#E20716;
    --main-color-hover:#DD610D;  
    --padding-bt:50px;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    outline: none;
}

a {
    text-decoration: none;
    color: inherit;
}

iframe {
    border: 0;
}

img {
    max-width: 100%;
    height: auto;
	display: block;
}

ul, li {
    list-style: none;
}

button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
}

.container {
    max-width: 1360px;
    margin-right: auto;
    margin-left: auto;
    width: 100%;
    position: relative;
}

.breadcrumbs .container>nav {
    display: flex;
    gap: 20px;
    color: rgba(0, 0, 0, .3);
}

.breadcrumbs a  {
    color: #000;
    transition: all .3s;
    white-space: nowrap;
}

.breadcrumbs a:hover { 
    color: var(--main-color); 
}

.breadcrumbs {
    margin-bottom: 50px;
}
.page-template-service-1 .last, 
.page-template-service-2 .last{
	color:rgba(255, 255, 255, .5);
}

p {
    margin-bottom: 30px;
}

h1 {
    font-weight: 600;
    font-size: 48px;
    margin-bottom: 30px;   
}
h1 strong {
    font-weight: 600;
    color: var(--main-color);  
}
 

h2 { 
    font-weight: 600;
    font-size: 48px;
    margin-bottom: 30px; 
}
h3 { 
    font-weight: 600;
    font-size: 38px;
    margin-bottom: 30px; 
}
 
.btn { 
    align-items: center;
    justify-content: center;
    color: #FEFAFF;
    background: var(--main-color);
    border-radius: 100px;
    height: 51px; 
    font-size: 18px;
    display: inline-flex;
    padding:  0 40px;  
    cursor: pointer;
    font-weight: 600;
    transition: all .3s;
    border: 0;
    gap: 10px;
    font-family: 'Montserrat', sans-serif; 
}

.btn:hover {
    background: var(--main-color-hover); 
}
 

*::-webkit-scrollbar {
    -webkit-appearance: none;
    cursor: default;
}

*::-webkit-scrollbar:vertical {
    width: 4px;
    cursor: default;
}

*::-webkit-scrollbar:horizontal {
    height: 4px;
    cursor: default;
}

*::-webkit-scrollbar-thumb {
    background-color: var(--main-color);
    -moz-border-radius: 6px;
    -webkit-border-radius: 6px;
    -khtml-border-radius: 6px;
    border-radius: 6px;
    cursor: default;
}

*::-webkit-scrollbar-track {
    -moz-border-radius: 6px;
    -webkit-border-radius: 6px;
    -khtml-border-radius: 6px;
    border-radius: 6px;
    background-color: #EFEFEF;
    cursor: default;
}

.contact-gal  .swiper-pagination {
    position: absolute;
    padding-top: 0;
    margin: 0;
    bottom: 20px !important;
    top: auto;
}
.swiper-pagination {
    position: relative;
    padding-top: 50px;
    margin: 0;
    bottom: auto;
    top: auto;
}

.contact-gal .swiper-pagination-bullet {
    width: 10px;
    height: 10px; 
    background: #fff;
    opacity: .4;
}
.swiper-pagination-bullet {
    width: 10px;
    height: 10px; 
    background: #E20716;
    opacity: .4;
}

.contact-gal .swiper-pagination-bullet.swiper-pagination-bullet-active {
    opacity: 1;
}

.swiper-pagination-bullet-active { 
    opacity: 1;
}

.slide-nav .swiper-button-prev, .slide-nav .swiper-button-next {
    left: auto;
    position: relative;
    margin-top: 0;
    top: auto;
    right: auto;
    user-select: none;
}

.swiper-button-next, .swiper-button-prev {
    width: 30px;
    min-width: 30px;
    height: 30px;  
    user-select: none; 
}
 

.swiper-button-next:after, .swiper-button-prev:after {
    content: none;
}

.slide-nav {
    display: flex;
    column-gap: 10px;
}

.title-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 48px;
    gap: 40px;
}

.title-row h2 {
    margin: 0;
}
 

html {
    scroll-behavior: smooth;
    scroll-padding-top: 100px;
}

body {
    font-family: 'Montserrat', sans-serif;
    font-size: 18px;
    line-height: 1.3;    
    font-weight: 400;
    color: #000;
    overflow-x: hidden;  
    padding-top: 160px;
}


body.home, .page-template-about {
    padding-top: 0;
}

/* header */

 

header {
    padding: 20px 0;
    border-bottom: 1px solid rgba(0, 0, 0, .1); 
    position: absolute;
    width: 100%;
    margin: 0px auto 0;
    top: 0;
    z-index: 2;
    transition: all .3s;
}

header.fixed {
    position: fixed;
    z-index: 99;
    top: 0;
    background: #fff;
    width: 100%;
    padding: 16px;
    box-shadow: 0 4px 20px rgba(53, 44, 52, 0.08);
    animation-name: nav;
    animation-duration: 1s;
    margin: 0;
}

.header__logo {
    max-width: 178px;
}
.logo-black {
    display: none;
}

header.fixed .logo-black {
    display: block;
}

header.fixed .logo-white {
    display: none;
}

.header-box {
    min-height: 135px;
}

@keyframes nav {
    0% {
        top: -100%
    }

    100% {
        top: 0
    }
}


.header-top span {
    height: 1px; 
    flex: 1;
    background: rgb(0 0 0 / 10%);
}

.home .header-top span, .page-template-about .header-top span { 
    background: rgba(255, 255, 255, .1);
}

/* .page-template-about header {
    border-bottom: 0;
} */

.header-top {
    padding: 0 0 10px;
    display: flex;
    align-items: center;
    gap: 30px;
}

.header__phone, .header__email {
    display: flex;
    gap: 10px;
    align-items: center;
}
.page-template-about .header__phone, .page-template-about .header__email,
.home .header__phone, .home .header__email { 
    color: #fff;
}
.page-template-about header.fixed .header__phone, .page-template-about header.fixed .header__email,
.home header.fixed .header__phone, .home header.fixed .header__email { 
    color: #000;
}

.header-container {
    display: flex;
    align-items: center;
    gap: 50px;
}

.header__nav {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 15px;
}

.header__nav a { 
    text-transform: uppercase;
}

.home .header__nav a, .page-template-about .header__nav a { 
    color: #fff;
}
.home header.fixed .header__nav a, .page-template-about header.fixed .header__nav a { 
    color: #000;
}

.header__burger {
    display: none;
}

.header__mess { 
    display: flex;
    align-items: center;
    gap: 10px;
}

.header__mess a {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #F4F4F4;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    transition: all .3s;
}
.mobile-menu {
    position: fixed;
    top: 76px;
    left: -450px;
    height: calc(100vh - 76px);
    bottom: 0;
    width: 100vw;
    background: #fff;
    z-index: 1000;
    overflow: hidden;
    max-width: 450px;
    box-shadow: 2px 0 8px rgba(0, 0, 0, 0.12);
    transition: all .3s;
    display: flex;
    flex-direction: column;
    border-top: 2px solid var(--main-color);
    padding: 25px;
}
.mobile__nav {
    display: flex;
    flex-direction: column;
    row-gap: 20px;
}
.mobile__nav a{
    text-transform: uppercase;
}
body.burger-active .mobile-menu {
    left: -0px;
}
.header__nav>li>.sub-menu {
    position: absolute;
    left: 0;
    top: 100%;
    width: 270px;
    height: auto;
    z-index: -10;
    opacity: 0;
    -webkit-transform: translateY(35px);
    transform: translateY(35px);
    pointer-events: none;
    transition: all .2s ease;
    display: flex;
    background: #FFFFFF;
    row-gap: 15px;
    flex-direction: column;
    box-shadow: 0px 5px 10px rgb(0 0 0 / 20%);
    border-radius: 10px;
    padding: 15px;
}
.header__nav>li>.sub-menu a {
    color: #000;
    font-size: 14px;
}
.header__nav>li>.sub-menu a:hover {
    color: var(--main-color);
}
.header__nav>li a:hover ~ .sub-menu, .header__nav>li>.sub-menu:hover {
    z-index: 100;
    opacity: 1;
    -webkit-transform: translateY(-1px);
    transform: translateY(-1px);
    pointer-events: auto;
}
.header__nav>li {
    position: relative;
}
/* client */

.client {
    background: #F4F4F4;
    padding: 50px 0;
    margin-bottom: 80px;
    overflow: hidden;
}

.client-slide2 {
    overflow: visible;
    padding-top: 25px;
}

.client-slide { 
    overflow: visible;
}

.client-item {
    width: 324px;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    backface-visibility: hidden;
    perspective: 1000px;
    will-change: transform;
    user-select: none;
}


.client-item img {
    border-radius: 20px;
}

.client-slide .swiper-wrapper,
.client-slide2 .swiper-wrapper,
.awards-slide .swiper-wrapper {
    -webkit-transition-timing-function: linear !important;
    transition-timing-function: linear !important;
    backface-visibility: hidden;
    transform-style: preserve-3d;
}
/* about */

 /* .page-template-about header {
    position: absolute;
    width: 100%;
    margin: 0px auto 0;
    top: 0;
    z-index: 2;
} */

.case-smi {
    background: #F4F4F4;
    border-radius: 20px;
    padding: 40px;
    margin-bottom: 60px;
}
.case-smi h2 { 
    font-weight: 500;
    font-size: 20px; 
}

.case-smi-nav .swiper-button-next, .case-smi-nav .swiper-button-prev   {
    width: 68px;
    min-width: 68px;
    height: 68px;
    background: var(--main-color);
    border-radius: 50%;
}

.case-smi-item {
    display: flex;
    height: auto;
}


.case-archive {
    padding-bottom: 50px;
}

.case {
    margin-bottom: var(--padding-bt);
    overflow: hidden;
}
.case h2 {
    margin-bottom: 10px;
}

.case h2 + p {
    margin-bottom: 50px;
    font-size: 20px;
}

.case-box .swiper-button-prev {
    left: -80px;
    width: 62px;
    min-width: 62px;
    height: 100px;
}

.case-box .swiper-button-next {
    right: -80px;
    width: 62px;
    min-width: 62px;
    height: 100px;
}

.case-box-bottom .swiper-pagination { 
    padding-top: 0; 
    width: auto;
}

.case-box-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 30px;
}

.case-gal-item {
    height: 580px;
    border-radius: 20px;
    position: relative;
    overflow: hidden;
}

.case-gal-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.case-gal-slide .swiper-button-next, .case-gal-slide .swiper-button-prev { 
    min-width: 54px;  
    background: #fff;
    width: 54px;
    height: 54px;
    border-radius: 50%;
}

.case-gal-pagination {
    padding-top: 0;
    transform: translateY(-125px);
}
.case-gal-pagination .swiper-pagination-bullet { 
    background: #fff; 
}

.case-page-box {
    background: #fff;
    border-radius: 20px;
    padding: 30px 40px;
    max-width: 1200px;
    margin: -80px auto 50px;
    position: relative;
    z-index: 1;
    border: 1px solid #EDEDED;
}

.case-page-top {
    display: flex;
    justify-content: space-between;
    margin-bottom: 30px;
}

.result-list {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    margin-bottom: 20px;
    gap: 20px;
}

.result-item {
    padding: 30px;
    border-radius: 20px;
    color: #fff;
    background: url(img/res1.jpg) no-repeat;
    background-size: cover;
    font-size: 20px;
    font-weight: 500;
}
.result-item-desc span {
    display: block;
    font-size: 48px;
    font-weight: 700;
}
.result-item:nth-child(2) { 
    background: url(img/res2.jpg) no-repeat; 
    background-size: cover;
}
.result-item:nth-child(3) { 
    background: url(img/res3.jpg) no-repeat; 
    background-size: cover;
}
.case-page-box h1 { 
    margin-bottom: 50px;
}
.case-client-title {
    font-weight: 500;
    color: var(--main-color);
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 30px;
}
.case-client-title span {
    width: 40px;
    height: 1px;
    background: var(--main-color);
}

.case-client-logo {
    max-width: 180px;
    margin-bottom: 30px;
}

.case-client-task ol {
    padding-left: 40px;
    display: flex;
    flex-direction: column;
    row-gap: 20px;
}

.case-client-task ol li {
    list-style-type: decimal-leading-zero;
    line-height: 1.45;
}

.case-client-task ol li::marker {
    font-weight: 600;
    color: var(--main-color);
}

.realization {
    padding-bottom: 60px;
    font-size: 24px;
}
.realization ul, .result ul  {
    padding-left: 40px;
    display: flex;
    flex-direction: column;
    row-gap: 20px;
	margin-bottom: 30px;
}
 .result ul  {
   font-size:20px;
}
.realization ul li, .result ul li {
    list-style: none;
    position: relative;
}
.realization ul li::before, .result ul li::before {
    content: '';
    width: 14px;
    height: 14px;
    background: url(img/icon/ul.svg) no-repeat;
    position: absolute;
    left: -40px;
    top: 10px;
}

.result-list.result-list-bottom {
    margin-bottom: 0px;
}

.result-list.result-list-bottom .result-item {
    font-weight: 700;
    color: #000000;
    background: #F4F4F4; 
}

.result-list.result-list-bottom .result-item-desc span {
    color: var(--main-color);
}
.result-list.result-list-bottom .result-item-desc {
    font-weight: 400;
}
.result p {
    font-size: 20px;
}

.realization>*:last-child {
    margin-bottom: 0;
}

.case-related h2 {
    margin-bottom: 50px;
}

.case-client  {
    padding-bottom: 60px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.case-client-info, .case-client-task {
    background: #F4F4F4;
    border-radius: 20px;
    padding: 40px;
}
.review h2 {
    color: #fff;
}

.review {
    background: url(img/rev.jpg) no-repeat;
    padding: 50px 0;
    background-size: cover;
    margin-bottom: 80px;
    overflow: hidden;
}

.review-slide {
    overflow: visible;
}

.review-slide .review__item-text {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    color: rgb(0 0 0 / 60%);
    font-size: 16px;
}

.review-item { 
    background: #fff;
    padding: 40px;
    border-radius: 20px;
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: 20px;
    height: auto;
}

.review-item-top .review__item-name span{
    padding-bottom: 5px;
}

.review__item-more {
    font-size: 16px;
    display: flex;
    align-items: center;
    gap: 10px;
    line-height: 1;
    color: var(--main-color);
    margin-top: 20px;
}

.rev-modal-text {
    font-size: 16px;
    padding-top: 20px;
}

.rev-modal-text p  {
    margin-bottom: 20px;
}

.review-item-top {
    display: grid;
    grid-template-columns: 1fr 140px;
    gap: 20px;
    margin-bottom: 20px;
}

.rev-modal-name span {
    padding-bottom: 10px;
}
/* about */

.about {
    padding-bottom: 80px;
    overflow: hidden;
}
 

.about-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
}

.about-foto {
    display: flex;
    gap: 20px;
}

.about-service {
    max-width: 935px;
    padding-top: 40px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.about-service-item {
    background: #F4F4F4;
    padding: 10px 15px;
    border-radius: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .3s;
    line-height: 1;
    font-size: 17px;
}
.about-service-item:hover {
    background: rgba(226, 7, 22, 0.1);
    color: var(--main-color);
}

.about-foto-2 {
    transform: translateY(100px);
}

.about-main {
    position: relative;
    height: 920px;
    margin-bottom: 30px;
}
.about-tooltip {
    position: absolute;
    color: #fff;
    z-index: 1;
    position: absolute;
    bottom: 75px;
    width: 310px;
    font-size: 16px;
    left: 70%;
    text-align: right;
}
.about-tooltip span {
    font-weight: 600;
}
.about-main video {
      position: absolute;
      width: 100vw;
      height: 920px;
      object-fit: cover;
      left: 0;
      top: 0;
      z-index: 1;
    }
.mask {
    position: absolute;
    z-index: 1;
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.mask-mob  {
    display: none;
}

.about-awards .marquee-items { 
    gap: 0; 
}

.about-awards h2 {
    margin-bottom: 10px;
}

.about-awards h2 + p {
    margin-bottom: 50px;
    font-size: 20px;
}
.about-awards { 
    margin-bottom: 80px;
}

.awards-item {
    width: 408px;
    padding: 40px 40px 20px;
    display: flex;
    flex-direction: column;
    align-items: center; 
    height: auto;
    row-gap: 20px;
    border-right: 1px solid rgba(0, 0, 0, .1);
    border-top: 1px solid rgba(0, 0, 0, .1);
    border-bottom: 1px solid rgba(0, 0, 0, .1);
}

.awards-item-text {
    font-size: 16px;
    text-align: center;
}
.awards-item-text span {
    display: block;
    font-size: 22px;
    font-weight: 600;
    margin-bottom: 10px;
}

.about-main-note-box {
    position: absolute;
    bottom: 150px;
    left: 66%;
    z-index: 1;
}

.about-main-tooltip {
    opacity: 0;
    pointer-events: none;
    color: #fff;
    width: 375px;
    position: absolute;
    transform: translateY(-135px);
}
.about-main-tooltip span {
    font-weight: 600;
}
.about-main-note {
    font-size: 40px;
    color: #fff;
    cursor: pointer;
}
.about-main-note:hover ~ .about-main-tooltip {
    opacity: 1;
}

.about-content {
    text-align: center;
    font-size: 26px;
    margin-bottom: var(--padding-bt);
}

.about-content>*:last-child {
    margin-bottom: 0;
}

.about-nums {
    background: #F4F4F4;
    padding: 60px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-radius: 30px;
    gap: 20px;
    grid-template-rows: 1fr 1fr;
    margin-bottom: 80px;
}

.about-num-1 {
    grid-row: span 2;
    padding: 60px;
    border-radius: 30px;
    background: url(img/ab.jpg) no-repeat;
    background-size: cover;
    display: flex;
    flex-direction: column;
    align-items: start;
    row-gap: 20px;
}

.about-num-1 span {
    color: #fff;
    display: block;
    margin-top: auto;
    width: 100%;
    text-align: right;
    font-size: 32px;
}

.about-num-1 p {
    margin: 0;
    font-size: 32px;
    color: #fff;
    display: flex;
    align-items: center;
    gap: 8px;
    line-height: 1;
}

.about-num-1 p span{ 
    background: #fff;
    width: 200px;
    height: 1px;
    margin: 0;
}

.about-num-2 {
    background: #fff;
    padding: 30px;
    border-radius: 30px;
    display: flex;
    flex-direction: column;
    align-items: start;
    row-gap: 20px;
    justify-content: end;
} 

.about-num-2 p {
    margin: 0;
    line-height: 1;
    font-weight: 800;
    font-size: 48px;
    color: var(--main-color);
}

.about-num-2 span { 
    font-size: 24px; 
}

.about-num-2 img {
    margin-left: auto;
}

.about-num-dark {
    font-weight: 800;
    font-size: 120px;
    color: #fff;
    line-height: 1;
}

.about-mission {
    font-size: 24px;
    margin-bottom: 80px;
}

.about-values {
    background: #F4F4F4;
    padding: 60px; 
    border-radius: 30px; 
    margin-bottom: 80px;
    overflow: hidden;
}

.values-item {
    background: #fff;
    border-radius: 20px;
    padding: 40px;
    font-size: 20px;
    display: flex;
    flex-direction: column;
    height: auto;
    width: 560px;
    row-gap: 30px;
}

.values-slide {
    overflow: visible;
}

.title-row h3 {
    margin: 0;
}

.related-nav .swiper-button-next, .related-nav .swiper-button-prev,
.review-nav .swiper-button-next, .review-nav .swiper-button-prev,
.values-nav .swiper-button-next, .values-nav .swiper-button-prev {
    width: 68px;
    min-width: 68px;
    height: 68px;
    background: var(--main-color);
    border-radius: 50%;
}

.values-item-title {
    font-size: 30px;
    font-weight: 600;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.values-item-title span {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    color: #fff;
    font-weight: 800;
    font-size: 20px;
    background: var(--main-color);
    display: flex;
    align-items: center;
    justify-content: center;
}

.values-pagination {
    display: none;
}

/* vakans */

.hiring {
    padding: 40px;
    border-radius: 20px;
    background: #F4F4F4;
    position: relative;
    margin-bottom: 50px;
}

.hiring-box {
    margin-bottom: 40px;
}

.hiring-box img {
    border-radius: 20px;
}

.v-search {
    padding-bottom: 80px;
}

.v-search-left {
    width: 100%;
}

.v-search-row {
    display: grid;
    grid-template-columns: 670px 670px;
    gap: 20px;
}

.v-search-text h3 { 
    font-size: 34px;
    margin-bottom: 20px;
}
.v-search-text   { 
    font-size: 20px; 
    padding: 40px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 20px;
    background: #fff;
}

.v-search-text ol {
    padding-left: 40px;
    display: flex;
    flex-direction: column;
    row-gap: 20px;
}

.red-box {
    margin: 0;
    font-size: 18px;
    color: #fff;
    background: #E20716;
    display: inline-flex;
    height: 57px;
    padding: 0 30px;
    border-radius: 50px;
    align-items: center;
    font-weight: 600;
}

.v-search-contact {
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 20px;
    padding-bottom: 40px;
}

.v-search-contact-inner {
    padding: 15px 40px 0;
    display: flex;
    flex-direction: column;
    row-gap: 18px;
}

.v-search-contact-inner .name-metro {
    font-size: 18px; 
    align-items: center;
}

.v-search-contact-inner h3 {
    font-size: 34px;
    margin-bottom: 0;
        line-height: 1.2;
}

.v-search-contact-inner .time-metro { 
    background: #F4F4F4; 
}

.v-search .contact-gal-item img {
    border-radius: 20px 20px 0 0;
}

.v-search-right, .v-search-left {
    display: flex;
    flex-direction: column;
    row-gap: 20px;
}

.v-search-text strong {
    color: var(--main-color);
}

.v-search-text blockquote {
    background: #F4F4F4;
    height: 50px;
    display: inline-flex;
    align-items: center;
    padding: 0 15px 0 40px;
    border-radius: 50px;
    background: #F4F4F4 url(img/icon/bq.svg) 12px 50% no-repeat;
}

.v-search-text blockquote p {
    margin: 0;
}

.v-search-text blockquote p strong {
    font-weight: 600;
    color: #000;
}

.v-search-num {
    padding: 40px;
    border-radius: 20px;
    display: flex;
    flex-direction: column;
    row-gap: 20px;
    background: url(img/vs1.jpg) no-repeat;
    background-size: cover;
    color: #fff;
}

.v-search-num + .v-search-num { 
    background: url(img/vs2.jpg) no-repeat; 
    background-size: cover;
}

.v-search-num p {
    margin: 0;
}

.v-search-num p span {
    font-size: 50px;
    font-weight: 800;
    display: block;
}

.v-search-nums {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.v-search-text ol li {
    list-style-type: decimal-leading-zero;
    line-height: 1.45;
}

.v-search-text ol li::marker {
  font-weight: 600;
  color: var(--main-color)
}

.what-item {
    padding: 40px;
    border-radius: 20px;
    background: #F4F4F4;
    position: relative;
    display: grid;
    grid-template-columns: 1fr 68px;
    gap: 30px;
}

.what-item p {
    font-size: 28px;
    margin: 0;
}
.what-item:nth-child(1),
.what-item:nth-child(4) {
    grid-column: span 2;
}

.what {
    padding-bottom: 80px;
}

.what-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.what-item p span {
    color: rgba(0, 0, 0, 0.4);
    display: block;
}
.what-item p strong {
    color: var(--main-color);
}

.vakans-box-left h1 {
    margin-bottom: 10px;
}

.vakans {
    padding: 40px;
    border-radius: 20px;
    background: #F4F4F4;
    position: relative;
    margin-bottom: 80px;
}

.vakans .tabs-btn { 
    margin-bottom: 40px;
}


.vakans-item {
    padding: 30px;
    border-radius: 20px;
    background: #fff;
    border: 1px solid #fff;
    display: flex;
    flex-direction: column;
    row-gap: 20px;
    transition: all .3s;
}

.vakans-item:hover { 
    border: 1px solid var(--main-color); 
}

.vakans-item-top {
    display: flex;
    justify-content: space-between;
}

.vakans-item-time {
    background: #F4F4F4;
    height: 43px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 15px;
    border-radius: 50px;
}

.vakans-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.vakans-item-name {
    font-size: 26px;
    font-weight: 600;
}

.vakans-item-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.vakans-item-desc {
    display: flex;
    gap: 10px;
}

.vakans-item-desc span {
    height: 43px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 15px;
    border-radius: 50px;
    border: 1px solid rgba(0, 0, 0, 0.1);
}

.what-num {
    font-size: 28px;
    color: #fff;
    font-weight: 800;
    background: #E20716;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px 15px;
    border-radius: 10px;
    height: 60px;
}

.vakans-box-left h1 + p {
    font-size: 20px;
    font-weight: 600;
    margin: 0;
}

.page-vakans-box {
    max-width: 1200px;
    margin: -50px auto 0;
    background: #E20716;
    display: grid;
    position: relative;
    color: #fff;
    padding: 40px;
    border-radius: 20px;
    grid-template-columns: 1fr 510px;
    gap: 30px;
    margin-bottom: 80px;
}

.vakans-box-right {
    padding-left: 30px;
    border-left: 1px solid;
    font-size: 20px;
    display: flex;
    font-weight: 600;
    flex-direction: column;
    justify-content: space-between;
}

.vakans-box-right p:last-child{
    margin-bottom: 0;
    font-weight: 900;
}

/* service */

.page-services-item {
    padding: 50px 130px 50px 50px;
    border-radius: 20px;
    background: #F4F4F4;
    display: flex;
    flex-direction: column;
    transition: all .3s;
    position: relative;
}
.page-services-item:hover {
    background: #E20716;
    color: #fff;
}
.page-services-item:hover .price { 
    color: #fff;
}
/* 
.page-services-items {
    display: flex;
    flex-direction: column;
    row-gap: 20px;
} */

.page-services-items {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.page-services-item h3 { 
    font-size: 32px;
}

.page-services-more {
    position: absolute;
    right: 50px;
    top: 50px;
    border-radius: 20px;
    background: #FFFFFF;
    border: 1px solid #fff;
    width: 66px;
    height: 66px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .3s;
}

.page-services-item:hover .page-services-more { 
    background: transparent;
}

.page-services-item:hover .page-services-more  svg path{ 
    fill: #fff;
}

.page-services-item .price {
    font-weight: 500;
    font-size: 32px;
    margin-bottom: 10px;
    color: var(--main-color);
    transition: all .3s;
} 
.page-services-item h3 {
    font-weight: 700;
    text-transform: uppercase;
    transition: all .3s;
} 
.page-services-item .desc {
    font-size: 22px;
    font-weight: 500;
}

.page-services h1 {
    margin-bottom: 20px;
}

.page-services h1 + p {
    font-size: 28px;
    margin-bottom: 50px;
}

.page-service-left h1 {
    color: #fff;
    font-size: 65px;
    font-weight: 900;
    font-family: 'Mulish';
    margin-bottom: 20px;
    line-height: 1.2;
}

.page-service-left h1 span {
    color: var(--main-color); 
}

.page-service-left h1 + p {
    color: #fff;
    font-size: 24px;
    margin-bottom: 50px;
}

.page-service-row {
    display: grid;
    grid-template-columns: 1fr 570px;
    gap: 50px;
    align-items: center;
    flex: 1;
}

.page-service-right {
    background: rgba(255, 255, 255, 0.1);
    padding: 40px;
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    color: #fff;
    font-size: 20px;
    backdrop-filter: blur(20px)

}

.page-services {
    padding-bottom: 50px;
}

.list {
    display: flex;
    flex-direction: column;
    row-gap: 10px;
}
.list2 li {
    border: 1px solid #ff0000;
    border-radius: 40px;
    padding: 25px 25px 25px 55px;
    position: relative; 
	margin-bottom:10px;
}
.content .list, .content .list2 {
    margin-bottom: 30px;
}

.list li {
    position: relative;
    padding-left: 30px;
}

.list li::before   {
    content: '';
    position: absolute;
    width: 20px;
    height: 4px;
    top: 10px;
    border-radius: 5px;
    background: var(--main-color);
    left: 0;
}

.list2 li::before {
    content: '';
    position: absolute;
    width: 20px;
    height: 4px;
    top: 50%;
    border-radius: 5px;
	transform: translatey(-50%);
    background: var(--main-color);
    left: 20px;
}

.page-template-service-1 header {
    margin-bottom: 0;
}

.page-service {
    position: relative;
    padding: 30px 0;
    min-height: 620px;
    display: flex;
    flex-direction: column;
}

.page-service .breadcrumbs .container {
    color: rgb(255 255 255 / 30%);
}

.page-service .breadcrumbs a {
    color: #fff; 
}

.page-service .breadcrumbs a:hover {
    color: var(--main-color); 
}

.page-service-bg {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    top: 0;
}

.tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.tags li {
    font-size: 17px;
    padding: 10px 15px;
    
    background: rgba(255, 255, 255, 0.1);
    -webkit-backdrop-filter:blur(20px);
    backdrop-filter: blur(20px);
    border: 1px solid #fff;
    border-radius: 100px;
}

.service-text {
    padding: 80px 0 50px;
    font-size: 20px;
}
.content>*:last-child {
    margin: 0;
}

.scroll-service {
    width: 140px;
    height: 140px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.25);
    position: absolute;
    bottom: -100px;
}

.work-items {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.work-item {
    background: #F4F4F4;
    padding: 40px;
    border-radius: 20px;
}

.num {
    font-size: 28px;
    color: #fff;
    font-weight: 800;
    background: #E20716;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px 15px;
    border-radius: 10px;
    height: 60px;
}

.work-item-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    align-items: start;
    margin-bottom: 30px;
    gap: 30px;
}

.work-item-title p {
    font-size: 28px;
    font-weight: 600;
    margin-bottom: 0px;
    line-height: 1.2;
}

.work {
    padding-bottom: 50px;
}

/* home */
.home-main-list {
    position: relative;
    z-index: 1;
    backdrop-filter: blur(20px);
    border: 1px solid rgb(255 255 255 / 20%);
    background: rgb(255 255 255 / 10%);
    border-radius: 20px;
    padding: 30px 20px;
    max-width: 840px;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 220px;
    gap: 20px;
    color: #fff;
    text-align: center;
    font-size: 16px;
}
.home-main-li span {
    font-size: 42px;
    font-weight: 900;
    color: var(--main-color);
    display: block;
    margin: 0 auto 10px;
}
.home-services { 
    padding-bottom: 80px;
}
.home-main-li {
    position: relative;
}
.home-main-li::before {
    content: '';
    width: 1px;
    height: 100%;
    position: absolute;
    right: -10px;
    background: rgba(255, 255, 255, .1);
}
.home-main-li:last-child:before {
    content: none; 
}
.home-main-overlay {
    background: rgb(0 0 0 / 70%);
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    z-index: 1;
}

.home-main-text .subtitle {
    font-size: 26px;
    color: #fff;
    font-weight: 800;
    margin-bottom: 40px;
    width: 100%;
    max-width: 840px;
    display: flex;
    gap: 10px;
    align-items: center;
    text-transform: uppercase;
}

.subtitle-line {
    flex: 1;
    background: var(--main-color);
    height: 4px;
}

.home-services h2 {
    text-align: center;
    justify-content: center;
    margin:0 auto 10px;
}
.home-services h2  + p{
    text-align: center;
    margin-bottom: 50px;
    font-size: 20px;
}
.home-services-items {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.home-services-item {
    padding: 40px;
    border-radius: 20px;
    background: #F4F4F4;
    display: flex;
    flex-direction: column;
    transition: all .3s;
    position: relative;    
    min-height: 240px;
}

.home-services-item h3 {
    margin-bottom: 10px;
    max-width: 500px;
}

.page-services-left, .page-services-right {
    display: flex;
    flex-direction: column;
    row-gap: 20px;
}

.home-services-item .price {
    font-weight: 500;
    font-size: 32px;
    margin-bottom: 10px;
    color: var(--main-color);
    transition: all .3s;
}


.home-services-item .desc {
    font-size: 28px;
    font-weight: 500; 
    color: #fff;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
}
.home-services-item:hover .desc { 
    max-height: 400px; 
}

.home-services-item:hover {
    background: #E20716;
    color: #fff;
}

.home-services-item:hover .page-services-more {
    background: transparent;
}
 
.home-services-item:hover .price { 
    color: #fff; 
}

.home-services-item:hover .page-services-more svg path {
    fill: #fff;
}

.interview  {
    padding-bottom: 50px;
}

.interview-row {
    display: grid;
    grid-template-columns: 1fr 730px;
    gap: 30px;
    align-items: center;
}

.interview-video {
    position: relative;
}

.interview-video span{
    position: absolute;
    margin: auto;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    pointer-events: none;
    transition: all .3s;
    width: 100px;
    height: 100px;
}

.interview-video:hover span{ 
    width: 110px;
    height: 110px;
}

/* .interview-vk {
    display: grid;
    padding: 0 30px;
    height: 84px;
    border: 1px solid #D5D5D5;
    max-width: 350px;
    align-items: center;
    justify-content: center;
    grid-template-columns: 160px 1fr;
    gap: 20px;
    border-radius: 20px;
    transition: all .3s;
} */
.interview-vk {
    display: grid;
    padding: 0 30px;
    height: 84px;
    border: 1px solid #D5D5D5;
    max-width: 230px;
    align-items: center;
    justify-content: center;
    grid-template-columns: 1fr;
    gap: 20px;
    border-radius: 20px;
    transition: all .3s;
}

.interview-vk:hover { 
    border: 1px solid var(--main-color); 
}

.interview-vk span {
    color: rgba(0, 0, 0, .5);
    font-size: 16px;
    line-height: 1;
}

.home-main {
    position: relative;
    height: 920px;
    overflow: hidden;
    padding: 230px 0 80px;
}
.home-main video.home-main-video {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover;
    left: 0;
    top: 0;
    z-index: 1;
}

.home-circle-video {
    position: absolute;
    right: 0;
    bottom: 0;
    z-index: 1;
    pointer-events: none;
}

.home-main-text {
    position: relative;
    z-index: 1;
    margin-bottom: auto;
    padding-bottom: 40px;
}

.home-main-text .title {
    font-size: 82px;
    font-weight: 900;
    color: var(--main-color);  
    text-transform: uppercase;
    max-width: 820px;
    line-height: 1; 
}
.home-main-text .title span { 
    color: #fff; 
}
.home-main .container {
    display: flex;
    flex-direction: column;
    height: 100%;
}
.subtitle-note:hover ~ .home-subtitle-tooltip {
    opacity: 1;
}
.subtitle-note:hover  {
    color: var(--main-color);
    cursor: pointer;
}
.home-subtitle-tooltip {
    background: #FFFFFF;
    border-radius: 10px;
    padding: 20px;
    width: 355px;
    font-size: 16px;
    position: absolute;
    top: -125px;
    left: 270px;
    pointer-events: none;
    opacity: 0;
    color: #000;
    text-transform: none;
    font-weight: 400;
}
.home-subtitle-tooltip span {
    font-weight: 600;
}
.home-subtitle-tooltip i {
    font-style: normal;
    color: var(--main-color);
}
.home-circle-inner {
    width: 1240px;
    height: 1240px;
    position: absolute;
    right: -670px;
    bottom: -670px;
    z-index: 1;
}
.home-circle-inner-line {
    position: absolute;
    right: 0;
    bottom: 0;
    z-index: 1;
    max-width: 400px;
}

.home-circle-inner  img { 
    animation-name: rotation;
    animation-duration: 12s;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
}

@keyframes rotation {
    0% {
        transform:rotate(0deg);
    }
    100% {
        transform:rotate(-360deg);
    }
}

/* blog */

.blog-archive-box {
    padding: 40px;
    border-radius: 20px;
    background: #F4F4F4;
    border: 1px solid #EDEDED;
}

.blog-archive-row {
    display: grid;
    grid-template-columns: 400px 1fr;
    gap: 30px;
}

.blog-archive__items {
    row-gap: 20px;
    display: flex;
    flex-direction: column;
}

.category-novosti .blog-archive__items {
    gap: 20px;
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.blog-row {
    display: grid;
    grid-template-columns: 600px 1fr;
    gap: 90px;
    align-items: center;
}
.blog-left h2 {
    margin-bottom: 20px;
}
 

.blog .blog-archive__item {
    background: #F4F4F4;
}

.blog-left p {
    font-size: 20px;
    margin-bottom: 30px;
}
.subscribe-form__inputs {
    display: grid;
    grid-template-columns: 1fr 206px;
    gap: 20px;
}
 .form.subscribe-form .btn {
    border-radius: 10px;
    height: 54px;
}
.blog-right {
    display: flex;
    flex-direction: column;
    row-gap: 20px;
}

.blog  {
    padding-bottom: 80px;
}

.article-page {
    padding-bottom: 80px;
}

.related-article-box {
    background: #F4F4F4;
    padding: 60px;
    border-radius: 20px;
    margin-bottom: 80px;
}

.blog-archive__item {
    background: #fff;
    padding: 30px;
    border-radius: 20px;
    display: flex;
    row-gap: 30px;
    flex-direction: column;
    border: 1px solid #fff;
    transition: all .3s;
    height: auto;
}

.blog-archive__item:hover { 
    border: 1px solid var(--main-color);
}

.blog-archive-desc h4 {
    font-size: 24px;
    font-weight: 600;
    margin-bottom: 10px;
}

.blog-archive-desc p {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    margin: 0;
}

.tag {
    background: rgba(226, 7, 22, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    color: #E20716;
    border-radius: 50px;
    height: 42px;
    padding: 0 20px;
    font-size: 18px; 
}

.read {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: #F4F4F4;
    border-radius: 50px;
    height: 42px;
    padding: 0 20px;
    font-size: 18px;
}

.blog-archive-top {
    display: flex;
    justify-content: space-between;
}

.blog-archive {
    padding-bottom: 50px;
}

.blog__nav li a {
    height: 55px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    background: #fff;
    padding: 0 20px;
    border: 1px solid #F4F4F4;
    border-radius: 100px;
    font-weight: 600;
    transition: all .3s;
    cursor: pointer;
}

.blog__nav li a:hover, .blog__nav li.current-menu-item a {
    color: #fff;
    background: var(--main-color);
    border: 1px solid var(--main-color);
}

.blog__nav {
    display: flex;
    gap: 10px;
}

.blog-archive-nav {
    margin-bottom: 50px;
}

.blog-archive h1 + p {
    font-size: 20px;
    margin-bottom: 50px;
}
.blog-archive h1 { 
    margin-bottom: 10px;
}

.smi-archive__items {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.article-page-img {
    height: 640px;
    position: relative;
    border-radius: 20px;
    overflow: hidden;
}

.article-page-img img{
    object-fit:cover;
    width: 100%;
    height: 100%;
    object-position: center;
}

.article-page-content {
    background: #fff;
    padding: 40px;
    max-width: 1200px;
    margin: -80px auto 0;
    position: relative;
    border-radius: 20px;
    border: 1px solid #EDEDED;
}

.content h2 { 
    font-size: 38px;
    margin-bottom: 30px;
}

.article-page__date {
    background: rgba(226, 7, 22, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    color: #E20716;
    border-radius: 50px;
    height: 42px;
    padding: 0 20px;
    font-size: 18px;
}

.article-page-top {
    display: flex;
    justify-content: space-between;
    margin-bottom: 30px;
}

.article-page-content.no-img {
    margin-top: 0;
}

/* case */

.case-filters {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 20px;
    margin-bottom: 20px;
}
#order-filter {
    appearance: none;
    background:  url(img/icon/select.svg) no-repeat 95% !important;
    height: 63px;
    width: 100%;
    padding: 20px 24px;
    font-size: 18px;
    border: 1px solid rgb(0 0 0 / 10%);
    border-radius: 10px;
    font-family: 'Montserrat', sans-serif;
}
/* Скрываем стандартную стрелку */
.select2-container--default .select2-selection--multiple .select2-selection__arrow {
    display: none !important;
}

/* Добавляем кастомную стрелку */
.select2-container--default .select2-selection--multiple {
    background:  url(img/icon/select.svg) no-repeat 95% !important;  
    background-size: 16px 9px !important;
    padding-right: 24px !important;  
}
.select2-container--default .select2-selection--multiple .select2-selection__clear {
    cursor: pointer;
    font-weight: bold;
    height: 20px;
    margin-right: 10px;
    margin-top: 0px;
    position: absolute;
    right: -3px;
    padding: 1px;
    top: 0px;
}
 

.filters-btns {
    display: flex; 
    gap: 10px; 
    align-items: center;
}
/* 
.case-filters-btns {
    display: flex;
    justify-content: end;
    gap: 10px;
    margin-bottom: 20px;
} */

#reset-filters {
    display: flex;
    align-items: center;
    gap: 5px;
    color: #E20716;
    cursor: pointer;
}


.case-archive__items {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 20px;
}

.case-filters .select2-container .select2-selection--multiple {
    min-height: 63px;
    border: solid rgb(0 0 0 / 10%) 1px;
    border-radius: 9px;
    padding: 0;
    display: flex;
    align-items: center;
}

.case-filters .select2-container .select2-search__field {
    padding-left: 24px;
    margin: 0;
}

.case-filters .select2-container .select2-search__field {
    padding-left: 24px;
    margin: 0;
    line-height: 1;
    color: #000000;
}

.case-filters .select2-container .select2-search__field::-webkit-input-placeholder {color: #000000;font-family: 'Montserrat';}
.case-filters .select2-container .select2-search__field::-moz-placeholder          {color: #000000;font-family: 'Montserrat';}
.case-filters .select2-container .select2-search__field:-moz-placeholder           {color: #000000;font-family: 'Montserrat';}
.case-filters .select2-container .select2-search__field:-ms-input-placeholder      {color: #000000;font-family: 'Montserrat';}
.case-filters .select2-selection__choice {
    font-size: 14px;
    background-color: transparent!important;
    border: 1px solid var(--main-color)!important;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
 
    border-right: 1px solid var(--main-color)!important; 
    color: var(--main-color)!important;
    bottom: 0!important;
}

.case-archive__item {
    min-height: 350px;
    border-radius: 20px;
    padding: 30px;
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.case-archive-img {
    position: absolute;
    left: 0;
    top: 0;
    object-fit: cover;
    object-position: center;
    width: 100%;
    height: 100%;
}
.case-archive-overlay {
    background: rgba(0, 0, 0, 0.5);
    position: absolute;
    left: 0;
    width: 100%;
    height: 100%;
    top: 0;
    transition: all .3s;
}
.case-archive__item:hover .case-archive-overlay {
    background: var(--main-color);
}

.case-archive-top {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 100px;
    gap: 15px;
    color: #fff;
}

.case-archive-top {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 100px;
    gap: 15px;
    color: #fff;
}
.case-archive-top h4 {
    font-weight: 400;
    font-size: 20px;
    margin: 0;
}

.case-archive-desc {
    position: relative;
    color: #fff;
    font-size: 14px;
    font-weight: 500;
    max-width: 270px;
}

.case-archive-desc span {
    display: block;
    line-height: 1;
    padding-bottom: 10px;
    font-size: 42px;
    font-weight: 600;
}
/* review */

.tabs-btn {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 50px;
}

.tab-button {
    height: 55px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    background: #fff;
    padding: 0 20px;
    border: 1px solid #F4F4F4;
    border-radius: 100px;
    font-weight: 600;
    transition: all .3s;
    cursor: pointer;
}


.tab-button:hover, .tab-button.active {
    color: #fff;
    background: var(--main-color); 
    border: 1px solid var(--main-color);
}


.video__items {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px 20px;
}

.video__item p {
    font-size: 24px;
    font-weight: 700;
    margin: 0;
    padding-top: 20px;
}

.video__item-link span {
    position: absolute;
    right: 0;
    left: 0;
    bottom: 0;
    top: 0;
    margin: auto; 
    width: 100px;
    height: 100px;
    transition: all .3s;
}
.video__item-link:hover span { 
    width: 110px;
    height: 110px; 
}

.video__item-link {
    border-radius: 20px;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.video__item-link span{
    position: absolute;
    right: 0;
    left: 0;
    bottom: 0;
    top: 0;
    margin: auto;
}

.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
}

.review__item {
    border: 1px solid rgba(226, 7, 22, 0.3);
    background: #fff;
    padding: 40px;
    border-radius: 20px;
    display: flex;
    flex-direction: column;
    row-gap: 40px;
}

.review__item-top {
    display: grid;
    grid-template-columns: 140px 1fr auto;
    gap: 20px;
}

.review__item-foto img {
    border-radius: 50%;
}

.review__item-name {
    font-size: 24px;
    font-weight: 700;
    line-height: 1;
    display: flex;
    flex-direction: column; 
    justify-content: center;
}

.review__item-name span {
    font-weight: 400;
    display: block;
    padding-top: 10px;
    font-size: 16px;
    color: var(--main-color);
}

.review__items {
    font-weight: 400;
    display: flex;
    flex-direction: column;
    row-gap: 20px;
}

.page-review-box {
    padding: 40px;
    background: #F4F4F4;
    border-radius: 20px;
    border: 1px solid #EDEDED;
}

.page-review {
    padding-bottom: 50px;
}

.btn-more-row {
    padding-top: 50px;
    display: flex;
    justify-content: space-between;
    gap: 30px;
    align-items: center;
}

.all {
    font-size: 20px;
}

/* faq */

.faq h2 {
    margin-bottom: 50px;
}

.carret {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    position: relative;
    background: var(--main-color);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .3s;
}

.faq__item-question.active .carret {
    background: var(--main-color);
    transform: rotate(90deg);
}
.faq__item-question.active .carret::before {
    height: 0;
}

.carret::before {
    content: '';
    width: 15px;
    height: 1px;
    background: #fff;
    transition: all .3s;
}

.carret::after {
    content: '';
    width: 1px;
    height: 15px;
    background: #fff;
    position: absolute
}

.faq__item {
    border: 1px solid #F4F4F4;
    border-radius: 10px;
    transition: all .3s;
    background: #F4F4F4;
}

.faq__item:hover  {
    border: 1px solid var(--main-color); 
}

.faq__item:hover .faq__item-question, .faq__item-question.active  {
    color: var(--main-color);
}

.faq__item:has(.faq__item-question.active)  {
    border: 1px solid var(--main-color); 
    padding-bottom: 20px;
}

.faq__item-answer {
    margin: 0px 30px;
    display: none;
    border-top: 1px solid rgb(0 0 0 / 10%);
    padding-top: 20px;
}

.faq__item-answer>*:last-child {
    margin: 0;
} 

.faq__item-question {
    font-size: 18px;
    font-weight: 600;
    display: grid;
    grid-template-columns: 1fr 36px;
    gap: 30px;
    align-items: center;
    padding: 20px 30px;
    cursor: pointer;
}

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

.faq {
    padding-bottom: 80px;
}

/* smi */

.smi {
    padding: 80px 0 60px;
    background: #F4F4F4;
    margin-bottom: 80px;
}

.smi h2 {
    margin-bottom: 10px;
}

.smi h2 + p {
    margin-bottom: 50px;
    font-size: 20px;
}

.smi__item {
    background: #fff;
    border-radius: 20px;
    padding: 30px;
    border: 1px solid #F4F4F4;
    display: flex;
    flex-direction: column;
    row-gap: 20px;
    transition: all .3s;
}

.smi__item:hover { 
    border: 1px solid var(--main-color); 
}

.smi__items {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 20px;
    margin-bottom: 50px;
}

.smi__item-top {
    display: flex;
    justify-content: space-between;
    color: #E20716;
    align-items: center;
    font-size: 16px;
    gap: 20px;
}

.smi__item-title {
    font-size: 20px;
    font-weight: 600;
    line-height: 1.2;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.smi__item-desc {
    font-size: 16px; 
    line-height: 1.2;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.smi__item-more {
    font-size: 16px;
    display: flex;
    align-items: center;
    gap: 10px;
    line-height: 1;
    color: var(--main-color);
    margin-top: auto;
}

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

.related {
    padding-bottom: 80px;
}

.cta-form-brif {
    display: none;
}

.cta-service  {
    padding-bottom: 50px;
}

.cta-service-desc .btn { 
    display: none;
}

.cta-service-box {
    background: #E20716;
    border-radius: 20px;
    display: flex;
    flex-direction: column;
    padding: 50px;
    justify-content: space-between;
    gap: 40px;
    min-height: 285px;
}

.cta-service-top {
    display: grid;
    grid-template-columns: 1fr 390px;
    color: #fff;
    gap: 30px;
    align-items: center;
}

.cta-service-top .btn {
    border: 1px solid #fff;
    height: 70px;
    font-size: 24px;
}

.cta-service-top h2 {
    margin: 0;
}

.cta-service-desc {
    display: flex;
    flex-direction: column;
    row-gap: 10px;
    color: #fff;
}

.cta-service-desc p {
    margin: 0;
}

.cta-service-desc p  span:first-child {
    font-weight: 700;
}

.related-items {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 10px;
}

.related-item {
    background: #F4F4F4;
    padding: 30px;
    border-radius: 20px;
    min-height: 150px;
    position: relative;
    display: flex;
    justify-content: center;
    flex-direction: column;
}

.related-item h3 {
    font-size: 22px;
    font-weight: 600;
    margin-bottom: 10px;
    line-height: 1.2;
    transition: all .3s;
}

.related-item .price {
    font-size: 18px;
    font-weight: 500;
    color: var(--main-color);
}

.related-item-more {
    position: absolute;
    right: 25px;
    top: 25px;
}

.related-item-more svg {
    transition: all .3s;
}

.related-item:hover .related-item-more svg path{
    fill: var(--main-color);
}
.related-item:hover h3{
    color: var(--main-color);
}

/* contact */
.map {
    height: 580px;
    width: 100%;
    position: relative;
}

#map-msk {
    width: 100%;
    height: 100%;
    border-radius: 20px;
    overflow: hidden;
}
.dark {
    font-size: 24px;
    font-weight: 700;
}

.content>*:last-child {
    margin-bottom: 0;
}

.content-contact {
    font-size: 20px;
    margin-bottom: 50px;
}

.container-contact {
    background: #fff;
    border-radius: 20px;
    padding: 40px;
    max-width: 1200px;
    border: 1px solid #EDEDED;
}

h1.line::after, h2.line::after {
    content: '';
    width: 40px;
    height: 1px;
    background: var(--main-color);
}

.line2::before {
    content: '';
    width: 40px;
    height: 1px;
    background: var(--main-color);
}

.client h2 { 
    justify-content: center;
}

h1.line, h2.line   {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--main-color);
    position: relative;
}

h1.line.white {
    color: #fff;
}

h1.line.white::after { 
    background: #fff;
}

.contact-items {
    display: grid;
    grid-template-columns: 550px 550px;
    gap: 20px;
    margin-bottom: 50px;
}

.contact-social {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 20px;
}

.contact-social ul {
    display: flex;
    align-items: center;
    gap: 10px;
}

.contact-gal {
    width: 100%;
}

.contact-gal-item img {
    border-radius: 20px;
}

.contact-item {
    background: #F4F4F4;
    border-radius: 20px;    
    padding: 30px;
}

.contact-item-adress {
    padding: 40px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

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

.name-metro {
    font-size: 20px;
    display: flex;
    gap: 10px;
}

.time-metro {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    height: 43px;
    background: #fff;
    border-radius: 100px;
    padding: 0 25px;
    font-size: 18px;
    font-weight: 600;
    color: var(--main-color);
}

.contact-adress { 
    font-size: 30px; 
    font-weight: 600;
}

.contact-adress span {
    display: block;
    font-size: 20px;
    margin-bottom: 20px;
    line-height: 1;
    font-weight: 400;
}

.contact-work {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 20px;
}

.contact-work span {
    font-weight: 700;
}

.contact-phone, .contact-email {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 600;
    font-size: 24px;
    line-height: 1;
    padding-top: 5px;
}

.contact-social ul li a {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--main-color);
}

.page-contact {
    margin-bottom: var(--padding-bt);
    margin-top: 30px;
}
/* footer */

footer {
    padding: 40px 0;
    background: #F4F4F4;
}

.footer__logo {
    mix-blend-mode: multiply;
    max-width: 178px;
}

.footer-top {
    gap: 50px;
    display: grid;
    grid-template-columns: 178px 1fr;
    margin-bottom: 20px;
}

.footer__cont {
    display: flex;
    align-items: center;
    justify-content: end;
    gap: 30px;
}

.footer__mess {
    padding: 0 20px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.footer__mess a {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    transition: all .3s;
}

.footer__phone, .footer__email {
    display: flex;
    align-items: center;
    gap: 10px;
}

.footer-center {
    display: grid;
    grid-template-columns: 180px 1fr;
    gap: 50px;
    align-items: center;
    margin-bottom: 40px;
}

.footer__cookie {
    text-align: right;
}

.footer__cookie a, .footer__polit a{
    text-decoration: underline;
    color: var(--main-color);
}

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

 
/* cta */

.cta  {
    padding-bottom: var(--padding-bt);
} 

.cta-box {
    background: #F4F4F4;
    padding: 40px;
    border-radius: 20px;
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: 1fr 440px;    
    gap: 60px;
}


.cta-form-box {
    background: #FFFFFF;
    border-radius: 20px;
    padding: 40px;
}

.cta-form__text h2 {
    margin-bottom: 20px;
}

.form__field {
    font-size: 18px; 
    height: 54px;
    width: 100%; 
    padding: 0 20px;
    color: #000;
    background: #F4F4F4;
    border: 1px solid #F4F4F4;
    border-radius: 10px; 
    font-family: 'Montserrat';
}

.cta-form__label {
    margin-bottom: 15px;
}

::-webkit-input-placeholder {color: #909090;font-family: 'Montserrat';}
::-moz-placeholder          {color: #909090;font-family: 'Montserrat';}
:-moz-placeholder           {color: #909090;font-family: 'Montserrat';}
:-ms-input-placeholder      {color: #909090;font-family: 'Montserrat';}

.form-group {
    position: relative;
    margin-bottom: 15px;
}

.cta-form__inputs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 15px;
    margin-bottom: 15px;
}

textarea.form__field {
    height: 100px;
    min-height: 100px;
    padding: 20px;
    width: 100% !important;
}

.form-group-file input[type=file] {
    position: absolute;
    opacity: 0;
    z-index: -1;
    width: 0;
}

.file-clear {
    cursor: pointer;
    text-align: center;
    text-decoration: underline;
    font-size: 14px;
    position: absolute;
    display: none;
    top: 125px;
}

 .form__file {
    font-size: 18px;
    height: 54px;
    width: 100%;
    padding: 0 20px;
    color: #000;
    background: #F4F4F4;
    border: 1px solid #F4F4F4;
    border-radius: 10px;
    font-family: 'Montserrat';
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2px;
    transition: all .3s;
    cursor: pointer;
}

.cta-form-bottom {
    display: grid;
    grid-template-columns: 1fr 225px;
    gap: 30px;
    align-items: center;
}

.cta-form-bottom .btn { 
    height: 57px; 
    padding: 0 25px; 
}

.form-group-file {
    margin-bottom: 30px;
}


.form-note a {
    text-decoration: underline;
    color: var(--main-color);
}

.form-note a:hover {
    text-decoration: none;
}

.form-note { 
    font-size: 16px; 
}

.cta-info-name {
    font-size: 26px;
    font-weight: 500;
    padding: 20px 0;
}

.cta-info-name p {
    font-size: 16px;
    font-weight: 400;
    margin: 0;
    padding-top: 10px;
}

.cta-info-name p span {
    color: var(--main-color);
}

.cta-info {
    padding-top: 8px;
}

.btn-red {
    border: 2px solid #E20716;
    border-radius: 100px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #E20716;
    gap: 10px;
    font-weight: 600;
    font-size: 18px;
    transition: all .3s;
    width: 100%;
}

.cta-info-btns-title {
    padding: 20px 0 10px;
}

.cta-info-btns  {
    display: flex;
    gap: 10px;
    align-items: center;
    width: 100%;
}

.cta-info {
    padding-top: 8px;
    display: flex;
    flex-direction: column;
    align-items: start;
    position: relative;
}

.cta-arrow {
    position: absolute;
    bottom: 50px;
    left: -50px;
}

.cta-info-cont > div {
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: right;
}

.cta-info-cont {
    width: 100%;
    margin-top: auto;
    display: flex;
    flex-direction: column;
    row-gap: 15px;
}

.modal .form-group {
    position: relative;
    margin-bottom: 10px;
}

.form-check span {
    display: block;
    position: relative;
    padding-left: 30px;
    color: #fff;
}

.modal .form-check span { 
    color: #909090;
}
.modal .form-check-input[type=checkbox] + span:after { 
    border-color: #909090; 
}
.modal .form-check-input:checked + span::before,
.modal .form-check-label span:before {
    border: 1px solid #909090;
}
.modal .form-check {
    padding: 8px 0;
}
.form-check span a { 
    text-decoration: underline;
    transition: all .3s;
}

.form-check span a:hover { 
    color: var(--main-color-hover);
    text-decoration: none;
}

.form-check-label .form-check-input {
    position: absolute;
    opacity: 0;
}

.form-check-label span:before, .form-check-label span:after {
    content: '';
    position: absolute;
    top: 2px;
    left: 0;
    transition: 0.15s ease-in-out;
    cursor: pointer;
}

.form-check-label span:before {
    width: 18px;
    height: 18px;
    background: transparent;
    border: 1px solid #fff;
    border-radius: 4px;
}

.form-check-input[type=checkbox] + span:after {
    width: 10px;
    height: 5px;
    margin: 5px 0 0 4px;
    border-style: solid;
    border-color: #fff;
    border-width: 0 0 2px 2px;
    opacity: 0;
    transform: rotate(-45deg);
}

.form-check-input:checked + span:after {
    opacity: 1;
}

.form-check-input:checked + span::before {
    border: 1px solid #fff;
}

.form__field.error { 
    border-color: red!important;
}
   
.form__field:focus, .form__field:hover,
.modal .form__field:focus, .modal .form__field:hover {
    border-color: var(--main-color)
}

 

.form-group:last-child {
    margin: 0;
}
 
.modal:not(.fancybox-content) {
    display: none;
}

label.error:not(#myfile-error) {
    color: red;
    font-size: 13px;
    position: absolute;
    left: 0;
    bottom: -16px;
    padding-left: 48px;
    display: none!important;
}

.form-check {
    position: relative;
    padding-left: 48px;
}


.modal {
    max-width: 984px;
    padding: 48px;
    width: 100%;
    background: #fff;
    border-radius: 28px; 
}
 
 

.form-check-input.error + span {
    color: #FF6868;
}

 
 

 


.modal .btn {
    border-radius: 48px;
    height: 53px;
    padding: 0 20px;
    font-weight: 400;
    font-size: 18px;
}

.modal .form__field {
    height: 53px;
    padding: 0 24px;
    border-radius: 24px;
    border: 1px solid #909090;
}

.fancybox-slide--html .fancybox-close-small {
    color: currentColor;
    padding: 0;
    right: 10px;
    top: 10px;
}

.modal label.error { 
    padding-left: 24px;
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 10px;
    margin-bottom: 18px;
}

.form-row .form-note { 
    padding-left: 20px;
    padding-top: 5px;
    margin-bottom: 0;
}

select.form__field {
    appearance: none;
    background: #fff url(img/down.svg) no-repeat 95% !important;
    cursor: pointer;
}



.marquee-block {
    margin-bottom: var(--padding-bt);
}

 
.marquee-wrap {
    position: relative;
    display: flex;
    overflow: hidden;
    user-select: none;
    gap: 20px;     
}

.marquee-wrap:before,
.marquee-wrap:after {
  content: "";
  height: 100%;
  top: 0;
  width: 10%;
  position: absolute;
  z-index: 1;
  pointer-events: none;
}

.marquee-items { 
    flex-shrink: 0; 
    display: flex;
    gap: 20px;
    justify-content: space-around;
    min-width: 100%;
}
 

.marquee-item {
    flex: 0 0 auto;
    width: auto; 
    padding: 0 30px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 40px;
    font-weight: 700;
    color: transparent; 
    -webkit-text-stroke: 1px #C8C8C8;
    text-transform: uppercase;  
    position: relative;
    transition: all 0.1s ease-in-out;
    font-family: sans-serif;
}


.marquee-items {
  -webkit-animation: scroll 80s linear infinite;
          animation: scroll 80s linear infinite;
}
 
.marquee-wrap:hover .marquee-items {
  -webkit-animation-play-state: paused;
          animation-play-state: paused;
}

@keyframes scroll {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(calc(-100% - 20px));
            transform: translateX(calc(-100% - 20px));
  }
}

.a-text-box {
    border: 1px solid #ff0000;
    border-radius: 40px;
    padding: 39px;
}

#myfile-error {
    position: absolute;
    font-size: 11px;
    top: 33px;
    border: 0;
    color: red;
    left:  50%;
    transform: translateX(-50%);
}

.file-clear {
    cursor: pointer;
    text-align: center;
    text-decoration: underline;
    font-size: 12px;
    position: absolute;
    display: none;
    top: 48px;
    color: #000;
    left:  50%;
    transform: translateX(-50%);
}

.files-check ~ .file-clear {
    display: block;
}

#thanks {
    max-width: 450px;
}
.bg-box {
    background: #F4F4F4;
    padding: 40px;
    border-radius: 20px;
    margin-bottom: 30px;
}
.bg-box>*:last-child,
.bg-box2>*:last-child {
    margin-bottom: 0;
}

.bg-box .title {
    font-weight: 700;
    position: relative;
    padding-left: 30px;
}

.bg-box .title::before {
    content: '';
    position: absolute;
    width: 20px;
    height: 4px;
    top: 10px;
    border-radius: 5px;
    background: var(--main-color);
    left: 0;
}

.bg-box2 {
    background: #FFFFFF;
    padding: 30px;
    border-radius: 20px;
}
.bg-box-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 20px;
}
.black {
    margin-bottom: 15px;
    font-weight: 600;
}

.bg-box-row2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
}

.bg-box-row2 .bg-box {
    margin: 0;
	text-align:left;
	font-size: 20px;
}
 
video, video:hover {
    pointer-events: none!important;
}