
* {
  margin: 0;
  padding: 0;
  border: 0;
}

body {
  line-height: 1.42857143;
  background-color: #fff;
  letter-spacing: 1px;
  position: relative;
  max-width: 100%;
  overflow-x: hidden;
}


a{
  transition: 200ms;
}

footer {
  position: sticky;
  z-index: 3;
}

.footer {
  background: rgb(2, 0, 36);
  background: linear-gradient(
    23deg,
    rgba(2, 0, 36, 1) 0%,
    rgb(194 194 213) 35%,
    rgba(0, 212, 255, 1) 100%
  );
  padding: 10px 3%;
  display: flex;
  bottom: 0;
  position: sticky;
  align-items: center;
  border-top: 5px solid;
  border-color: #fff;
}

.footer-nav p{
  color: white;
  font-size: 16px;
}


hr {
  background-color: #a42123;
  height: 0.1px;
  border: 1px solid #a42123;
  margin-bottom: 15px;
}


.carousel {
  height: 600px;
  width: 450px;
  display: flex;
  margin:auto;
}


html , body , .page-container{
  height: 100%;
}

.page-container{
  display: flex;
  flex-direction: column;
}

p{
  font-weight: 500;
}

.container a{
  color: #FD4B40;
  text-decoration: none;
  font-weight: 700;
}
.container a:hover , .container a:focus{
  color: #ff655c;
}

.h2{
  font-weight: 700;
  font-size: 28px;
  line-height: 34px;
  color: #FD4B40;
  text-align: center;
}

.png-page{
  margin-top: 50px;
}

.png-page p{
  line-height: 26px;
  font-size: 14px;
}

.container.container--wide{
  max-width: 100%;
  background: black;
}

/* .container .page-section:not(:first-of-type){
  margin-top: 15px;
} */

.page-section--introduction{
  margin-bottom: 50px;
}
.page-section--introduction p{
  text-align: center;
  margin-top: 50px;
}

.service{
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  transition: 200ms;
  cursor: default;
}
.service.service--active .service__chevron{
  transform: scaleY(-1);
}
.service.service--active .service__description{
  height: auto;
  overflow: auto;
}
.service.service--active .service__top:hover , .service.service--active .service__top:focus{
  background: #ffffff00;
}
.services-container{
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 20px;
  padding: 50px 0;
  overflow: hidden;
}
.service .service__top{
  display: flex;
  align-items: center;
  padding: 20px 40px 20px 20px;
  border-radius: 10px;
  width: calc(100% - 60px);
  position: relative;
  cursor: pointer;
  z-index: 2;
  background: black;
  transition: 200ms;
}
.service .service__top:hover , .service .service__top:focus{
  background: #ffffff0d;
}
.service .service__icon{
  margin-right: 20px;
}
.service .service__icon svg{
  fill: #FD4B40;
  width: 60px;
  height: 60px;
}
.service .service__name{
  font-weight: 700;
  color: white;
  font-size: 20px;
  line-height: 24px;
  display: block;
  margin-top: -5px;
}
.service .service__description{
  color: white;
  font-size: 14px;
  line-height: 24px;
  padding-left: 102px;
  transition: 200ms;
  height: 1px;
  overflow: hidden;
}
.service .service__chevron{
  flex: 0 0 34px;
  width: 34px;
  height: 34px;
  fill: #FD4B40;
  position: absolute;
  top: 0; bottom: 0; right: 0;
  margin: auto 0;
  transition: 200ms;
}

.page-section--contact{
  padding: 30px 0;
}

.contact-list-container{
  display: flex;
  justify-content: center;
}

.page-section .h2{
  margin-bottom: 20px;
}

.page-section ul{
  margin-top: 30px;
  list-style-type: none;
  text-align: center;
}

.page-section ul span , .page-section ul b{
  display: inline-block;
}
.page-section ul li{
  display: flex;
  align-items: center;
}
.page-section ul li:not(:first-of-type){
  margin-top: 20px;
}
.page-section ul span{
  font-weight: 700;
  width: 250px;
  display: flex;
  align-items: center;
  color: #FD4B40;
  font-size: 18px;
  line-height: 24px;
}
.page-section ul b{
  font-weight: 600;
}
.page-section ul svg{
  width: 26px;
  height: 26px;
  fill: #FD4B40;
  margin-right: 15px;
}
.page-section--work-hours p{
  margin-top: 30px;
}

