:root {
	--main: #07699e;
    --hover-color: #188ecd;
	--white: #fff;
	--black: #171717;
	--hover-black: #5b5b5b;
	--grey: #e5e5e5;
    --font-family: "Plus Jakarta Sans", sans-serif;
    --third-family: "Inter", sans-serif;
    --font3: "Montserrat", sans-serif;
}
body { height: 100vh; font-family: var(--font-family); color: var(--black); }
#app {
    display: flex;
    flex-direction: column;
    height: 100%;
}
#main { margin-bottom: auto; }
#footer { flex: 0 0 auto; }

main#main > * { margin-bottom: 100px; }

h1 { margin-bottom: 28px; }

a, a.nav-link{ color: var(--black); text-decoration: none; transition: all 0.4s ease; }
a:hover{ color: var(--hover-color); }

.btn {
    font: 500 16px var(--font-family);
    padding: 10px 24px;
    border-radius: 40px;
    background: var(--main);
    color: var(--white);
    border: none!important;
    box-shadow: none!important;
}
.btn:hover, .btn:active, .btn:focus{
    color: var(--white)!important;
    background-color: var(--hover-color)!important;
}

.btn.btn-outline {
    background: var(--white);
    border: 1px solid var(--main)!important;
    color: var(--black)!important;
}
.btn.btn-outline:hover,.btn.btn-outline:active, .btn.btn-outline:focus {
    background-color: #07699e2e!important;
}

.form-control:focus {
    box-shadow: none;
}

div.ajax-progress { display: none; }

.contacts-wrapper.page-contacts { display: flex; flex-direction: column; gap: 16px; }
.contacts-wrapper.page-contacts .contact-item { font-size: 18px; font-weight: 500; }

#block-vesta-theme-content .search-api-page-block-form-search.search-api-page-block-form.search-form.search-block-form { display: flex; flex-direction: row; align-items: center; gap: 12px; margin-bottom: 14px; }

@media screen and (max-width: 1200px) {
}
@media screen and (max-width: 992px) {
    .btn { font-size: 14px; }
    main#main > * { margin-bottom: 80px; }
    #scrollToTop { right: 55px; }
}
@media screen and (max-width: 991px) {
    #app { padding-top: 112px; }
}
@media screen and (max-width: 767px) {
    main#main > * { margin-bottom: 60px; }
    #scrollToTop { right: 30px; }
}
@media screen and (max-width: 576px) {
}

/*---------------HEADER---------------*/
header { margin-bottom: 36px; }
header#header .ht-wrapper {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    padding: 24px 0px;
    border-bottom: 1px solid #ececec;
}
header#header .ht-wrapper .contacts-wrapper {
    display: flex;
    flex-direction: row;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
    column-gap: 30px;
    row-gap: 6px;
    padding: 0px 16px;
}
.contacts-wrapper .contact-item {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 8px;
    font: 700 14px var(--font-family);
}
header#header .ht-wrapper .btn-wrapper {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 16px;
    flex: 0 0 auto;
}
header#header .ht-wrapper .btn-wrapper .region-search { position: relative; }
header#header .ht-wrapper .btn-wrapper > a { padding: 16px 24px; }

.search-js-btn {
    display: block;
    position: relative;
    padding: 13.5px 27.5px 13.5px 25.5px;
    z-index: 11;
}
.search-js-btn > img { margin-right: 1px; }
.search-js-btn > span {
    position: absolute;
    width: 100%;
    height: 100%;
    top: -3px;
    left: 3px;
    transform: rotate(45deg);
    font-size: 32px;
    opacity: 0;
    display: flex;
    justify-content: center;
    align-items: center;
}
.search-js-btn.active > span{
    opacity: 1;
}
.search-js-btn.active img {
    opacity: 0;
}
.search-js-btn > span,
.search-js-btn > img {
    transition: all 0.4s ease;
}

