@charset "utf-8";

/* ---------------------------------------------------------
concept
----------------------------------------------------------*/
.concept:before{
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  background-position: center center;
  background-size: cover;
  position: fixed;
  top: 6rem;
  left: 0;
  background-image: url(../images/concept/concept-03.jpg);
}
.concept.bg-2:before{
  background-image: url(../images/concept/concept-06.jpg);
}
.concept.bg-3:before{
  background-image: url(../images/concept/concept-15.jpg);
}

/* headline */
.headline{
  padding: 8rem 0 12rem;
  text-align: center;
}
.headline p{
  font-size: 2.4rem;
}
.headline p:not(:last-of-type){
  margin-bottom: 6rem;
}
.headline .house{
  margin: 5rem 0 4rem;
}
.headline_b{
  font-weight: bold;
  font-size: 3rem;
}

/* point */
.points{
  padding: 12rem 0;
  margin: 0 auto;
}
.points_inner{
  width:1420px;
  height: 830px;
  position: relative;
  margin: 0 auto;
}
.point1_text{
  position: absolute;
  top: 70px;
  right: 50px;
  width: 650px;
  padding-left: 80px;
  line-height: 1.5;
}
.point1_text .js_line{
  display: block;
  content: "";
  width: 70px;
  height: 1px;
  background-color: #000;
  position: absolute;
  left: 0;
  top: 35px;
}
.point2_media{
  position: absolute;
  top: 350px;
  right: 0;
}
.point2_text{
  position: absolute;
  top: 570px;
  left: 50px;
  width: 650px;
  padding-right: 80px;
  line-height: 1.5;
}
.point2_text .js_line{
  display: block;
  content: "";
  width: 160px;
  height: 1px;
  background-color: #000;
  position: absolute;
  right: 0;
  top: 35px;
}
.js_swipe{
  max-width: 72rem;
  width: 100%;
  overflow: hidden;
}
.js_swipe .slide-img{
  max-width: 72rem;
  width: 100%;
}

/* feature */
.feature{
  padding: 16rem 0 12rem;
}
.feature_headline{
  text-align: center;
  font-size: 3.8rem;
  margin-bottom: 22rem;
}
.feature_headline img{
  margin-bottom: 8rem;
}
.feature_headline span{
  font-size: 5rem;
  font-weight: bold;
}

/* desc */
.desc {
  display: flex;
  align-items: center;
}
.desc img{
  width: 50%;
}
.desc .text{
  width: 50%;
  padding: 0 1rem .5rem 4rem;
}
.desc.alt img{
  order: 2;
}
.desc.alt .text{
  order: 1;
  padding: 0 4rem .5rem 1rem;
  text-align: right;
}
.desc .text h3{
  font-size: 2vw;
  line-height: 1;
  display: inline-block;
  margin-bottom: 1.5rem;
  margin-top: -1rem;
}
.desc .text .paragraph:not(:last-of-type){
  margin-bottom: 1.5rem;
}
.desc .text .paragraph h4{
  font-size: 1.5vw;
  line-height: 1;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
}
.desc:not(.alt) .text .paragraph h4::before{
  display: block;
  content: "<<<";
  padding-right: .5rem;
}
.desc.alt .text .paragraph h4{
  justify-content: flex-end;
}
.desc.alt .text .paragraph h4::after{
  content: ">>>";
  padding-left: .5rem;
}
.desc .text .paragraph p{
  line-height: 1.4;
  font-size: 1.15vw;
}
.desc .text .paragraph span{
  font-weight: bold;
  border-bottom: 2px solid #efce0a;
}

/* designers */
.designers h3{
  text-align:center;
  font-size: 3.4rem;
  letter-spacing: .1rem;
}
.designers h3 span{
  font-weight: bold;
  font-size: 5.6rem;
}
.designers .point1_text{
  top:32px;
}
.designers .point2_text{
  top: 505px;
}
.designers .closing{
  font-size: 2.6rem;
  text-align: center;
  line-height: 1.4;
}
.designers .closing p:first-of-type{
  margin-bottom: 3rem;
}
.designers .closing span{
  font-size: 3.2rem;
  font-weight: bold;
}

/* ---------------------------------------------------------
PC&SP コンテンツ調整
----------------------------------------------------------*/
@media screen and (max-width:1000px){
  /* common */
  .concept:before{
    top: var( --sp-header);
  }

    /* point */
  .points{
    padding: 6rem 2rem;
  }
  .points_inner{
    width: 100%;
    height: auto;
    position: static;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
  .point1_media,
  .point2_media{
    position: static;
    margin-bottom: 1rem;
  }
  .point1_text,
  .point2_text{
    position: static;
    width: 100%;
    max-width: 720px;
  }
  .point1_text{
    padding-left: 0;
    margin-bottom: 4rem;
  }
  .point2_text{
    padding-right: 0;
  }
  .point1_text::before,
  .point2_text::before{
    display: none;
  }


  /* feature */
  .feature{
    padding: 6rem 2rem 2rem;
  }
  .feature_headline{
    font-size: 1.8rem;
    margin-bottom: 6rem;
    line-height: 1.5;
  }
  .feature_headline img{
    width: 100%;
    max-width: 420px;
    margin-bottom: 1.5rem;
  }
  .feature_headline span{
    font-size: 2.2rem;
  }


  /* desc */
  .desc {
    flex-direction: column;
    justify-content: center;
  }
  .desc img{
    width: 100%;
  }
  .desc .text,
  .desc.alt .text{
    width: 100%;
    padding: 2rem 0 4rem;
  }
  .desc.alt img{
    order: 1;
  }
  .desc.alt .text{
    order: 2;
    text-align: left;
  }
  .desc .text h3{
    font-size: 2.4rem;
    margin-bottom: 2rem;
    line-height: 1.7;
    margin-top: 0;
  }
  .desc .text .paragraph:not(:last-of-type){
    margin-bottom: 3.5rem;
  }
  .desc .text .paragraph h4{
    font-size: 1.8rem;
    line-height: 1.5;
  }
  .desc:not(.alt) .text .paragraph h4::before,
  .desc .text .paragraph h4::after{
    display: none;
  }
  .desc.alt .text .paragraph h4{
    justify-content: flex-start;
  }
  .desc .text .paragraph p{
    font-size: 1.6rem;
    line-height: 1.7;
  }


}

/* ---------------------------------------------------------
ONLY SP
----------------------------------------------------------*/
@media screen and (max-width:750px){
    /* common */
  .concept:before{
    top: var( --sp-header);
  }

  /* headline */
  .headline{
    padding: 4rem 1.25rem 6rem;
  }
  .headline p{
    font-size: 1.7rem;
  }
  .headline .magic{
    width: 80%;
    max-width: 200px;
  }
  .headline p:not(:last-of-type){
    margin-bottom: 3rem;
  }
  .headline .house{
    margin: 2.5rem 0 2rem;
  }
  .headline_b{
    font-size: 2.2rem;
  }

  /* designers */
  .designers h3{
    font-size: 1.8rem;
  }
  .designers h3 span{
    font-size: 2.4rem;
  }
  .designers .point1_text{
    top: auto;
  }
  .designers .point2_text{
    top: auto;
  }
  .designers .closing{
    font-size: 1.8rem;
    text-align: left;
    line-height: 1.5;
  }
  .designers .closing p:first-of-type{
    margin-bottom: 2rem;
  }
  .designers .closing span{
    font-size: 2.4rem;
  }
}
