@import "includes/scss/swiper-bundle.min.css";
*, *:before, *:after {
  box-sizing: border-box;
}

html, body, div, span, object, iframe, figure, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, code, em, img, small, strike, strong, sub, sup, tt, b, u, i, ol, ul, li, fieldset, form, label, table, caption, tbody, tfoot, thead, tr, th, td, main, canvas, embed, footer, header, nav, section, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  text-size-adjust: none;
}

footer, header, nav, section, main {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

input {
  -webkit-appearance: none;
  border-radius: 0;
}

.hide-scrollbars {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.hide-scrollbars::-webkit-scrollbar {
  display: none;
}

@font-face {
  font-family: "Raleway";
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
  src: url("includes/fonts/Raleway-Italic-VariableFont_wght.ttf") format("true type");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Raleway";
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("includes/fonts/Raleway-VariableFont_wght.ttf") format("true type");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Bitter";
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
  src: url("includes/fonts/Bitter-Italic-VariableFont_wght.ttf") format("true type");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Bitter";
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("includes/fonts/Bitter-VariableFont_wght.ttf") format("true type");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
html, body {
  color: #2f4858;
  font-family: Bitter, sans-serif;
  font-size: 16px;
  line-height: 1.3;
  scroll-behavior: smooth;
  scroll-padding-top: 5rem;
}

b, strong {
  font-weight: bold;
}

i, em {
  font-style: italic;
}

.bg--gray {
  background: #e8ecef;
}
.bg--gray .h1::after, .bg--gray .h2::after, .bg--gray .h3::after {
  background: #006d8c;
}
.bg--dark {
  background: #2f4858;
  color: white;
}
.bg--dark .h1::after, .bg--dark .h2::after, .bg--dark .h3::after {
  background: #d0e5b3;
}
.bg--dark a {
  color: #d0e5b3;
  text-decoration: none;
}

.h1, .h2, .h3 {
  position: relative;
  font-family: Raleway, sans-serif;
  font-weight: 700;
  line-height: 1.1;
}
.h1::after, .h2::after, .h3::after {
  content: "";
  background: #d0e5b3;
  position: relative;
  display: block;
  width: 5rem;
  height: 0.3125rem;
  margin-top: 1.25rem;
}

.h1 {
  font-size: clamp(30px, 6vw, 50px);
  margin-bottom: 1.25rem;
}

.h2 {
  font-size: clamp(25px, 4vw, 40px);
  margin-bottom: 1.25rem;
}

.h3 {
  font-size: clamp(18px, 3vw, 25px);
  margin-bottom: 0.625rem;
}
.h3::after {
  content: none;
}

.descr {
  position: relative;
  display: block;
  font-size: clamp(16px, 2vw, 19px);
  margin-bottom: 1.25rem;
}

.btn {
  background: #006d8c;
  position: relative;
  display: inline-block;
  padding: 0.8em 1.2em calc(0.8em - 3px);
  color: white;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: none;
  text-decoration: none;
  border-bottom: solid 0.3125rem #00546a;
  transition: 0.3s ease-in-out;
  cursor: pointer;
}
.btn:hover {
  background: #00546a;
}
.btn--white {
  background: white;
  border-bottom-color: #d6d6d6;
  color: #00546a;
  font-weight: 600;
}
.btn--white:hover {
  background: #d6d6d6;
}

#wrapper {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
}

#header {
  background: #0f101f;
  position: sticky;
  display: block;
  top: 0;
  margin-top: 0;
  border-bottom: solid 0.1875rem #006d8c;
  z-index: 100;
  box-shadow: 0 0 0.625rem rgba(15, 16, 31, 0.5);
}
#header .branding {
  position: relative;
  display: inline-block;
  width: auto;
  padding: 0.625rem 0;
  height: 5rem;
}
#header .branding svg {
  position: relative;
  display: block;
  width: auto;
  height: 100%;
}

#container {
  flex: 1;
}

.module {
  position: relative;
  display: block;
  padding: clamp(35px, 7vw, 70px) 0;
  overflow: clip;
}
.module__wrap {
  position: relative;
  display: block;
  max-width: 56.25rem;
  margin: 0 auto;
  padding: 0 clamp(20px, 3vw, 30px);
}

