html {
  box-sizing: border-box;
}

*,
*::before,
*::after {
  box-sizing: inherit;
  margin: 0;
  padding: 0;
}


a {
  color: inherit;
  text-decoration: none;
}

img {
  max-width: 100%;
}

body {
  min-width: 320px;
  font-family: 'Montserrat', Arial, sans-serif;
  font-style: normal;
  font-size: 18px;
  background-color: #FFFFFF;
  /*overflow: hidden;*/
}

/* glob */
ul {
  list-style: none;
  margin: 0;
  padding: 0;
}


.list-reset {
  margin: 0;
  padding: 0;
  list-style: none;
}

.btn-reset {
  padding: 0;
  border: none;
  background-color: transparent;
  cursor: pointer;
}

.flex {
  display: flex;
}

h1,
h2,
h3,
h4,
h5 {
  margin: 0;
}

p {
  margin: 0;
}

.container {
  max-width: 1903px;
  padding: 0 66px;
  margin: 0 auto;
}

/* /glob */


/* header */

.burger {
  width: 30px;
  height: 23px;
  display: none;
}

.burger__line {
  display: inherit;
  width: 30px;
  height: 3px;
  margin-bottom: 7px;
  background-color: #000000;
  transition: all 0.5s ease-in-out;
}

.burger__line:last-child {
  margin-bottom: 0;
}

.burger-active {
  position: relative;
}

.header {
  width: 100%;
  max-height: 100px;
  background: #FFFFFF;
  box-shadow: 0 5px 40px rgba(0, 0, 0, 0.1);
  border-radius: 0 0 32px 32px;
  padding: 24px 0;
  margin-bottom: 50px;
  align-items: center;
}

.header__container {
  width: 1770px;
  align-items: center;
  justify-content: space-between;
}

.header__logo {
  max-width: 225px;
  height: 72px;
}

.header__nav {
  padding-left: 295px;
  align-items: center;
  justify-content: space-between;
}

.header__nav-list {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  padding: 0;
  list-style: none;
}


.header__nav-item {
  display: flex;
  flex-direction: row;
  align-items: center;
  margin-right: 85px;
}

.header__nav-item:last-child {
  margin-right: 0;
}

.header__nav-item:first-child {
  white-space: nowrap;
}


.header-link {
  font-style: normal;
  font-weight: 600;
  font-size: 18px;
  line-height: 22px;
  color: #000000;
  text-decoration: none;
}

.header-link:after {
  display: block;
  content: '';
  height: 2px;
  width: 100%;
}

.header-link:hover:after {
  background-color: #FF9900;
}

.header-link:active {
  color: #E1670E;
}


.header__search-block {
  height: 24px;
  width: 24px;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}


.header__search-block--active {
  position: absolute;
  width: fit-content;
  height: fit-content;
  padding: 15px 13px 16px 32px;
  right: 0;
  top: -90%;
  z-index: 5;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  background-color: #FFFFFF;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.12);
  border-radius: 24px;
  transition: all 0.3s ease-in-out;
}
.header__search-block--active .header__search-input {
  display: block;
  width: 412px;
  padding: 5px;
  margin-right: 14px;
  border: none;
  border-bottom: 1px solid #CACACA;
  font-size: 18px;
}


.header__search-block--active .header__search_icon {
  margin-right: 20px;
}

.header__search-block--active .header__search-exit {
  display: block;
}


.header__search-input {
  display: none;
}

.header__search-input:active, :hover, :focus {
  outline: 0;
  outline-offset: 0;
}

.header__search-input::-webkit-input-placeholder {
  color: #CACACA;
}

.header__search-exit {
  stroke: #CACACA;
  fill: none;
  transition: all 0.3s ease-in-out;
  display: none;
  cursor: pointer;
}

.header__search-exit:focus {
  border: 2px solid #FF9900;
}

.header__search-exit:hover {
  stroke: #FF9900;
}

.header__search-exit:active {
  stroke: #000000;
}


.header__search_icon {
  fill: none;
  stroke: #333333;
  cursor: pointer;
  transition: 0.3s all ease-in-out;
}

