@charset "UTF-8";

html {
  font-size: 62.5%;
}


body {
  width: 100%;
}


img,
video,
svg {
  width: 100%;
  height: auto;
}

#SPRING-OUTER a{
  display: block;
}

#SPRING-OUTER .price span {
  display: inline-block;
}

/*==========================
			共通
=========================*/



/*.back_pc{
    background: url(../img/BK_pc.jpg); 
    background-repeat: no-repeat;
    background-position: center;
    background-size: 140rem;
    background-position-y: -11.1rem;
}*/


#SPRING-OUTER {
  width: 100%;
  margin: auto;
  margin-bottom: 12rem;
  padding-top: 3rem;
  font-size: 1.3rem;
  letter-spacing: 0.05em;
  line-height: 2;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  color: #000000;
  font-feature-settings: "palt";
}

.ta_c {
  text-align: center;
}

.text-box{
  font-size: 1.3rem;
  letter-spacing: 0.05em;
  line-height: 2;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  color: #000000;
  font-feature-settings: "palt";
  white-space: nowrap;
}

.price {
  font-family: forma-djr-display, sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: 1.2rem;
  line-height: 1;
  letter-spacing: 0.12em;
  font-feature-settings: "palt";
  color: #42210B;
  margin-top: 2.85rem;
}

.price_mb{
  margin-bottom: 1.3rem;
}

.price span{
  font-weight: inherit;
}

h2.sect_number{
  font-family: forma-djr-display,sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 16rem;
  line-height: 1;
  font-feature-settings: "palt";
  position: absolute;
  letter-spacing: 0.05em;
}

h3.ttl{
  font-family: forma-djr-display,sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #42210B;
  font-size: 2rem;
  line-height: 1.4;
  letter-spacing: 0.075em;
  font-feature-settings: "palt";
  margin-top: 3.6rem;
  margin-bottom: 1.95rem;
}

.flex{
  display: flex;
}

.flex-column{
  display: flex;
}

@media screen and (min-width: 768px) {
  .pc-flex{
    display: flex;
  }
}
/*==========================
          top
=========================*/
.top{
  width: 100%;
  margin: auto;
  margin-bottom: 11.3rem;
}

.top-img{
  width: 100%;
  margin: auto;
  margin-bottom: 7.5rem;
}

.top .text-box{
  font-size: 1.4rem;
  letter-spacing: 0.025em;
  line-height: 2.2;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  color: #000000;
  font-feature-settings: "palt";
}

/*=======//top==============================================*/

/*==========================
      section01
=========================*/
.sect01{
  width: 113rem;
  padding-left: 3rem;
  padding-bottom: 5rem;
  margin: auto;
  margin-bottom: 15rem;
  position: relative;
}

.sect01 .flex-column{
  width: 113rem;
}

.sect01::before{
  content: "";
  width: 44rem;
  height: 60rem;
  background-color: #E8ECF0;
  left: 3rem;
  top: 12rem;
  position: absolute;
  z-index: -1;
}

.sect01::after{
  content: "";
  width: 69rem;
  height: 73.8rem;
  background-color: #FCFBF5;
  right: 0;
  bottom: 0;
  position: absolute;
  z-index: -1;
}

.img01{
  width: 44rem;
  margin-left: 6rem;
}

.sect01 .description-box{
  margin-left: 8rem;
  padding-top: 15rem;
  position: relative;
}

@media screen and (min-width: 768px) {
.sect01 .item-box.flex{
  display: flex;
  justify-content: space-between;
  position: relative;
  width: 38rem;
}
}



.sect01 h2.sect_number{
  color: #E1E6EB;
  bottom: -22px;
  right: -10.2rem;
}

.img01_item01{
  width: 18rem;
  margin-top: 6rem;
}

.img01_item02{
  width: 18rem;
  z-index: 2;
}








/*=======//section01==============================================*/


