@charset "UTF-8";

/* 下層ページ　共通仕様 */
.sub-page-title {
  font-size: 2em;
  font-weight: bold;
  margin-bottom: clamp(50px, 4vw, 80px);
}

/* ページトップ */
.page-title-area {
  padding: 2.5vw 5vw 1.5vw;
  background: linear-gradient(to bottom right, #F5FAFF, #97C8EB);
  overflow: hidden;
}

.page-title-area-iiner {
  width: 100%;
  margin: 0 auto;
}

.page-title--01 {
  font-size: 8em;
  font-weight: bold;
  color: #97c8eb7d;
  line-height: 0.7;
  margin-bottom: 15px;
}

.page-title--02 {
  font-size: 1.8em;
  font-weight: bold;
  color: #004C99;
}


/* ページトップ　説明書き */
.top-text__text--01 {
  font-size: 1.8em;
  font-weight: bold;
  color: #004C99;
  margin-bottom: clamp(10px, 2vw, 20px);
}

.top-text__text--02 {
  font-size: 1.1em;
}


/* 施工案内 */
.left-bar {
  font-size: 1.3em;
  font-weight: bold;
  margin-bottom: 7%;
}

.service-info {
  background-color: #F7F7F7;
}

.service-info__group-01,
.service-info__group-02,
.service-info__group-03,
.service-info__group-04 {
  padding: 3%;
  background-color: #FCFCFC;
  box-shadow: 0px 0px 8px #00000010;
}

.service-info .group-01__content-01,
.service-info__group-02,
.service-info__group-03,
.service-info__group-04 {
  display: flex;
  gap: 4%;
}

.service-info__group-02,
.service-info__group-03,
.service-info__group-04 {
  margin-top: 3vw;
}

.service-info .group-01__content-01 img,
.service-info__group-02 img,
.service-info__group-03 img,
.service-info__group-04 img {
  width: calc((100% - 4%)/2);
}

.service-info .content-01__text-group,
.service-info .group-02__text-group,
.service-info .group-03__text-group,
.service-info .group-04__text-group {
  width: calc((100% - 4%)/2);
  padding-top: 1%;
}

.service-info__group-01 .service-info__service-text {
  margin-bottom: 10%;
}


.content-01__details {
  width: 100%;
  margin-top: clamp(20px, 3vw, 40px);
}

.service-info .details__btn {
  width: 100%;
  height: 60px;
  padding-left: 5%;
  text-align: left;
  font-size: 1.2em;
  color: #FCFCFC;
  font-weight: 500;
  background: linear-gradient(to bottom right, #1E7FE2, #1894ED);
  position: relative;
}

.service-info .details__btn:hover{
  background: linear-gradient(to bottom right, #1169c1, #1894ED);
}

.detail-btn__icon {
  position: absolute;
  top: 50%;
  right: 5%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
}

.detail-btn__icon * {
  width: 22px;
  height: 4px;
  background-color: #FCFCFC;
  transition: transform .5s ease;
}

.detail-btn__icon--02 {
  transform: translateY(-100%) rotate(90deg);
}

.detail-btn__icon.show .detail-btn__icon--01 {
  display: none;
}

.detail-btn__icon.show .detail-btn__icon--02 {
  transform: rotate(-180deg);
}

.detail-inner {
  width: 100%;
  background-color: #F7F7F7;
  display: none;
  padding: 3%;
  gap: 4%;
}

.detail__img-group {
  width: calc((100% - 4%)/2);
}

.detail__img-group * {
  width: 100%;
}

.detail__img--02 {
  margin-top: 3%;
}

.detail__text-group {
  width: calc((100% - 4%)/2);
}

.detail__text-group .text-group__title--01,
.detail__text-group .text-group__title--02 {
  font-size: 1.2em;
  margin-top: 1%;
}

.detail__text-group .text-group__title--02 {
  margin-top: 12%;
}

.detail__text-group .text-group__text--01 span {
  text-decoration: underline;
  text-underline-offset: 10%;
}

.detail__text-group .text-02__inner-title--01,
.detail__text-group .text-02__inner-title--02 {
  font-weight: 600;
  font-size: 1.1em;
  margin-bottom: 3%;
}

.detail__text-group .text-02__inner-title--01 span,
.detail__text-group .text-02__inner-title--02 span {
  color: #004C99;
  margin-right: 1%;
}

.detail__text-group .text-02__inner-title--02 {
  margin-top: 7%;
}

.detail-text__check-lists {
  margin: 5% 0;
}

.detail__check-lists {
  margin: 5% 0;
  font-weight: bold;
}

.detail__check-lists span {
  color: #004C99;
  margin-right: 1%;
}


/* 施工の流れ */
.service-flow__intro {
  text-align: center;
  margin: 3vw 0 3vw;
}

.flow-group {
  display: flex;
  gap: 2%;
}

.flow-group__content {
  width: calc((100% - (2% * 3))/4);
  border: solid 3px #004C99;
  box-shadow: 0px 0px 8px #00000010;
  position: relative;
}

.flow-group__deco {
  background-color: #004C99;
  width: 30%;
  padding-top: 30%;
  clip-path: polygon(0 0, 100% 0, 0 100%);
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(-1px, -1px);
}

.flow-group__deco-num {
  position: absolute;
  top: 30%;
  left: 30%;
  transform: translate(-50%, -50%);
  color: #FCFCFC;
  font-weight: bold;
}

.flow-group__title {
  width: 100%;
  text-align: center;
  padding: 20% 0 15%;
  color: #004C99;
  font-weight: bold;
  font-size: 1.2em;
  border-bottom: solid 1px #D9D9D9;
}

.flow-group__explain {
  padding: 5%;
}


/* よくあるご質問 */
.service-question {
  background-color: #F7F7F7;
}

.service-question__contents {
  width: 100%;
}

.service-question__content {
  margin-bottom: 1vw;
  box-shadow: 0px 0px 8px #00000010;
}

.service-question__btn {
  width: 100%;
  height: 70px;
  position: relative;
  background-color: #FCFCFC;
  cursor: pointer;
}

.service-question-btn__title {
  position: absolute;
  font-size: 1.1em;
  font-weight: 500;
  position: absolute;
  width: 100%;
  top: 50%;
  left: 0;
  padding: 0 70px 0 100px;
  transform: translateY(-50%);
}

.service-question__icon-01 {
  width: 70px;
  height: 70px;
  background-color: #004C99;
  position: absolute;
  top: 0;
  left: 0;
}

.service-question__icon-01 p {
  color: #FCFCFC;
  font-size: 2em;
  font-weight: 500;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.service-question__icon-02 {
  position: absolute;
  top: 50%;
  right: 2%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
}

.service-question__icon-02 * {
  width: 22px;
  height: 4px;
  background-color: #004C99;
  transition: transform .5s ease;
}

.service-question__icon-02--01 {
  transform: translateY(100%) rotate(90deg);
}

.service-question__icon-02.show .service-question__icon-02--01 {
  display: none;
}

.service-question__icon-02.show .service-question__icon-02--02 {
  transform: rotate(-180deg);
}

.service-question__inner-text {
  display: none;
  padding: 3% 70px 3% 100px;
  width: 100%;
  background-color: #FCFCFC;
}



@media(max-width:1000px) {

  /* 施工の流れ */
  .flow-group {
    gap: 0;
    flex-wrap: wrap;
  }

  .flow-group__content {
    width: calc((100% - (2% * 4))/2);
    margin: 2%;
  }

  .flow-group__deco {
    width: 20%;
    padding-top: 20%;
  }

  .flow-group__title {
    padding: 10% 0 10%;
    font-size: 1.4em;
  }

  .flow-group__explain {
    padding: 7%;
  }
}





@media(max-width:780px) {

  /* 下層ページ　共通仕様 */
  .sub-page-title {
    font-size: 1.8em;
  }


  /* ページトップ */
  .page-title-area {
    padding: 20px 5vw 15px;
  }


  .page-title--01 {
    font-size: 5em;
    margin-bottom: 7px;
  }

  .page-title--02 {
    font-size: 1.5em;
  }


  /* ページトップ　説明書き */
  .top-text__text--01 {
    font-size: 1.5em;
  }


  /* 施工案内 */
  .left-bar {
    font-size: 1.3em;
    font-weight: bold;
    margin-bottom: 5%;
  }

  .service-info .group-01__content-01,
  .service-info__group-03 {
    flex-direction: column;
  }

  .service-info__group-02,
  .service-info__group-04 {
    flex-direction: column-reverse;
  }

  .service-info .group-01__content-01 img,
  .service-info__group-02 img,
  .service-info__group-03 img,
  .service-info__group-04 img {
    width: 100%;
  }

  .service-info .content-01__text-group,
  .service-info .group-02__text-group,
  .service-info .group-03__text-group,
  .service-info .group-04__text-group {
    width: 100%;
    padding-top: 0;
    padding: 4% 1% 1%;
  }

  .service-info__group-01 .service-info__service-text {
    margin-bottom: 5%;
  }

  .content-01__btn {
    margin: 0 auto;
  }

.service-info .details__btn {
  height: 50px;
}

.detail-btn__icon * {
  width: 18px;
  height: 3px;
}
  
  .detail-inner {
    flex-direction: column;
    gap: 0;
  }

  .detail__img-group {
    width: 100%;
  }

  .detail__text-group {
    width: 100%;
  }


  .detail__img-group img:nth-of-type(2) {
    display: none;
  }

  .detail__text-group .text-group__title--01,
  .detail__text-group .text-group__title--02 {
    margin-top: 10px;
  }

  .detail__text-group .text-group__title--02 {
    margin-top: 30px;
  }


  /* よくあるご質問 */
  .service-question__btn {
    height: 60px;
    font-size: 1em;
  }

  .service-question-btn__title {
    padding: 0 55px 0 75px;
  }


  .service-question__icon-01 {
    width: 60px;
    height: 60px;
  }

  .service-question__icon-01 p {
    font-size: 2em;
  }

  .service-question__icon-02 * {
    width: 18px;
    height: 3px;
  }


  .service-question__inner-text {
    padding: 3% 55px 3% 75px;
  }
}



@media(max-width:560px) {
  .flow-group {
    flex-wrap: nowrap;
    flex-direction: column;
  }

  .flow-group__content {
    width: 100%;
    margin: 0 0 3% 0;
  }

  .flow-group__title {
    padding: 6% 0 6%;
    font-size: 1.4em;
  }

  .flow-group__deco {
    width: 15%;
    padding-top: 15%;
  }

  .flow-group__explain {
    padding: 5%;
  }


  /* よくあるご質問 */
  .service-question__btn {
    font-size: .8em;
  }

  .service-question__inner-text p {
    font-size: .8em;
  }



}