/* ===============================================
  * COMMON *
=============================================== */
:root {
  --spacer-xxs: 1.5rem;
  --spacer-xs: 2rem;
  --spacer-s: 1.8rem;
  --spacer-m: 4rem;
  --spacer-l: 5rem;
  --spacer-xl: 6rem;
  --padding-horizontal: 5.2%;
  --transition-duration: 1.5s;
}


@media (min-width: 769px) {
  :root {
    --spacer-xxs: 3rem;
    --spacer-xs: 4rem;
    --spacer-s: 3rem;
    --spacer-m: 8rem;
    --spacer-l: 10rem;
    --spacer-xl: 12rem;
    --padding-horizontal: min(4.54%, 5rem);
  }
}



.main-area{
  background-color: var(--color-bg-main);
}
.lp_area::before {
  pointer-events: none;
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  aspect-ratio: 375/541;
  background: url(/Page/LP/2023/0821_limited/assets/imgs/bg-desktop.png) top/100% no-repeat;
  /* mix-blend-mode: lighten; */
}
.contentsArea{
  position: relative;
  z-index: 5;
}
.lp_area img{
  width: 100%;
  height: auto;
}
.maivsiual{
  position: relative;
}
.lp_area .slick-slide{
  height: fit-content;
}
.slider-arrow{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
}
.fa-angle-right{
  right: 5rem;
}
.fa-angle-left{
  left: 5rem;
}
.slider-arrow img {
  transition-property: transform;
  transition-duration: 0.5s;
  transform: translateX(0);
}
.slider-arrow img:hover {
  transform: translateX(-2rem);
}

/*
 * Structure
 */

.main-area.lp,
.main-area.lp * {
  box-sizing: border-box;
  position: relative;
}

.main-area.lp {
  margin: 0;
  background-color: var(--color-bg-main);
}



@media (max-width: 768px) {
  .slider-arrow{
    display: none!important;
  }
  .pcOnly{
    display: none!important;
  }
}


@media (min-width: 769px) {
  .spOnly{
    display: none!important;
  }
}




/*
 * Text
 */
  .lead.__mv,
  .lead.__mv .en{
    display: block;
    text-align: center;
    font-feature-settings: "palt";
    font-family: var(--font-jp);
    color: #250D00;
  }
  .lead.__mv .en{
    font-family: adobe-garamond-pro, serif;
    font-weight: 400;
    font-style: normal;
  }
  .sec .ttl .name{
    display: block;
    font-family: adobe-garamond-pro, serif;
    font-weight: 400;
    font-style: normal;
    color: #250D00;
  }
  .sec .ttl .subTtl{
    display: block;
    font-feature-settings: "palt";
    font-family: var(--font-jp);
    color: #250D00;
  }
  .sec .ttl .subTtl {
      text-align: left;
      margin-bottom: calc(28 * (100vw / 750));
      font-size: calc(17 * (100vw / 750));
      line-height: 2;
      letter-spacing: 0.1em;
  }
  .sec .detail > *{
    display: block;
    font-feature-settings: "palt";
    font-family: var(--font-jp);
    font-weight: 400;
    font-style: normal;
  }
  .sec .detail .ttl{
    display: block;
    font-family: adobe-garamond-pro, serif;
    font-weight: 400;
    font-style: normal;
  }
  .sec .creditWrap{
    position: relative;
    font-feature-settings: "palt";
    font-family: var(--font-jp);
  }
  .sec .creditWrap .dot::before,
  .sec .creditWrap .dot::after{
    content: "";
    position: absolute;
    display: block;
    width: calc(8 * (100vw / 750));
    height: calc(8 * (100vw / 750));
    border-radius: 50%;
    background: #250d00;
  }
  .sec .creditWrap a,
  .sec .creditWrap .dot{
    position: unset;
    display: block;
  }
  .sec .creditWrap .dot.__top::before{
    top: calc(3 * (100vw / 750));
    left: calc(3 * (100vw / 750));
  }
  .sec .creditWrap .dot.__top::after{
    top: calc(3 * (100vw / 750));
    right: calc(3 * (100vw / 750));
  }
  .sec .creditWrap .dot.__bottom:before{
    bottom: calc(3 * (100vw / 750));
    left: calc(3 * (100vw / 750));
  }
  .sec .creditWrap .dot.__bottom::after{
    bottom: calc(3 * (100vw / 750));
    right: calc(3 * (100vw / 750));
  }
  .treatment .ttl .en{
    display: block;
    text-align: center;
    font-family: adobe-garamond-pro, serif;
    font-weight: 400;
    font-style: normal;
    color: #250D00;
  }
  .treatment .ttl .jp{
    display: block;
    text-align: center;
    font-family: var(--font-jp);
    font-weight: 400;
    font-style: normal;
    color: #250D00;
  }
