:root {
  --bs-body-font-family: "Montserrat", sans-serif;
  --bs-body-font-family-2: "Manrope", sans-serif;
  --bs-body-color: #1e1e1e;
  --bs-front-h1: 64px;
  --bs-desc-slide: 24px;
  --bs-block-title: 40px;
  --bs-border-radius: 4px;
  --bs-link-color: #fff;
  --bs-link-hover-color: #fff;
  --bs-padding-benefits: 90px 0;
  --bs-padding-services: 90px 0;
  --bs-padding-form: 85px 0 160px;
  --bs-padding-about: 92px 0 75px;
  --bs-padding-gallery: 90px 0;
  --bs-gradient-bg-img: linear-gradient(90deg, #ed1f24, #e66c1b);
  --bs-gradient-hover-bg-img: linear-gradient(90deg, #e66c1b, #ed1f24);
  --bs-link-color-rgb: 0, 0, 0;
  --bs-link-hover-color-rgb: 0, 0, 0;
  header .nav {
    --bs-nav-link-padding-x: 1rem;
    --bs-nav-link-padding-y: 28px;
  }
  .dropdown-menu {
    --bs-dropdown-link-active-bg: transparent;
    --bs-dropdown-bg: #eef1f6;
  }
  header .nav-link:focus,
  header .nav-link:hover {
    background-image: linear-gradient(180deg, #ed1f24, #e66c1b);
  }
}
a {
  text-decoration: none;
}
.btn-primary {
  background-image: var(--bs-gradient-bg-img);
  transition: background-image 1s ease-in-out;
  font-family: var(--bs-body-font-family-2);
  font-weight: 600;
}
.btn-primary:hover {
  background-image: var(--bs-gradient-hover-bg-img);
}
.btn {
  border: none;
}
.btn-callback {
  width: 100%;
  padding: 7px;
}
.block-title {
  font-size: var(--bs-block-title);
  text-align: center;
  font-weight: 700;
  letter-spacing: 0.8px;
  line-height: 22px;
  color: #353536;
  margin-bottom: 60px;
}

/* header */
.logo {
  width: 142px;
}
.contact a {
  color: #202938;
  font-family: var(--bs-body-font-family-2);
  font-weight: 600;
}
.contact a:hover {
  color: #000;
}
.col-callback {
  width: 170px;
}
header .nav-link {
  text-transform: uppercase;
  font-weight: 500;
}
.header-bottom {
  background: #353536;
}
.dropdown-item.active,
.dropdown-item:active,
.dropdown-item:hover {
  background-image: var(--bs-gradient-bg-img);
  color: #fff;
}
.dropdown-item {
  white-space: normal;
}
header .region-navigation .nav > .nav-item:hover .dropdown-menu {
  width: 479px;
}
/* end header */

/* слайдер */
.front h1 {
  font-size: var(--bs-front-h1);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 110%;
  width: 90%;
}
.btn-form {
  background-image: var(--bs-gradient-bg-img);
  padding: 20px;
  width: 286px;
  color: #fff;
  border-radius: 4px;
  text-align: center;
  display: block;
  font-family: var(--bs-body-font-family-2);
  font-weight: 700;
}
.btn-form:hover {
  background-image: var(--bs-gradient-hover-bg-img);
  transition: background-image 1s ease-in-out;
}
.node--type-slide .field--name-body {
  font-weight: 700;
  font-size: var(--bs-desc-slide);
  margin: 38px 0 80px;
}
.node--type-slide {
  position: relative;
}
/* end слайдер */

/* преимущества */
.benefits-block {
  padding: var(--bs-padding-benefits);
}
.node--type-preimushchestva {
  display: flex;
  padding: 26px 32px 10px 35px;
  background-color: #eef1f6;
  gap: 21px;
  height: 100%;
}
.node--type-preimushchestva .field--name-node-title {
  font-size: 22px;
  font-weight: 700;
  line-height: 110%;
  margin-bottom: 15px;
  width: 90%;
}
.field--name-field-img-benefits {
  width: 180px;
  text-align: center;
}
.view-benefits .view-content,
.view-services .view-content,
.field--name-field-gallery {
  row-gap: 30px;
}
.node--type-preimushchestva.clearfix:after,
.block-content--type-o-nas.clearfix:after {
  display: none;
}
/* end преимущества */

/* услуги */
.services-block {
  padding: var(--bs-padding-services);
  background-color: #eef1f6;
}
.node--type-services .field--name-node-title a {
  font-size: 18px;
  font-weight: 700;
  line-height: 110%;
  background-image: var(--bs-gradient-bg-img);
  text-align: center;
  padding: 6px;
  align-content: center;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  min-height: 90px;
  color: #fff;
  display: block;
}

.node--type-services .field--name-node-title a:hover {
  background-image: var(--bs-gradient-hover-bg-img);
  color: #fff;
}
.view-services.view-display-id-block_1 .more-link {
  height: 100%;
}
.view-display-id-block_1 .node--type-services img {
  width: 100%;
}
.view-services.view-display-id-block_1 .more-link a {
  background-image: var(--bs-gradient-bg-img);
  height: 100%;
  justify-content: center;
  color: #fff;
}
.view-services.view-display-id-block_1 .more-link a:hover {
  background-image: var(--bs-gradient-hover-bg-img);
}
.view-services.view-display-id-block_1 .more-link a:after {
  background: url(/sites/all/themes/vesta_theme/image/next-white.svg) center
    center no-repeat;
  background-size: contain;
}
.node--type-services {
  position: relative;
}
.field--name-field-dokumenty .field__items {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}
.field--name-field-dokumenty {
  margin-top: 20px;
}
img.image-style-dokumenty-k-uslugam {
  border: 1px solid #d9d9d9;
}
.js-form-item-services {
  margin-bottom: 20px;
}
/* end услуги */

/* ФОС */
#block-vesta-theme-zagolovokfos {
  color: #fff;
  font-size: var(--bs-block-title);
  text-align: center;
  font-weight: 700;
  line-height: 130%;
  margin-bottom: 103px;
}

.form-block {
  background: url(/sites/all/themes/vesta_theme/image/form-bg.png) center center
    no-repeat;
  background-size: cover;
  padding: var(--bs-padding-form);
}
div#block-vesta-theme-vebforma {
  width: 390px;
  margin: 0 auto;
}
.form-text {
  margin: 0 0 25px 0;
}
.webform-submission-form .form-control {
  padding: 17px 20px;
}
.webform-button--submit {
  width: 100%;
  padding: 18px;
}
#block-vesta-theme-vebforma .webform-element-description {
  color: #fff;
  line-height: 103%;
}
.description {
  font-size: 12px;
}
#block-vesta-theme-vebforma .webform-element-description a {
  color: #fff;
}