.header__search_icon:focus {
  border: 2px solid #FF9900;
}

.header__search_icon:hover {
  stroke: #FF9900;
}


.header__search_icon:active {
  color: #E1670E;
}

.header__search {
  position: relative;
  width: 24px;
  height: 24px;
  display: block;
}

/* hero  */


.hero-container {
  pointer-events: none;
  position: absolute;
  top: 250px;
  z-index: 1;
  display: flex;
  flex-direction: column;
  background-size: cover;
  padding: 0 80px;
  border-radius: 32px;
}

.swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
  bottom: 30px!important;
  left: 0;
}

:root {
  --swiper-theme-color: #ffffff!important;
}

.swiper-pagination-bullet {
  width: 15px!important;
  height: 15px!important;
}

.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 10px!important;
}


.swiper-slide__img-1 {
  width: 1770px;
  height: 620px!important;
  background: url("../img/low-angle-photo-of-balconies-2462015.png") no-repeat center;
  background-size: cover;
  border-radius: 32px;
}

.swiper-slide__img-2 {
  width: 1770px;
  height: 620px!important;
  background: url("../img/hero-pic-1920-2.png") no-repeat center;
  background-size: cover;
  border-radius: 32px;
}

.swiper-slide__img-3 {
  width: 1770px;
  height: 620px!important;
  background: url("../img/hero-pic-1920-3.png") no-repeat center;
  background-size: cover;
  border-radius: 32px;
}

.hero-translate {
  transform: translateX(-150px);
}

.hero-button {
  width: 280px;
  padding: 25px 39px;
  background: #FF9900;
  border-radius: 16px;
  font-style: normal;
  font-weight: 700;
  font-size: 25px;
  line-height: 28px;
  color: #FFFFFF;
  pointer-events: visiblePainted;
  transition: 0.3s background ease-in-out;
}
.hero-button:focus {
  background: #FFB84D;
}

.hero-button:hover {
  background: #FFB84D;
}

.hero-button:active {
  background: #E1670E;
}

.hero-text {
  max-width: 890px;
  display: inline-block;
  font-style: normal;
  font-weight: 800;
  font-size: 70px;
  line-height: 85px;
  color: #FFFFFF;
  margin-bottom: 24px;
}


.hero-content {
  display: inline-block;
  max-width: 890px;
  font-style: normal;
  font-weight: 700;
  font-size: 24px;
  line-height: 29px;
  color: #FFFFFF;
  margin-bottom: 90px;
}

.hero-next-svg-1 {
  background: #FFFFFF;
  border-radius: 15px;
}

.hero-next-svg-2 {
  background: #CACACA;
  border-radius: 15px;
}

.hero-next-svg-3 {
  background: #CACACA;
  border-radius: 15px;
}


/* main  */

.main__about-us {
  padding-top: 49px;

}

