/* template@basic.less */
@font-face {
  font-family: 'Montserrat';
  src: url(https://ecoland.com.pl/storage/fonts/Montserrat-Bold.ttf);
  font-weight: 800;
}
@font-face {
  font-family: 'Montserrat';
  src: url(https://ecoland.com.pl/storage/fonts/Montserrat-Medium.ttf);
  font-weight: 600;
}
@font-face {
  font-family: 'Montserrat';
  src: url(https://ecoland.com.pl/storage/fonts/Montserrat-Regular.ttf);
  font-weight: 400;
}
@font-face {
  font-family: 'Montserrat';
  src: url(https://ecoland.com.pl/storage/fonts/Montserrat-Light.ttf);
  font-weight: 200;
}
@font-face {
  font-family: 'Cormorant';
  src: url(https://ecoland.com.pl/storage/fonts/Cormorant-Bold.otf);
  font-weight: 800;
}
@font-face {
  font-family: 'Cormorant';
  src: url(https://ecoland.com.pl/storage/fonts/Cormorant-Semibold.otf);
  font-weight: 600;
}
@font-face {
  font-family: 'Cormorant';
  src: url(https://ecoland.com.pl/storage/fonts/Cormorant-Book.otf);
  font-weight: 400;
}
@font-face {
  font-family: 'Cormorant';
  src: url(https://ecoland.com.pl/storage/fonts/Cormorant-Light.otf);
  font-weight: 200;
}
@font-face {
  font-family: 'Pragmatica';
  src: url(https://ecoland.com.pl/storage/fonts/Pragmatica.otf);
  font-weight: 600;
}
/*BASIC__STYLE*/
/*МАСКА КАРТИНКИ*/
/*МАСКА КАРТИНКИ*/
/*БОКС ДЛЯ ФОТО*/
/*БОКС ДЛЯ ФОТО*/
/*ЦВЕТОВОЙ ГРАДИЕНТ*/
/*ЦВЕТОВОЙ ГРАДИЕНТ*/
/*ЗАДНИЙ ФОН*/
/*ЗАДНИЙ ФОН*/
/*ЗАКРЫТИЕ*/
.closer__btn {
  cursor: pointer;
  width: 3vw;
  height: 3vw;
  position: absolute;
  right: 1vw;
  top: 0.5vw;
  background: url(/public/img/close.png), #146451;
  background-size: 70% 70%;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 9999;
}
@media screen and (max-width: 800px) {
  .closer__btn {
    width: 10vw;
    height: 10vw;
    right: 5vw;
  }
}
.closer__btn:hover {
  background-color: red;
}
/*ЗАКРЫТИЕ*/
* {
  margin: 0;
  padding: 0;
  border: none;
  outline: none;
  font-size: inherit;
  font-weight: inherit;
  font-family: inherit;
  color: inherit;
}
strong {
  font-weight: 600;
}
body {
  max-width: 100vw;
  overflow: hidden;
  overflow-y: auto;
  background-color: #ffffff;
}
@media screen and (max-width: 800px) {
  body {
    padding-bottom: 8vw;
  }
}
a {
  text-decoration: none;
  color: inherit;
  width: auto;
  height: auto;
}
table {
  border: none;
  border-collapse: collapse;
}
div {
  display: block;
  margin: 0;
  padding: 0;
  font-size: inherit;
  font-family: 'Montserrat';
}
img {
  margin: 0px;
  padding: 0px;
  overflow: hidden;
}
span {
  font-size: inherit;
  font-weight: inherit;
  font-family: inherit;
}
p {
  font-size: inherit;
  font-weight: inherit;
  font-family: inherit;
}
ul {
  margin-top: 0.3vw;
  margin-left: 1%;
}
ul,
li {
  font-size: inherit;
  font-weight: inherit;
  font-family: inherit;
}
nav {
  display: flex;
  justify-content: center;
}
/*BASIC__STYLE*/
.form_type_1 {
  width: 100%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
}
@media screen and (max-width: 800px) {
  .form_type_1 {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
.inputGroup {
  width: 100%;
  float: left;
  margin-top: 0.4vw;
}
@media screen and (max-width: 800px) {
  .inputGroup {
    margin-top: 3.4vw;
  }
}
.regulationsLabel {
  color: #fff;
  font-family: 'Montserrat';
}
.regulationsLabel:hover + .formaInfoWindow {
  display: block;
}
@media screen and (max-width: 800px) {
  .regulationsLabel {
    font-size: 4vw;
    margin-top: 2vw;
  }
}
#regulationsCheckbox {
  width: 1.5vw;
}
.regulationsLabel {
  color: #fff;
  font-family: 'Montserrat';
}
.regulationsLabel:hover + .formaInfoWindow {
  display: block;
}
@media screen and (max-width: 800px) {
  .regulationsLabel {
    font-size: 3.5vw;
  }
}
.regulationsGroup {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: center;
  position: relative;
  padding-bottom: 0.3vw;
}
@media screen and (max-width: 800px) {
  .regulationsGroup {
    flex-direction: column;
  }
}
.custom-checkbox {
  position: absolute;
  z-index: -1;
  opacity: 0;
}
.custom-checkbox + label {
  display: inline-flex;
  align-items: center;
  user-select: none;
}
.custom-checkbox + label::before {
  content: '';
  display: inline-block;
  width: 1.5em;
  height: 1.5em;
  flex-shrink: 0;
  flex-grow: 0;
  border: 1px solid #fff6;
  border-radius: 0.25em;
  margin-right: 0.5em;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 50% 50%;
}
@media screen and (max-width: 800px) {
  .custom-checkbox + label::before {
    border: 1px solid #fff;
  }
}
.custom-checkbox:checked + label::before {
  background-color: #005742;
  border-color: #00432e;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%23fff' d='M6.564.75l-3.59 3.612-1.538-1.55L0 4.26 2.974 7.25 8 2.193z'/%3e%3c/svg%3e");
}
.custom-checkbox:not(:disabled):not(:checked) + label:hover::before {
  border-color: #b3d7ff;
}
/* стили для активного состояния чекбокса (при нажатии на него) */
.custom-checkbox:not(:disabled):active + label::before {
  background-color: #005742;
  border-color: #00432e;
}
/* стили для чекбокса, находящегося в фокусе */
.custom-checkbox:focus + label::before {
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}
/* стили для чекбокса, находящегося в фокусе и не находящегося в состоянии checked */
.custom-checkbox:focus:not(:checked) + label::before {
  border-color: #80bdff;
}
/* стили для чекбокса, находящегося в состоянии disabled */
.custom-checkbox:disabled + label::before {
  background-color: #e9ecef;
}
.formaInfoWindow {
  width: 96%;
  padding-left: 2%;
  padding-right: 2%;
  padding-top: 0.5vw;
  padding-bottom: 0.5vw;
  position: absolute;
  top: 100%;
  left: 0;
  background: #005742;
  color: #fff;
  font-family: 'Montserrat';
  font-size: 0.9vw;
  border: 1px solid #005742;
  display: none;
}
@media screen and (max-width: 800px) {
  .formaInfoWindow {
    width: 100%;
    font-size: 2.3vw;
    position: relative;
    display: block;
    margin-top: 4vw;
    background: unset;
    border: unset;
    padding: 0;
  }
}
.windowFormSubmit {
  width: 26%;
  color: #fff;
  font-size: 1.3vw;
  font-family: tahoma;
  z-index: 3;
  outline: 1px solid #0c634e;
  padding-top: 0.4vw;
  padding-bottom: 0.4vw;
  padding-left: 5%;
  padding-right: 5%;
  border-radius: 35px;
  background: #005742;
  background-image: url(/public/img/linkIcon.png);
  background-size: 1.5vw 1vw;
  background-repeat: no-repeat;
  background-position: 90% center;
  margin-top: 0.4vw;
  cursor: pointer;
}
@media screen and (max-width: 800px) {
  .windowFormSubmit {
    width: 50%;
    font-size: 5vw;
    background-size: 3.5vw 2vw;
  }
}
h2 {
  font-size: 2.09vw;
  font-family: 'Pragmatica';
  font-weight: 600;
  color: #004231;
}
@media screen and (max-width: 800px) {
  h2 {
    font-size: 6.27vw;
  }
}
@media screen and (max-width: 800px) {
  h2 {
    font-size: 5vw;
  }
}
.formBlock {
  width: 32%;
  height: auto;
  padding-left: 2%;
  padding-right: 2%;
  position: absolute;
  background: url(/public/img/form_bg.png), #004231;
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: right center;
  right: 5%;
  border: 1px solid #005742;
  outline: 1px solid #fff9;
  outline-offset: 0px;
  border-radius: 20px;
  padding-bottom: 2.5vw;
}
@media screen and (max-width: 800px) {
  .formBlock {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .formBlock {
    position: relative;
    right: 0%;
    width: 96%;
    padding-left: 2%;
    padding-right: 2%;
    padding-top: 5vw;
    padding-bottom: 5vw;
  }
}
.form_title {
  width: 96%;
  height: auto;
  padding-left: 2%;
  padding-right: 2%;
  font-size: 1.485vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #000000;
  margin-top: 1vw;
  background: #fff;
  outline: 1px dashed #fff9;
  text-align: center;
  padding-top: 1vw;
  padding-bottom: 1vw;
  border-radius: 30px;
  margin-bottom: 1vw;
  text-transform: uppercase;
}
@media screen and (max-width: 800px) {
  .form_title {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .form_title {
    font-size: 4.455vw;
  }
}
.form_input {
  width: 96%;
  height: auto;
  padding-left: 2%;
  padding-right: 2%;
  font-size: 1.265vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #000000;
  border-radius: 30px;
  padding-top: 0.6vw;
  padding-bottom: 0.6vw;
  margin-top: 0.8vw;
}
@media screen and (max-width: 800px) {
  .form_input {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .form_input {
    font-size: 3.795vw;
  }
}
@media screen and (max-width: 800px) {
  .form_input {
    margin-top: 2vw;
    margin-bottom: 2vw;
    padding-bottom: 3vw;
    padding-top: 3vw;
    padding-left: 5%;
    padding-right: 5%;
    width: 90%;
  }
}
.h2_block_cover {
  width: 50%;
  margin-left: 25%;
  margin-right: 25%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.6vw;
  text-align: center;
  text-transform: uppercase;
}
@media screen and (max-width: 800px) {
  .h2_block_cover {
    flex-direction: column;
    align-items: center;
  }
}
.h2_block_cover h2 {
  font-size: 2.42vw;
  font-family: 'Montserrat';
  font-weight: 400;
  color: #ffffff;
}
@media screen and (max-width: 800px) {
  .h2_block_cover h2 {
    font-size: 7.26vw;
  }
}
@media screen and (max-width: 800px) {
  .h2_block_cover {
    width: 90%;
    margin-left: 5%;
    margin-right: 5%;
  }
}
.h2_block_cover .h2_subtitle {
  font-size: 1.65vw;
  font-family: 'Pragmatica';
  font-weight: 200;
  color: #ffffff;
  letter-spacing: 3px;
  padding: 0 3vw;
  background-image: url('/public/img/set-left.png'), url('/public/img/set-right.png');
  background-position: left center, right center;
  background-size: 2.6vw 1.2vw, 2.6vw 1.2vw;
  background-repeat: no-repeat, no-repeat;
}
@media screen and (max-width: 800px) {
  .h2_block_cover .h2_subtitle {
    font-size: 4.95vw;
  }
}
@media screen and (max-width: 800px) {
  .h2_block_cover .h2_subtitle {
    background-size: 6.6vw 4.2vw, 6.6vw 4.2vw;
    font-size: 6vw;
  }
}
.h2_block_cover .h2_line {
  width: 22%;
  height: 2px;
  background-color: #005742;
}
.forma_title_type_1 {
  width: 100%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  text-align: center;
  font-size: 2.09vw;
  font-family: 'Pragmatica';
  font-weight: 400;
  color: #ffffff;
  text-transform: uppercase;
  letter-spacing: 2px;
}
@media screen and (max-width: 800px) {
  .forma_title_type_1 {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .forma_title_type_1 {
    font-size: 6.27vw;
  }
}
.forma_subtitle_type_1 {
  width: 95%;
  height: auto;
  padding-left: 2.5%;
  padding-right: 2.5%;
  text-align: center;
  font-size: 0.99vw;
  font-family: 'Montserrat';
  font-weight: 400;
  color: #005742;
  text-transform: uppercase;
  letter-spacing: 2px;
}
@media screen and (max-width: 800px) {
  .forma_subtitle_type_1 {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .forma_subtitle_type_1 {
    font-size: 2.97vw;
  }
}
@media screen and (max-width: 800px) {
  .forma_subtitle_type_1 {
    margin-bottom: 6vw;
  }
}
.forma_type1 {
  width: 91%;
  height: auto;
  padding-left: 4.5%;
  padding-right: 4.5%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-top: 2vw;
  gap: 1.5vw;
}
@media screen and (max-width: 800px) {
  .forma_type1 {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .forma_type1 {
    flex-direction: column;
    align-items: center;
  }
}
.forma_type1_input {
  width: 97.3%;
  padding-left: 1.5%;
  padding-right: 1.5%;
  margin-left: 10%;
  margin-right: 10%;
  padding-top: 0.6vw;
  padding-bottom: 0.6vw;
  font-size: 1.32vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #ffffff;
  background-color: rgba(255, 255, 255, 0.06);
  border-bottom: 5px solid #005742;
}
@media screen and (max-width: 800px) {
  .forma_type1_input {
    font-size: 3.96vw;
  }
}
input::-webkit-input-placeholder {
  color: #004231;
}
input::-moz-placeholder {
  color: #004231;
  opacity: 1;
  /* Убирает прозрачность в Firefox */
}
input:-ms-input-placeholder {
  color: #004231;
}
input::placeholder {
  color: #004231;
}
textarea::-webkit-input-placeholder {
  color: #004231;
}
textarea::-moz-placeholder {
  color: #004231;
  opacity: 1;
  /* Убирает прозрачность в Firefox */
}
textarea:-ms-input-placeholder {
  color: #004231;
}
textarea::placeholder {
  color: #004231;
}
.textarea_type1 {
  background-color: rgba(255, 255, 255, 0.4);
}
.send_btn {
  width: 37%;
  padding-left: 1.5%;
  padding-right: 1.5%;
  padding-top: 0.6vw;
  padding-bottom: 0.6vw;
  font-size: 1.32vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #ffffff;
  background-color: rgba(255, 255, 255, 0.06);
  border-bottom: 5px solid #0003;
  outline: 1px solid #0002;
  text-align: center;
  margin-left: 60%;
  cursor: pointer;
  transition: 0.4s;
}
@media screen and (max-width: 800px) {
  .send_btn {
    font-size: 3.96vw;
  }
}
.send_btn:hover {
  background-color: rgba(20, 100, 81, 0.1);
  border-bottom: 5px solid #0007;
  outline: 1px solid #0005;
}
@media screen and (max-width: 800px) {
  .send_btn {
    width: 60%;
    margin-left: 0%;
    padding-top: 4vw;
    padding-bottom: 4vw;
    margin-top: 4vw;
  }
}
.body_block_title {
  width: 100%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  text-transform: uppercase;
}
@media screen and (max-width: 800px) {
  .body_block_title {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .body_block_title {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .body_block_title {
    gap: 0.5vw 0.5vw;
    text-align: center;
  }
}
.body_block_title .h2_mini_title {
  font-size: 1.43vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #005742;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 800px) {
  .body_block_title .h2_mini_title {
    font-size: 4.29vw;
  }
}
@media screen and (max-width: 800px) {
  .body_block_title .h2_mini_title {
    margin-bottom: 1vw;
    flex-direction: column;
    font-size: 4.5vw;
  }
}
.h2_mini_title::before {
  content: '';
  width: 2vw;
  height: 3px;
  background-color: #004231;
  display: inline-flex;
  margin-right: 0.5vw;
}
@media screen and (max-width: 800px) {
  .h2_mini_title::before {
    display: none;
  }
}
@media screen and (max-width: 800px) {
  .h2_mini_title::after {
    content: '';
    width: 50%;
    height: 2px;
    background-color: #004231;
    display: block;
    margin-top: 2vw;
  }
}
.custom-select {
  width: 100%;
  padding-top: 0.5vw;
  padding-bottom: 0.5vw;
  background-color: rgba(255, 255, 255, 0.3);
  margin-top: 0.6vw;
  font-size: 1.21vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #ffffff;
  padding-left: 2%;
  appearance: none;
  /* вимикає дефолтне оформлення */
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url(/public/img/triangl_white.png);
  background-repeat: no-repeat;
  background-position: right 0.6vw center;
  background-size: 1vw;
  cursor: pointer;
}
@media screen and (max-width: 800px) {
  .custom-select {
    font-size: 3.63vw;
  }
}
@media screen and (max-width: 800px) {
  .custom-select {
    background-image: url(/public/img/triangl_white.png);
    background-repeat: no-repeat;
    background-position: right 0.6vw center;
    background-size: 2vw;
  }
}
.custom-select option {
  color: #000;
  /* Колір тексту опцій */
  background-color: rgba(255, 255, 255, 0.3);
}
.phone_code_select {
  width: 22%;
  padding-right: 2vw;
  border-right: 2px solid #004231;
}
@media screen and (max-width: 800px) {
  .phone_code_select {
    width: 29.5%;
  }
}
.phone_number_input {
  width: 77% !important;
  margin: 0;
}
@media screen and (max-width: 800px) {
  .phone_number_input {
    width: 70% !important;
  }
}
.forma_number_select_cover {
  width: 100%;
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  justify-content: flex-start;
}
@media screen and (max-width: 800px) {
  .forma_number_select_cover {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .forma_number_select_cover {
    flex-direction: row;
  }
}
.open_forma_select {
  border-bottom: 5px solid #005742;
  padding-top: 0.65vw;
  padding-bottom: 0.65vw;
  margin-top: 0;
}
/* template@header.less */
@keyframes scalePulse {
  0% {
    transform: scale(1);
  }
  30% {
    transform: scale(1.05);
  }
  60% {
    transform: scale(1.09);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes logo_text_animation {
  0% {
    transform: scale(1);
    background: linear-gradient(0deg, #004231, #146451);
    /* напрям градієнта */
    -webkit-background-clip: text;
    /* вирізати фон тільки по тексту */
    -webkit-text-fill-color: transparent;
    /* зробити текст прозорим */
  }
  30% {
    transform: scale(1.1);
    background: linear-gradient(200deg, #004231, #469683);
    /* напрям градієнта */
    -webkit-background-clip: text;
    /* вирізати фон тільки по тексту */
    -webkit-text-fill-color: transparent;
    /* зробити текст прозорим */
  }
  60% {
    transform: scale(0.9);
    background: linear-gradient(100deg, #004231, #78c8b5);
    /* напрям градієнта */
    -webkit-background-clip: text;
    /* вирізати фон тільки по тексту */
    -webkit-text-fill-color: transparent;
    /* зробити текст прозорим */
  }
  100% {
    transform: scale(1);
    background: linear-gradient(0deg, #004231, #32826f);
    /* напрям градієнта */
    -webkit-background-clip: text;
    /* вирізати фон тільки по тексту */
    -webkit-text-fill-color: transparent;
    /* зробити текст прозорим */
  }
}
@keyframes logo_img_animation {
  0% {
    transform: rotate(0deg);
  }
  30% {
    transform: rotate(90deg);
  }
  60% {
    transform: rotate(180deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes fon_scale {
  0% {
    transform: scale(1.1);
  }
  25% {
    transform: scale(1.08);
  }
  50% {
    transform: scale(1.05);
  }
  75% {
    transform: scale(1.03);
  }
  100% {
    transform: scale(1.1);
  }
}
header {
  width: 90%;
  height: auto;
  padding-left: 5%;
  padding-right: 5%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
}
@media screen and (max-width: 800px) {
  header {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  header {
    flex-direction: column;
    align-items: center;
  }
}
.header_line {
  width: 100%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: flex-start;
  padding-top: 1vw;
}
@media screen and (max-width: 800px) {
  .header_line {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .header_line {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .header_line {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding-top: 1vw;
    padding-bottom: 1vw;
    width: 94%;
    padding-left: 3%;
    padding-right: 3%;
    position: fixed;
    top: 0;
    left: 0;
    background-color: rgba(255, 255, 255, 0.8);
    z-index: 888;
  }
}
.logo_block {
  width: 50%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
}
@media screen and (max-width: 800px) {
  .logo_block {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .logo_block {
    flex-direction: column;
    align-items: center;
  }
}
.logo_block > a {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
}
@media screen and (max-width: 800px) {
  .logo_block > a {
    flex-direction: column;
    align-items: center;
  }
}
.logo_block > a:hover .logo_text_cover {
  animation: logo_text_animation 1s linear;
}
.logo_block > a:hover .logo_img_cover {
  animation: logo_img_animation 0.5s linear;
}
@media screen and (max-width: 800px) {
  .logo_block {
    width: 12%;
    align-items: flex-start;
  }
}
.logo_img_cover {
  width: 5vw;
  height: 5vw;
  outline: unset;
  outline-offset: -2px;
  transform: scale(1.4);
}
.logo_img_cover img {
  object-fit: contein;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .logo_img_cover {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
.logo_img_cover img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .logo_img_cover {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
@media screen and (max-width: 800px) {
  .logo_img_cover {
    transform: scale(1.1);
    width: 100%;
    height: auto;
  }
}
.logo_text_cover {
  font-size: 2.2vw;
  font-family: 'Pragmatica';
  font-weight: 600;
  color: #004231;
  padding-left: 2vw;
  background: linear-gradient(0deg, #004231, #146451);
  /* напрям градієнта */
  -webkit-background-clip: text;
  /* вирізати фон тільки по тексту */
  -webkit-text-fill-color: transparent;
  /* зробити текст прозорим */
  transition: 2s;
}
@media screen and (max-width: 800px) {
  .logo_text_cover {
    font-size: 6.6vw;
  }
}
@media screen and (max-width: 800px) {
  .logo_text_cover {
    margin-top: 0vw;
    display: none;
  }
}
.header_line_right_side {
  width: 50%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
}
@media screen and (max-width: 800px) {
  .header_line_right_side {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .header_line_right_side {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .header_line_right_side {
    width: 70%;
    align-items: center;
    justify-content: space-between;
    flex-direction: row;
    flex-wrap: wrap;
  }
}
.menuBox {
  cursor: pointer;
  width: 25%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  padding-top: 0.7vw;
  padding-bottom: 0.7vw;
  background: #00523d;
  outline: 2px solid #004231;
  margin-left: 10%;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 800px) {
  .menuBox {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
.menuBox:hover {
  background: linear-gradient(0deg, #004231, #3c8c79);
  outline: 2px solid #00523d;
  animation: scalePulse 3s infinite linear;
}
@media screen and (max-width: 800px) {
  .menuBox {
    width: 15%;
    background: #00523d;
    outline: 2px solid #055c47;
    animation: unset !important;
    order: 2;
  }
}
.btn_effect1::after {
  content: '';
  width: 4vw;
  height: 150%;
  position: absolute;
  transform: rotate(25deg);
  background-color: #fff8;
  left: -10vw;
  top: -20%;
  filter: blur(10px);
}
.btn_effect1:hover::after {
  left: 120%;
  transition: 0.3s;
}
.menuButton {
  font-size: 1.32vw;
  font-family: 'Pragmatica';
  font-weight: 600;
  color: #ffffff;
  padding-left: 34%;
  padding-right: 5%;
  background: url(/public/img/menu.png);
  background-position: 5% center;
  background-size: 2vw;
  background-repeat: no-repeat;
}
@media screen and (max-width: 800px) {
  .menuButton {
    font-size: 3.96vw;
  }
}
@media screen and (max-width: 800px) {
  .menuButton {
    width: 60%;
    padding-top: 5vw;
    padding-bottom: 5vw;
    font-size: 4vw;
    background: url(/public/img/menu.png);
    background-position: center center;
    background-size: 8vw;
    background-repeat: no-repeat;
    background-color: unset;
    outline: unset;
    z-index: 3;
    content: '';
  }
  .menuButton .menu_text {
    display: none;
  }
}
.language-switcher {
  position: relative;
  width: 15%;
  user-select: none;
  cursor: pointer;
  margin-left: 1vw;
}
@media screen and (max-width: 800px) {
  .language-switcher {
    width: 60%;
    margin-left: 0;
    order: 1;
  }
}
.selected-language {
  padding: 0.5vw 0.6vw;
  padding-right: 0.4vw;
  font-size: 1.65vw;
  font-family: 'Pragmatica';
  font-weight: 600;
  color: #004231;
  background-image: url('/public/img/triangl.png');
  background-position: 70% 45%;
  background-size: 1vw 1vw;
  background-repeat: no-repeat;
}
@media screen and (max-width: 800px) {
  .selected-language {
    font-size: 4.95vw;
  }
}
@media screen and (max-width: 800px) {
  .selected-language {
    display: none;
  }
}
.language-options {
  position: absolute;
  top: 90%;
  left: 0;
  width: 100%;
  background-color: #004231;
  border: 1px solid #005742;
  border-radius: 6px;
  list-style: none;
  margin: 4px 0 0;
  padding: 0;
  display: none;
  z-index: 10;
  box-shadow: 0 4px 10px #145645;
  z-index: 100;
}
@media screen and (max-width: 800px) {
  .language-options {
    display: flex;
    justify-content: center;
    position: relative;
    margin-top: 1vw;
    margin-bottom: 1vw;
  }
}
.language-options li {
  padding: 8px 12px;
  transition: background-color 0.2s ease;
  font-size: 1.54vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #ffffff;
  transition: 0.5s;
  border-radius: 10px;
}
@media screen and (max-width: 800px) {
  .language-options li {
    font-size: 4.62vw;
  }
}
.language-options li:hover {
  transform: scale(1.1);
}
@media screen and (max-width: 800px) {
  .language-options li {
    font-size: 4vw;
  }
}
.active_lang {
  background-color: #146451;
  color: #004231;
  transform: scale(1.1);
}
.language-options li:hover {
  background-color: #f5f5f5;
  color: #004231;
}
.language-switcher:hover .language-options {
  display: block;
}
@media screen and (max-width: 800px) {
  .language-switcher:hover .language-options {
    display: flex;
  }
}
.header_contacts_block {
  width: 50%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
}
@media screen and (max-width: 800px) {
  .header_contacts_block {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .header_contacts_block {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .header_contacts_block {
    align-items: center;
    gap: 3vw 2vw;
    display: none;
  }
}
.header_contacts_cover {
  font-size: 1.43vw;
  font-family: 'Pragmatica';
  font-weight: 600;
  color: #004231;
  padding-left: 2vw;
}
@media screen and (max-width: 800px) {
  .header_contacts_cover {
    font-size: 4.29vw;
  }
}
@media screen and (max-width: 800px) {
  .header_contacts_cover {
    padding-left: 8vw;
  }
}
.header_phone_box {
  background-image: url(/public/img/phone_green.png);
  background-size: 1.2vw 1.2vw;
  background-position: 1% center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 800px) {
  .header_phone_box {
    background-size: 5.1vw 5vw;
  }
}
.header_email_box {
  font-size: 1.21vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #004231;
  background-image: url(/public/img/mail.png);
  background-size: 1.1vw 1vw;
  background-position: 1% center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 800px) {
  .header_email_box {
    font-size: 3.63vw;
  }
}
@media screen and (max-width: 800px) {
  .header_email_box {
    background-size: 5.1vw 5vw;
  }
}
.header_contacts_button {
  width: 3vw;
  height: 3vw;
  outline: 2px solid #00523d;
  border-radius: 10px;
  cursor: pointer;
  position: absolute;
  overflow: hidden;
  right: 1vw;
  top: 20%;
  background: url('/public/img/triangl_white.png'), linear-gradient(0deg, #004231, #3c8c79);
  background-position: center center;
  background-size: 1.5vw 1.5vw, 100% 100%;
  background-repeat: no-repeat;
}
.header_contacts_button:hover {
  animation: scalePulse 3s infinite linear;
}
@media screen and (max-width: 800px) {
  .header_contacts_button {
    width: 12vw;
    height: 12vw;
    border-radius: 30px;
    background: url('/public/img/triangl_white.png'), linear-gradient(0deg, #004231, #3c8c79);
    background-position: center center;
    background-size: 4.5vw 4.5vw, 100% 100%;
    background-repeat: no-repeat;
    position: relative;
    margin-top: 1vw;
    margin-bottom: 4vw;
  }
}
.header_contacts_hidden {
  width: 90%;
  height: 6vw;
  outline: 2px solid #00523d;
  border-radius: 10px;
  position: absolute;
  left: 0vw;
  top: 110%;
  background: linear-gradient(154deg, #004231, #3c8c79);
  display: none;
  z-index: 100;
  padding-left: 3%;
  padding-right: 3%;
  padding-top: 1vw;
  padding-bottom: 1vw;
}
@media screen and (max-width: 800px) {
  .header_contacts_hidden {
    height: auto;
    padding: 5vw 5%;
    top: 100%;
  }
}
.white_phone {
  background: url(/public/img/phone.png);
  background-size: 1.2vw 1.2vw;
  background-position: 1% center;
  background-repeat: no-repeat;
  color: #fff;
  font-size: 1.2vw;
}
@media screen and (max-width: 800px) {
  .white_phone {
    font-size: 4vw;
    background-size: 4.8vw 4.9vw;
  }
}
.white_adres {
  background: url(/public/img/adress_white.png);
  background-size: 1.7vw 1.6vw;
  background-position: 0% center;
  background-repeat: no-repeat;
  color: #fff;
  font-size: 1vw;
  margin-top: 1vw;
}
@media screen and (max-width: 800px) {
  .white_adres {
    font-size: 4vw;
    background-size: 5.1vw 4.4vw;
  }
}
/*slider items*/
.header_slider_body {
  width: 100%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  margin-top: 1vw;
  position: relative;
}
@media screen and (max-width: 800px) {
  .header_slider_body {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .header_slider_body {
    margin-top: 14vw;
  }
}
.slider_mask {
  height: 100%;
  width: 100%;
  position: absolute;
  background: url(/public/img/header_mask.webp);
  background-size: 100% 100%;
  background-position: center;
  top: 0;
  left: 0;
  z-index: 50;
}
@media screen and (max-width: 800px) {
  .slider_mask {
    display: none;
  }
}
.slider_body {
  width: 100%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  height: 40vw;
  overflow: hidden;
}
@media screen and (max-width: 800px) {
  .slider_body {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .slider_body {
    height: 60vh;
  }
}
.header_slide_item {
  width: 100%;
  height: 40vw;
  outline: unset;
  outline-offset: -2px;
  overflow: hidden;
  display: none;
}
.header_slide_item img {
  object-fit: contein;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .header_slide_item {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
.header_slide_item img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .header_slide_item {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
.header_slide_item img {
  transform: scale(1.1);
}
@media screen and (max-width: 800px) {
  .header_slide_item {
    height: 60vh;
  }
}
.header_active_slide {
  position: absolute;
  overflow: hidden;
  top: 0;
  left: 0;
  z-index: 40;
  display: block;
}
.header_active_slide img {
  transition: 3s;
  animation: fon_scale 15s infinite linear;
}
/*slider items*/
.slider_content {
  position: absolute;
  top: 0;
  left: 0;
  width: 50%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  z-index: 80;
  padding: 3vw 0;
}
@media screen and (max-width: 800px) {
  .slider_content {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .slider_content {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .slider_content {
    padding: 4vw 0;
    margin-top: 5vh;
    background-color: rgba(255, 255, 255, 0.6);
  }
}
.text_typing {
  animation: typing 2s steps(14, end);
  white-space: nowrap;
  overflow: hidden;
}
.slider_content h1 {
  font-size: 1.98vw;
  font-family: 'Pragmatica';
  font-weight: 600;
  color: #004231;
  background-color: rgba(255, 255, 255, 0.9);
  text-align: left;
  line-height: 100%;
  padding-top: 0.2vw;
  padding-bottom: 0.2vw;
  text-transform: uppercase;
  animation: typing 2s steps(14, end);
  white-space: nowrap;
  overflow: hidden;
}
@media screen and (max-width: 800px) {
  .slider_content h1 {
    font-size: 5.94vw;
  }
}
@media screen and (max-width: 800px) {
  .slider_content h1 {
    font-size: 5vw;
    background-color: rgba(255, 255, 255, 0);
    line-height: 1.3em;
  }
}
/* Анімація друку */
@keyframes typing {
  from {
    width: 0;
  }
  to {
    width: 100%;
  }
}
/* Анімація курсору */
@keyframes blink-caret {
  from,
  to {
    border-color: transparent;
  }
  50% {
    border-color: #146451;
  }
}
.h1_sub {
  font-size: 1.43vw;
  font-family: 'Montserrat';
  font-weight: 800;
  color: #005742;
}
@media screen and (max-width: 800px) {
  .h1_sub {
    font-size: 4.29vw;
  }
}
@media screen and (max-width: 800px) {
  .h1_sub {
    font-size: 4vw;
    text-align: center;
    color: #005742;
  }
}
.header_slider_navigation {
  width: 15vw;
  position: absolute;
  bottom: -0.5vw;
  right: 0;
  z-index: 101;
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0.5vw;
}
@media screen and (max-width: 800px) {
  .header_slider_navigation {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .header_slider_navigation {
    bottom: -4vw;
    flex-direction: row;
    gap: 5vw;
    width: 100%;
    justify-content: space-between;
  }
}
.header_navigation {
  width: 3vw;
  height: 2vw;
  outline: unset;
  outline-offset: -2px;
  background: linear-gradient(90deg, #004231, #1e604f);
  padding: 0.4vw 1.5vw;
  outline: 3px solid #fff;
  border-radius: 20px;
  cursor: pointer;
  transition: 0.4s;
}
.header_navigation img {
  object-fit: contein;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .header_navigation {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
.header_navigation img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .header_navigation {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
.header_navigation:hover {
  background: linear-gradient(90deg, #146451, #1e7560);
  animation: scalePulse 2s infinite linear;
}
@media screen and (max-width: 800px) {
  .header_navigation {
    width: 12vw;
    height: 4vw;
    padding: 2.4vw 4.5vw;
  }
}
.header_center_contact_block {
  margin-top: 5vw;
  width: 70%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  margin-left: 10%;
}
@media screen and (max-width: 800px) {
  .header_center_contact_block {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .header_center_contact_block {
    flex-direction: column;
    align-items: center;
  }
}
.header_consultation_btn {
  font-size: 0.88vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #ffffff;
  background-color: #004231;
  padding: 0.5vw 1vw;
  cursor: pointer;
  transition: 0.4s;
  overflow: hidden;
  position: relative;
  box-shadow: 4px 4px 0px 0px rgba(0, 66, 49, 0.49);
  -webkit-box-shadow: 4px 4x 0px 0px rgba(0, 66, 49, 0.49);
  -moz-box-shadow: 4px 4px 0px 0px rgba(0, 66, 49, 0.49);
}
@media screen and (max-width: 800px) {
  .header_consultation_btn {
    font-size: 2.64vw;
  }
}
.header_consultation_btn:hover {
  background-color: #005742;
}
@media screen and (max-width: 800px) {
  .header_consultation_btn {
    padding: 3vw 2vw;
    font-size: 4vw;
  }
}
.header_center_contact_phone_block {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  margin-left: 1vw;
  gap: 1vw;
}
@media screen and (max-width: 800px) {
  .header_center_contact_phone_block {
    flex-direction: column;
    align-items: center;
  }
}
.header_center_contact_icon {
  width: 1.4vw;
  height: 1.3vw;
  outline: unset;
  outline-offset: -2px;
  background-color: #004231;
  padding: 0.4vw 0.4vw;
  box-shadow: 4px 4px 0px 0px rgba(0, 66, 49, 0.49);
  -webkit-box-shadow: 4px 4x 0px 0px rgba(0, 66, 49, 0.49);
  -moz-box-shadow: 4px 4px 0px 0px rgba(0, 66, 49, 0.49);
}
.header_center_contact_icon img {
  object-fit: contein;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .header_center_contact_icon {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
.header_center_contact_icon img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .header_center_contact_icon {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
@media screen and (max-width: 800px) {
  .header_center_contact_icon {
    width: 6vw;
    height: 6vw;
    margin-top: 4vw;
    padding: 1vw 1vw;
  }
}
.header_center_contact_phone {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
}
@media screen and (max-width: 800px) {
  .header_center_contact_phone {
    flex-direction: column;
    align-items: center;
  }
}
.header_center_contact_phone .phone_title {
  font-size: 0.88vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #004231;
}
@media screen and (max-width: 800px) {
  .header_center_contact_phone .phone_title {
    font-size: 2.64vw;
  }
}
@media screen and (max-width: 800px) {
  .header_center_contact_phone .phone_title {
    font-size: 4.5vw;
    font-weight: 900;
  }
}
.header_center_contact_phone .phone_num {
  font-size: 0.99vw;
  font-family: 'Pragmatica';
  font-weight: 600;
  color: #004231;
}
@media screen and (max-width: 800px) {
  .header_center_contact_phone .phone_num {
    font-size: 2.97vw;
  }
}
@media screen and (max-width: 800px) {
  .header_center_contact_phone .phone_num {
    font-size: 4vw;
    font-family: 'Montserrat';
    font-weight: 600;
  }
}
.mobile_header_num {
  display: none;
}
@media screen and (max-width: 800px) {
  .mobile_header_num {
    display: block;
  }
}
.header_line_mask {
  display: none;
}
.sticky {
  width: 90%;
  padding-left: 5%;
  padding-right: 5%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  padding-top: 1vw;
  padding-bottom: 1vw;
}
.sticky .logo_img_cover {
  width: 3.5vw;
  height: 3.5vw;
}
.sticky .header_contacts_cover {
  font-size: 1.21vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #004231;
}
@media screen and (max-width: 800px) {
  .sticky .header_contacts_cover {
    font-size: 3.63vw;
  }
}
.sticky .header_line_mask {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  background-color: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.sticky + .header_slider_body {
  margin-top: 8vw;
}
/* projects_fotogalery_01@projects_fotogalery_01_catalog.less */
.our__works__slider__block {
  width: 95%;
  height: auto;
  padding-left: 2.5%;
  padding-right: 2.5%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  margin-top: 3vw;
  margin-bottom: 4vw;
  gap: 2vw;
}
@media screen and (max-width: 800px) {
  .our__works__slider__block {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .our__works__slider__block {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .our__works__slider__block {
    margin: 8vw 0;
  }
}
.our__works__slider__box {
  width: 100%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2vw;
}
@media screen and (max-width: 800px) {
  .our__works__slider__box {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .our__works__slider__box {
    flex-direction: column;
    align-items: center;
  }
}
.our__works__slider__line {
  width: 100%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  overflow: hidden;
}
@media screen and (max-width: 800px) {
  .our__works__slider__line {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .our__works__slider__line {
    flex-direction: column;
    align-items: center;
  }
}
.our__works__slider__body {
  width: 100%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  position: relative;
  gap: 1vw 3%;
}
@media screen and (max-width: 800px) {
  .our__works__slider__body {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .our__works__slider__body {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .our__works__slider__body {
    flex-direction: row;
  }
}
.our__works__slider__item {
  width: 22%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  position: relative;
  flex: 0 0 auto;
  -webkit-box-shadow: 7px 6px 13px 1px #dcbb89;
  -moz-box-shadow: 7px 6px 13px 1px #dcbb89;
  box-shadow: 7px 6px 13px 1px #dcbb89;
}
@media screen and (max-width: 800px) {
  .our__works__slider__item {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .our__works__slider__item {
    box-shadow: unset;
    margin: 0;
    height: 90%;
  }
}
.our__works__item__wrapper {
  width: 100%;
  height: 25vw;
  outline: unset;
  outline-offset: -2px;
  position: relative;
  outline: 3px solid #146451;
  outline-offset: -3px;
}
.our__works__item__wrapper img {
  object-fit: contein;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .our__works__item__wrapper {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
.our__works__item__wrapper img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .our__works__item__wrapper {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
@media screen and (max-width: 800px) {
  .our__works__item__wrapper {
    height: 100%;
  }
}
.our__works__item__mask {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: 2;
  background-color: rgba(20, 100, 81, 0.2);
}
.our__works__item__content__box {
  width: 100%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 3;
}
@media screen and (max-width: 800px) {
  .our__works__item__content__box {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .our__works__item__content__box {
    flex-direction: column;
    align-items: center;
  }
}
.our__works__item__content__box .our__works__item__content__title {
  width: 100%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  font-size: 1.65vw;
  font-family: 'Montserrat';
  font-weight: 400;
  color: #ffffff;
  font-family: 'IMPACT';
  text-align: center;
  padding: 1.5vw 0;
  background-color: rgba(0, 87, 66, 0.8);
}
@media screen and (max-width: 800px) {
  .our__works__item__content__box .our__works__item__content__title {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .our__works__item__content__box .our__works__item__content__title {
    font-size: 4.95vw;
  }
}
.our__works__item__content__box .our__works__item__content__btn {
  width: 32%;
  height: auto;
  padding-left: 4%;
  padding-right: 4%;
  font-size: 1.32vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #ffffff;
  position: absolute;
  right: -0.3vw;
  bottom: -0.3vw;
  padding-top: 1vw;
  padding-bottom: 1vw;
  padding-right: 25%;
  background-color: #005742;
  background-image: url(/public/img/arrow.png);
  background-position: 85% 53%;
  background-size: 2.4vw 1.4vw;
  background-repeat: no-repeat;
  transition: .6s;
  cursor: pointer;
}
@media screen and (max-width: 800px) {
  .our__works__item__content__box .our__works__item__content__btn {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .our__works__item__content__box .our__works__item__content__btn {
    font-size: 3.96vw;
  }
}
@media screen and (max-width: 800px) {
  .our__works__item__content__box .our__works__item__content__btn {
    width: 50%;
    height: auto;
    padding-left: 5%;
    padding-right: 5%;
    bottom: 0;
    right: 0;
    padding-top: 2vw;
    padding-bottom: 2vw;
    background-size: 10vw 6vw;
  }
}
@media screen and (max-width: 800px) and screen and (max-width: 800px) {
  .our__works__item__content__box .our__works__item__content__btn {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
.our__works__item__content__box .our__works__item__content__btn:hover {
  background-color: #00503d;
  background-position: 90% 53%;
}
.our__works__navigation__block {
  width: 100%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  display: none;
}
@media screen and (max-width: 800px) {
  .our__works__navigation__block {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .our__works__navigation__block {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .our__works__navigation__block {
    gap: 6vw;
  }
}
.our__works__arrows__box {
  width: 10%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 800px) {
  .our__works__arrows__box {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .our__works__arrows__box {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .our__works__arrows__box {
    flex-direction: row;
  }
}
.our__works__arrows__box .left__arrow {
  border-radius: 30px 0 0 30px;
}
.our__works__arrows__box .right__arrow {
  border-radius: 0 30px 30px 0;
}
.our__works__arrows__wrapper {
  width: 3vw;
  height: auto;
  outline: unset;
  outline-offset: -2px;
  padding: 0.3vw 0.7vw;
  background-color: #005742;
  cursor: pointer;
  transition: .6s;
}
.our__works__arrows__wrapper img {
  object-fit: contein;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .our__works__arrows__wrapper {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
.our__works__arrows__wrapper img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .our__works__arrows__wrapper {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
@media screen and (max-width: 800px) {
  .our__works__arrows__wrapper {
    width: 8%;
    padding: 2.3vw 2.7vw;
  }
}
.our__works__arrows__wrapper:hover {
  background-color: #00432e;
}
.our__works__more__btn {
  width: 22vw;
  height: auto;
  padding-left: 2.5vw;
  padding-right: 2.5vw;
  font-size: 1.43vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #ffffff;
  background-color: #004231;
  padding-top: 1vw;
  padding-bottom: 1vw;
  padding-right: 8%;
  background-image: url(/public/img/arrow__long__w.png);
  background-position: 85% 53%;
  background-size: 3vw 1.4vw;
  background-repeat: no-repeat;
  transition: .6s;
  cursor: pointer;
}
@media screen and (max-width: 800px) {
  .our__works__more__btn {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .our__works__more__btn {
    font-size: 4.29vw;
  }
}
@media screen and (max-width: 800px) {
  .our__works__more__btn {
    width: 80vw;
    height: auto;
    padding-left: 5vw;
    padding-right: 5vw;
    background-size: 9vw 6vw;
    padding-top: 3vw;
    padding-bottom: 3vw;
  }
}
@media screen and (max-width: 800px) and screen and (max-width: 800px) {
  .our__works__more__btn {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
.our__works__more__btn:hover {
  background-color: #1e604f;
  background-position: 90% 53%;
}
.gallery__projects__mask {
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  position: fixed;
  top: 0;
  left: 101vw;
  width: 100vw;
  height: 100vh;
  z-index: 9999;
}
@media screen and (max-width: 800px) {
  .gallery__projects__mask {
    flex-direction: column;
    align-items: center;
  }
}
#window__projects__photo__gallery {
  width: 90%;
  height: 90vh;
  padding-left: 0%;
  padding-right: 0%;
  overflow: hidden;
}
@media screen and (max-width: 800px) {
  #window__projects__photo__gallery {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  #window__projects__photo__gallery {
    height: 98vh;
  }
}
#window__projects__photo__gallery,
#window__projects__photo__gallery object {
  width: 90%;
  height: 90%;
  margin-left: 3%;
  padding-right: 1%;
  padding-left: 1%;
}
#page_load_block object body {
  background-color: unset;
}
.implementations__block {
  width: 95%;
  height: auto;
  padding-left: 2.5%;
  padding-right: 2.5%;
  margin-top: 3vw;
  margin-bottom: 4vw;
  position: relative;
}
@media screen and (max-width: 800px) {
  .implementations__block {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
.implementations__block h2 {
  font-size: 2.2vw;
  font-family: 'Montserrat';
  font-weight: 800;
  color: #000000;
}
@media screen and (max-width: 800px) {
  .implementations__block h2 {
    font-size: 6.6vw;
  }
}
.implementations__box {
  width: 100%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin-top: 4vw;
  gap: 2vw 1%;
}
@media screen and (max-width: 800px) {
  .implementations__box {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .implementations__box {
    flex-direction: column;
    align-items: center;
  }
}
.implementations__box .our__works__slider__item {
  width: 24%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  margin: 0;
}
@media screen and (max-width: 800px) {
  .implementations__box .our__works__slider__item {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
/* template@modal_menu.less */
/*MODAL MENU*/
#modal_menu_mask {
  width: 100vw;
  height: 100vh;
  position: fixed;
  z-index: 1000;
  left: 100vw;
  top: 0;
  background: rgba(0, 0, 0, 0.8);
}
.modal_menu {
  width: 36%;
  height: 100dvh;
  padding-left: 2%;
  padding-right: 2%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #fff;
}
@media screen and (max-width: 800px) {
  .modal_menu {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .modal_menu {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .modal_menu {
    background-color: rgba(255, 255, 255, 0.9);
  }
}
.modal_menu_logo {
  width: 25%;
  height: cover;
  outline: unset;
  outline-offset: -2px;
}
.modal_menu_logo img {
  object-fit: contein;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .modal_menu_logo {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
.modal_menu_logo img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .modal_menu_logo {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
@media screen and (max-width: 800px) {
  .modal_menu_logo {
    width: 30%;
    display: none;
  }
}
.modal_menu nav {
  width: 70%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  margin-top: 3vw;
}
@media screen and (max-width: 800px) {
  .modal_menu nav {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .modal_menu nav {
    width: 90%;
  }
}
.modal_menu nav ul {
  width: 100%;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 1vw;
}
@media screen and (max-width: 800px) {
  .modal_menu nav ul {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .modal_menu nav ul {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .modal_menu nav ul {
    align-items: flex-start;
    gap: 3vw;
  }
}
.modal_menu nav li {
  list-style: none;
}
.modal__menu__item {
  font-size: 1.65vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #004231;
  padding-left: 1vw;
  padding-top: 0.4vw;
  padding-bottom: 0.4vw;
  padding-right: 1vw;
  transition: .4s;
}
@media screen and (max-width: 800px) {
  .modal__menu__item {
    font-size: 4.95vw;
  }
}
.modal__menu__item:hover {
  font-size: 1.65vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #ffffff;
  background-color: #004231;
  padding-left: 1.5vw;
}
@media screen and (max-width: 800px) {
  .modal__menu__item:hover {
    font-size: 4.95vw;
  }
}
@media screen and (max-width: 800px) {
  .modal__menu__item:hover {
    font-size: 4.5vw;
  }
}
@media screen and (max-width: 800px) {
  .modal__menu__item {
    font-size: 4.5vw;
  }
}
/* template@header_forma.less */
.forma_fixed_block {
  width: 100vw;
  height: 100dvh;
  padding-left: 0;
  padding-right: 0;
  position: fixed;
  top: 0;
  right: -103vw;
  z-index: 1000;
}
@media screen and (max-width: 800px) {
  .forma_fixed_block {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
.forma_mask {
  background-color: rgba(0, 0, 0, 0.2);
  width: 100vw;
  height: 100dvh;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index: -1;
  position: absolute;
  top: 0;
  left: 0;
}
.modal_forma_body {
  width: 40vw;
  height: 100dvh;
  padding-left: 1vw;
  padding-right: 1vw;
  background-color: rgba(0, 66, 49, 0.6);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 800px) {
  .modal_forma_body {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  .modal_forma_body {
    flex-direction: column;
    align-items: center;
  }
}
.modal_forma_body .forma_subtitle_type_1 {
  color: #fff;
}
.modal_forma_body .forma_type1_input {
  background-color: rgba(255, 255, 255, 0.8);
}
@media screen and (max-width: 800px) {
  .modal_forma_body {
    width: 94%;
    padding-left: 3%;
    padding-right: 3%;
  }
}
/* template@footer.less */
footer {
  min-height: 40vh;
  border-top: 3px solid #004231;
  width: 90%;
  height: auto;
  padding-left: 5%;
  padding-right: 5%;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  margin-top: 4vw;
}
@media screen and (max-width: 800px) {
  footer {
    width: 100%;
    padding: unset;
    margin-left: unset;
    margin-right: unset;
  }
}
@media screen and (max-width: 800px) {
  footer {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  footer {
    padding-bottom: 6vw;
    margin-top: 4vw;
    padding-top: 3vw;
  }
}
.logo_cover {
  width: 12%;
  height: auto;
  outline: unset;
  outline-offset: -2px;
}
.logo_cover img {
  object-fit: contein;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .logo_cover {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
.logo_cover img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .logo_cover {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
@media screen and (max-width: 800px) {
  .logo_cover {
    width: 40%;
  }
}
.footer_contacts {
  width: 26%;
  height: auto;
  outline: unset;
  outline-offset: -2px;
}
.footer_contacts img {
  object-fit: contein;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .footer_contacts {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
.footer_contacts img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .footer_contacts {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
@media screen and (max-width: 800px) {
  .footer_contacts {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 80%;
  }
}
.footer_contacts_item {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  margin-top: 0.5vw;
}
@media screen and (max-width: 800px) {
  .footer_contacts_item {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .footer_contacts_item {
    margin-top: 1vw;
    width: 90%;
    background-color: rgba(255, 255, 255, 0.05);
    outline: 2px solid rgba(255, 255, 255, 0.2);
    margin-left: 0%;
    padding-top: 1vw;
    padding-bottom: 1vw;
    flex-direction: column;
    margin-top: 2vw;
  }
}
.contact_img_cover {
  width: 1.4vw;
  height: 1.4vw;
  outline: unset;
  outline-offset: -2px;
  margin-right: 1vw;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.contact_img_cover img {
  object-fit: contein;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .contact_img_cover {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
.contact_img_cover img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .contact_img_cover {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
@media screen and (max-width: 800px) {
  .contact_img_cover {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .contact_img_cover {
    height: 3vw;
    width: 3vw;
    margin-right: 0vw;
  }
}
.contact_text_cover {
  width: 80%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
}
@media screen and (max-width: 800px) {
  .contact_text_cover {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .contact_text_cover {
    align-items: center;
    gap: 0.5vw 0;
    text-align: center;
    width: 100%;
  }
}
.contact_text_cover a {
  display: block;
  width: 100%;
}
.contact_text_cover .contact_text {
  font-size: 1.32vw;
  font-family: 'Montserrat';
  font-weight: 400;
  color: #004231;
  width: 90%;
}
@media screen and (max-width: 800px) {
  .contact_text_cover .contact_text {
    font-size: 3.96vw;
  }
}
@media screen and (max-width: 800px) {
  .contact_text_cover .contact_text {
    text-align: center;
    width: 100%;
  }
}
.contact_text_cover .contact_title {
  font-size: 0.99vw;
  font-family: 'Montserrat';
  font-weight: 800;
  color: #004231;
}
@media screen and (max-width: 800px) {
  .contact_text_cover .contact_title {
    font-size: 2.97vw;
  }
}
@media screen and (max-width: 800px) {
  .contact_text_cover .contact_title {
    width: 100%;
  }
}
.footer_contacts_title {
  font-size: 1.43vw;
  font-family: 'Montserrat';
  font-weight: 600;
  color: #004231;
}
@media screen and (max-width: 800px) {
  .footer_contacts_title {
    font-size: 4.29vw;
  }
}
@media screen and (max-width: 800px) {
  .footer_contacts_title {
    margin-top: 1vw;
  }
}
.icon_item {
  width: 3vw;
  height: auto;
  outline: unset;
  outline-offset: -2px;
}
.icon_item img {
  object-fit: contein;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .icon_item {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
.icon_item img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 800px) {
  .icon_item {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    flex-grow: -1;
  }
}
@media screen and (max-width: 800px) {
  .icon_item {
    width: 10vw;
    height: 10vw;
  }
  .icon_item img {
    object-fit: contain;
  }
}
.icons_cover {
  width: 25%;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.6vw;
}
@media screen and (max-width: 800px) {
  .icons_cover {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .icons_cover {
    flex-direction: row;
    width: 70%;
    margin-top: 6vw;
    margin-bottom: 6vw;
    gap: 2vw;
  }
}
.icons_title {
  width: 100%;
  font-size: 1.32vw;
  font-family: 'Pragmatica';
  font-weight: 600;
  color: #004231;
  text-align: center;
}
@media screen and (max-width: 800px) {
  .icons_title {
    font-size: 3.96vw;
  }
}
