@charset "UTF-8";

:root {
  --font-sans: 'Gill Sans', sans-serif;
  --font-serif: "Cormorant Infant", serif;
  --font-mincho: "Shippori Mincho B1", serif;
  --color-bg: #FBF1E9;
  --color-bg_second: #EDE1D8;
  --color-font: #000000;
  --color-main: #502913;
  --color-second: #263520;
  --color-line: #707070;
}

/*--------------------------------
            CSS Animation
 --------------------------------*/

/*------------ Fade In ------------*/

#lp_contents .fadeIn {
  opacity: 0;
  transition: 2s;
  -ms-filter: blur(6px);
  filter: blur(6px);
}

#lp_contents .fadeIn.is-show {
  opacity: 1;
  -ms-filter: blur(0);
  filter: blur(0);
}

#lp_contents .fadeInZoom {
  opacity: 0;
  transform: scale(0.8);
  transition: 2s;
  -ms-filter: blur(6px);
  filter: blur(6px);
}

#lp_contents .fadeInZoom.is-show {
  opacity: 1;
  transform: scale(1);
  -ms-filter: blur(0);
  filter: blur(0);
}

#lp_contents .fadeInUp {
  opacity: 0;
  transform: translate(0, 5rem);
  transition: 2s;
}

#lp_contents .fadeInUp.is-show {
  transform: translate(0, 0);
  opacity: 1;
}

#lp_contents .delay1{
  transition-delay: 1s;
}
#lp_contents .delay2{
  transition-delay: 1.25s;
}
#lp_contents .delay3{
  transition-delay: 1.5s;
}
#lp_contents .delay4{
  transition-delay: 1.75s;
}


/*--------------------------------
                共 通
 --------------------------------*/

#Wrap,.wrapBottom,.wrapTop{
  width: 100%;
}

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

#lp_contents{
  font-family: 'ヒラギノ角ゴシック','Hiragino Sans','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3','ヒラギノ角ゴ StdN','Hiragino Kaku Gothic StdN',YuGothic,'Yu Gothic','メイリオ', Meiryo,sans-serif;
  font-feature-settings: "palt";
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 2;
  text-align: center;

  color: var(--color-font);
  background-color: var(--color-bg);
  position: relative;
  /*overflow: hidden;*/
}
#lp_contents .sp_only{display: none;}
#lp_contents img{width: 100%;display: block;transition: all 0.5s}
#lp_contents a{display: block;cursor: pointer;transition: all 0.5s;color: inherit;}
#lp_contents ul li,#LP_page ol li{list-style: 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;}
#lp_contents sup{
  font-size: 50%;
  margin-top: -0.6rem;
}
#lp_contents small.note{
  display: inline-block;
  margin-top: 1rem;
  font-size: 1rem;
  line-height: 1.5;
}
#lp_contents section{
  position: relative;
}

#lp_contents ._inner{
  width: 130rem;
  margin: auto;
  border: 1px solid var(--color-line);
  border-top-width: 0;
}

#lp_contents .link_btn{
  position: relative;
  width: 14rem;
  height: 3rem;
  background-color: var(--color-second);
  color: #fff;
  font-family: var(--font-serif);
  font-size: 1.8rem;
  font-style: italic;
  display: flex;
  align-items: center;
  justify-content: center;
}

#lp_contents .all_btn_wrap{
  padding: 6rem 0;
}

#lp_contents .all_btn_wrap .link_btn{
  width: 42rem;
  height: 6rem;
  font-family: var(--font-mincho);
  font-style: normal;
  margin: auto;
}

#lp_contents .all_btn_wrap._inner{
  border-bottom-width: 0;
}

#lp_contents .arrow{
  width: 1rem;
  height: 1rem;
  background-image: url(../img/arrow.svg);
  background-repeat: no-repeat;
  background-size: 100%;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 1.5rem;
  margin: auto;
  transition: all 0.5s;
}

#lp_contents a:hover .arrow{
  transform: translateX(0.5rem);
}


/*------------ sec_mv ------------*/

#lp_contents .sec_mv ._inner{
  border-bottom-width: 0;
}