@media (max-width: 768px) {
  .lead.__mv,
  .lead.__mv .en{
    display: block;
    text-align: center;
    font-feature-settings: "palt";
    font-family: var(--font-jp);
    font-size: calc(25 * (100vw / 750));
    line-height: 2;
    letter-spacing: 0.075em;
    color: #250D00;
  }
  .lead.__mv .en{
    margin: calc(75 * (100vw / 750)) auto calc(80 * (100vw / 750));
    font-family: adobe-garamond-pro, serif;
    font-weight: 400;
    font-style: normal;
    font-size: calc(25 * (100vw / 750));
    line-height: 2;
    letter-spacing: 0.05em;
  }
  .sec .ttl .name{
    display: block;
    margin-bottom: calc(0 * (100vw / 750));
    font-family: adobe-garamond-pro, serif;
    font-weight: 400;
    font-style: normal;
    font-size: calc(55 * (100vw / 750));
    line-height: 1.745;
    letter-spacing: 0.00em;
    color: #250D00;
  }
  .sec .ttl .subTtl{
    display: block;
    margin-bottom: calc(45 * (100vw / 750));
    font-feature-settings: "palt";
    font-family: var(--font-jp);
    font-size: calc(25 * (100vw / 750));
    line-height: 1.6;
    letter-spacing: 0.1em;
    color: #250D00;
  }
  .sec .detail > *{
    display: block;
    margin-bottom: calc(07 * (100vw / 750));
    font-feature-settings: "palt";
    font-family: var(--font-jp);
    font-weight: 400;
    font-style: normal;
    font-size: calc(20 * (100vw / 750));
    line-height: 1.6;
    letter-spacing: 0.075em;
  }
  .sec .detail .ttl{
    display: block;
    margin-bottom: calc(14 * (100vw / 750));
    font-family: adobe-garamond-pro, serif;
    font-weight: 400;
    font-style: normal;
  }
  .sec .creditWrap{
    position: relative;
    font-feature-settings: "palt";
    font-family: var(--font-jp);
    font-size: calc(23 * (100vw / 750));
    line-height: 1.435;
    letter-spacing: 0.075em;
  }
  .treatment .ttl .en{
    display: block;
    margin-bottom: calc(05 * (100vw / 750));
    text-align: center;
    font-family: adobe-garamond-pro, serif;
    font-weight: 400;
    font-style: normal;
    font-size: calc(40 * (100vw / 750));
    line-height: 1.75;
    letter-spacing: 0.05em;
  }
  .treatment .ttl .jp{
    display: block;
    text-align: center;
    margin-bottom: calc(13 * (100vw / 750));
    font-family: var(--font-jp);
    font-weight: 400;
    font-style: normal;
    font-size: calc(30 * (100vw / 750));
    line-height: 2.333;
    letter-spacing: 0.075em;
  }
}


@media (min-width: 769px) {
  .lead,
  .lead > *{
    display: block;
    text-align: center;
    font-feature-settings: "palt";
    font-family: var(--font-jp);
    font-size: 1.75rem;
    line-height: 2;
    letter-spacing: 0.075em;
    color: #250D00;
  }
  .sec .ttl{
    text-align: center;
    font-family: "trajan-pro-3", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 2.5rem;
    line-height: 2.4;
    letter-spacing: 0.08em;
    margin-bottom: 0.7rem;
    color: #250D00;
  }
  .lead.__mv .en{
    margin: 5.1rem auto 7.1rem;
    font-size: 1.8rem;
    line-height: 2;
    letter-spacing: 0.05em;
  }
  .sec .ttl .name{
    text-align: left;
    margin-bottom: 1.3rem;
    font-size: 3.6rem;
    line-height: 1;
    letter-spacing: 0.00em;
  }
  .sec .ttl .subTtl {
    margin-bottom: 2.8rem;
    font-size: 1.7rem;
    line-height: 2;
    letter-spacing: 0.1em;
}
  .sec .detail .ttl {
      text-align: left;
      margin-bottom: 1.2rem;
      font-size: 1.2rem;
      line-height: 1;
  }
  
  .sec .creditWrap .ttl{
    text-align: left;
    font-family: var(--font-jp);
    font-size: 1.3rem;
    line-height: 1.846;
    margin-bottom: 0.2rem;
  }
  .sec .creditWrap li > *{
    font-family: var(--font-jp);
    font-size: 1.2rem;
    line-height: 1.8;
    letter-spacing: 0.05em;
    color: #250D00;
  }
}

 






