@charset "UTF-8";

:root {
  --font-lp_base: "AlrightSans", "Open Sans", "Helvetica Neue", Helvetica, Arial, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Sans", "ヒラギノ角ゴシック", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ ProN", "ヒラギノ角ゴ Pro", "メイリオ", "Meiryo", sans-serif;
  --color-lp_bg: #e8faf8;
  --color-lp_font: #000000;
  --color-lp_primary: #2bb5a6;
  --color-lp_white: #FFF;
}

/*--------------------------------
                共 通
 --------------------------------*/
.lp-insert-area #detailOne{
  width: 100%;
}

#lp_contents img{width: 100%;display: block;height: auto; image-rendering: -webkit-optimize-contrast; -webkit-backface-visibility: hidden;}
#lp_contents a{display: block;width: 100%;cursor: pointer;transition: all 0.5s;color: inherit;}
#lp_contents a:hover{opacity: .8}
#lp_contents ul li,#lp_contents ol li{list-style: none;}
#lp_contents .sp_only{display: none;}

#lp_contents h1,#lp_contents h2,#lp_contents h3{padding: 0;float: none;font-weight: normal;}

#lp_contents p {
  display: block;
  margin: 0;
  font-size: 1.6rem;
  line-height: 2.7rem;
}

#lp_contents .note{
  display: block;
  font-size: 1.3rem;
  line-height: 1.75;
}

#lp_contents .bold{
  font-weight: bold;
}

#lp_contents .lead{
  font-size: 1.8rem;
  line-height: 2;
}

/*------------ lp_contents ------------*/
#lp_contents *{
  box-sizing: border-box;
}

#lp_contents{
  font-family: var(--font-lp_base);
  font-feature-settings: "palt";
  font-size: 1.6rem;
  letter-spacing: 0.075em;
  line-height: 2.7rem;
  text-align: center;
  padding: 8rem 7rem;

  color: var(--color-lp_font);
  background-color: var(--color-lp_bg);
  position: relative;
  /*overflow: hidden;*/
}

#lp_contents .lp_inner{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 96rem;
  margin: auto;
}

#lp_contents section{
  position: relative;
  border-radius: 3rem;
  background-color: var(--color-lp_white);
  margin: 0 auto 7rem;
  padding: 6rem 5rem;
  width: 96rem;
}

/*------------ sec_1 ------------*/
#lp_contents .sec_1{
  padding: 6rem 9rem;
}

#lp_contents .main_ttl{
  width: 42rem;
  margin-left: 21rem;
  margin-bottom: 3rem;
}

#lp_contents .mv_img{
  margin: 0 auto 4rem;
}

#lp_contents .item_name{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.2rem;
  margin-bottom: 1rem;
  font-size: 2rem;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.125em;
}

#lp_contents .item_name span{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 9.3rem;
  height: 3.2rem;
  border-radius: 0.3rem;
  background-color: var(--color-lp_primary);
  color: var(--color-lp_white);
}

#lp_contents .img_1{
  width: 20rem;
  margin: 2.4rem auto 0;
}

/*------------ sec_2~4 ------------*/
#lp_contents .sec_2,
#lp_contents .sec_3,
#lp_contents .sec_4,
#lp_contents .sec_5{
  display: grid;
  gap: 2rem;
  width: 46.5rem;
  padding: 4rem;
  margin-left: 0;
  margin-right: 0;
}

#lp_contents .sec_2,
#lp_contents .sec_3{
  margin-bottom: 3.6rem;
}

#lp_contents .sec_ttl{
  font-size: 2.2rem;
  font-weight: bold;
  line-height: 1;
  color: var(--color-lp_primary);
}

#lp_contents .txt_left{
  text-align: justify;
  letter-spacing: 0.05em;
}

/*------------ sec_6 ------------*/
#lp_contents .howto_ttl{
  margin-bottom: 4rem;
  font-size: 6.4rem;
  font-weight: bold;
  line-height: 1;
  color: var(--color-lp_primary);
}

#lp_contents .howto_wrap{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  text-align: justify;
  gap: 1.5rem;
}

#lp_contents .howto_txt{
  font-size: 2.1rem;
}

#lp_contents .point{
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 1.5rem 0;
  width: 11rem;
  height: 3.6rem;
  background-color: var(--color-lp_primary);
  color: var(--color-lp_white);
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1;
}

#lp_contents .img_6{
  width: 19rem;
}

/*------------ sec_7 ------------*/
#lp_contents .sec_7{
  display: grid;
  gap: 5.5rem;
}

#lp_contents .item_wrap{
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 2rem;
}

#lp_contents .txt_blk{
  width: 46rem;
  text-align: left;
}

#lp_contents .item_name_img{
  width: 32rem;
  margin-bottom: 1.5rem;
}

#lp_contents .movie_blk{
  position: relative;
  width: 32rem;
  height: auto;
  padding: 18%;
}

#lp_contents .movie_blk iframe{
  position: absolute;
  top: 0;
  left: 0;
  transform: none;
  width: 101%;
  height: 100%;
}