header#header .ht-wrapper .btn-wrapper .region.region-search .search-api-page-block-form-search.search-api-page-block-form.search-form {
    width: 0;
    overflow: hidden;
    position: absolute;
    right: 100%;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    transition: all 0.3s ease;
    z-index: 10;
    width: 100%;
    height: 100%;
    border: 1px solid var(--main);
    border-radius: 40px;
    display: flex;
    flex-direction: row;
    align-items: center;
    padding: 0px 14px;
    background: white;
}
header#header .ht-wrapper .btn-wrapper .region.region-search .search-api-page-block-form-search.search-api-page-block-form.search-form form {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 8px;
    opacity: 0;
}
header#header .ht-wrapper .btn-wrapper .region.region-search .search-api-page-block-form-search.search-api-page-block-form.search-form.active{ width: 345px; padding-right: 80px; }
header#header .ht-wrapper .btn-wrapper .region.region-search .search-api-page-block-form-search.search-api-page-block-form.search-form.active form { opacity: 1; transition: opacity 0.3s ease; transition-delay: 0.15s;}
header#header .ht-wrapper .btn-wrapper .region.region-search .search-api-page-block-form-search.search-api-page-block-form.search-form.active form input { border: none; padding-right: 0;}

header#header .hb-wrapper { display: flex; flex-direction: row; align-items: center; margin-top: 24px; }

header#header .hb-wrapper .region.region-navigation-services .view.view-nashi-uslugi-menyu .view-header {
    font: 600 16px var(--font-family);
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 16px;
    padding: 6px 12px;
}

header#header .hb-wrapper .region.region-navigation-services .view.view-nashi-uslugi-menyu .view-content {
    display: none;
    grid-auto-flow: column;
    grid-template-rows: repeat(9, auto);
    position: absolute;
    border-radius: 24px;
    box-shadow: 0 4px 280px 0 rgba(0, 0, 0, 0.08);
    background: var(--white);
    z-index: 10;
    padding: 40px;
    gap: 16px 40px;
    width: max-content;
}
header#header .hb-wrapper .region.region-navigation-services .view.view-nashi-uslugi-menyu .view-content h3 { font: 600 18px var(--font-family); margin: 0; }
header#header .hb-wrapper .region.region-navigation-services .view.view-nashi-uslugi-menyu .view-content .views-row { font: 500 16px var(--font-family); }

header#header .hb-wrapper .region.region-navigation-services .view.view-nashi-uslugi-menyu:hover .view-content { display: inline-grid; }


header#header .hb-wrapper .region.region-navigation ul.nav {
    font: 400 16px var(--font-family);
    display: flex;
    flex-direction: row;
    gap: 16px;
    margin-left: 56px;
}
header#header .hb-wrapper .region.region-navigation ul.nav .nav-link { padding: 6px 12px; }
header#header .hb-wrapper .region.region-navigation ul.nav .nav-link:focus { background-color: unset; }
header#header .hb-wrapper .region.region-navigation ul.nav .nav-link:hover{ color: var(--hover-color); }
header#header .hb-wrapper .region.region-navigation ul.nav .nav-link.is-active {
    border-bottom: 2px solid #07699e;
    font-weight: 600;
    color: #07699e;
}

header#header .hb-wrapper .region.region-navigation ul.dropdown-menu {
    font: 500 16px var(--font-family);
}
header#header .hb-wrapper .region.region-navigation ul.dropdown-menu .dropdown-item { padding: 6px 12px; }
header#header .hb-wrapper .region.region-navigation ul.dropdown-menu .dropdown-item:focus { background-color: unset; }
header#header .hb-wrapper .region.region-navigation ul.dropdown-menu .dropdown-item:hover { color: var(--hover-color); background-color: unset; }
header#header .hb-wrapper .region.region-navigation ul.dropdown-menu .dropdown-item:active { color: var(--black); background-color: unset; }
header#header .hb-wrapper .region.region-navigation ul.dropdown-menu .dropdown-item.active {
    background-color: unset;
    font-weight: 600;
    color: #07699e;
}


@media screen and (max-width: 1200px) {
    header#header .hb-wrapper .region.region-navigation-services .view.view-nashi-uslugi-menyu .view-content { grid-template-rows: repeat(12, auto); }
}
@media screen and (max-width: 992px) {
}
@media screen and (max-width: 767px) {
}
@media screen and (max-width: 576px) {
}
/*------------------------------------*/

/*---------------HEADER-MOBILE---------------*/
header#header-mob > div { padding: 5px 12px; }
header#header-mob .wr-nav { display: flex; flex-direction: row; align-items: center; gap: 12px; }