/*mv_wrap*/
#lp_contents .sec_mv .mv_wrap{
  position: relative;
  width: 100%;
  height: 60rem;
  background-color: var(--color-main);
  overflow: hidden;
}

#lp_contents .sec_mv .mv_wrap:before,
#lp_contents .sec_mv .mv_wrap:after{
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
  position: absolute;
  left: 0;
  z-index: 1;
}

#lp_contents .sec_mv .mv_wrap:before{
  top: 1.5rem;
}

#lp_contents .sec_mv .mv_wrap:after{
  bottom: 1.5rem;
}

#lp_contents .sec_mv .mv_wrap ._inner{
  display: flex;
  justify-content: center;
  align-items: center;
  border-color: #fff;
  height: 100%;
  position: relative;
}

#lp_contents .sec_mv .mv_wrap h1{
  position: relative;
  width: 43rem;
  z-index: 3;
}

#lp_contents .sec_mv .mv_wrap .mv_item{
  position: absolute;
  z-index: 2;
}

#lp_contents .sec_mv .mv_wrap .mv_item_1{
  width: 28rem;
  bottom: 1rem;
  left: 5rem;
}

#lp_contents .sec_mv .mv_wrap .mv_item_2{
  width: 27rem;
  top: 15rem;
  left: 14.5rem;
}

#lp_contents .sec_mv .mv_wrap .mv_item_3{
  width: 24rem;
  bottom: 11rem;
  right: -0.5rem;
}

#lp_contents .sec_mv .mv_wrap .mv_item_4{
  width: 20rem;
  top: 8rem;
  left: -1rem;
}

#lp_contents .sec_mv .mv_wrap .mv_item_5{
  width: 23rem;
  top: 7rem;
  right: 9rem;
}

#lp_contents .sec_mv .mv_wrap .mv_item_6{
  width: 23rem;
  bottom: 11rem;
  right: 23rem;
}

#lp_contents .sec_mv .mv_wrap .mv_item_7{
  width: 23rem;
  bottom: 5rem;
  right: 15rem;
}

/*lead*/
#lp_contents .sec_mv .lead{
  font-size: 1.8rem;
  line-height: 2.5;
  padding: 8rem;
}

/*nav_ttl*/
#lp_contents .sec_mv .nav_ttl{
  font-family: var(--font-mincho);
  font-size: 2.8rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  line-height: 1;
  color: var(--color-main);
  padding-bottom: 3rem;
}

#lp_contents .sec_mv .nav_ttl big{
  font-size: 4rem;
  font-weight: 400;
}

/*nav_list*/
#lp_contents .sec_mv .nav_list{
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
}

#lp_contents .sec_mv .nav_list ._inner{
  border-bottom-width: 0;
}

#lp_contents .sec_mv .nav_list ol{
  display: flex;
}

#lp_contents .sec_mv .nav_list li{
  position: relative;
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 5.6rem;
  font-family: var(--font-mincho);
  font-size: 2.8rem;
  color: var(--color-main);
}

#lp_contents .sec_mv .nav_list li:not(:last-child){
  border-right: 1px solid var(--color-line);
}

#lp_contents .sec_mv .nav_list .arrow{
  width: 1.5rem;
  height: 1.5rem;
  right: 3rem;
  background-image: url(../img/nav-arrow.svg);
}

#lp_contents .sec_mv .nav_list a:hover .arrow{
  transform: translateY(0.5rem);
}


/*------------ sec_item ------------*/

#lp_contents .sec_item{
  border-bottom: 1px solid var(--color-line);
}

#lp_contents .sec_item:nth-of-type(odd),
#lp_contents .sec_item:nth-of-type(odd) .item_wrap .ttl_blk{
  background-color: var(--color-bg_second);
}

#lp_contents .sec_item ._inner{
  padding-top: 9rem;
  border-bottom-width: 0;
}

/*ttl_wrap*/
#lp_contents .sec_item .ttl_wrap{
  margin-bottom: 7rem;
}