/* about us */
.main__card-right {

  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.main__card-block {
  display: flex;
  flex-direction: row;
  border: 1px solid #CACACA;
  padding: 65px 118px 63px 55px;
  border-radius: 32px;
}

.main__card-block:first-child {
  margin-bottom: 32px;
}

.main__card-image {
  display: flex;
  margin-right: 49px;
  align-items: center;
}

.main__card-text {
  display: flex;
  flex-direction: column;
}

.main__card-title {
  margin-bottom: 10px;
  font-weight: 700;
  font-size: 24px;
  line-height: 29px;
}

.main__card-description {
  font-weight: 400;
  font-size: 16px;
  line-height: 32px;
}


/* about us */

.main__title {
  font-style: normal;
  font-weight: 400;
  font-size: 48px;
  line-height: 59px;
  color: #000000;
  margin-bottom: 20px;
}

.main__text {
  max-width: 1235px;
  font-style: normal;
  font-weight: 400;
  font-size: 16px;
  line-height: 32px;
  color: #000000;
  margin-bottom: 50px;
}

.main__content-block {
  width: 1920px;
  height: 622px;
  display: flex;
  background: url(../img/Rectangle2.png) no-repeat center;
  border-radius: 32px;
  align-items: flex-end;
  margin-right: 32px;
  background-size: cover;
}


.main__content {
  display: flex;
  flex-direction: row;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 32px;
  padding: 50px;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

.main__content-text {
  max-width: 433px;
  font-style: normal;
  font-weight: 700;
  font-size: 16px;
  line-height: 32px;
  color: #FFFFFF;
  margin-right: 160px;
}

.main__button {
  display: inline-block;
  padding: 17px 36px;
  border: 3px solid #FF9900;
  border-radius: 16px;
  font-style: normal;
  font-weight: 700;
  font-size: 18px;
  line-height: 20px;
  text-align: center;
  color: #FFFFFF;
  transition: 0.3s background ease-in-out;
}

.main__button:focus {
  background: #FF9900;
}

.main__button:hover {
  background: #FF9900;
}

.main__button:active {
  background: #E1670E;
}

.main__card {
  max-width: 100%;
  max-height: 100%;

  justify-content: space-between;
  flex-direction: row;
}

.main__card-2 {
  width: 49%;
  height: 50%;
  flex-wrap: wrap;
  justify-content: flex-start;
}

.main__content-2 {
  background: #FFFFFF;
  border: 1px solid #CACACA;
  border-radius: 32px;
}

.main__content-2 svg {
  position: relative;
  left: 60px;
  top: 65px;
}

.main__content-2-title {
  position: relative;
  left: 300px;
  top: -106px;
  font-weight: 700;
  font-size: 24px;
  line-height: 29px;
  color: #000000;
}

.main__content-2-text {
  position: relative;
  left: 300px;
  top: -97px;
  width: 450px;
  display: inline-block;
  font-weight: 400;
  font-size: 16px;
  line-height: 32px;
  color: #000000;
}


.main__content-3 {
  border: 1px solid #CACACA;
  border-radius: 32px;
}

.main__content-3 svg {
  max-width: 190px;
  height: 165px;
}

.main__content-3-title {
  max-width: 412px;
  font-weight: 700;
  font-size: 24px;
  line-height: 29px;
  color: #000000;
}

.main__content-3-text {
  max-width: 450px;
  font-weight: 400;
  font-size: 16px;
  line-height: 32px;
  color: #000000;
}

/* how-work  */
.how-work {
  padding-top: 100px;

}

.how-work__title {
  font-weight: 400;
  font-size: 48px;
  line-height: 59px;
  margin-bottom: 48px;
}

.how-work__steps {
  list-style: none;
  display: flex;
  margin-bottom: 45px;
}

.step__button {
  font-family: 'Montserrat', Arial, sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 18px;
  line-height: 22px;
  transition: 0.3s color ease-in-out;
  margin-right: 86px;
}

/*.step__button:focus {*/
/*  border: 2px solid #FF9900;*/
/*}*/

.step__button:hover {
  color: #FF9900;
}

.step__button:active {
  color: #E1670E;
}



.how-work__bold-text {
  font-weight: 700;
  font-size: 24px;
  line-height: 32px;
  margin-bottom: 8px;
}

.how-work__text {
  max-width: 730px;
  font-weight: 400;
  font-size: 16px;
  line-height: 32px;
}

.how-work__text {
  margin-bottom: 14px;
}

.how-work__right {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}

.haw-work__left {
  margin-right: 142px;
  flex-shrink: 1;
}

/*степы*/

.how-work__img, .how-work__img-2, .how-work__img-3, .how-work__img-4 {
  flex-shrink: 0;
  width: 872px;
  height: 470px;
  background-size: cover;
  border-radius: 32px;
}

.how-work__img {
  background: url("../img/Rectangle18.png") no-repeat center;
}

.how-work__img-2 {
  background: url("../img/how-work__img-2.png") no-repeat center;
}

.how-work__img-3 {
  background: url("../img/how-work__img-3.png") no-repeat center;
}

.how-work__img-4 {
  background: url("../img/how-work__img-4.png") no-repeat center;
}

.step__button-active {
  color: #FF9900;
}

.how-work__right {
  display: none;
}

.how-work__right-active {
  display: flex;
}



/*/степы*/


.how-work__button {
  padding: 21px 41px;
  background: #FF9900;
  border-radius: 17px;
  font-weight: 700;
  font-size: 17px;
  line-height: 20px;
  color: #FFFFFF;
  margin-right: 28px;
  transition: 0.3s background ease-in-out;
}

.how-work__button:focus {
  background: #FFB84D;
}

.how-work__button:hover {
  background: #FFB84D;
}

.how-work__button:active {
  background: #E1670E;
}

.how-work__button-2 {
  font-family: 'Montserrat';
  font-style: normal;
  padding: 21px 36px;
  background: transparent;
  border: 1px solid #000000;
  border-radius: 16px;
  font-weight: 400;
  font-size: 16px;
  line-height: 19px;
  transition: 0.3s background ease-in-out, 0.3s color ease-in-out;
}

.how-work__button-2:focus {
  background: #666666;
  color: #FFFFFF;
}

.how-work__button-2:hover {
  background: #666666;
  color: #FFFFFF;
}

.how-work__button-2:active {
  background: #000000;
  color: #FFFFFF;
}


/* faq  */

.faq {
  padding: 112px 0 95px 0;
}

.faq__title {
  font-weight: 400;
  font-size: 48px;
  line-height: 59px;
  margin-bottom: 28px;
}

.faq__text {
  cursor: pointer;
}

.faq__picture {
  cursor: pointer;
  min-width: 50px;
}

.faq__line {
  align-items: center;
  border-bottom: 1px solid #CACACA;
  border-top: 1px solid #CACACA;
  font-weight: 700;
  font-size: 24px;
  line-height: 32px;
  padding: 30px 0;
  fill: #CACACA;
  transition: all 0.3s ease-in-out;
}


.ac-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.ac .ac-trigger {
  padding: 0!important;
}

.ac {
  border-left: none!important;
  border-right: none!important;
}

.ac-text {
  max-width: 1003px!important;
  padding: 30px 0 0 0!important;
}

.ac-text:nth-child(2) {
  max-width: 1003px!important;
  padding: 32px 0 10px 0!important;
}

.ac .ac-panel .ac-text {
  font: 16px/32px 'Montserrat', Arial, sans-serif!important;
}

.faq__line:focus {
  color: #FF9900;
  fill: #FF9900;
}

.faq__line:hover {
  color: #FF9900;
  border-color: #FF9900;
  fill: #FF9900;
}

.faq__line svg:hover{
  transition: all 0.3s ease-in-out;
}

.is-active svg{
  transform: rotate(45deg);
  transition: all 0.3s ease-in-out;
}


.accordion__content {
  overflow: hidden;
  visibility: hidden;
  transition-property: height, visibility;
  transition-timing-function: ease;
}

.accordion--active .accordion__content {
  visibility: visible;
}

.accordion__heading {
  margin: 0;
}

/* /faq  */

/* footer */
.footer {
  background: #000000;
  min-width: max-content;

}

.footer__container {
  padding: 50px 0;
  flex-direction: row;
  justify-content: space-between;
}

.footer__logo {
  margin-bottom: 15px;
}

.footer__nav {
  display: flex;
  flex-direction: column;
  list-style: none;
  color: #cacaca;
  font-weight: 600;
  font-size: 18px;
  line-height: 36px;
  margin-bottom: 90px;
}

.footer__link-text {
  transition: 0.3s color ease-in-out;
}

.footer__link-text:focus {
  border: 1px solid #FF9900;

}

.footer__link-text:hover {
  color: #FF9900;
}

.footer__link-text:active {
  color: #E1670E;
}


.footer__ref svg {
  fill: #666666;
  transition: 0.3s all ease-in-out;
  cursor: pointer;
}

.footer__ref svg:first-child {
  margin-right: 25px;
}

.footer__ref {
  display: flex;
}

.footer__ref svg:focus {
  fill: #666666;
}

.footer__ref svg:hover {
  fill: #FF9900;
}

.footer__ref svg:active {
  fill: #E1670E;
}

.footer-form {
  width: 32%;
  display: flex;
  flex-direction: column;
}

.footer-form__title {
  font-weight: 400;
  font-size: 48px;
  line-height: 59px;
  color: #CACACA;
  margin-bottom: 20px;
}

.footer-form__input-name::placeholder,
.footer-form__input-email::placeholder,
.footer-form__input-text::placeholder {
  font-family: 'Montserrat', Arial, sans-serif;
}

.footer-form__input-name,
.footer-form__input-email {
  padding: 16px 0 14px 23px;
  background: #414141;
  border-radius: 16px;
  margin-bottom: 25px;
  font-style: normal;
  font-weight: 400;
  font-size: 16px;
  line-height: 32px;
  color: #CACACA;
  border: none;
}

.footer-form__input-text {
  padding: 14px 0 104px 24px;
  background: #414141;
  border-radius: 16px;
  margin-bottom: 31px;
  font-style: normal;
  font-weight: 400;
  font-size: 16px;
  line-height: 32px;
  color: #CACACA;
  border: none;
}

.footer-form__input-name:focus,
.footer-form__input-email:focus,
.footer-form__input-text:focus {
  background-color: #666666;
}

.footer-form__input-name:hover,
.footer-form__input-email:hover,
.footer-form__input_text:hover {
  background-color: #666666;
}

.footer-form__input-name:active,
.footer-form__input-email:active,
.footer-form__input-text:active {
  background-color: #666666;
}

.footer-form__input-name::-webkit-input-placeholder,
.footer-form__input-email::-webkit-input-placeholder,
.footer-form__input-text::-webkit-input-placeholder {
  color: #CACACA;
}

.footer__link-text {
  font-weight: 600;
  font-size: 18px;
  line-height: 36px;
}

.footer__left {
  width: 33%;

}

.footer__right {
  width: 33%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.footer-checkbox-label {
  color: #CACACA;
  font-weight: 400;
  font-size: 16px;
  line-height: 32px;
  cursor: pointer;
}

.footer-form__btn_checkbox {
  justify-content: center;
  align-items: center;
}

.footer-form__btn-checkbox {
  align-items: center;
}

.footer__custom-checkbox {
  position: relative;
}

.footer-checkbox {
  position: absolute;
  z-index: -1;
  opacity: 0;
}

.footer-checkbox + .footer-checkbox-label {
  display: inline-flex;
  align-items: center;
  user-select: none;
}

.footer-checkbox + .footer-checkbox-label::before {
  content: '';
  display: inline-block;
  min-width: 14px;
  height: 14px;
  flex-shrink: 0;
  flex-grow: 0;
  border: 1px solid #CACACA;
  border-radius: 2px;
  margin-right: 4px;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 50% 50%;
}

.footer-checkbox:checked + .footer-checkbox-label::before {
  background-image: url("../img/checkbox.svg");
  background-size: contain;

}

.footer-form__submit-btn {
  padding: 19px 54px;
  background: #FF9900;
  border-radius: 16px;
  font-style: normal;
  font-weight: 700;
  font-size: 17px;
  line-height: 21px;
  color: #FFFFFF;
  margin-right: 20px;
  transition: 0.3s all ease-in-out;
  cursor: pointer;
  border: none;
}

.footer-form__submit-btn:focus {
  background-color: #FFB84D;
}

.footer-form__submit-btn:hover {
  background-color: #FFB84D;
}

.footer-form__submit-btn:active {
  background-color: #E1670E;
}

.footer__text {
  color: #CACACA;
  max-width: 363px;
  font-weight: 400;
  font-size: 16px;
  line-height: 32px;
}

/* /footer  */

.main__content__media {
  display: none;
}

.main__content__media-text {
  font-style: normal;
  font-weight: 400;
  font-size: 14px;
  line-height: 28px;
  margin-bottom: 12px;
}

.main__content__media-button {
  padding: 12px 44px;
  color: #FF9900;
  font-style: normal;
  font-weight: 700;
  font-size: 12px;
  line-height: 15px;
  border: 2px solid #FF9900;
  border-radius: 8px;
  margin-bottom: 32px;
}