/* ===============================================
  * Contents *
=============================================== */

@media (max-width: 768px) {
  .lineclip {
    display: block;
    width: calc(660 * (100vw / 750));
    margin: 0 auto calc(50 * (100vw / 750));
  }
  .spOnly.pop{
        position: absolute;
    top: calc(-60 * (100vw / 750));
    right: calc(-25 * (100vw / 750));
    width: calc(170 * (100vw / 750));
  }
  /* mainVisual */
  .imgBox.__mv{
    margin-bottom: calc(145 * (100vw / 750));
  }
  .gridWrap{
    display: grid;
    grid-template-columns: calc(45 * (100vw / 750)) calc(321 * (100vw / 750)) auto;
    grid-template-rows: calc(27 * (100vw / 750)) auto;
    margin-bottom: calc(94 * (100vw / 750));
  }
  .sec.__01 .imgBox.__0101,
  .sec.__03 .imgBox.__0301,
  .sec.__05 .imgBox.__0501{
    width: calc(300 * (100vw / 750));
    grid-area: 1 / 2;
  }
  .sec.__01 .prod,
  .sec.__03 .prod,
  .sec.__05 .prod{
    grid-area: 2 / 3;
  }
  .detail::before{
    content: "";
    display: block;
    width: calc(10 * (100vw / 750));
    height: calc(10 * (100vw / 750));
    margin: 0 auto calc(14 * (100vw / 750)) calc(3 * (100vw / 750));
    box-shadow: 0 0 calc(0.2 * (100vw / 750)) calc(0.2 * (100vw / 750)) #250d00;
    border-radius: 50vh;
    background: #250d00;
  }
  .detail{
    position: relative;
    margin-bottom: calc(53 * (100vw / 750));
  }
  .sec .detail li{
    display: flex;
    flex-direction: row;
    align-items: flex-start;
  }
  .sec .detail li .left{
    white-space: nowrap;
    width: fit-content;
    padding-right: calc(11 * (100vw / 750));
  }
  .sec .detail li.lineup{
  margin-bottom: calc(5 * (100vw / 750));
  }
  .sec .creditWrap{
    max-width: calc(330 * (100vw / 750));
    width: fit-content;
    padding: calc(25 * (100vw / 750)) calc(20 * (100vw / 750)) calc(20 * (100vw / 750)) calc(28 * (100vw / 750));
    margin: 0 0 0 calc(8 * (100vw / 750));
    border: 1px solid #250d00;
  }

  /* sec 02 */
  .sec.__02 .gridWrap ,
  .sec.__04 .gridWrap {
    display: grid;
    grid-template-columns: calc(51 * (100vw / 750)) calc(346 * (100vw / 750)) auto;
    grid-template-rows: calc(23 * (100vw / 750)) auto;
    margin-bottom: calc(100 * (100vw / 750));
  }
  .sec.__02 .imgBox.__0201,
  .sec.__04 .imgBox.__0401{
    width: calc(300 * (100vw / 750));
    grid-area: 1 / 3;
  }
  .sec.__02 .prod,
  .sec.__04 .prod{
    grid-area: 2 / 2;
  }
  .sec.__02 .ttl .subTtl{
    white-space: nowrap;
  }


  /* sec 03 */
  .sec.__03 .gridWrap{
    display: grid;
    grid-template-columns: calc(45 * (100vw / 750)) calc(309 * (100vw / 750)) auto;
    grid-template-rows: calc(24 * (100vw / 750)) auto;
    margin-bottom: calc(93 * (100vw / 750));
  }
  .sec.__03 .detail {
    margin-bottom: calc(83 * (100vw / 750));
  }


  /* sec 04 */
  .sec.__04 .gridWrap{
    display: grid;
    grid-template-columns: calc(45 * (100vw / 750)) calc(359 * (100vw / 750)) auto;
    grid-template-rows: calc(24 * (100vw / 750)) auto;
    margin-bottom: calc(96 * (100vw / 750));
  }
  .sec.__04 .ttl .subTtl {
    margin-bottom: calc(85 * (100vw / 750));
  }


  /* sec 05 */
  .sec.__05 .gridWrap{
    display: grid;
    grid-template-columns: calc(45 * (100vw / 750)) calc(330 * (100vw / 750)) auto;
    grid-template-rows: calc(24 * (100vw / 750)) auto;
    margin-bottom: calc(96 * (100vw / 750));
  }
  .sec.__05 .detail {
    margin-bottom: calc(53 * (100vw / 750));
  }
  .sec.__05 .imgBox.__0501 {
    margin-top: calc(30 * (100vw / 750));
  }


  /* treatment */
  .treatment{
    text-align: center;
    font-feature-settings: "palt";
    font-family: var(--font-jp);
    margin: calc(79 * (100vw / 750)) auto calc(87 * (100vw / 750));
  }
  .treatment .lead{
    font-size: calc(23 * (100vw / 750));
    line-height: 1.739;
  }
  .treatment .lead span:not(.info){
    display: inline-block;
    transform: scale(0.7);
  }
  .treatment .lead span.info{
    display: block;
    font-size: calc(17 * (100vw / 750));
    line-height: 2.059;
    letter-spacing: 0.05em;
    margin-top: calc(20 * (100vw / 750));
  }


  /* shopInfo */
  .shopInfo{
    display: block;
    text-align: center;
    font-family: var(--font-jp);
    font-size: calc(30 * (100vw / 750));
    line-height: 2.333;
    letter-spacing: 0.05em;
    margin: calc(80 * (100vw / 750)) auto calc(200 * (100vw / 750));
  }
  .buyBtn {
    width: calc(320 * (100vw / 750));
    margin: auto;
    padding: 0 0 calc(210 * (100vw / 750));
  }
}

