h1 {
  font-size: 1.29616rem;
  line-height: 1.2em;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
}

@media screen and (min-width: 30rem) {
  h1 {
    font-size: calc(1.29616rem + 1.14525 * (100vw - 30rem) / 45);
  }
}

@media screen and (min-width: 75rem) {
  h1 {
    font-size: 2.44141rem;
  }
}

@media (min-width: 40em) {
  h1 {
    margin-bottom: 2.25rem;
  }
}

h2 {
  font-size: 1.21477rem;
  line-height: 1.2em;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
}

@media screen and (min-width: 30rem) {
  h2 {
    font-size: calc(1.21477rem + 0.73836 * (100vw - 30rem) / 45);
  }
}

@media screen and (min-width: 75rem) {
  h2 {
    font-size: 1.95312rem;
  }
}

@media (min-width: 40em) {
  h2 {
    margin-top: 2.25rem;
    margin-bottom: 2.25rem;
  }
}

h3 {
  font-size: 1.13849rem;
  line-height: 1em;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
}

@media screen and (min-width: 30rem) {
  h3 {
    font-size: calc(1.13849rem + 0.42401 * (100vw - 30rem) / 45);
  }
}

@media screen and (min-width: 75rem) {
  h3 {
    font-size: 1.5625rem;
  }
}

h4 {
  font-size: 1.067rem;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
}

@media screen and (min-width: 30rem) {
  h4 {
    font-size: calc(1.067rem + 0.183 * (100vw - 30rem) / 45);
  }
}

@media screen and (min-width: 75rem) {
  h4 {
    font-size: 1.25rem;
  }
}

h5 {
  font-size: 1rem;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
}

@media screen and (min-width: 30rem) {
  h5 {
    font-size: calc(1rem + 0 * (100vw - 30rem) / 45);
  }
}

@media screen and (min-width: 75rem) {
  h5 {
    font-size: 1rem;
  }
}

h6 {
  font-size: 0.93721rem;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
}

@media screen and (min-width: 30rem) {
  h6 {
    font-size: calc(0.93721rem + -0.13721 * (100vw - 30rem) / 45);
  }
}

@media screen and (min-width: 75rem) {
  h6 {
    font-size: 0.8rem;
  }
}

.title-big {
  font-size: 4.768rem;
  line-height: 5rem;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  letter-spacing: -7px;
}

@media screen and (min-width: 30rem) {
  .title-big {
    font-size: calc(4.768rem + 7.882 * (100vw - 30rem) / 45);
  }
}

@media screen and (min-width: 75rem) {
  .title-big {
    font-size: 12.65rem;
  }
}

@media (min-width: 33.125em) {
  .title-big {
    line-height: 8rem;
  }
}

@media (min-width: 60em) {
  .title-big {
    line-height: 10.65rem;
    letter-spacing: -16px;
  }
}

@media (min-width: 100em) {
  .title-big {
    line-height: 12.65rem;
  }
}

.title-medium {
  font-size: 1.56rem;
  line-height: 2rem;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  letter-spacing: 4px;
}

@media screen and (min-width: 30rem) {
  .title-medium {
    font-size: calc(1.56rem + 2.34 * (100vw - 30rem) / 45);
  }
}

@media screen and (min-width: 75rem) {
  .title-medium {
    font-size: 3.9rem;
  }
}

@media (min-width: 75em) {
  .title-medium {
    line-height: 3.9rem;
  }
}

.layout-center,
.layout-center--form,
.component-gallery__content,
.component-gallery__content--carousel {
  margin-right: auto;
  margin-left: auto;
  padding: 0 10px;
  max-width: 1190px;
}

@media (min-width: 40em) {
  .layout-center--form {
    padding: 0 68px;
  }
}

.component-gallery {
  max-width: 635px;
  margin: 0 auto;
}

.component-gallery__wrapper {
  margin-bottom: 1.5rem;
}

@media (min-width: 40em) {
  .component-gallery__wrapper {
    margin-bottom: 2.5rem;
  }
}

.component-gallery__wrapper--blue {
  position: relative;
}

.component-gallery__wrapper--blue::before {
  content: '';
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 50%;
  background-color: #1764e2;
}

.component-gallery__wrapper--white {
  overflow: hidden;
  background-color: #fff;
  margin-bottom: 0;
}

@media (min-width: 40em) {
  .component-gallery__content {
    padding: 0 10%;
    margin-bottom: 1rem;
  }
}

.component-gallery__content, .component-gallery__content--carousel {
  position: relative;
  margin-top: 2rem;
  margin-bottom: 2rem;
  z-index: 1;
  text-align: center;
}

@media (min-width: 40em) {
  .component-gallery__content, .component-gallery__content--carousel {
    margin-top: 4rem;
    margin-bottom: 4rem;
  }
}

@media (min-width: 40em) {
  .component-gallery__content .component__title--left, .component-gallery__content--carousel .component__title--left {
    max-width: 70%;
  }
}

@media (min-width: 40em) {
  .component-gallery__content--carousel {
    padding: 0 3rem;
  }
}

.component-gallery__content--blue {
  margin-top: 0;
  padding-top: .1rem;
}

.component-gallery__content--blue .component__title,
.component-gallery__content--blue .component__title--left {
  color: #fff;
}

