/*Media*/
/*Colors*/
/*Fonts*/
/*General*/
html {
  font-size: 62.5%;
}
html,
body {
  height: 100%;
  font-family: 'Montserrat', sans-serif;
}
html div,
body div {
  box-sizing: border-box;
}
body {
  display: flex;
  flex-direction: column;
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  min-width: 320px;
  font-size: 1.5rem;
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: subpixel-antialiased;
  padding: 0;
  margin: 0;
}
.content {
  flex: 1 0 auto;
  overflow: hidden;
}
.content__header {
  position: relative;
  overflow: hidden;
  background-color: #D6FE51;
}
input,
textarea,
button,
select {
  font-family: 'Montserrat', sans-serif;
}
input[type="number"] {
  -moz-appearance: textfield;
}
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
}
button {
  margin: 0;
}
button:not(:disabled) {
  cursor: pointer;
}
button:disabled {
  opacity: 0.5;
}
.container {
  max-width: 156rem;
  padding-left: 3.5rem;
  padding-right: 3.5rem;
  box-sizing: border-box;
  margin-left: auto;
  margin-right: auto;
}
@media print, (min-width: 1280px) {
  .container {
    padding-left: 10rem;
    padding-right: 10rem;
  }
}
/*
	This will hide the focus indicator if the element receives focus via the mouse,
	but it will still show up on keyboard focus.
*/
.js-focus-visible :focus:not(.focus-visible) {
  outline: none;
}
.ht {
  margin: 0;
  color: #000000;
}
.ht--h2 {
  font-weight: 700;
  font-size: 2.8rem;
  line-height: 1.2em;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
@media print, (min-width: 1280px) {
  .ht--h2 {
    font-size: 7.7rem;
  }
}
.ht--h3 {
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.2em;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
@media print, (min-width: 1280px) {
  .ht--h3 {
    font-size: 3.3rem;
  }
}
.btn {
  display: inline-flex;
  align-items: center;
  padding: 1.5rem 3.5rem;
  font-weight: 700;
  font-size: 2rem;
  line-height: 1.2em;
  text-transform: uppercase;
  text-decoration: none;
  color: #0E0E0E;
  border: 1px solid #000000;
  box-sizing: border-box;
  background-color: #76F3BC;
  transition: 0.15s ease-in;
}
@media print, (min-width: 1280px) {
  .btn {
    padding: 1.5rem 7.5rem;
    font-size: 2.2rem;
  }
}
.btn:hover:not(:disabled) {
  transition-duration: 0.3s;
  background-color: #000000;
  color: #FFFFFF;
}
.btn--empty {
  border: none;
  background-color: transparent;
}
.hidden {
  display: none;
}
.has-error {
  color: red;
}
.overflow {
  overflow: hidden;
}
.h {
  position: relative;
  z-index: 1;
  padding-left: 3rem;
  padding-right: 3rem;
  box-sizing: border-box;
  margin: 0 auto;
}
@media print, (min-width: 1280px) {
  .h {
    padding-left: 6rem;
    padding-right: 6rem;
  }
}
.h.opened {
  z-index: 10;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
}
.h.opened .h__nav {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 2;
  overflow: auto;
  padding-left: 3rem;
  padding-right: 3rem;
  height: 100vh;
  padding-top: 9.9rem;
  padding-bottom: 2.7rem;
  box-sizing: border-box;
  background-color: #76F3BC;
}
.h.opened .h__nav-list {
  margin: 0 auto;
  text-align: center;
}
.h.opened .h__nav-item {
  margin: 0;
}
.h__container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 180rem;
  margin: 0 auto;
  box-sizing: border-box;
  padding-top: 2rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid #000000;
}
@media print, (min-width: 1280px) {
  .h__container {
    justify-content: flex-start;
    padding-top: 3rem;
    padding-bottom: 3rem;
  }
}
.h__logo {
  font-size: 2.2rem;
  line-height: 1.2em;
  font-weight: 800;
  color: #333333;
  text-decoration: none;
  text-transform: uppercase;
  z-index: 1;
}
@media print, (min-width: 1280px) {
  .h__logo {
    font-size: 3.3rem;
    margin-right: 13.1rem;
  }
}
.h__nav {
  display: none;
  position: relative;
  z-index: 1;
  width: 100%;
  box-sizing: border-box;
}
@media print, (min-width: 1280px) {
  .h__nav {
    display: flex;
    justify-content: space-between;
  }
}
.h__nav-list {
  box-sizing: border-box;
  padding-bottom: 4.8rem;
  padding-left: 0;
  list-style: none;
}
@media print, (min-width: 1280px) {
  .h__nav-list {
    display: flex;
    padding-bottom: 0;
  }
}
.h__nav-item:not(:last-child) {
  margin-right: 5.6rem;
}
.h__nav-link {
  display: inline-block;
  margin-bottom: 3rem;
  font-size: 2.2rem;
  line-height: 1.2em;
  font-weight: 500;
  color: #0E0E0E;
  text-decoration: none;
  text-transform: uppercase;
}
.h__nav-link.active {
  font-weight: 600;
}
.h__nav-link:hover {
  color: #0E0E0E;
  text-decoration: underline;
}
@media print, (min-width: 1280px) {
  .h__nav-link {
    margin-bottom: 0;
  }
}
.h__btn {
  display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  padding: 1.5rem;
  margin-bottom: 8.7rem;
  background-color: #76F3BC;
  border: 1px solid #000000;
  font-size: 2rem;
  line-height: 1.2em;
  font-weight: 700;
  color: #000000;
  text-decoration: none;
  text-transform: uppercase;
}
.h__btn:hover {
  opacity: 0.8;
  color: #0E0E0E;
}
.h__btn:hover .h__btn-icon {
  opacity: 0.8;
}
@media print, (min-width: 1280px) {
  .h__btn {
    justify-content: flex-start;
    padding: 0;
    margin-bottom: 0;
    border: none;
    background-color: transparent;
    font-size: 2.2rem;
    color: #0E0E0E;
  }
  .h__btn span {
    margin-right: 1.6rem;
  }
}
.h__btn-icon {
  display: none;
}
@media print, (min-width: 1280px) {
  .h__btn-icon {
    display: inline-block;
    max-width: 6.6rem;
    max-height: 2rem;
  }
}
.h__soc-list {
  list-style: none;
  padding-left: 0;
  margin: 0;
}
@media print, (min-width: 1280px) {
  .h__soc-list {
    display: none;
  }
}
.h__soc-item {
  margin-bottom: 2rem;
  text-align: center;
}
.h__soc-link {
  font-size: 2rem;
  line-height: 1.4em;
  font-weight: 500;
  color: #000000;
  text-decoration: none;
}
.h__soc-link:hover {
  color: #000000;
  opacity: 0.8;
}
/* burger */
.h__burger {
  z-index: 3;
}
@media print, (min-width: 1280px) {
  .h__burger {
    display: none;
  }
}
.burger {
  height: 1.9rem;
  width: 3.6rem;
  background-color: transparent;
  border: 0;
  outline: none;
  padding: 1rem 0 1rem 0;
  box-sizing: border-box;
}
.burger:hover .burger__line,
.burger:active .burger__line {
  width: 3.6rem;
}
.burger.active .burger__line:first-child {
  width: 3.6rem;
  top: 0;
  transform: translateX(-50%) rotate(45deg);
}
.burger.active .burger__line:nth-child(2) {
  width: 0;
}
.burger.active .burger__line:last-child {
  width: 3.6rem;
  top: 0;
  transform: translateX(-50%) rotate(-45deg);
}
.burger__inner {
  position: relative;
  display: block;
  height: 0;
  width: 3.6rem;
}
.burger__line {
  display: block;
  position: absolute;
  left: 50%;
  top: 0;
  z-index: 1;
  height: 0.1rem;
  transform: translateX(-50%);
  transition: all 0.2s ease;
  background-color: #333333;
}
.burger__line:first-child {
  width: 3.6rem;
  top: -0.8rem;
}
.burger__line:nth-child(2) {
  width: 3.6rem;
}
.burger__line:last-child {
  width: 3.6rem;
  top: 0.8rem;
}
.f {
  box-sizing: border-box;
  padding-top: 5.8rem;
  padding-bottom: 4.3rem;
  background-color: #D6FE51;
  color: #000000;
}
@media print, (min-width: 1280px) {
  .f {
    padding-top: 7.2rem;
    padding-bottom: 5.8rem;
  }
}
.f__container {
  position: relative;
}
@media print, (min-width: 1280px) {
  .f__container {
    display: flex;
    justify-content: space-between;
    padding-bottom: 6.8rem;
  }
}
@media print, (min-width: 1280px) {
  .f__item {
    height: auto;
    padding-bottom: 0;
  }
}
@media (max-width: 767px) {
  .f__item:last-child {
    box-sizing: border-box;
    padding-bottom: 6.4rem;
  }
}
@media print, (min-width: 1280px) {
  .f__item--main {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    box-sizing: border-box;
    padding-right: 10rem;
  }
}
.f__menu-title {
  margin: 0;
  margin-top: 3.9rem;
  margin-bottom: 1.6rem;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 2em;
  text-transform: uppercase;
}
@media print, (min-width: 1280px) {
  .f__menu-title {
    margin-top: 0;
    margin-bottom: 1.2rem;
    font-size: 2rem;
  }
}
.f__logo {
  display: block;
  margin-bottom: 2.3rem;
  font-size: 2.2rem;
  line-height: 1.2em;
  font-weight: 800;
  text-decoration: none;
  text-transform: uppercase;
  color: #000000;
}
@media print, (min-width: 1280px) {
  .f__logo {
    margin-bottom: 7.5rem;
    font-size: 3.3rem;
  }
}
.f__logo:hover {
  color: #000000;
}
.f__copyright {
  position: absolute;
  bottom: 0;
  left: 0;
}
@media (max-width: 1279px) {
  .f__copyright {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    height: 4rem;
  }
}
@media print, (min-width: 1280px) {
  .f__copyright {
    position: relative;
  }
}
.f__copyright p {
  margin: 0;
  font-weight: 400;
  font-size: 1.1rem;
  line-height: 1.4em;
}
@media print, (min-width: 1280px) {
  .f__copyright p {
    font-size: 1.6rem;
  }
}
.f__contact-link {
  display: flex;
  align-items: center;
  margin-right: 4.1rem;
  text-decoration: none;
}
.f__contact-link:not(:last-child) {
  margin-bottom: 2rem;
}
@media print, (min-width: 1280px) {
  .f__contact-link:not(:last-child) {
    margin-right: 3rem;
  }
}
.f__contact-link:hover {
  opacity: 0.8;
}
.f__contact-icon {
  height: 1.9rem;
  width: 1.9rem;
  margin-right: 3rem;
  color: #000000;
}
@media print, (min-width: 1280px) {
  .f__contact-icon {
    margin-right: 2.4rem;
  }
}
.f__menu-list {
  list-style: none;
  padding-left: 0;
  margin: 0;
}
.f__menu-link {
  font-weight: 500;
  font-size: 1.1rem;
  line-height: 2.5em;
  color: #000000;
  text-decoration: none;
  text-transform: uppercase;
}
@media print, (min-width: 1280px) {
  .f__menu-link {
    font-size: 2rem;
  }
}
.f__menu-link:hover {
  color: #000000;
  text-decoration: underline;
}
.f__contact-link {
  text-decoration: none;
  color: #000000;
}
.f__contact-link:hover {
  color: #000000;
}
.f__social {
  margin-top: 4rem;
  text-align: right;
}
@media print, (min-width: 1280px) {
  .f__social {
    margin-top: 0;
  }
}
.f__social-link {
  text-decoration: none;
  color: #000000;
}
.f__social-link:hover {
  color: #000000;
  opacity: 0.8;
}
.f__social-icon {
  width: 4rem;
  height: 4rem;
  color: #000000;
}
.banner {
  padding-top: 4.2rem;
  padding-bottom: 4rem;
}
@media print, (min-width: 1280px) {
  .banner {
    padding-top: 6.8rem;
    padding-bottom: 7.4rem;
  }
}
.banner__container {
  position: relative;
  z-index: 3;
}
.banner__header {
  z-index: 1;
  padding-bottom: 14rem;
  box-sizing: border-box;
}
@media print, (min-width: 1280px) {
  .banner__header {
    max-width: 90%;
    padding-bottom: 12.5rem;
  }
}
.banner__title {
  margin: 0;
}
.banner__title-pc {
  display: none;
}
@media print, (min-width: 1280px) {
  .banner__title-pc {
    display: block;
    max-width: 100%;
  }
}
.banner__title-mobile {
  display: block;
}
@media print, (min-width: 1280px) {
  .banner__title-mobile {
    display: none;
  }
}
.banner__subtitle {
  margin: 0;
  margin-bottom: 1.6rem;
  font-weight: 700;
  font-size: 4.4rem;
  line-height: 1em;
  color: #000000;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
@media print, (min-width: 1280px) {
  .banner__subtitle {
    margin-bottom: 4.1rem;
    font-size: 12rem;
  }
}
.banner__descr {
  margin: 0;
  margin-bottom: 1.6rem;
  font-weight: 500;
  font-size: 1.7rem;
  line-height: 1.2em;
  color: #231F20;
}
@media print, (min-width: 1280px) {
  .banner__descr {
    max-width: 105.3rem;
    margin-bottom: 3.4rem;
    font-size: 3.3rem;
  }
}
.banner__spot {
  position: absolute;
  top: 0;
  left: 0;
  display: none;
}
@media print, (min-width: 768px) {
  .banner__spot {
    display: block;
  }
}
.banner__spot--mobile {
  display: block;
}
@media print, (min-width: 768px) {
  .banner__spot--mobile {
    display: none;
  }
}
.banner__img {
  position: absolute;
  bottom: -13%;
  left: 0;
  width: 100%;
  object-fit: cover;
  object-position: left top;
}
@media print, (min-width: 768px) {
  .banner__img {
    bottom: -15%;
    right: 0;
    left: auto;
    width: 48%;
    max-width: 102rem;
    height: auto;
    object-fit: fill;
  }
}
.banner__footer {
  overflow: hidden;
  margin-left: -3.5rem;
  margin-right: -3.5rem;
}
@media print, (min-width: 1280px) {
  .banner__footer {
    margin-left: 0;
    margin-right: 0;
  }
}
.banner__slide {
  display: flex;
  align-items: center;
  height: auto;
}
.banner__slide-img {
  width: 100%;
}
.about {
  position: relative;
  background-color: #E5E5E5;
}
.about__container {
  position: relative;
  z-index: 1;
}
@media print, (min-width: 1280px) {
  .about__container {
    display: flex;
  }
}
@media print, (min-width: 1280px) {
  .about__photo {
    flex-basis: 45%;
  }
}
.about__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.about__text {
  box-sizing: border-box;
  padding: 4.5rem 3rem 4rem 3rem;
}
@media print, (min-width: 1280px) {
  .about__text {
    flex-basis: 55%;
    padding: 5.5rem 10rem 5.5rem 9.1rem;
  }
}
.about__title {
  margin-bottom: 1.9rem;
}
@media print, (min-width: 1280px) {
  .about__title {
    margin-bottom: 3rem;
  }
}
.about__descr {
  margin: 0;
  font-size: 1.5rem;
  line-height: 1.2em;
  font-weight: 500;
  color: #333333;
}
@media print, (min-width: 1280px) {
  .about__descr {
    font-size: 2.2rem;
    line-height: 1.4em;
  }
}
.about__descr:not(:last-child) {
  margin-bottom: 1rem;
}
@media print, (min-width: 1280px) {
  .about__descr:not(:last-child) {
    margin-bottom: 2rem;
  }
}
.about__spot {
  position: absolute;
  right: 0;
  bottom: 0;
}
@media (max-width: 767px) {
  .about__spot {
    width: 60%;
  }
}
.offer {
  background-color: #76F3BC;
  overflow: hidden;
}
.offer__container {
  box-sizing: border-box;
  padding-top: 5.2rem;
  padding-bottom: 6.4rem;
}
@media print, (min-width: 1280px) {
  .offer__container {
    padding-top: 7rem;
    padding-bottom: 7rem;
  }
}
.offer__title {
  margin-bottom: 1.9rem;
  text-align: center;
}
@media print, (min-width: 1280px) {
  .offer__title {
    margin-bottom: 7.4rem;
  }
}
.offer__slider {
  margin-right: -24rem;
  overflow: hidden;
}
@media print, (min-width: 1280px) {
  .offer__slider {
    margin-right: 0;
  }
}
.offer__slide {
  position: relative;
  height: auto;
  box-sizing: border-box;
  padding: 1.5rem 3rem 3.5rem 3rem;
  background-color: rgba(234, 234, 234, 0.3);
}
.offer__slide:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 0;
  right: -1.7rem;
  display: block;
  height: 100%;
  width: 3px;
  background-color: #000000;
}
@media print, (min-width: 1280px) {
  .offer__slide {
    padding: 2.7rem 5rem 4.7rem 5rem;
  }
  .offer__slide:not(:last-child)::after {
    right: -3.6rem;
  }
}
.offer__slide-num {
  display: inline-block;
  height: 7.5rem;
  width: 11.6rem;
  padding-top: 2rem;
  padding-right: 4.9rem;
  padding-bottom: 1.3rem;
  box-sizing: border-box;
  margin-bottom: 1.8rem;
  border-bottom: 2px solid #000000;
}
@media print, (min-width: 1280px) {
  .offer__slide-num {
    height: 16.9rem;
    width: 23.7rem;
    padding-bottom: 3.6rem;
    padding-right: 8.4rem;
    margin-bottom: 3.1rem;
  }
}
.offer__slide-icon {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.offer__slide-title {
  margin-bottom: 1.6rem;
}
@media print, (min-width: 1280px) {
  .offer__slide-title {
    margin-bottom: 2.4rem;
  }
}
.offer__slide-descr {
  margin: 0;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.2em;
  color: #333333;
}
@media print, (min-width: 1280px) {
  .offer__slide-descr {
    font-size: 2.2rem;
    line-height: 1.4em;
  }
}
.projects {
  background-color: #000000;
  overflow: hidden;
}
.projects__container {
  box-sizing: border-box;
  padding-top: 5.2rem;
  padding-bottom: 6.4rem;
}
@media print, (min-width: 1280px) {
  .projects__container {
    padding-top: 7rem;
    padding-bottom: 7rem;
  }
}
.projects__title {
  max-width: 90%;
  margin: 0 auto;
  margin-bottom: 3rem;
  text-align: center;
  color: #FFFFFF;
}
@media print, (min-width: 1280px) {
  .projects__title {
    margin-bottom: 7rem;
  }
}
.projects__slider-box {
  position: relative;
}
.projects__slider {
  overflow: hidden;
}
@media (max-width: 767px) {
  .projects__slider {
    margin-left: -3.5rem;
    margin-right: -3.5rem;
  }
}
@media print, (min-width: 1280px) {
  .projects__slider {
    max-height: 70rem;
  }
}
.projects__slide {
  height: auto;
}
@media print, (min-width: 1280px) {
  .projects__slide {
    display: flex;
  }
}
.projects__slide-header {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 3.5rem;
  box-sizing: border-box;
}
.projects__slide-photo {
  max-width: 28rem;
  max-height: 28rem;
  border-radius: 50%;
  overflow: hidden;
}
@media print, (min-width: 1280px) {
  .projects__slide-photo {
    max-width: 60rem;
    max-height: 60rem;
  }
}
.projects__slide-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.projects__slide-body {
  box-sizing: border-box;
  padding: 3.5rem 3.5rem 4rem 3.5rem;
  color: #FFFFFF;
  background-color: #2F2F2F;
}
@media print, (min-width: 1280px) {
  .projects__slide-body {
    padding: 7.1rem 5rem 6rem 7.7rem;
  }
}
.projects__slide-head {
  position: relative;
  display: flex;
  justify-content: space-between;
  box-sizing: border-box;
  padding-bottom: 2.3rem;
  margin-bottom: 3.4rem;
}
.projects__slide-head:after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  display: block;
  height: 1px;
  width: 7rem;
  background-color: #FFFFFF;
}
@media print, (min-width: 1280px) {
  .projects__slide-head:after {
    width: 14.6rem;
  }
}
.projects__slide-htitle {
  margin: 0;
  margin-bottom: 0.4rem;
  font-weight: 700;
  font-size: 2.5rem;
  line-height: 1.2em;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #FFFFFF;
}
@media print, (min-width: 1280px) {
  .projects__slide-htitle {
    margin-bottom: 0.5rem;
    font-size: 5.5rem;
  }
}
.projects__slide-hdescr {
  margin: 0;
  font-weight: 500;
  font-size: 1.1rem;
  line-height: 1.4em;
  color: #FFFFFF;
}
@media print, (min-width: 1280px) {
  .projects__slide-hdescr {
    font-size: 2.2rem;
  }
}
.projects__slide-himg {
  width: 4.4rem;
  height: 4.4rem;
  object-fit: cover;
}
@media print, (min-width: 1280px) {
  .projects__slide-himg {
    width: 9.2rem;
    height: 9.2rem;
  }
}
.projects__slide-bbody {
  position: relative;
  box-sizing: border-box;
  padding-bottom: 2.2rem;
  margin-bottom: 3.4rem;
}
@media print, (min-width: 1280px) {
  .projects__slide-bbody {
    padding-bottom: 5.4rem;
  }
}
.projects__slide-bbody:after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  display: block;
  height: 1px;
  width: 7rem;
  background-color: #FFFFFF;
}
@media print, (min-width: 1280px) {
  .projects__slide-bbody:after {
    width: 14.6rem;
  }
}
.projects__slide-btitle {
  margin: 0;
  margin-bottom: 0.7rem;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.2em;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #FFFFFF;
}
@media print, (min-width: 1280px) {
  .projects__slide-btitle {
    font-size: 3.3rem;
  }
}
.projects__slide-bdescr {
  margin: 0;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.4em;
  color: #FFFFFF;
}
@media print, (min-width: 1280px) {
  .projects__slide-bdescr {
    font-size: 2.2rem;
  }
}
.projects__slide-fline {
  display: flex;
  align-items: center;
}
.projects__slide-fline:not(:last-child) {
  margin-bottom: 1.2rem;
}
.projects__slide-ficon {
  width: 1.2rem;
  height: 1.2rem;
  margin-right: 1.2rem;
}
@media print, (min-width: 1280px) {
  .projects__slide-ficon {
    width: 2.5rem;
    height: 2.5rem;
    margin-right: 2.6rem;
  }
}
.projects__slide-fnum {
  min-width: 17%;
  box-sizing: border-box;
  margin-right: 1.3rem;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.4em;
  color: #FFFFFF;
}
@media print, (min-width: 1280px) {
  .projects__slide-fnum {
    margin-right: 2.3rem;
    font-size: 3.3rem;
  }
}
.projects__slide-farrow {
  max-width: 4.1rem;
  margin-right: 1.2rem;
}
@media print, (min-width: 1280px) {
  .projects__slide-farrow {
    max-width: 8.6rem;
    margin-right: 2.6rem;
  }
}
.projects__slide-fdescr {
  font-weight: 500;
  font-size: 1.1rem;
  line-height: 1.4em;
  color: #FFFFFF;
}
@media print, (min-width: 1280px) {
  .projects__slide-fdescr {
    font-size: 2.2rem;
  }
}
.projects__slider-pagination {
  position: relative;
  margin-top: 5.2rem;
}
@media print, (min-width: 1280px) {
  .projects__slider-pagination {
    position: absolute;
    top: calc(50% - 12rem);
    right: -5%;
    display: flex;
    flex-direction: column;
    height: 100%;
    max-height: 24rem;
    margin-top: 0;
  }
}
.projects__slider-pagination .swiper-pagination-bullet {
  width: 10%;
  max-width: 5.8rem;
  height: 8px;
  margin: 0 6px!important;
  border-radius: 0;
  border: 1px solid #FFFFFF;
  background-color: transparent;
  box-shadow: 1px 1px 1px #000000;
}
.projects__slider-pagination .swiper-pagination-bullet:hover {
  background-color: #FFFFFF;
}
@media print, (min-width: 1280px) {
  .projects__slider-pagination .swiper-pagination-bullet {
    height: 10%;
    max-height: 5.8rem;
    width: 0.8rem;
    margin: 6px 0!important;
  }
}
.projects__slider-pagination .swiper-pagination-bullet-active {
  background-color: #FFFFFF;
}
.projects__slider-next {
  display: none;
}
@media print, (min-width: 1280px) {
  .projects__slider-next {
    top: calc(50% + 12rem);
    bottom: 0;
    right: -5%;
    left: auto;
    display: block;
    height: 19rem;
    width: 1.2rem;
    margin-top: 0;
  }
}
.projects__slider-next:hover {
  opacity: 0.8;
}
.projects__slider-next:after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background-image: url(../icons/arrow-down.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}
.projects__slider-prev {
  display: none;
}
@media print, (min-width: 1280px) {
  .projects__slider-prev {
    top: calc(50% - 36rem);
    right: -5%;
    left: auto;
    display: block;
    height: 19rem;
    width: 1.2rem;
    margin-top: 0;
  }
}
.projects__slider-prev:hover {
  opacity: 0.8;
}
.projects__slider-prev:after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background-image: url(../icons/arrow-up.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}
.reviews {
  position: relative;
  background-color: #76F3BC;
  overflow: hidden;
}
.reviews__container {
  position: relative;
  z-index: 1;
  box-sizing: border-box;
  padding-top: 5.2rem;
  padding-bottom: 6.8rem;
}
@media print, (min-width: 1280px) {
  .reviews__container {
    padding-top: 13.3rem;
    padding-bottom: 14.1rem;
  }
}
.reviews__title {
  max-width: 90%;
  margin: 0 auto;
  margin-bottom: 2.6rem;
  text-align: center;
}
@media print, (min-width: 1280px) {
  .reviews__title {
    margin-bottom: 7.6rem;
  }
}
.reviews__slider {
  overflow: hidden;
}
.reviews__slide {
  box-sizing: border-box;
  padding: 0 3.7rem;
  border-width: 2px;
  border-style: solid;
  border-image: linear-gradient(90deg, black 0, black 3%, transparent 3%, transparent 97%, black 97%, black 100%) 1;
}
@media print, (min-width: 1280px) {
  .reviews__slide {
    padding: 0 5.9rem;
  }
}
.reviews__slide-descr {
  margin: 0;
  margin-bottom: 1.8rem;
  font-weight: 500;
  font-size: 2.2rem;
  line-height: 1.4em;
  color: #333333;
}
@media print, (min-width: 1280px) {
  .reviews__slide-descr {
    font-size: 2.2rem;
  }
}
.reviews__slide-link {
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.4em;
  text-transform: uppercase;
  color: #000000;
  text-decoration: none;
}
@media print, (min-width: 1280px) {
  .reviews__slide-link {
    font-size: 4.4rem;
  }
}
.reviews__slider-navigation {
  position: relative;
  display: none;
}
@media print, (min-width: 1280px) {
  .reviews__slider-navigation {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 7.6rem;
  }
}
.reviews__slider-navigation .swiper-button-prev,
.reviews__slider-navigation .swiper-button-next {
  position: relative;
  height: 1.2rem;
  width: 19rem;
  margin-top: 0;
}
.reviews__slider-navigation .swiper-button-prev {
  left: 0;
}
.reviews__slider-navigation .swiper-button-next {
  right: 0;
}
.reviews__slider-navigation .swiper-button-prev:after {
  content: '';
  display: block;
  height: 1.2rem;
  width: 19rem;
  background-image: url(../icons/arrow-reviews.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}
.reviews__slider-navigation .swiper-button-next:after {
  content: '';
  display: block;
  height: 1.2rem;
  width: 19rem;
  background-image: url(../icons/arrow-reviews.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  transform: rotate(180deg);
}
.reviews__slider-pagination {
  position: relative;
  margin: 0 5.6rem;
}
.reviews__slider-pagination .swiper-pagination-bullet {
  width: 5.8rem;
  height: 0.8rem;
  margin: 0 0.6rem !important;
  border-radius: 0;
  border: 1px solid #000000;
  background-color: transparent;
  box-shadow: 0.1px 0.1px 0.1px #000000;
}
.reviews__slider-pagination .swiper-pagination-bullet:hover {
  background-color: #000000;
}
.reviews__slider-pagination .swiper-pagination-bullet-active {
  background-color: #000000;
}
.reviews__spot {
  position: absolute;
  top: -10%;
  left: 0;
  display: none;
}
@media print, (min-width: 768px) {
  .reviews__spot {
    display: block;
    top: -30%;
    left: -30%;
  }
}
.reviews__spot--mobile {
  display: block;
}
@media print, (min-width: 768px) {
  .reviews__spot--mobile {
    display: none;
  }
}
.team {
  background-color: #000000;
  overflow: hidden;
}
.team__container {
  box-sizing: border-box;
  padding-top: 5.2rem;
  padding-bottom: 6.8rem;
}
@media print, (min-width: 1280px) {
  .team__container {
    padding-top: 7rem;
    padding-bottom: 9.7rem;
  }
}
.team__title {
  max-width: 90%;
  margin: 0 auto;
  margin-bottom: 4.9rem;
  text-align: center;
  color: #FFFFFF;
}
@media print, (min-width: 1280px) {
  .team__title {
    margin-bottom: 9.9rem;
  }
}
.team__slider {
  margin-left: -6.3rem;
  margin-right: -24rem;
  overflow: hidden;
}
@media print, (min-width: 1280px) {
  .team__slider {
    margin-left: 0;
    margin-right: 0;
  }
}
.team__slide {
  position: relative;
  height: auto;
  background-color: #EAEAEA;
}
.team__slide-header {
  position: relative;
  display: block;
  padding-left: 3.3rem;
  margin-bottom: 5.4rem;
  box-sizing: border-box;
}
@media print, (min-width: 1280px) {
  .team__slide-header {
    padding-left: 5.4rem;
    margin-bottom: 8.7rem;
  }
}
.team__slide-header:after {
  content: '';
  position: absolute;
  left: 3.3rem;
  bottom: -2.4rem;
  display: block;
  height: 1px;
  width: 15.2rem;
  background-color: #000000;
}
@media print, (min-width: 1280px) {
  .team__slide-header:after {
    left: 5.4rem;
    bottom: -4rem;
  }
}
.team__slide-img {
  width: 100%;
  object-fit: cover;
}
.team__slide-title {
  margin-bottom: 3.5rem;
}
@media print, (min-width: 1280px) {
  .team__slide-title {
    margin-bottom: 2.4rem;
  }
}
.team__slide-body {
  box-sizing: border-box;
  padding: 3.3rem;
  padding-top: 0;
}
@media print, (min-width: 1280px) {
  .team__slide-body {
    padding: 5.7rem;
    padding-top: 0;
  }
}
.team__slide-descr {
  margin: 0;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.2em;
  color: #333333;
}
@media print, (min-width: 1280px) {
  .team__slide-descr {
    font-size: 2.2rem;
    line-height: 1.4em;
  }
}
.contact {
  background-color: #E5E5E5;
}
.contact__container {
  padding-top: 5.2rem;
  padding-bottom: 3.7rem;
}
@media print, (min-width: 1280px) {
  .contact__container {
    display: flex;
    flex-wrap: wrap;
    padding-top: 6.3rem;
    padding-bottom: 6.3rem;
  }
}
.contact__title {
  flex-basis: 100%;
  text-align: center;
  margin-bottom: 4.5rem;
}
@media print, (min-width: 1280px) {
  .contact__title {
    margin-bottom: 5.4rem;
  }
}
.contact__form {
  flex-basis: 50%;
}
@media (max-width: 1279px) {
  .contact__form {
    margin-bottom: 5.8rem;
  }
}
.contact__form-input {
  width: 100%;
  margin-bottom: 1.4rem;
  padding: 1.8rem 2.5rem;
  box-sizing: border-box;
  border: 1.4px solid #000000;
  background-color: transparent;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.4em;
  color: #000000;
  text-transform: uppercase;
}
.contact__form-input::placeholder {
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.4em;
  color: #000000;
}
.contact__form-input.has-error {
  border-color: red;
}
@media print, (min-width: 1280px) {
  .contact__form-input {
    font-size: 2.2rem;
    margin-bottom: 2rem;
  }
}
.contact__form-text {
  height: 18.2rem;
  margin-bottom: 2.1rem;
}
.contact__form-text.has-error {
  border-color: red;
}
@media print, (min-width: 1280px) {
  .contact__form-text {
    height: 26rem;
    margin-bottom: 3.2rem;
  }
}
.contact__form-btn {
  width: 100%;
  justify-content: center;
}
.contact__form-msg {
  display: none;
  margin: 0;
  margin-top: 2rem;
  margin-bottom: 1rem;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.4em;
  color: #000000;
}
@media print, (min-width: 1280px) {
  .contact__form-msg {
    font-size: 2.2rem;
  }
}
.contact__form-msg--success {
  display: block;
}
.contact__form-msg--error {
  display: block;
  color: red;
}
.contact__form-error {
  display: inline-block;
  margin: 0;
  margin-bottom: 1.5rem;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.4em;
  color: red;
}
.contact__form-error.hidden {
  display: none;
}
.contact__text {
  flex-basis: 50%;
}
@media print, (min-width: 1280px) {
  .contact__text {
    padding-left: 15rem;
    box-sizing: border-box;
  }
}
.contact__ttitle {
  margin: 0;
  margin-bottom: 2.1rem;
  font-weight: 700;
  font-size: 2.2rem;
  line-height: 1.4em;
  color: #000000;
}
@media print, (min-width: 1280px) {
  .contact__ttitle {
    margin-bottom: 3.1rem;
    font-size: 4rem;
  }
}
.contact__tdescr {
  margin-bottom: 4.9rem;
}
@media print, (min-width: 1280px) {
  .contact__tdescr {
    margin-bottom: 6.7rem;
  }
}
.contact__tdescr-text {
  margin: 0;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.4em;
  color: #000000;
}
@media print, (min-width: 1280px) {
  .contact__tdescr-text {
    font-size: 2.2rem;
  }
}
.contact__tdescr-text:not(:last-child) {
  margin-bottom: 2.1rem;
}
@media print, (min-width: 1280px) {
  .contact__tdescr-text:not(:last-child) {
    margin-bottom: 3rem;
  }
}
.contact__tdescr-text {
  margin: 0;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.4em;
  color: #000000;
}
@media print, (min-width: 1280px) {
  .contact__tdescr-text {
    font-size: 2.2rem;
  }
}
.contact__tdescr-text:not(:last-child) {
  margin-bottom: 2.1rem;
}
.contact__fline:not(:last-child) {
  margin-bottom: 3.1rem;
  border-bottom: 1px solid #000000;
}
@media print, (min-width: 1280px) {
  .contact__fline:not(:last-child) {
    margin-bottom: 3.9rem;
  }
}
.contact__ftitle {
  margin: 0;
  margin-bottom: 0.2rem;
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.4em;
  color: #000000;
  text-transform: uppercase;
}
@media print, (min-width: 1280px) {
  .contact__ftitle {
    font-size: 3.3rem;
  }
}
.contact__flink {
  display: inline-block;
  margin-bottom: 3.3rem;
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 1.4em;
  color: #000000;
  text-decoration: none;
}
.contact__flink:hover {
  opacity: 0.8;
  color: #000000;
}
@media print, (min-width: 1280px) {
  .contact__flink {
    margin-bottom: 3.1rem;
    font-size: 2rem;
  }
}
.contact__fline-icon {
  width: 2.3rem;
  height: 2.3rem;
}