.page-section--work-hours{
  padding: 30px 0;
}
.work-hours-list-container{
  display: flex;
  justify-content: center;
}

.page-section--reviews{
  padding: 30px 0;
  color: white;
}
.page-section--reviews svg{
  fill: #FD4B40;
  width: 20px;
  height: 20px;
}
.reviews-container{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  margin-top: 30px;
  grid-gap: 30px;
}
.review{
  text-align: center;
}
.review .review-name{
  color: #FD4B40;
  font-weight: 600;
}
.review .review-main{
  margin-top: 20px;
  font-size: 14px;
  line-height: 24px;
}
.review svg{
  display: inline-block;
  margin-bottom: -5px;
  margin-right: 15px;
}

.gas-safety{
  text-align: center;
  margin-top: 50px;
  pointer-events: none;
  user-select: none;
}
.gas-safety.gas-safety--small .gas-safety__image{
  width: 40px;
}
.gas-safety.gas-safety--small{
  margin-top: 0;
  margin-left: 10px;
}
.gas-safety .gas-safety__image{
  width: 100px;
}



/* ------------ */
/* Gallery page */
/* ------------ */
.page--gallery{
  padding-bottom: 55px;
}
.page--gallery .page-section .h2{
  margin-bottom: 20px;
}
.page--gallery .page-section:not(:first-of-type){
  margin-top: 100px;
}



/* ------------ */
/* Contact page */
/* ------------ */
.page-section--contact .contact-body{
  text-align: center;
}



/* --------- */
/* Area page */
/* --------- */
.page-section .area-list{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 15px;
}

.page-section .area-list li:not(:first-of-type){
  display: flex;
  align-items: center;
  margin-top: 0px;
  text-align: left;
}

.page-section .area-list li span{
  color: black;
  font-size: 16px;
}

.page-section .area-list li svg{
  fill: black;
}

.page-section .area-list div{
  font-size: 13px;
  font-weight: 700;
  text-align: left;
  margin-left: 23px;
  color: #FD4B40;
  line-height: 26px;
}

.page-section .area-map{
  margin-top: 40px;
}