#lp_contents .series_ttl{
  width: 75rem;
  margin: 0 auto 2.4rem;
}

#lp_contents .img_8{
  width: 46rem;
  margin: 0 auto 2rem;
}

/*------------ link_btn ------------*/
#lp_contents .link_btn{
  position: relative;
  width: 65.6rem;
  height: 7.6rem;
  margin: auto;
  border-radius: 0.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-lp_primary);
  color: var(--color-lp_white);
  font-size: 2rem;
  font-weight: bold;
  line-height: 1;
}

#lp_contents .link_btn:before{
  content: '';
  display: block;
  background: var(--color-lp_white);
  height: calc(tan(60deg) * 1.5rem / 2);
  width: 1.3rem;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  position: absolute;
  top: 0;
  bottom: 0;
  right: 18rem;
  margin: auto;
}



/*--------------------------------
            Responsive
 --------------------------------*/

@media screen and (max-width: 1400px){
  html {
    font-size: calc(10 * (100vw / 1400));
  }
}

@media (min-width: 768px) and (max-width: 1200px) {
  html {
    font-size: calc(10 * (100vw / 1200));
  }
}

/*--------------------------------
            Layout  SP
 --------------------------------*/
@media (max-width: 767px) {

  html {
    font-size: calc(10 * (100vw / 750));
  }

  #lp_contents .sp_only{display: block;}
  #lp_contents .pc_only{display: none;}

  #lp_contents a:hover{opacity: 1}

  #lp_contents p {
    font-size: 2.5rem;
    line-height: 4rem;
  }

  #lp_contents .note{
    font-size: 2rem;
  }

  #lp_contents .lead{
    font-size: 2.6rem;
  }

  /*------------ lp_contents ------------*/
  #lp_contents *{
    box-sizing: border-box;
  }

  #lp_contents{
    font-size: 2.5rem;
    line-height: 4rem;
    padding: 6rem 2.5rem;
  }

  #lp_contents .lp_inner{
    width: 70rem;
  }

  #lp_contents section{
    border-radius: 2rem;
    margin: 0 auto 5.6rem;
    padding: 7rem 3rem;
    width: 70rem;
  }

  /*------------ sec_1 ------------*/
  #lp_contents .sec_1{
    padding: 5rem 3rem;
  }

  #lp_contents .main_ttl{
    width: 50rem;
    margin-left: 8rem;
    margin-bottom: 5rem;
  }

  #lp_contents .mv_img{
    margin: 0 auto 8rem;
  }

  #lp_contents .item_name{
    gap: 2.4rem;
    margin-bottom: 4rem;
    font-size: 3.5rem;
  }

  #lp_contents .item_name span{
    width: 16rem;
    height: 5.6rem;
    border-radius: 0.5rem;
    font-size: 3rem;
  }

  #lp_contents .img_1{
    width: 39.5rem;
    margin: 7rem auto 0;
  }

  /*------------ sec_2~4 ------------*/
  #lp_contents .sec_2,
  #lp_contents .sec_3,
  #lp_contents .sec_4,
  #lp_contents .sec_5{
    gap: 3.6rem;
    width: 70rem;
    padding: 7rem 7.2rem;
  }

  #lp_contents .sec_2,
  #lp_contents .sec_3{
    margin-bottom: 5.6rem;
  }

  #lp_contents .sec_ttl{
    font-size: 3.4rem;
  }

  /*------------ sec_6 ------------*/
  #lp_contents .howto_ttl{
    margin-bottom: 8rem;
    font-size: 7.8rem;
  }

  #lp_contents .howto_wrap{
    text-align: center;
    gap: 8rem;
  }

  #lp_contents .howto_txt{
    font-size: 3.1rem;
    line-height: 5rem;
    letter-spacing: 0;
  }

  #lp_contents .point{
    margin: 3rem auto 2rem;
    width: 17rem;
    height: 5.3rem;
    font-size: 3.6rem;
  }

  #lp_contents .img_6{
    width: 42rem;
  }

  /*------------ sec_7 ------------*/
  #lp_contents .sec_7{
    gap: 9rem;
    padding: 7rem 1.5rem;
  }

  #lp_contents .item_wrap{
    width: 60rem;
    margin: auto;
    gap: 4rem;
    justify-content: left;
    flex-direction: column-reverse;
  }

  #lp_contents .txt_blk{
    width: 60rem;
  }

  #lp_contents .item_name_img{
    width: 47rem;
  }

  #lp_contents .movie_blk{
    width: 60rem;
    padding: 49%;
  }

  #lp_contents .series_ttl{
    width: 61rem;
    margin: 0 auto 4rem;
  }

  #lp_contents .img_8{
    width: 100%;
    margin: 0 auto 4rem;
  }

  #lp_contents .sec_7 .lead{
    letter-spacing: 0.03em;
  }

  /*------------ link_btn ------------*/
  #lp_contents .link_btn{
    width: 70rem;
    height: 9rem;
    font-size: 3.1rem;
  }

  #lp_contents .link_btn:before{
    height: calc(tan(60deg) * 2.2rem / 2);
    width: 1.5rem;
    right: 14rem;
  }

}