/*==========================
      section02
=========================*/
.sect02{
  width: 114rem;
  /*padding-right: 6rem;*/
  margin: auto;
  margin-bottom: 15rem;
}

@media screen and (min-width: 768px) {
.sect02 .flex-column{
  justify-content: center;
  /*padding-left: 6rem;*/
}

.sect02 .description-box{
  padding-top: 9rem;
  position: relative;
  background-color: #FCFBF5;
  padding-right: 17rem;
  padding-left: 8rem;
  padding-bottom: 9rem;
  height: 100%;
}

.sect02 .description-box::before{
  content: "";
  width: 100%;
  /*height: 63.9rem;*/
  height: 91.42857143%;
  background-color: #FBF9DF;
  left: -6rem;
  top: 12rem;
  position: absolute;
  z-index: -1;
}

/*.sect02::after{
  content: "";
  width: 69rem;
  height: 69.9rem;
  background-color: #FCFBF5;
  left: 9rem;
  top: 0;
  position: absolute;
  z-index: -1;
}*/

}

.img02{
  width: 48rem;
  margin-top: 18rem;
  margin-left: -9rem;
  position: relative;
  z-index: 2;
}

.sect02 .item-box.flex{
  width: 38rem;
  display: flex;
  justify-content: space-between;
  margin: auto;
  position: relative;
}

.sect02 h2.sect_number{
  color: #FAF8D7;
  top: -6.4rem;
  right: -6rem;
  z-index: -1;
}

.img02_item01{
  width: 18rem;
}

.img02_item02{
  width: 18rem;
  margin-top: 3rem;
}



/*=======//section02==============================================*/


/*==========================
      section03
=========================*/
.sect03{
  /*width: 76rem;*/
  /*padding-left: 4rem;*/
  /*padding-bottom: 8rem;*/
  margin: auto;
  margin-bottom: 15rem;
  text-align: center;
}

.sect03 .flex-column{
  margin: auto;
}

@media screen and (min-width: 768px) {
.sect03 .description-box{
  padding-top: 21rem;
  padding-right: 8rem;
  padding-bottom: 8rem;
  padding-left: 5rem;
  position: relative;
  margin-top: -14.8rem;
  background-color: #FCFBF5; 
  justify-content: center;
  display: inline-flex;
  margin-left: -5.1rem;
}

.sect03 .description-box::before{
  content: "";
  width: 19rem;
  height: 48rem;
  background-color: #F8F0F0;
  right: -9rem;
  top: -13rem;
  position: absolute;
  z-index: -3;
}

/*.sect03::after{
  content: "";
  width: 67rem;
  height: 56rem;
  background-color: #FCFBF5;
  left: 4rem;
  bottom: 0;
  position: absolute;
  z-index: -2;
}*/

.img03{
  width: 44rem;
  /*margin-left: 13rem;*/
  margin: auto;
  /*margin-left: 51.5rem;*/
  /*padding-left: 2rem;*/
  position: relative;
  z-index: 3;
  padding-right: 2rem;

}

}


.sect03 .Explanation-box{
  margin-left: 5.3rem;
}

.sect03 h2.sect_number{
  color: #F0DDDB;
  bottom: -9rem;
  right: -12.3rem;
  z-index: -1;
}

.img03_item01{
  width: 16rem;
  margin-top: 2rem;
  /*margin-left: -3rem;*/
}




/*=======//section03==============================================*/


/*==========================
      section04
=========================*/
.sect04{
  width: 108rem;
  /*padding-left: 3rem;*/
  /*padding-bottom: 4.7rem;*/
  margin: auto;
  margin-bottom: 15rem;
  position: relative;
}

.sect04 .flex-column{
  width: 108rem;
}

.sect04 h3{
  margin-top: 2.6rem;
}