.search-mobile-js-btn {
    display: block;
    position: relative;
    z-index: 11;
}
.search-mobile-js-btn > img { margin-right: 1px; }
.search-mobile-js-btn > span {
    position: absolute;
    width: 100%;
    height: 100%;
    top: -3px;
    left: 3px;
    transform: rotate(45deg);
    font-size: 32px;
    opacity: 0;
    display: flex;
    justify-content: center;
    align-items: center;
}
.search-mobile-js-btn.active > span{
    opacity: 1;
}
.search-mobile-js-btn.active img {
    opacity: 0;
}
.search-mobile-js-btn > span,
.search-mobile-js-btn > img {
    transition: all 0.4s ease;
}
header#header-mob .region.region-search-mobile { display: none; }
header#header-mob .region-search-mobile form { position: relative; }
header#header-mob .region-search-mobile .form-item.form-type-search { width: 100%; }
header#header-mob .region-search-mobile .form-item.form-type-search input { padding-right: 48px; }
header#header-mob .region-search-mobile .form-actions { display: block; }
header#header-mob .region-search-mobile .form-actions button {
    position: absolute;
    background: url(/sites/all/themes/vesta_theme/image/icons/search.svg) no-repeat center !important;
    font-size: 0;
    width: 38px;
    height: 38px;
    border: 0px solid;
    box-shadow: none;
    top: 0;
    right: 0;
    z-index: 2;
}

.offcanvas .region.region-navigation ul.dropdown-menu .dropdown-item { padding: 6px 12px; }
.offcanvas .region.region-navigation ul.dropdown-menu .dropdown-item:focus { background-color: unset; }
.offcanvas .region.region-navigation ul.dropdown-menu .dropdown-item:hover { color: var(--hover-color); background-color: unset; }
.offcanvas .region.region-navigation ul.dropdown-menu .dropdown-item:active { color: var(--black); background-color: unset; }
.offcanvas .region.region-navigation ul.dropdown-menu .dropdown-item.is-active {
    background-color: unset;
    font-weight: 600;
    color: #07699e;
}

.offcanvas .contact-item {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 8px;
    font: 400 16px var(--font-family);
}

@media screen and (max-width: 1200px) {
}
@media screen and (max-width: 992px) {
}
@media screen and (max-width: 767px) {
}
@media screen and (max-width: 576px) {
    header#header-mob .contact-item { display: none; }
}
/*-------------------------------------------*/

/*---------------BANNER---------------*/
#banner-block .banner-img img {
    max-width: 676px;
    width: 100%;
    height: auto;
    object-fit: cover;
}
#banner-block .banner-text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 50px;
}
#banner-block .banner-text #block-vesta-theme-polnyyciklrabototdemontazhadoblagoustroystva .field.field--name-body.clearfix::after { display: none; }
#banner-block .banner-text #block-vesta-theme-polnyyciklrabototdemontazhadoblagoustroystva .field.field--name-body {
    display: flex;
    flex-direction: column;
    gap: 32px;
}

#banner-block .banner-text #block-vesta-theme-polnyyciklrabototdemontazhadoblagoustroystva .field.field--name-body h1 { font: 700 44px / 1.31818 var(--font-family); margin: 0; }
#banner-block .banner-text #block-vesta-theme-polnyyciklrabototdemontazhadoblagoustroystva .field.field--name-body p { font: 400 22px / 1.52381 var(--font-family); opacity: 0.7; }
#banner-block .banner-text .wp-btns {
    display: flex;
    flex-direction: row;
    gap: 16px;
}
#banner-block .banner-text .wp-btns a { align-content: center; font: 700 21px var(--font-family); padding: 20px 40px; }
#banner-block .banner-text .wp-btns a.btn-outline { font-weight: 400; }

@media screen and (max-width: 1200px) {
    #banner-block .banner-text #block-vesta-theme-polnyyciklrabototdemontazhadoblagoustroystva .field.field--name-body h1 { font-size: 38px; }
    #banner-block .banner-text #block-vesta-theme-polnyyciklrabototdemontazhadoblagoustroystva .field.field--name-body p { font-size: 20px; }
    #banner-block .banner-text .wp-btns a { padding: 16px 24px; }
}
@media screen and (max-width: 992px) {
    #banner-block .banner-text #block-vesta-theme-polnyyciklrabototdemontazhadoblagoustroystva .field.field--name-body h1 { font-size: 32px; }
    #banner-block .banner-text #block-vesta-theme-polnyyciklrabototdemontazhadoblagoustroystva .field.field--name-body p { font-size: 18px; }
    #banner-block .banner-text .wp-btns a { font-size: 14px; }
}
@media screen and (max-width: 767px) {
}
@media screen and (max-width: 576px) {
    #banner-block .banner-text #block-vesta-theme-polnyyciklrabototdemontazhadoblagoustroystva .field.field--name-body h1 { font-size: 28px; }
    #banner-block .banner-text #block-vesta-theme-polnyyciklrabototdemontazhadoblagoustroystva .field.field--name-body p { font-size: 16px; }
}
/*------------------------------------*/