#block-vesta-theme-vebforma .form-checkbox {
  appearance: none;
  width: 18px;
  height: 18px;
  border: 2px solid #fff;
  border-radius: 0.25rem;
  background-color: transparent;
  cursor: pointer;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out,
    border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  margin: 0;
  flex-shrink: 0;
}
#block-vesta-theme-vebforma .form-checkbox:checked {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'  viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: center;
}
.js-form-item-privacy {
  display: flex;
  gap: 10px;
  margin-top: 10px;
}

/* end ФОС */

/* О нас */
.region-about {
  background: url(/sites/all/themes/vesta_theme/image/about-bg.svg) top center
    no-repeat;
  background-size: contain;
  padding: var(--bs-padding-about);
}
.block-content--type-o-nas {
  display: flex;
  gap: 77px;
  justify-content: space-between;
  color: #353536;
}
.block-content--type-o-nas .field--name-body p:first-child {
  font-size: 36px;
  font-weight: 500;
  line-height: 120%;
  margin-bottom: 40px;
}
.block-content--type-o-nas .field--name-body p {
  font-size: 24px;
  line-height: 120%;
}
.field--name-field-gallery img {
  border-radius: 4px;
}
/* end О нас */

/* Фотогаларея */
.gallery-block {
  padding: var(--bs-padding-gallery);
  background-color: #eef1f6;
}
.more-link a {
  font-size: 18px;
  font-weight: 700;
  line-height: 110%;
  color: #353536;
  display: flex;
  align-items: center;
  gap: 16px;
}
.more-link a:after {
  content: "";
  background: url(/sites/all/themes/vesta_theme/image/next.svg) center center
    no-repeat;
  width: 29px;
  height: 23px;
  display: block;
  background-size: contain;
}
.view-fotogalereya .more-link {
  margin-top: 30px;
}
/* end Фотогаларея */