.keyvisual {
  position: relative;
  display: flex;
  width: 100%;
  min-height: 75vh;
  padding-bottom: 0;
  align-items: flex-end;
}
.keyvisual .module__wrap {
  background: rgba(47, 72, 88, 0.25);
  padding-top: clamp(35px, 7vw, 70px);
  padding-bottom: clamp(70px, 14vw, 140px);
  color: white;
  backdrop-filter: blur(0.1875rem);
  opacity: 1;
  transform: translateY(0);
  transition: 0.6s ease-in-out;
}
.keyvisual__thumb {
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
.keyvisual__thumb img {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  object-fit: cover;
  object-position: center right;
}
.keyvisual__title, .keyvisual__descr {
  text-shadow: 0 0.3125rem 0.625rem rgba(47, 72, 88, 0.5);
}
.keyvisual__title {
  opacity: 1;
  transform: translateY(0);
  transition: 0.6s ease-in-out 0.1s;
}
.keyvisual__descr {
  opacity: 1;
  transform: translateY(0);
  transition: 0.6s ease-in-out 0.2s;
}
.keyvisual .buttons {
  opacity: 1;
  transform: translateY(0);
  transition: 0.6s ease-in-out 0.3s;
}
.keyvisual.js-transition .module__wrap {
  opacity: 0;
  transform: translateY(2.1875rem);
  transition: 0.6s ease-in-out;
}
.keyvisual.js-transition .keyvisual__title {
  opacity: 0;
  transform: translateY(2.1875rem);
}
.keyvisual.js-transition .keyvisual__descr {
  opacity: 0;
  transform: translateY(2.1875rem);
}
.keyvisual.js-transition .buttons {
  opacity: 0;
  transform: translateY(2.1875rem);
}

.textblock .module__wrap {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  flex-direction: column-reverse;
}
@media only screen and (min-width: 768px) {
  .textblock .module__wrap {
    flex-direction: unset;
    gap: 2.1875rem;
    justify-content: center;
    align-items: center;
  }
  .textblock .module__wrap > * {
    position: relative;
    display: block;
    width: calc((100% - 35px) / 2);
  }
}
.textblock__thumb {
  position: relative;
  display: block;
  margin: clamp(-70px, -7vw, -35px);
  margin-top: 1.25rem;
  aspect-ratio: 3/2;
  opacity: 1;
  transform: translateX(0);
  transition: 0.6s ease-in-out;
}
@media only screen and (min-width: 768px) {
  .textblock__thumb {
    margin: 0;
    aspect-ratio: 1;
  }
}
.textblock__thumb img {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  object-fit: cover;
  object-position: center;
}
.textblock__info {
  opacity: 1;
  transform: translateX(0);
  transition: 0.6s ease-in-out;
}
.textblock.js-transition .textblock__info {
  opacity: 0;
  transform: translateX(2.1875rem);
}
.textblock.js-transition .textblock__thumb {
  opacity: 0;
  transform: translateX(-2.1875rem);
}

.services {
  position: relative;
  display: block;
}
.services__title {
  opacity: 1;
  transform: translateY(0);
  transition: 0.6s ease-in-out;
}
.services__descr {
  opacity: 1;
  transform: translateY(0);
  transition: 0.6s ease-in-out;
}
.services-list {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  padding-top: clamp(10px, 2vw, 35px);
}
.services-item {
  position: relative;
  display: flex;
  width: 100%;
  padding-bottom: 1.25rem;
  gap: 1.25rem;
  opacity: 1;
  transform: translateX(0);
}
@media only screen and (min-width: 768px) {
  .services-item {
    width: calc((100% - 20px) / 2);
    border-bottom: none;
  }
}
.services-item:not(:last-of-type) {
  border-bottom: solid 0.0625rem #d6d6d6;
}
@media only screen and (min-width: 768px) {
  .services-item:not(:last-of-type) {
    border-bottom: none;
  }
}
.services-item__icon {
  position: relative;
  display: block;
  width: 3.125rem;
  aspect-ratio: 1;
  border-radius: 100%;
}
.services-item__icon img {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 1;
  margin: 0;
  padding: 0;
  object-fit: contain;
  object-position: center;
}
.services-item__info {
  flex: 1;
}
.services-item:nth-of-type(1) {
  transition: 0.6s ease-in-out 0.1s;
}
.services-item:nth-of-type(2) {
  transition: 0.6s ease-in-out 0.2s;
}
.services-item:nth-of-type(3) {
  transition: 0.6s ease-in-out 0.3s;
}
.services-item:nth-of-type(4) {
  transition: 0.6s ease-in-out 0.4s;
}
.services-item:nth-of-type(5) {
  transition: 0.6s ease-in-out 0.5s;
}
.services-item:nth-of-type(6) {
  transition: 0.6s ease-in-out 0.6s;
}
.services-item:nth-of-type(7) {
  transition: 0.6s ease-in-out 0.7s;
}
.services-item:nth-of-type(8) {
  transition: 0.6s ease-in-out 0.8s;
}
.services-item:nth-of-type(9) {
  transition: 0.6s ease-in-out 0.9s;
}
.services-item:nth-of-type(10) {
  transition: 0.6s ease-in-out 1s;
}
.services.js-transition .services__title {
  opacity: 0;
  transform: translateY(2.1875rem);
}
.services.js-transition .services__descr {
  opacity: 0;
  transform: translateY(2.1875rem);
}
.services.js-transition .services-item:nth-of-type(2n + 1) {
  opacity: 0;
  transform: translateX(-2.1875rem);
}
.services.js-transition .services-item:nth-of-type(2n + 2) {
  opacity: 0;
  transform: translateX(2.1875rem);
}

@media only screen and (min-width: 768px) {
  .form .module__wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 1.25rem;
  }
}
@media only screen and (min-width: 768px) {
  .form .module__wrap > div {
    display: flex;
    width: calc((100% - 20px) / 2);
  }
  .form .module__wrap > div:first-of-type {
    flex-direction: column;
  }
  .form .module__wrap > div:first-of-type > div:first-of-type {
    flex: 1;
  }
  .form .module__wrap > div:last-of-type {
    flex-direction: column;
  }
}
.form #emailrepeat {
  position: absolute;
  display: block;
  width: 0;
  height: 0;
  top: 0;
  left: 0;
  opacity: 0;
  pointer-events: none;
}