/*---------------УСЛУГИ---------------*/
#categories-services-block { margin-bottom: 64px !important; }
#categories-services-block .block-title {
    font: 700 16px var(--font-family);
    text-transform: uppercase;
    color: var(--main);
    margin-bottom: 16px;
}
#categories-services-block .view-header {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
    gap: 12px;
    margin-bottom: 40px;
}
#categories-services-block .view-header p {
    font: 700 36px / 1.33333 var(--font-family);
}
#categories-services-block .view-header a {
    font: 400 18px / 1.33333 var(--font-family);
    text-decoration: underline;
    text-decoration-skip-ink: none;
    color: rgba(0, 0, 0, 0.8);
}

.view.view-service.view-id-service.view-display-id-page_1 .view-content.row { row-gap: 30px; }

@media screen and (max-width: 1200px) {
}
@media screen and (max-width: 992px) {
    #categories-services-block .block-title { margin-bottom: 12px; }
    #categories-services-block .view-header p { font-size: 28px; }
}
@media screen and (max-width: 767px) {
    #categories-services-block .block-title { font-size: 14px; margin-bottom: 8px; }
    #categories-services-block .view-header p { font-size: 24px; }
}
@media screen and (max-width: 576px) {
}
/*------------------------------------*/

/*---------------ПАРТНЕРЫ---------------*/
#partners-block .block-title {
    font: 700 16px var(--font-family);
    text-transform: uppercase;
    color: var(--main);
    margin-bottom: 16px;
}
#partners-block .view-header {
    margin-bottom: 40px;
}
#partners-block .view-header p {
    font: 700 36px / 1.33333 var(--font-family);
}

@media screen and (max-width: 992px) {
    #partners-block .block-title { margin-bottom: 12px; }
    #partners-block .view-header p { font-size: 28px; }
}
@media screen and (max-width: 767px) {
    #partners-block .block-title { font-size: 14px; margin-bottom: 8px; }
    #partners-block .view-header p { font-size: 24px; }
}
/*--------------------------------------*/

/*---------------ПРЕИМУЩЕСТВА---------------*/
#advantages-block .block-title {
    font: 700 16px var(--font-family);
    text-transform: uppercase;
    color: var(--main);
    margin-bottom: 16px;
}
#advantages-block .view-header {
    margin-bottom: 40px;
}
#advantages-block .view-header p {
    font: 700 36px / 1.33333 var(--font-family);
}

@media screen and (max-width: 992px) {
    #advantages-block .block-title { margin-bottom: 12px; }
    #advantages-block .view-header p { font-size: 28px; }
}
@media screen and (max-width: 767px) {
    #advantages-block .block-title { font-size: 14px; margin-bottom: 8px; }
    #advantages-block .view-header p { font-size: 24px; }
}
/*------------------------------------------*/

/*---------------О-НАС---------------*/
#about-block .wr-about > div { padding: 0px 15px; }
#about-block .wr-about .about-region-img {
    border-radius: 24px;
    width: 100%;
    height: 626px;
    object-fit: cover;
}

#about-block .wr-about .block.block-block-content .block-title {
    font: 700 16px var(--font-family);
    text-transform: uppercase;
    color: var(--main);
    margin-bottom: 16px;
}

#about-block .wr-about .block.block-block-content .field.field--name-body > * { font: 400 20px / 1.6 var(--font-family); margin-bottom: 24px; opacity: 0.8; }
#about-block .wr-about .block.block-block-content .field.field--name-body h3 { font: 700 36px / 1.33333 var(--font-family); margin-bottom: 20px; opacity: 1; }
#about-block .wr-about .block.block-block-content .field.field--name-body h6 { margin-bottom: 16px; opacity: 1; }
#about-block .wr-about .btn.btn-outline { font: 400 21px var(--font-family); padding: 16px 40px; }

