@charset "UTF-8";
/* %算出に使用 */
/* ===============================
  家づくりの流れ
=============================== */
/* 注文住宅
------------------------------*/
.housing-flow__mv {
  background: url(../img/housing-flow_mv.jpg) no-repeat center center/cover;
}

/* リノベーション
------------------------------*/
.renovation-flow__mv {
  background: url(../img/renovation-flow_mv.jpg) no-repeat center center/cover;
}

/*------------------------------
introduction
------------------------------*/
.introduction {
  padding: 2.9% 0 7.7%;
}

.introduction__heading {
  margin-top: 4.9%;
}
@media (max-width: 767px) {
  .introduction__heading {
    margin-top: 5.3333333333vw;
  }
}

.introduction__message {
  margin-top: 2.4%;
}
@media (max-width: 767px) {
  .introduction__message {
    margin-top: 4.1899441341%;
  }
}

.introduction__figure {
  margin-top: 5%;
  margin-top: 3.7%;
}
@media (max-width: 767px) {
  .introduction__figure {
    width: calc(100% + 8vw);
    padding-right: 2%;
    overflow: scroll;
    overflow-y: hidden;
  }
  .introduction__figure img {
    max-width: unset;
    width: 280vw;
  }
}

@media (min-width: 768px) {
  .introduction__figure-2 {
    width: 85.3%;
  }
}

/*------------------------------
step
------------------------------*/
.step {
  margin-bottom: 10.1910828025vw;
  padding: 5% 0 9.1%;
  position: relative;
}
.step::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background: #e9e6de;
  width: 88.3%;
  height: 100%;
}
.step.type2 {
  padding-bottom: 17.7%;
}
@media (max-width: 767px) {
  .step::before {
    width: 100%;
  }
}

.step__list {
  position: relative;
}

.step__item {
  display: flex;
  height: 12.5vw;
}
.step__item:nth-child(n+2) {
  margin-top: 8.75%;
  position: relative;
}
.step__item:nth-child(n+2)::before {
  content: "";
  position: absolute;
  top: -35%;
  left: 50%;
  transform: translateX(-50%);
  background: url(../img/icon_arrow01.svg) no-repeat center center/contain;
  width: 3.821656051vw;
  aspect-ratio: 126/66;
}
@media (max-width: 767px) {
  .step__item {
    display: block;
    height: auto;
  }
  .step__item:nth-child(n+2) {
    margin-top: 13%;
  }
  .step__item:nth-child(n+2)::before {
    top: -10%;
    width: 11%;
  }
}

.step__image {
  width: 21.6666666667%;
}
@media (max-width: 767px) {
  .step__image {
    width: 100%;
  }
  .step__image img {
    aspect-ratio: 315/120;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.step__label {
  width: 24.2%;
  font-size: 1.9108280255vw;
  font-weight: 200;
  line-height: 2;
  color: #fff;
  background: #47555e;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  letter-spacing: 0.05em;
}
@media (max-width: 767px) {
  .step__label {
    width: 100%;
    font-size: 4.2666666667vw;
  }
}

.step__label--dark {
  background: #182935;
}

.step__body {
  width: 54.1666666667%;
  width: 49.3%;
  background: #fff;
  padding: 0 3.8%;
  padding-right: 2%;
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  justify-content: center;
}
.step__body.type2 {
  letter-spacing: -0.18em;
}
@media (max-width: 767px) {
  .step__body {
    width: 100%;
    padding-bottom: 3%;
  }
}

.step__heading {
  font-size: 1.5923566879vw;
  font-weight: 200;
  line-height: 2.4;
}
.step__heading span {
  font-size: 1.0191082803vw;
}
@media (max-width: 767px) {
  .step__heading {
    font-size: 4.2666666667vw;
  }
  .step__heading span {
    font-size: 3.7333333333vw;
  }
}

.step__description {
  font-size: 1.0191082803vw;
  font-weight: 200;
  line-height: 2.25;
}
@media (max-width: 767px) {
  .step__description {
    font-size: 3.2vw;
    line-height: 1.6;
  }
}
/*# sourceMappingURL=flow.css.map */