@media screen and (min-width: 768px) {
.sect04 .description-box{
  margin-left: -6rem;
  margin-top: 12rem;
  position: relative;
  background-color: #FCFBF5;
  padding-top: 6rem;
  padding-right: 8rem;
  padding-bottom: 5rem;
  padding-left: 14rem;
}
.sect04 .description-box::before{
  content: "";
  width: 100%;
  height: 97.1%;
  background-color: #EEECEF;
  right: -6rem;
  top: -6rem;
  position: absolute;
  z-index: -1;
}

/*.sect04::after{
  content: "";
  width: 56rem;
  height: 71rem;
  background-color: #FCFBF5;
  right: 6rem;
  bottom: 0;
  position: absolute;
  z-index: -1;
}*/
}

.img04{
  width: 44rem;
  height: 66rem;
  margin-left: 8rem;
  position: relative;
  z-index: 3;
}

.sect04 .item-box.flex{
  display: flex;
  justify-content: space-between;
  position: relative;
  width: 34rem;
}

.sect04 h2.sect_number{
  color: #E8E6EA;
  bottom: -10.5rem;
  left: -4.2rem;
  z-index: -1;
}

.img04_item01{
  width: 16rem;
  margin-top: 3rem;
}

.img04_item02{
  width: 16rem;
}




/*=======//section04==============================================*/


/*==========================
      section05
=========================*/
.sect05{
  width: 94rem;
  padding-bottom: 8rem;
  margin: auto;
  margin-bottom: 12rem;
  position: relative;
}

.sect05::before{
  content: "";
  width: 60rem;
  height: 65.3rem;
  background-color: #F5E3E3;
  left: 0rem;
  bottom: 6rem;
  position: absolute;
  z-index: -3;
}

.sect05::after{
  content: "";
  width: 88rem;
  height: 65.3rem;
  background-color: #FCFBF5;
  left: 6rem;
  bottom: 0;
  position: absolute;
  z-index: -2;
}

@media screen and (min-width: 768px) {
  .sect05 .item-box{
    justify-content: space-between;
    position: relative;
    width: 58rem;
    margin: auto;
  }
}

.img05{
  width: 48rem;
  margin-left: 34rem;
}

.sect05 .description-box{
  margin-top: 7.6rem;
  /* margin-left: -8rem; */
  width: 58rem;
  margin-left: 14rem;
}

.sect05 .Explanation-box{
  margin: auto;
}

.sect05 h2.sect_number{
  color: #F2DAD9;
  bottom: -9rem;
  right: -13.9rem;
  z-index: -1;
}

.img05_item01{
  width: 18rem;
}

.img05_item02{
  width: 18rem;
}

.img05_item03{
  width: 18rem;
}


@media screen and (min-width: 768px) {

}


/*=======//section05==============================================*/


/*==========================
      ボタン
=========================*/
.lp-button a {
  font-size: 1.3rem;
  font-family: pragmatica, sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1;
  padding: 1.5rem 3.8rem 1.7rem;
  display: inline-block!important;
  color: #000000;
  border: 1px solid #8b8b8b;
  letter-spacing: 0.08em;
  background-color: #ffffff;
}

/*=======//ボタン==============================================*/

/*==========================
		アニメーション
=========================*/

/*-----追加CSS------------------*/
.js-fade {
  transition-duration: 1s;
  visibility: hidden;
  opacity: 0;
}

.js-fade.active {
  visibility: visible;
  opacity: 1;
}


/*=======//アニメーション=========================================*/

/*=====PCのみ==============================*/
@media screen and (min-width: 768px) {
  .sp_only {
    display: none;
  }

  .pc-order01 {
    order: 1;
  }

  .pc-order02 {
    order: 2;
  }


}

/*=====//PCのみ==============================*/

/*=====タブレットのみ==============================*/
@media screen and (min-width: 768px) and (max-width: 1400px) {
  html {
    font-size: calc(10*(100vw/1400)) !important;
  }

}

/*=====//タブレットのみ==============================*/