@media (min-width: 768px) {
  .lineclip {
    display: block;
    width: 96rem;
    margin: 0 auto 2.3rem;
  }
  /* mainVisual */
  .imgBox.__mv{
    width: 110rem;
    margin: auto;
    margin-bottom: 9rem;
  }
  .gridWrap{
    width: 96rem;
    display: grid;
    grid-template-columns: 8.3rem 39.8rem auto;
    grid-template-rows: 16rem auto;
    margin: auto;
    margin-bottom: 8rem;
  }
  .sec.__01 .imgBox.__0101,
  .sec.__03 .imgBox.__0301,
  .sec.__05 .imgBox.__0501{
    width: 37.4rem;
    grid-area: 1 / 2;
  }
  .sec.__01 .prod,
  .sec.__03 .prod,
  .sec.__05 .prod{
    grid-area: 2 / 3;
  }
  .detail::before{
    content: "";
    display: block;
    width: 0.4rem;
    height: 0.4rem;
    margin: 0 auto 1.3rem 0.3rem;
    box-shadow: 0 0 0.1rem 0.1rem #000;
    border-radius: 50vh;
    background: #250d00;
  }
  .detail{
    position: relative;
    margin-bottom: 3.1rem;
  }
  .sec .detail li{
    display: flex;
    flex-direction: row;
    align-items: flex-start;
  }
  .sec .detail li .left{
    white-space: nowrap;
    width: fit-content;
    padding-right: 1.1rem;
  }
  .sec .detail li.lineup{
  margin-bottom: 0rem;
  font-size: 1.3rem;
  line-height: 1.72;
  letter-spacing: 0.16em;
  }
  .sec .creditWrap{
    min-width: 23rem;
    width: fit-content;
    padding: 1.4rem 2rem 0.9rem 2rem;
    margin: 0 0 0 0;
    font-size: 1.2rem;
    line-height: 1.72;
    letter-spacing: 0.1em;
    border: 1px solid #250d00;
  }

  /* sec 02 */
  .sec.__02 .gridWrap ,
  .sec.__04 .gridWrap {
    display: grid;
    grid-template-columns: 17.6rem 39.6rem auto;
    grid-template-rows: 15.3rem auto;
    margin-bottom: 8.4rem;
  }
  .sec.__02 .imgBox.__0201,
  .sec.__04 .imgBox.__0401{
    width: 35.4rem;
    grid-area: 1 / 3;
  }
  .sec.__02 .prod,
  .sec.__04 .prod{
    grid-area: 2 / 2;
  }
  .sec.__02 .ttl .subTtl{
    white-space: nowrap;
    margin-bottom: 2.6rem;
  }


  /* sec 03 */
  .sec.__03 .gridWrap{
    display: grid;
    grid-template-columns: 8.2rem 39.9rem auto;
    grid-template-rows: 15.5rem auto;
    margin-bottom: 7.6rem;
  }
  .sec.__03 .detail {
    margin-bottom: 3.1rem;
  }


  /* sec 04 */
  .sec.__04 .gridWrap{
    display: grid;
    grid-template-columns: 17.7rem 39.5rem auto;
    grid-template-rows: 15.6rem auto;
    margin-bottom: 8.6rem;
  }
  .sec.__04 .ttl .subTtl {
    margin-bottom: 2.4rem;
  }


  /* sec 05 */
  .sec.__05 .gridWrap{
    display: grid;
    grid-template-columns: 8.2rem 39.9rem auto;
    grid-template-rows: 15rem auto;
    margin-bottom: 7.9rem;
  }
  .sec.__05 .detail {
    margin-bottom: 3rem;
  }
  .sec.__05 .imgBox.__0501 {
    margin-top: 0rem;
  }
  .sec .creditWrap {
    min-width: 21rem;
  }
  
  .sec .creditWrap .dot::before,
  .sec .creditWrap .dot::after{
    content: "";
    position: absolute;
    display: block;
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background: #250d00;
  }
  .sec .creditWrap .dot{
    position: unset;
    display: block;
  }
  .sec .creditWrap .dot.__top::before{
    top: 0.3rem;
    left: 0.3rem;
  }
  .sec .creditWrap .dot.__top::after{
    top: 0.3rem;
    right: 0.3rem;
  }
  .sec .creditWrap .dot.__bottom:before{
    bottom: 0.3rem;
    left: 0.3rem;
  }
  .sec .creditWrap .dot.__bottom::after{
    bottom: 0.3rem;
    right: 0.3rem;
  }


  /* treatment */
  .treatment{
    text-align: center;
    font-feature-settings: "palt";
    font-family: var(--font-jp);
    margin: 7.7rem auto 7.7rem;
  }
  .treatment .ttl .en {
    display: block;
    margin-bottom: 1.9rem;
    font-size: 2rem;
    line-height: 1.2;
    letter-spacing: 0.05em;
    color: #250D00;
  }
  .treatment .ttl .jp {
    margin-bottom: 1.9rem;
    font-size: 1.7rem;
    line-height: 1;
    letter-spacing: 0.075em;
    color: #250D00;
}
  .treatment .lead{
    font-size: 1.2rem;
    line-height: 1.72;
    letter-spacing: 0.1em;
  }
  .treatment .lead span:not(.info){
    display: inline-block;
    transform: scale(0.7);
    font-size: 1.2rem;
    line-height: 1.72;
  }
  .treatment .lead span.info{
    display: block;
    font-size: 1rem;
    line-height: 2.059;
    letter-spacing: 0.05em;
    margin-top: 0.8rem;
  }


  /* shopInfo */
  .shopInfo{
    display: block;
    text-align: center;
    font-family: var(--font-jp);
    font-size: 3.0rem;
    line-height: 2.333;
    letter-spacing: 0.05em;
    margin: 6.9rem auto 7.8rem;
  }
  .buyBtn {
    width: 26rem;
    padding: 0 0 18rem;
    margin: auto;
  }
}