@media screen and (max-width: 1200px) {
}
@media screen and (max-width: 992px) {
    #about-block .block-title { margin-bottom: 12px; }
    #about-block .wr-about .block.block-block-content .field.field--name-body > * { font-size: 18px; }
    #about-block .wr-about .block.block-block-content .field.field--name-body h3 { font-size: 28px; }
    #about-block .wr-about .btn.btn-outline { font-size: 14px; padding: 12px 26px; }
}
@media screen and (max-width: 767px) {
    #advantages-block .block-title { font-size: 14px; margin-bottom: 8px; }
    #about-block .wr-about .block.block-block-content .field.field--name-body > * { font-size: 16px; margin-bottom: 16px; }
    #about-block .wr-about .block.block-block-content .field.field--name-body h3 { font-size: 24px; margin-bottom: 12px; }
}
@media screen and (max-width: 576px) {
}
/*-----------------------------------*/

/*---------------ГАЛЕРЕЯ---------------*/
#gallery-block .block-title {
    font: 700 16px var(--font-family);
    text-transform: uppercase;
    color: var(--main);
    margin-bottom: 16px;
}
#gallery-block .view-header {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
    gap: 12px;
    margin-bottom: 40px;
}
#gallery-block .view-header p {
    font: 700 36px / 1.33333 var(--font-family);
}
#gallery-block .view-header a {
    font: 400 18px / 1.33333 var(--font-family);
    text-decoration: underline;
    text-decoration-skip-ink: none;
    color: rgba(0, 0, 0, 0.8);
}

@media screen and (max-width: 992px) {
    #gallery-block .block-title { margin-bottom: 12px; }
    #gallery-block .view-header p { font-size: 28px; }
}
@media screen and (max-width: 767px) {
    #gallery-block .block-title { font-size: 14px; margin-bottom: 8px; }
    #gallery-block .view-header p { font-size: 24px; }
}
/*-------------------------------------*/

/*---------------КАРТА---------------*/
#map-block {
    display: flex;
    flex-direction: column;
    align-items: center;
}
#map-block .region.region-map {
    width: 100%;
    max-width: 1620px;
}
#map-block .block-title { font: 400 42px / 1.47619 var(--font-family); margin-bottom: 40px; }
#map-block .region.region-map #block-vesta-theme-yandekskarta-2 .field.field--name-body {
    border: 1px solid var(--grey);
    border-radius: 16px;
    overflow: hidden;
}

@media screen and (max-width: 992px) {
    #map-block .block-title { margin-bottom: 36px; margin-bottom: 28px; }
}
@media screen and (max-width: 767px) {
    #map-block .block-title { font-size: 32px; margin-bottom: 16px; }
}
/*-----------------------------------*/

/*---------------FOOTER---------------*/
footer#footer .container { padding: 40px 6px 67px 6px; border-top: 1px solid #ececec; }
footer#footer .footer-top {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 30px;
    margin-bottom: 40px;
    max-width: 1094px;
}
footer#footer .footer-top .logo img { width: 265px; height: auto; object-fit: cover;}
footer#footer .footer-top .footer-services { font: 400 12px var(--font-family); }
footer#footer .footer-top .footer-services { font: 400 12px var(--font-family); }
footer#footer .footer-top .footer-services .view.view-services.view-id-services .view-content {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

footer#footer .footer-top .footer-nav .nav {
    font: 400 12px var(--font-family);
    display: flex;
    flex-direction: column;
    gap: 10px;
}
footer#footer .footer-top .footer-nav .nav .nav-item a { padding: 0; }
footer#footer .footer-top .footer-nav .nav .nav-item a::after { display: none; }

footer#footer .footer-top .contacts-wrapper .contact-item { font: 700 16px var(--font-family); margin-bottom: 16px; }
footer#footer .footer-top .contacts-wrapper > a.btn { padding: 16px 24px; margin-top: 16px; }

footer#footer .footer-bottom {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 30px;
    font: 300 13px / 1.23077 var(--third-family);
    text-align: center;
}

@media screen and (max-width: 1200px) {
}
@media screen and (max-width: 992px) {
    footer#footer .footer-bottom { gap: 12px; }
}
@media screen and (max-width: 767px) {
    footer#footer .footer-bottom { flex-direction: column; align-items: center; }
    footer#footer .footer-top { justify-content: space-around; }
        
}
@media screen and (max-width: 576px) {
}
/*------------------------------------*/