/*=====SPのみ==============================*/
@media screen and (max-width: 767px) {
  .pc_only {
    display: none;
  }


  /*==========================
			共通
=========================*/

  /*.back_sp {
    background: url(../img/BK_sp.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-position-y: -67px;
    background-size: 100%;
  }*/


#SPRING-OUTER {
  width: 100%;
  margin: auto;
  margin-bottom: calc(150*(100vw/750));
  padding-top: calc(0*(100vw/750));
  font-size: calc(26*(100vw/750));
  letter-spacing: 0.05em;
  line-height: 2;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  color: #000000;
  font-feature-settings: "palt";
}

.ta_c {
  text-align: center;
}

.text-box{
  font-size: calc(26*(100vw/750));
  letter-spacing: 0.05em;
  line-height: 2;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  color: #000000;
  font-feature-settings: "palt";
}

.price {
  font-family: forma-djr-display, sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: calc(24*(100vw/750));
  line-height: 1;
  letter-spacing: 0.12em;
  font-feature-settings: "palt";
  color: #42210B;
  margin-top: calc(56*(100vw/750));
}

.price_mb{
  margin-bottom: calc(22*(100vw/750));
}

h2.sect_number{
  font-family: forma-djr-display,sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: calc(192*(100vw/750));
  line-height: 1;
  font-feature-settings: "palt";
  position: absolute;
  letter-spacing: 0.05em;
}

h3.ttl{
  font-family: forma-djr-display,sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #42210B;
  font-size: calc(40*(100vw/750));
  line-height: 1.4;
  letter-spacing: 0.075em;
  font-feature-settings: "palt";
  margin-top: calc(76*(100vw/750));
  margin-bottom: calc(39*(100vw/750));
}

.flex{
  display: flex;
}

.flex-column{
  display: flex;
  flex-direction: column;
}

@media screen and (min-width: 768px) {
  .pc-flex{
    display: flex;
  }
}
/*==========================
          top
=========================*/
.top{
  width: 100%;
  margin: auto;
  margin-bottom: calc(136*(100vw/750));
}

.top-img{
  width: 100%;
  margin: auto;
  margin-bottom: calc(136*(100vw/750));
}

.top .text-box{
  font-size: calc(28*(100vw/750));
  letter-spacing: 0.025em;
  line-height: 2;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  color: #000000;
  font-feature-settings: "palt";
}

/*=======//top==============================================*/

/*==========================
      section01
=========================*/
.sect01{
  width: calc(750*(100vw/750));
  padding-left: 0;
  padding-bottom: calc(100*(100vw/750));
  margin: auto;
  margin-bottom: calc(200*(100vw/750));
  position: relative;
}

.sect01 .flex-column{
  width: calc(750*(100vw/750));
}

.sect01::before{
  content: "";
  width: calc(750*(100vw/750));
  height: calc(540*(100vw/750));
  background-color: #E8ECF0;
  left: 0;
  right: 0;
  margin: auto;
  top: calc(150*(100vw/750));
  position: absolute;
  z-index: -1;
}

.sect01::after{
  content: "";
  width: calc(750*(100vw/750));
  height: calc(1446*(100vw/750));
  background-color: #FCFBF5;
  left: 0;
  right: 0;
  margin: auto;
  bottom: 0;
  position: absolute;
  z-index: -1;
}

.img01{
  width: calc(560*(100vw/750));
  margin-left: 0;
  margin: auto;
}

.sect01 .description-box{
  width: calc(750*(100vw/750));
  margin-left: calc(0*(100vw/750));
  padding-top: calc(80*(100vw/750));
  position: relative;
}

.sect01 .item-box.flex{
  display: flex;
  justify-content: space-between;
  position: relative;
  width: calc(560*(100vw/750));
  margin-left: calc(44*(100vw/750));
}

.sect01 h2.sect_number{
  color: #E1E6EB;
  bottom: calc(-32*(100vw/750));
  right: calc(-113*(100vw/750));
}

.img01_item01{
  width: calc(270*(100vw/750));
  margin-top: calc(80*(100vw/750));
}

.img01_item02{
  width: calc(270*(100vw/750));
  z-index: 2;
}