/* ===============================================
  * item - n *
=============================================== */
@media (max-width: 768px) {
  .lp_area::before {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    aspect-ratio: 375/541;
    background-image: url(/Page/LP/2023/0821_limited/assets/imgs/bg-mobile.png);
    background-repeat: no-repeat;
    background-size: 100%;
  }
  .maivsiual .lead{
    margin: 7.5rem auto 7.3rem;
  }

.main-area.lp .pop{position: fixed;top: 19rem;right: 1.6rem;width: 7rem;opacity: 0;transition: opacity 0.8s;/* visibility: hidden; */z-index: 10;}
.main-area.lp .pop.onView{opacity: 1;visibility: visible;}
.main-area.lp .pop.onView.none{
  opacity: 0;
}
  
}


@media (min-width: 769px) {
  .main-lp_area::before {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    aspect-ratio: 375/541;
    background-image: url(/Page/LP/2023/0821_limited/assets/imgs/bg-mobile.png);
    background-repeat: no-repeat;
    background-size: 100%;
  }
  .maivsiual .lead{
    margin: 8rem auto 9.1rem;
    font-size: 1.5rem;
    line-height: 2.04;
    text-align: center;
  }

.main-area.lp .pop{position: fixed;top: 19rem;right: 29.6rem;width: 7rem;opacity: 0;transition: opacity 0.8s;/* visibility: hidden; */z-index: 10;}
.main-area.lp .pop.onView{opacity: 1;visibility: visible;}
.main-area.lp .pop.onView.none{
  opacity: 0;
}

}








/* ===============================================
  * ITEM - 1 *
=============================================== */