#lp_contents .sec_item .ttl_wrap h2{
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 2.5rem;
  font-family: var(--font-mincho);
  font-size: 6rem;
  line-height: 1;
  color: var(--color-main);
  margin-bottom: 4rem;
  transform: translateX(-0.5rem);
}

#lp_contents .sec_item .ttl_wrap h2 big{
  font-size: 9rem;
}

#lp_contents .sec_item .ttl_wrap h2 .times{
  width: 3.6rem;
  height: 3.6rem;
  display: block;
  position: relative;
  transform: translateX(-0.6rem);
}

#lp_contents .sec_item .ttl_wrap h2 .times:before,
#lp_contents .sec_item .ttl_wrap h2 .times:after{
  content: "";
  width: 4.8rem;
  height: 1px;
  background-color: var(--color-main);
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}

#lp_contents .sec_item .ttl_wrap h2 .times:after{
  transform: rotate(-45deg);
}

/*item_wrap*/
#lp_contents .sec_item .item_wrap{
  display: flex;
  flex-wrap: wrap;
}

#lp_contents .sec_item .item_wrap > li{
  width: calc(100% / 3);
  border: 1px solid var(--color-line);
  border-right-width: 0;
}

#lp_contents .sec_item .item_wrap > li:first-child{
  border-left-width: 0;
}

#lp_contents .sec_item .item_wrap .ttl_blk{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1.5rem;
  width: 100%;
  height: 6rem;
  font-family: var(--font-sans);
  font-size: 1.5rem;
  border-bottom: 1px solid var(--color-line);
  background-color: var(--color-bg);
}

#lp_contents .sec_item .item_wrap .ttl_blk .brand{
  font-family: var(--font-serif);
  font-size: 2.4rem;
}

#lp_contents .sec_item .item_wrap .item_blk{
  padding: 3.5rem 5.5rem 4rem;
}

#lp_contents .sec_item .item_wrap .item_blk .lead{
  margin-bottom: 2.5rem;
}

#lp_contents .sec_item .item_wrap .item_blk figure{
  position: relative;
  border: 1px solid var(--color-line);
  margin-bottom: 2rem;
}

#lp_contents .sec_item .item_wrap .item_blk figure a{
  overflow: hidden;
}

#lp_contents .sec_item .item_wrap .item_blk figure a:hover img{
  transform: scale(1.05);
}

#lp_contents .sec_item .item_wrap .item_blk .icon{
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: transparent linear-gradient(114deg, #E07A64 0%, #B04832 100%) 0% 0% no-repeat padding-box;
  min-width: 10rem;
  min-height: 4rem;
  padding: 0.5rem 1rem;
  font-family: var(--font-serif);
  font-size: 1.8rem;
  font-style: italic;
  font-weight: bold;
  line-height: 1.2;
  color: #fff;
  border-radius: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

#lp_contents .sec_item .item_wrap .item_blk .best_cosme_logo{
  width: 9rem;
  position: absolute;
  top: -3rem;
  letter-spacing: 0.5rem;
}

#lp_contents .sec_item .item_wrap .item_blk .item_name{
  text-align: left;
  line-height: 1.5;
  font-weight: bold;
  margin-bottom: 1rem;
}

#lp_contents .sec_item .item_wrap .item_blk .item_price{
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: var(--font-serif);
  font-size: 1.9rem;
}

#lp_contents .sec_item .item_wrap .check_blk{
  background-color: rgba(255, 255, 255, .5);
  padding: 2rem 1.5rem;
  margin-top: 2.5rem;
}

#lp_contents .sec_item .item_wrap .check_blk .check_ttl{
  line-height: 1;
  margin-bottom: 1.5rem;
}

#lp_contents .sec_item .item_wrap .check_blk ul{
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  width: fit-content;
  margin: auto;
}