.component-gallery__content--blue .component__title::after,
.component-gallery__content--blue .component__title--left::after {
  background-color: #fff;
}

.component-gallery__content--blue .component__body,
.component-gallery__content--blue .component__body a,
.component-gallery__content--blue .component__body--left,
.component-gallery__content--blue .component__body--left a {
  color: #fff;
}

.slick-initialized.component-gallery--carousel .component-gallery__item.slick-slide {
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: center;
          justify-content: center;
  -webkit-box-align: center;
          align-items: center;
  min-height: 150px;
}

@media (min-width: 40em) {
  .slick-initialized.component-gallery--carousel .component-gallery__item.slick-slide {
    min-height: 200px;
  }
}

@media (min-width: 50em) {
  .slick-initialized.component-gallery--carousel .component-gallery__item.slick-slide {
    min-height: 220px;
  }
}

@media (min-width: 55.5em) {
  .slick-initialized.component-gallery--carousel .component-gallery__item.slick-slide {
    min-height: 250px;
  }
}

@media (min-width: 75em) {
  .slick-initialized.component-gallery--carousel .component-gallery__item.slick-slide {
    min-height: 265px;
  }
}

.component-gallery__link {
  position: relative;
  display: block;
}

.component-gallery__link::after {
  content: '';
  position: absolute;
  display: block;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0;
  background-color: transparent;
  transition: height 0.2s, color 0.2s;
}

.component-gallery__link:hover::after {
  height: 4px;
  background-color: #1764e2;
}

.component-gallery .component-gallery__link {
  box-shadow: 0 0 8px 0 rgba(69, 73, 91, 0.2);
}

.component-gallery .component-gallery__link:hover {
  box-shadow: 0 8px 9px 0 rgba(69, 73, 91, 0.2);
}

.component-gallery__readmore {
  margin-top: 4rem;
}

@media (min-width: 40em) {
  .component-gallery__readmore {
    position: absolute;
    top: 0;
    right: 0;
    margin-top: .5rem;
  }
  .component-gallery__content--blue .component-gallery__readmore {
    margin-top: 2rem;
    margin-right: 1rem;
    background-color: #fff;
    color: #173353;
  }
  .component-gallery__content--blue .component-gallery__readmore:hover, .component-gallery__content--blue .component-gallery__readmore:focus, .component-gallery__content--blue .component-gallery__readmore:active {
    background-color: #173353;
    color: #fff;
  }
}

.component-gallery button.slick-prev, .component-gallery button.slick-next,
.component-gallery [type='button'].slick-prev,
.component-gallery [type='button'].slick-next, .component-gallery--carousel button.slick-prev, .component-gallery--carousel button.slick-next,
.component-gallery--carousel [type='button'].slick-prev,
.component-gallery--carousel [type='button'].slick-next {
  position: absolute;
  width: 30px;
  height: 30px;
  padding: 0;
  box-shadow: none;
  overflow: hidden;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: transparent;
}

.component-gallery button.slick-prev::before, .component-gallery button.slick-next::before,
.component-gallery [type='button'].slick-prev::before,
.component-gallery [type='button'].slick-next::before, .component-gallery--carousel button.slick-prev::before, .component-gallery--carousel button.slick-next::before,
.component-gallery--carousel [type='button'].slick-prev::before,
.component-gallery--carousel [type='button'].slick-next::before {
  content: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 49 43"><path fill="none" stroke="%231764e2" stroke-width="4" d="M26.7 41.5l19.5-20.3L26.9 1M0 21.3h45.4"/></svg>');
}

.component-gallery button.slick-prev:hover, .component-gallery button.slick-next:hover,
.component-gallery [type='button'].slick-prev:hover,
.component-gallery [type='button'].slick-next:hover, .component-gallery--carousel button.slick-prev:hover, .component-gallery--carousel button.slick-next:hover,
.component-gallery--carousel [type='button'].slick-prev:hover,
.component-gallery--carousel [type='button'].slick-next:hover {
  box-shadow: none;
}

.component-gallery .slick-prev, .component-gallery--carousel .slick-prev {
  left: 30%;
  top: 100%;
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

@media (min-width: 50em) {
  .component-gallery .slick-prev, .component-gallery--carousel .slick-prev {
    top: calc(50% - 30px);
    left: -3rem;
  }
}

.component-gallery .slick-next, .component-gallery--carousel .slick-next {
  right: 30%;
  top: 111%;
}

@media (min-width: 50em) {
  .component-gallery .slick-next, .component-gallery--carousel .slick-next {
    top: calc(50% - 12px);
    right: -3rem;
  }
}

.component-gallery .slick-dots, .component-gallery--carousel .slick-dots {
  bottom: -40px;
}

.component-gallery .slick-dots li button, .component-gallery--carousel .slick-dots li button {
  width: 12px;
  height: 12px;
  background-color: rgba(69, 73, 91, 0.2);
}

.component-gallery .slick-dots li button::before, .component-gallery--carousel .slick-dots li button::before {
  content: '';
}

.component-gallery .slick-dots li.slick-active button, .component-gallery--carousel .slick-dots li.slick-active button {
  background-color: #1764e2;
}

.component-gallery .slick-dots {
  bottom: -40px;
}

.component-gallery--carousel .slick-dots {
  bottom: -30px;
}