/*=======//section01==============================================*/


/*==========================
      section02
=========================*/
.sect02{
  width: calc(750*(100vw/750));
  padding-right: 0;
  margin: auto;
  margin-bottom: calc(230*(100vw/750));
  padding-bottom: calc(100*(100vw/750));
  position: relative;
}

.sect02 .flex-column{
  width: calc(750*(100vw/750));
}

.sect02::before{
  content: "";
  width: calc(600*(100vw/750));
  height: calc(1442*(100vw/750));
  background-color: #FBF9DF;
  left: 0;
  top: calc(815*(100vw/750));
  position: absolute;
  z-index: -1;
}

.sect02::after{
  content: "";
  width: calc(720*(100vw/750));
  height: calc(1592*(100vw/750));
  background-color: #FCFBF5;
  left: calc(30*(100vw/750));
  top: calc(630*(100vw/750));
  position: absolute;
  z-index: -1;
}

.img02{
  width: calc(600*(100vw/750));
  margin-top: calc(90*(100vw/750));
  margin-left: calc(90*(100vw/750));
  position: relative;
}

.sect02 .description-box{
  width: calc(750*(100vw/750));
  margin: auto;
  padding-top: calc(80*(100vw/750));
  position: relative;
  margin-left: calc(14*(100vw/750));
}

.sect02 .item-box.flex{
  width: calc(560*(100vw/750));
  display: flex;
  justify-content: space-between;
  position: relative;
  margin-left: calc(95*(100vw/750));
}

.sect02 h2.sect_number{
  color: #FAF8D7;
  top: calc(-83*(100vw/750));
  right: calc(-60*(100vw/750));
  z-index: -1;
}

.img02_item01{
  width: calc(270*(100vw/750));
}

.img02_item02{
  width: calc(270*(100vw/750));
  margin-top: calc(80*(100vw/750));
}


/*=======//section02==============================================*/


/*==========================
      section03
=========================*/
.sect03{
  width: calc(750*(100vw/750));
  padding-left: 0;
  padding-bottom: calc(100*(100vw/750));
  margin: auto;
  margin-bottom: calc(200*(100vw/750));
  position: relative;
}

.sect03 .flex-column{
  margin: auto;
}

.sect03::before{
  content: "";
  width: calc(190*(100vw/750));
  height: calc(1200*(100vw/750));
  background-color: #F8F0F0;
  right: 0rem;
  top: calc(368*(100vw/750));
  position: absolute;
  z-index: -3;
}

.sect03::after{
  content: "";
  width: calc(700*(100vw/750));
  height: calc(1476*(100vw/750));
  background-color: #FCFBF5;
  left: 0;
  bottom: 0;
  position: absolute;
  z-index: -2;
}

.img03{
  width: calc(560*(100vw/750));
  margin-left: calc(70*(100vw/750));
  position: relative;
}

.sect03 .description-box{
  margin-left: 0;
  margin: auto;
  margin-top: calc(100*(100vw/750));
  margin-left: calc(-51*(100vw/750));
}

.sect03 .Explanation-box{
  margin-left: 0;
  margin: auto;
}

.sect03 h2.sect_number{
  color: #F0DDDB;
  bottom: calc(-110*(100vw/750));
  right: calc(-100*(100vw/750));
  z-index: -1;
}

.img03_item01{
  width: calc(240*(100vw/750));
  margin: auto;
  margin-top: calc(0*(100vw/750));
}

/*=======//section03==============================================*/


/*==========================
      section04
=========================*/
.sect04{
  width: calc(750*(100vw/750));
  padding-left: 0;
  padding-bottom: calc(100*(100vw/750));
  margin: auto;
  margin-bottom: calc(200*(100vw/750));
  position: relative;
}

.sect04 .flex-column{
  width: calc(750*(100vw/750));
}

.sect04 h3{
  margin-top: calc(72*(100vw/750));
}