#lp_contents .sec_item .item_wrap .check_blk li{
  padding-left: 2.5rem;
  background-image: url(../img/check.svg);
  background-size: 1.5rem 1.2rem;
  background-repeat: no-repeat;
  background-position: top 0.35rem left;
  text-align: left;
  line-height: 1.5;
}


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

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

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

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

  #FooterWrap{
    margin-top: -2.25rem;
  }

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

  #lp_contents ._inner{
    width: 100%;
    border-top-width: 0;
    border-left-width: 0;
    border-right-width: 0;
  }

  #lp_contents .all_btn_wrap .link_btn{
    width: 35rem;
  }


  /*------------ sec_mv ------------*/

  /*mv_wrap*/
  #lp_contents .sec_mv .mv_wrap{
    height: 43rem;
  }

  #lp_contents .sec_mv .mv_wrap:before{
    top: 1rem;
  }

  #lp_contents .sec_mv .mv_wrap:after{
    bottom: 1rem;
  }

  #lp_contents .sec_mv .mv_wrap ._inner{
    width: 41rem;
    display: block;
    border-left-width: 1px;
    border-right-width: 1px;
  }

  #lp_contents .sec_mv .mv_wrap h1{
    width: 25rem;
    padding-top: 7.5rem;
    padding-left: 7rem;
    box-sizing: content-box;
  }

  #lp_contents .sec_mv .mv_wrap .mv_item_1{
    width: 20rem;
    bottom: -3.5rem;
    left: 1rem;
  }

  #lp_contents .sec_mv .mv_wrap .mv_item_2{
    width: 11.2rem;
    top: 0.5rem;
    left: -0.25rem;
  }

  #lp_contents .sec_mv .mv_wrap .mv_item_4{
    width: 17rem;
    top: 13.6rem;
    left: -5.5rem;
  }

  #lp_contents .sec_mv .mv_wrap .mv_item_5{
    width: 14.4rem;
    top: 3rem;
    right: -1.5rem;
  }

  #lp_contents .sec_mv .mv_wrap .mv_item_6{
    width: 19rem;
    bottom: 3.5rem;
    right: -2rem;
  }

  #lp_contents .sec_mv .mv_wrap .mv_item_7{
    width: 19rem;
    bottom: -1.25rem;
    right: -7.75rem;
  }

  /*lead*/
  #lp_contents .sec_mv .lead{
    font-size: 1.7rem;
    padding: 5rem;
  }

  /*nav_ttl*/
  #lp_contents .sec_mv .nav_ttl{
    font-size: 2.2rem;
  }

  #lp_contents .sec_mv .nav_ttl big{
    font-size: 3rem;
  }

  #lp_contents .sec_mv .nav_list li{
    font-size: 2.2rem;
  }

  /*nav_list*/
  #lp_contents .sec_mv .nav_list .arrow{
    width: 1rem;
    height: 1rem;
    right: 1.5rem;
  }


  /*------------ sec_item ------------*/

  #lp_contents .sec_item ._inner{
    padding-top: 6rem;
  }

  /*ttl_wrap*/
  #lp_contents .sec_item .ttl_wrap{
    margin-bottom: 4rem;
  }

  #lp_contents .sec_item .ttl_wrap h2{
    gap: 2rem;
    font-size: 4.8rem;
    margin-bottom: 3rem;
  }

  #lp_contents .sec_item .ttl_wrap h2 big{
    font-size: 7.2rem;
  }

  #lp_contents .sec_item .ttl_wrap h2 .times{
    width: 2.5rem;
    height: 2.5rem;
  }

  #lp_contents .sec_item .ttl_wrap h2 .times:before,
  #lp_contents .sec_item .ttl_wrap h2 .times:after{
    width: 3rem;
  }

  /*item_wrap*/
  #lp_contents .sec_item .item_wrap > li{
    width: 100%;
    border-width: 0;
  }

  #lp_contents .sec_item .item_wrap .ttl_blk{
    border-top: 1px solid var(--color-line);
    position: sticky;
    top: 6.6rem;
    left: 0;
    z-index: 2;
  }

  #lp_contents .sec_item .item_wrap .item_blk{
    padding: 3.5rem 4rem 4rem;
  }

  #lp_contents .sec_item .item_wrap .item_blk .best_cosme_logo{
    width: 10rem;
  }

  /*all_btn_wrap*/
  #lp_contents .sec_item .all_btn_wrap{
    padding-top: 0;
  }
}