form {
  position: relative;
  display: block;
  width: 100%;
  padding-top: 3.125rem;
}
@media only screen and (min-width: 768px) {
  form {
    padding-top: 0;
    padding-left: 4.375rem;
  }
}
form > div {
  position: relative;
  display: block;
  margin-bottom: 1.25rem;
}
form input,
form textarea,
form select {
  background: none;
  position: relative;
  display: block;
  width: 100%;
  padding: 0.625rem 0.75rem 0.5rem;
  color: white;
  font-weight: 500;
  font-size: inherit;
  letter-spacing: 0.05em;
  border: solid 0.0625rem rgba(214, 214, 214, 0.5);
}
form input + label,
form textarea + label,
form select + label {
  background: #2f4858;
  position: absolute;
  display: block;
  padding: 0 0.1875rem;
  top: -0.625rem;
  left: 0.625rem;
  font-size: 0.8em;
  letter-spacing: 0.05em;
}
form input + label span,
form textarea + label span,
form select + label span {
  color: #d0e5b3;
}
form input:focus,
form textarea:focus,
form select:focus {
  outline: none;
}
form textarea {
  appearance: none;
  resize: none;
  min-width: 100%;
  width: 100%;
  max-width: 100%;
  min-height: 9.375rem;
  height: 9.375rem;
  max-height: 9.375rem;
}
form .btn {
  border-top: none;
  border-right: none;
  border-left: none;
}

.form-feedback {
  font-size: 0.9em;
  text-align: center;
  padding: 1rem;
  margin-bottom: 2rem;
}
@media only screen and (min-width: 768px) {
  .form-feedback {
    margin-left: 4.375rem;
  }
}
.form-feedback--success {
  background: #e8ecef;
  color: #006d8c;
}
.form-feedback--error {
  background: #e8ecef;
  color: #970353;
}

.gallery {
  position: relative;
  display: block;
  padding: 0;
}
.gallery-item {
  position: relative;
  display: block;
  width: 66.6666666667%;
  margin: 0 !important;
  aspect-ratio: 1;
}
@media only screen and (min-width: 768px) {
  .gallery-item {
    width: auto;
    height: 25rem;
    aspect-ratio: 3/2;
  }
}
.gallery-item img {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  object-fit: cover;
  object-position: center;
}

.branding__text path {
  fill: #d6d6d6;
}
.branding__lines {
  fill: #d0e5b3;
}

#footer {
  background: #0f101f;
  position: sticky;
  display: block;
  top: 0;
  margin-top: 0;
  z-index: 100;
  box-shadow: 0 0 0.625rem rgba(15, 16, 31, 0.5);
}
#footer > div {
  padding: 1.25rem 0;
}
#footer ul {
  position: relative;
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  column-gap: 1.875rem;
  row-gap: 1.25rem;
  text-align: center;
}
#footer ul li {
  color: #2f4858;
}
#footer ul li a {
  color: #006d8c;
  text-decoration: none;
}

.texteditor h2 {
  position: relative;
  display: block;
  margin: 2em 0 1em;
}
.texteditor a {
  color: #006d8c;
  text-decoration: none;
}
.texteditor ul {
  position: relative;
  display: block;
  list-style: disc;
  line-height: 1.5;
  padding: 1rem 0 1rem 1rem;
}

/*# sourceMappingURL=style.css.map */