.sect04::before{
  content: "";
  width: calc(560*(100vw/750));
  height: calc(1830*(100vw/750));
  background-color: #EEECEF;
  right: 0;
  top: calc(235*(100vw/750));
  position: absolute;
  z-index: -3;
}

.sect04::after{
  content: "";
  width: calc(720*(100vw/750));
  height: calc(1830*(100vw/750));
  background-color: #FCFBF5;
  right: calc(30*(100vw/750));
  bottom: 0;
  position: absolute;
  z-index: -2;
}

.img04{
  width: calc(560*(100vw/750));
  height: calc(840*(100vw/750));
  margin-left: calc(80*(100vw/750));
  position: relative;
}

.sect04 .description-box{
  width: calc(750*(100vw/750));
  margin: auto;
  margin-left: calc(-16*(100vw/750));
  padding-top: calc(100*(100vw/750));
  position: relative;
}

.sect04 .item-box.flex{
  display: flex;
  justify-content: space-between;
  position: relative;
  width: calc(500*(100vw/750));
  margin-left: calc(140*(100vw/750));
}

.sect04 h2.sect_number{
  color: #E8E6EA;
  bottom: calc(-138*(100vw/750));
  left: calc(-51*(100vw/750));
  z-index: -1;
}

.img04_item01{
  width: calc(240*(100vw/750));
  margin-top: calc(80*(100vw/750));
}

.img04_item02{
  width: calc(240*(100vw/750));
}

/*=======//section04==============================================*/


/*==========================
      section05
=========================*/
.sect05{
  width: calc(750*(100vw/750));
  padding-bottom: calc(100*(100vw/750));
  margin: auto;
  margin-bottom: calc(150*(100vw/750));
  position: relative;
}

.sect05::before{
  content: "";
  width: calc(600*(100vw/750));
  height: calc(1633*(100vw/750));
  background-color: #F5E3E3;
  left: 0rem;
  bottom: calc(180*(100vw/750));
  position: absolute;
  z-index: -3;
}

.sect05::after{
  content: "";
  width: calc(720*(100vw/750));
  height: calc(1633*(100vw/750));
  background-color: #FCFBF5;
  left: calc(30*(100vw/750));
  bottom: 0;
  position: absolute;
  z-index: -2;
}

.sect05 .item-box{
  justify-content: start;
  position: relative;
  width: calc(560*(100vw/750));
  margin: auto;
  flex-wrap: wrap;
}


.img05{
  width: calc(600*(100vw/750));
  margin-left: calc(90*(100vw/750));
}

.sect05 .description-box{
  width: calc(750*(100vw/750));
  margin: auto;
  margin-top: calc(80*(100vw/750));
}

.sect05 .Explanation-box{
  margin: auto;
  margin-left: calc(30*(100vw/750));
}

.sect05 h2.sect_number{
  color: #F2DAD9;
  bottom: calc(100*(100vw/750));
  right: calc(-45*(100vw/750));
  z-index: -1;
}

.img05_item01{
  width: calc(270*(100vw/750));
  margin-top: calc(80*(100vw/750));
}

.img05_item02{
  width: calc(270*(100vw/750));
  margin-left: calc(20*(100vw/750));
}

.img05_item03{
  width: calc(270*(100vw/750));
  margin-left: calc(192*(100vw/750));
}

.price_mt{
  margin-top: calc(22*(100vw/750));
}


/*=======//section05==============================================*/


  /*==========================
      ボタン
=========================*/
.lp-button a {
    font-size: calc(26*(100vw/750));
    font-family: pragmatica, sans-serif;
    font-weight: 400;
    font-style: normal;
    line-height: 1;
    padding: calc(20*(100vw/750)) calc(30*(100vw/750)) calc(20*(100vw/750));
    display: inline-block!important;
    color: #272727;
    border: 1px solid #8b8b8b;
    letter-spacing: 0.08em;
  }

  /*=======//ボタン==============================================*/


}

/*=====//SPのみ==============================*/