.page-section .reviews-additional{
  margin-top: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-section .reviews-additional-link{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: auto;
  margin-right: auto;
}
.page-section .reviews-additional-link svg{
  margin-right: 10px;
}
.page-section .reviews-additional-link span:before{
  text-decoration: underline;
}



/* -------- */
/* QNA page */
/* -------- */
.page-section--qna .h2{
  margin-bottom: 40px;
}
.qna-el{
  border: 1px solid #FD4B40;
  border-radius: 6px;
}
.qna-el:not(:first-of-type){
  margin-top: 20px;
}
.qna-el.qna-el--active .qna-el__answer{
  display: block;
}
.qna-el.qna-el--active .qna-el__question__chevron{
  transform: scaleY(-1);
  transition: 200ms;
}
.qna-el .qna-el__answer{
  padding: 0 24px 20px;
  display: none;
  font-weight: 400;
  font-size: 14px;
  line-height: 26px;
}
.qna-el__question{
  padding: 20px 24px;
  display: flex;
  align-items: center;
  cursor: pointer;
  font-size: 18px;
}
.qna-el__question__chevron{
  margin-left: auto;
  width: 30px;
  height: 30px;
  flex: 0 0 30px;
  padding-left: 20px;
}
.qna-el__question span{
  color: #FD4B40;
  font-weight: 700;
  pointer-events: none;
  user-select: none;
}
.qna-el__question svg{
  fill: #FD4B40;
}



/* ------------- */
/* Services page */
/* ------------- */

.page--services .container{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 30px;
}
.page-section ul{
  margin-top: 16px;
}
.page-section ul .service:not(:first-of-type){
  margin-top: 12px;
}
.page--services .page-section{
  box-shadow: 0px 2px 6px #3f3e3e38;
  background: #fafafa;
  border-radius: 10px;
  padding: 20px 28px;
}
.page--services .page-section > .h2{
  text-align: left;
  font-size: 21px;
}
.page--services .service{
  display: flex;
  flex-direction: row;
  align-items: center;
}
.page--services ul .service span{
  color: black;
  display: inline-block;
  text-align: left;
  font-size: 16px;
}
.page--services ul .service{
  align-items: left;
}
.page--services ul .service svg{
  fill: black;
  width: 20px;
  height: 20px;
}
.png-page{
  padding-bottom: 50px;
}
.page--contact .page-section.page-section--contact{
  padding-top: 0;
}



.modal{
  display: none;
  position: fixed;
  top: 0; left: 0;
  z-index: 100;
  width: 100%;
  height: 100%;
}
.modal.modal--open{
  display: block;
}
.modal.modal--nav{
  display: none;
  grid-template-columns: 340px auto;
}
.modal.modal--nav.modal--open{
  display: grid;
}
.modal-wrapper{
  background: transparent;
  height: 100%;
  z-index: 104;
}
.modal.modal--open .modal-wrapper{
  background: #000000d1;
}
.modal-dialogue{
  background: white;
  height: 100%;
  position: relative;
  border-right: 2px solid #FD4B40;
  overflow: hidden;
  z-index: 106;
}
.modal-btn-close{
  position: absolute;
  top: 16px; right: 16px;
  height: 30px;
  width: 30px;
  fill: #FD4B40;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.modal-btn-close svg{
  width: 24px;
  height: 24px;
}
.modal--nav .modal-header{
  background: #FD4B40;
  color: white;
  padding: 15px 20px;
  font-weight: 700;
  font-size: 24px;
  box-shadow: 0px 1px 7px #00000085;
}
.modal--nav .modal-body{
  display: flex;
  flex-direction: column;
}
.modal--nav .nav-link{
  line-height: unset;
  padding: 14px 20px;
  height: unset;
  line-height: unset;
  display: flex;
  align-items: center;
  transition: 100ms;
  position: relative;
}
/* .modal--nav .nav-link.active::before{
  content: '';
  display: block;
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 5px;
  height: 35px;
  margin: auto 0;
  border-radius: 0 6px 6px 0;
  background: #FD4B40;
} */
.modal--nav .nav-link:hover{
  background: #f4f4f4;
}
.modal--nav .nav-link svg{
  fill: #FD4B40;
  width: 24px;
  height: 24px;
  flex: 0 0 24px;
}
.modal--nav .nav-link span{
  display: inline-block;
  margin-bottom: -2px;
  margin-left: 14px;
}
.modal--nav .nav-link:not(:first-of-type){
  margin-top: 5px;
}
.modal--nav .modal-body{
  margin-top: 15px;
}




/* ------------------------------ */
/* MOBILE VERSIONs OF THE WEBSITE */
/* ------------------------------ */

@media(max-width: 1300px){
  .page--services .container{
    grid-template-columns: 1fr 1fr;
  }
}

@media(max-width: 900px){
  .png-page{
    margin-top: 40px;
  }
  .page--services .container{
    grid-gap: 20px;
  }
  .page--services .page-section{
    padding: 16px 22px;
    border-radius: 6px;
  }
  .page--services .page-section > .h2{
    font-size: 18px;
    line-height: 26px;
  }
  .page--services ul .service svg{
    margin-right: 14px;
    margin-top: -2px;
  }
  .page--services ul .service span{
    font-size: 14px;
    line-height: 20px;
  }
}

@media(max-width: 800px){
  .page-section--qna .h2{
    margin-bottom: 30px;
  }
  .qna-el__question{
    font-size: 16px;
    padding: 16px 20px;
  }
  .qna-el .qna-el__answer{
    padding: 0 20px 16px;
    font-size: 13px;
    line-height: 22px;
    margin-top: -3px;
  }
  .png-page{
    margin-top: 30px;
  }
  .png-page p{
    font-size: 13px;
    line-height: 24px;
  }
  .h2{
    font-size: 24px;
    line-height: 28px;
  }
  .page-section--introduction{
    margin-bottom: 30px;
  }
  .page-section--introduction p{
    margin-top: 30px;
  }
  .services-container{
    padding: 30px 0;
    gap: 10px;
  }
  .service .service__icon{
    margin-right: 14px;
    margin-bottom: -1px;
  }
  .service .service__icon svg{
    flex: 0 0 40px;
    width: 40px;
    height: 40px;
  }
  .service .service__top{
    padding: 14px 32px 14px 14px;
    width: calc(100% - 46px);
  }
  .service .service__name{
    font-size: 18px;
    line-height: 22px;
    margin-top: -3px;
  }
  .service .service__description{
    padding-left: 70px;
    font-size: 13px;
    line-height: 22px;
  }
  .page-section ul{
    margin-top: 10px;
  }
  .page-section ul span , .page-section ul b{
    font-size: 14px;
    line-height: 22px;
  }
  .page-section ul svg{
    width: 22px;
    height: 22px;
    margin-right: 10px;
  }
  .page-section ul li:not(:first-of-type){
    margin-top: 12px;
  }
  .page-section--work-hours{
    padding-top: 0;
  }
  .page-section--work-hours p{
    margin-top: 16px;
  }
  .reviews-container{
    gap: 20px;
  }
  .review svg{
    margin-bottom: -5px;
    margin-right: 8px;
  }
  .review .review-main{
    margin-top: 10px;
    font-size: 12px;
    line-height: 20px;
  }
  .review .review-name{
    font-size: 14px;
  }
  .page-section .reviews-additional{
    margin-top: 22px;
  }
  .page-section .reviews-additional-link{
    font-size: 13px;
  }
  .page--services .container{
    grid-template-columns: 1fr;
  }
}

@media(max-width: 650px){
  .carousel{
    width: 300px;
    height: 500px;
  }
  .page--gallery .page-section:not(:first-of-type){
    margin-top: 80px;
  }
}

@media(max-width: 560px){
  .page-section--qna .h2{
    margin-bottom: 20px;
  }
  .page--services .page-section > .h2{
    text-align: center;
  }
  .qna-el:not(:first-of-type){
    margin-top: 21px;
  }
  .qna-el__question__chevron{
    width: 26px;
    height: 26px;
    flex: 0 0 26px;
    padding-left: 14px;
  }
  .png-page{
    margin-top: 20px;
  }
  .png-page p{
    font-size: 12px;
    line-height: 22px;
    text-align: center;
  }
  .page-section--introduction{
    margin-bottom: 20px;
  }
  .container{
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
  .h2{
    font-size: 20px;
    line-height: 26px;
  }
  .page-section--introduction p{
    margin-top: 20px;
  }
  .services-container{
    padding: 20px 0;
  }
  .page-section ul li{
    flex-direction: column;
  }
  .page-section ul span{
    justify-content: center;
  }
  .page-section ul li:not(:first-of-type){
    margin-top: 20px;
  }
  .page-section ul b{
    margin-top: 4px;
  }
  .page-section--work-hours{
    margin-top: 10px;
  }
  .page-section--work-hours p{
    margin-top: 0;
  }
  .page-section ul.work-hours-list{
    margin: 0;
  }
  .work-hours-list-container{
    margin: 24px 0;
  }
  .reviews-container{
    grid-template-columns: 1fr;
    grid-gap: 30px;
  }
  .page-section .reviews-additional{
    margin-top: 25px;
  }
  .page-section .reviews-additional-link{
    flex-direction: column-reverse;
  }
  .page-section .reviews-additional-link svg{
    margin-right: 0;
    margin-top: 10px;
  }
  .page-section .reviews-additional-link span{
    margin-top: 0;
    text-align: center;
  }
  .service .service__name{
    font-size: 15px;
    line-height: 20px;
  }
  .service .service__icon{
    margin-bottom: -2px;
  }
  .page--services ul .service svg{
    flex: 0 0 20px;
  }
  .page-section ul span{
    width: unset;
  }
}

@media(max-width: 480px){
  .modal.modal--nav{
    grid-template-columns: 280px auto;
  }
}

@media(max-width: 390px){
  .qna-el__question{
    font-size: 14px;
    padding: 12px 16px;
  }
  .qna-el .qna-el__answer{
    padding: 0 16px 12px;
    font-size: 12px;
    line-height: 20px;
    margin-top: 0;
  }
}