/* карта */
div#block-vesta-theme-kontakty .block-title {
  text-align: left;
  margin-bottom: 40px;
  color: #fff;
}
#block-vesta-theme-kontakty .contact-item {
  display: flex;
  gap: 17px;
  font-size: 18px;
  font-weight: 500;
}
#block-vesta-theme-kontakty .phone-group .contact-item {
  font-weight: 700;
}
.phone-group {
  display: flex;
  flex-direction: column;
  gap: 13px;
}
.region-map {
  position: relative;
}
div#block-vesta-theme-kontakty {
  background-image: linear-gradient(180deg, #ed1f24, #e66c1b);
  opacity: 95%;
  color: #fff;
  position: absolute;
  top: 28px;
  bottom: 32px;
  left: 0;
  width: 1002px;
  z-index: 1;
  padding: 87px 327px 130px 374px;
}
div#block-vesta-theme-kontakty .phone a,
div#block-vesta-theme-kontakty .mail a {
  color: #fff;
}
div#block-vesta-theme-kontakty .phone a:hover,
div#block-vesta-theme-kontakty .mail a:hover {
  color: #ffffffc7;
}
div#block-vesta-theme-kontakty .adress {
  margin-bottom: 21px;
}
div#block-vesta-theme-kontakty .mail {
  margin-top: 25px;
}
.mapContainer {
  height: 500px;
}
/* end карта */

/* footer */
footer#footer {
  background-color: #353536;
  padding: 46px 0 20px;
}
footer ul.nav {
  flex-direction: column;
}
.col-nav {
  margin-left: 152px;
}
.copyright {
  color: #cdc8c8;
  margin-top: 21px;
}

.copyright a {
  color: #cdc8c8;
}
.copyright a:hover {
  color: #ffffffc7;
}
.privacy {
  font-size: 14px;
  line-height: 17px;
}
.col-contact,
.col-contact a {
  color: #fff;
}
.col-contact a:hover {
  color: #ffffffc7;
}
footer .nav-link {
  padding: 0 0 15px 0;
}
footer .nav-link:hover {
  color: #ffffffc7;
}
footer .nav-link.is-active {
  font-weight: 500;
}
footer .contact-item {
  display: flex;
  gap: 9px;
  align-items: center;
  font-weight: 500;
}
.col-contact {
  display: flex;
  flex-direction: column;
  gap: 13px;
  margin-left: 43px;
}
.col-webvesta a {
  color: #fff;
  font-size: 14px;
}
.col-webvesta a:hover {
  color: #ffffffc7;
}

.search-form__submit,
.search-form__submit:hover,
.search-form__submit:first-child:active,
.search-form__submit:focus-visible,
.search-form__submit:disabled {
  background: url(/sites/all/themes/vesta_theme/image/search.svg) center center
    no-repeat;
  color: transparent;
  width: 20px;
  height: 20px;
}
.form-search.form-control {
  border-bottom: 1px solid #ee1c25;
  background: transparent;
  border-top: none;
  border-left: none;
  border-right: none;
  border-radius: 0;
}
footer .form-search.form-control {
  color: #fff;
}
.form-control:focus {
  box-shadow: 0 0 0 0.15rem rgb(232 88 30 / 22%);
  border-color: rgb(232 88 30);
}
.form-search.form-control::placeholder {
  color: transparent;
}
.search-api-page-block-form-search {
  position: relative;
  width: max-content;
}
.search-api-page-block-form-search .form-actions {
  position: absolute;
  right: 0;
  bottom: 5px;
}
.col-search {
  margin-top: 53px;
}
footer .dropdown-toggle::after {
  display: none;
}
.col-webvesta {
  margin-top: 85px;
}
/* end footer */

/*  модалка */
.ajax-progress .throbber,
.ajax-progress-throbber .throbber {
  display: inline-block;
  float: none;
  margin: 400px auto 0 auto;
  width: 64px;
  height: 64px;
  background: url("../image/preloader.gif") no-repeat center center;
}
.ajax-progress,
.ajax-progress-throbber {
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.2);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 4444;
  vertical-align: middle;
  text-align: center;
}
.ui-widget-header {
  border: none;
  background-color: #fff;
}
.ui-dialog .ui-dialog-titlebar-close {
  background: url("../image/close.svg");
  border: none;
  background-size: contain;
  width: 15px;
  height: 15px;
  background-repeat: no-repeat;
}
.ui-dialog .ui-dialog-title {
  font-size: 18px;
}

/* end модалка */
.block.block-vesta-privacy-access-d10 .block-metrika-btns button:hover,
.block.block-vesta-privacy-access-d10 .block-metrika-btns button {
  border: none;
}
.nav-tabs .nav-link {
  color: #000;
}
.not-front main#main {
  margin: 40px 0;
}
div#block-vesta-theme-bloknastranicekontakty .contact-item {
  display: flex;
  gap: 10px;
}

.webform-confirmation {
  background-color: #fff;
  text-align: center;
  padding: 10px;
  border-radius: 4px;
}
