﻿@charset "UTF-8";

/*//////////////////////////////////////////////////

CSS Rei Fukuoka Collaboration Collection

//////////////////////////////////////////////////*/

/* ========================================================
                      * Layout style *
========================================================= */

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

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

@media (min-width: 1600px) {
  html {
    font-size: 62.5%
  }

}

footer {
  position: relative;
  z-index: 10;
  margin-top: 0 !important;
}

#share {
  display: none;
  z-index: 111 !important;
  transition: all 0.6s 0.3s;
}

@media screen and (max-width: 768px) {
  #share.move:not(.hidden) {
    translate: 0 calc(-150 * 60rem / 750);
  }
}

.share-txt {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.share-txt span {
  margin-top: calc(40 * (100vw / 750));
  margin-bottom: calc(40* (100vw / 750));
}

span.result {
  display: none !important;
}

/* ========================================================
                      * root *
========================================================= */
:root {
  --color_white: #fff;
  --color_black: #000000;
  --color_text: #727171;
  --color_pink:#f7c6bd;
  --color_lightpink:#fce8e5;
  --font_ja: "helvetica-neue-lt-pro", "hiragino-kaku-gothic-pron", sans-serif;
}

#Wrap {
  width: 100%;
}

/* ========================================================
                      * lp_contents *
========================================================= */

#lp_contents * {
  box-sizing: border-box;
  font-feature-settings: "palt";
  font-family: var(--font_ja);
  font-weight: 300;
  color: var(--color_text);
  line-height: 2;
  text-align: center;
  letter-spacing: 0.15em;
}

@media (min-width: 769px) {
  #lp_contents {
    position: relative;
    width: 100%;
    max-width: 100vw;
    height: 100%;
  }
}

#lp_contents .pcOnly {
  display: block !important;
}

#lp_contents .spOnly {
  display: none;
}

@media (max-width: 769px) {
#lp_contents .pcOnly {
  display: none !important;
}

#lp_contents .spOnly {
  display: block;
}
}

#lp_contents img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

#lp_contents a {
  width: 100%;
  height: 100%;
  display: inline-block;
}

#lp_contents h1,
#lp_contents h2,
#lp_contents h3,
#lp_contents h4,
#lp_contents h5 {
  font-weight: 300;
}

#lp_contents .lp_contents_inner {
  position: relative;
  z-index: 1;
  overflow: clip;
}

/* ========================================================
                      * PC *
========================================================= */
@media (min-width: 769px) {

  #lp_contents:before {
    position: fixed;
    content: "";
    width: 100%;
    height: 100%;
    background: url(../img/bg_pc.jpg) no-repeat;
    background-size: cover;
    background-position: top center;
    content: "";
    top: 0;
    left: 0;
    z-index: 0;
  }

  #lp_contents .fixed_area {
    display: grid;
    grid-template-columns: 1fr 60rem 1fr;
    width: 100%;
    height: 100%;
    margin: 0 auto;
  }

  #lp_contents .lp_contents_inner {
    grid-column: 2;
    width: 60rem;
    position: relative;
    z-index: 1;
    margin: 0 auto;
    overflow: clip;
  }

  #lp_contents .fixed_right,
  #lp_contents .fixed_left {
    position: -webkit-sticky;
    position: sticky;
    display: grid !important;
    justify-content: center;
    align-content: center;
    place-items: center;
    pointer-events: all;
    height: 100vh;
  }

  #lp_contents .fixed_right {
    top: 0;
    grid-column: 3;
    -webkit-clip-path: border-box;
    clip-path: border-box;
  }

  #lp_contents .fixed_left {
    display: grid !important;
    top: 0;
    grid-column: 1;
    -webkit-clip-path: border-box;
    clip-path: border-box;
    align-items: center;
  }

  #lp_contents .logo {
    width: 22.5rem;
    text-align: center;
  }

  #lp_contents .fixed_left .date {
    gap: 1.5rem;
    margin-top: 3rem ;
  }
  
  #lp_contents .fixed_left .date_item {
    gap: 1rem;
  }
  
  #lp_contents .date_item span {
    height: 0.1rem;
  }

  #lp_contents .fixed_left .date dl:first-of-type {
    width: 25rem;
  }

  #lp_contents .fixed_left .date dl:nth-of-type(2){
    width: 25.2rem;
  }
  
  #lp_contents .fixed_left .date dt,
  #lp_contents .fixed_left .date dd {
    font-size: 1.6rem;
  }
  
  #lp_contents .fixed_left .subtitle {
    margin-top: 3rem;
    font-size: 1.2rem;
  }

  #lp_contents .fixed_right .linkwrap {
    position: relative;
  }

  #lp_contents .fixed_right nav {
    margin-top: 0;
    padding: 0;
  }
  
  #lp_contents .fixed_right .menu_list {
    gap: 1rem;
  }
  
  #lp_contents .fixed_right .menu_list li {
    padding: 1rem 0 0.5rem;
    width: 12rem;
    height: 12rem;
    border: var(--color_pink) solid 0.1rem;

  }
  
  #lp_contents .fixed_right .menu_list li a img {
    width: 5.5rem;
  }
  
  #lp_contents .fixed_right .menu_list li a p {
    margin-top: 0.8rem;
    font-size: 1.1rem;
  }
  
  #lp_contents .fixed_right .menu_list li a span {
    margin-top:0.5rem;
    width: 1.3rem;
    height: 0.7rem;
  }

  #lp_contents .fixed_right .btn_all {
    position: absolute;
    bottom: -36.2rem;
    right: 4rem;
    width: 30rem;
    margin: 0 auto;
    border: var(--color_pink) solid 0.1rem;
    border-radius: 3rem;
  }
  
  #lp_contents .fixed_right .btn_all a {
    padding: 1rem 0 1rem;
    font-size: 1.2rem;
  }
  
  #lp_contents .fixed_right .btn_all a span {
    margin-top: 0.4rem;
    font-size: 2.2rem;
  }

}

@media (max-width: 768px) {

  /* SP時ナビゲーション設定 */
  #lp_contents .nav_fixed {
    position: fixed;
    bottom: 0;
    display: block;
    /* translate: 0 100%; */
    /* opacity: 0; */
    transition: all .5s;
    z-index: 10;
    width: 100%;

    transform: translateY(100%);
    transition: all 0.6s 0.3s;
    margin-top: 0;
  }

  #lp_contents .nav_fixed.active {
    transition: all 0.6s 0.3s;
    visibility: visible;
    transform: translateY(0);
    transition-delay: 0.5s;
  }

  #lp_contents .nav_fixed{
    padding: 0 !important;
  }

  #lp_contents .nav_fixed .menu_list {
    width: 100%;
    background-color: var(--color_white);
    gap: 0;
  }

  #lp_contents .nav_fixed .menu_list li {
    width: calc(100% / 3);
    height: calc(198 * 60rem / 750);
    padding: calc(20 * 60rem / 750) 0 calc(20 * 60rem / 750);
    border-radius: unset;
    border-top: var(--color_pink) solid calc(2 * 60rem / 750);
    border-right: var(--color_pink) solid calc(2 * 60rem / 750);
    border-left: 0;
  }

  #lp_contents .nav_fixed .menu_list li:last-of-type {
    border-right: none;
  }

  #lp_contents .nav_fixed .menu_list li a img {
    width: calc(100 * 60rem / 750);
  }

  #lp_contents .nav_fixed .menu_list li a p {
    font-size: calc(20 * 60rem / 750);
    margin-top: calc(10 * 60rem / 750);
  }

  #lp_contents .nav_fixed .menu_list li a span {
    margin-top:calc(12 * 60rem / 750);
    width: calc(22 * 60rem / 750);
    height: calc(12 * 60rem / 750);
  }

}
.lp_contents_inner:before {
  position: absolute;
  width: 100%;
  height: 100%;
  background: url(../img/bg_full.jpg) no-repeat;
  background-size: cover;
  content: "";
  top: calc(524 * 60rem / 750);
  left: 50%;
  transform: translateX(-50%);
}
.bg02 {
  background: url(../img/bg_sp05.jpg) no-repeat;
  background-size: cover;
  background-position: top center;
  padding-bottom: calc(120 * 60rem / 750);
}

/* ========================================================
                      * sec_mv  *
========================================================= */

#lp_contents .mv {
  width: 100%;
}

#lp_contents .lead_area {
  padding-top: calc(100 * 60rem / 750);
}

#lp_contents .title {
  margin: 0 auto;
  width: calc(454 * 60rem / 750);
}

#lp_contents .date {
  display: flex;
  flex-direction: column;
  gap: calc(27 * 60rem / 750);
  margin-top: calc(60 * 60rem / 750);
}

#lp_contents .date_item {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: calc(20 * 60rem / 750);
}

#lp_contents .date_item span {
  flex: 1;
  background-color: var(--color_pink);
  height: calc(2 * 60rem / 750);
}

#lp_contents .date dt,
#lp_contents .date dd {
  font-size: calc(32 * 60rem / 750);
  line-height:1;
  letter-spacing: 0.04em;
  color: var(--color_pink);
  font-weight: 300;
}

#lp_contents .subtitle {
  margin-top: calc(60 * 60rem / 750);
  font-size: calc(24 * 60rem / 750);
  line-height:1;
  letter-spacing: 0.04em;
  color: var(--color_pink);
  font-weight: 300;
}

#lp_contents nav {
  margin-top:calc(120 * 60rem / 750);
  padding: 0 calc(25 * 60rem / 750);
}

#lp_contents .menu_list {
  display: flex;
  gap: calc(20 * 60rem / 750);
}

#lp_contents .menu_list li {
  padding: calc(20 * 60rem / 750) 0 calc(15 * 60rem / 750);
  width: calc(220 * 60rem / 750);
  height: calc(220 * 60rem / 750);
  border-radius: 50%;
  border: var(--color_pink) solid calc(2 * 60rem / 750);
  background-color: var(--color_white);
}

#lp_contents .menu_list li a {
  display: flex;
  flex-direction: column;
  align-items: center;
}

#lp_contents .menu_list li a img {
  width: calc(100 * 60rem / 750);
}

#lp_contents .menu_list li a p {
  margin-top:calc(12 * 60rem / 750);
  font-size:calc(20 * 60rem / 750);
  font-weight: 300;
  color: var(--color_pink);
  letter-spacing: 0.04em;
  line-height: calc(24/20);
}

#lp_contents .menu_list li a p br {
  line-height: 0;
}

#lp_contents .menu_list li a span {
  margin-top:calc(12 * 60rem / 750);
  width: calc(22 * 60rem / 750);
  height: calc(12 * 60rem / 750);
  background: url(../img/arrow_sp.svg) no-repeat;
  background-size: contain;
  content: "";
}

#lp_contents .accordion {
  position: relative;
  z-index: 2;
  margin-top: calc(105 * 60rem / 750);
}

#lp_contents .accordion_wrap {
  display: grid;
  grid-template-rows: 0fr;
  justify-content: center;
  transition: grid-template-rows .8s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
}

#lp_contents .open > .accordion_wrap {
  grid-template-rows: 1fr;
}

#lp_contents .accordion_inner {
  position: relative;
  min-height: calc(280 * 60rem / 750);
  overflow: hidden; 
}

#lp_contents .accordion_text {
  margin-top: calc(30 * 60rem / 750);
  font-size:calc(22 * 60rem / 750);
  letter-spacing: 0.2em;
  line-height: calc(52.8/22);
}

#lp_contents .accordion_inner .accordion_text:first-of-type {
  margin-top: calc(0 * 60rem / 750);
}

#lp_contents .accordion_btn {
  display: flex;
  align-items: center;
  gap: calc(5 * 60rem / 750);
  margin: calc(70 * 60rem / 750) auto 0;
  width: fit-content;
  height: auto;
  line-height: 1;
  text-align: center;
  cursor: pointer;
  flex-direction: column;
}

#lp_contents .accordion.open .accordion_btn {
  flex-direction: column-reverse;
  margin: calc(60 * 60rem / 750) auto 0;
  gap: calc(15 * 60rem / 750);
}

#lp_contents .accordion_btn .accordion_btn_text {
  display: block;
  width: fit-content;
  height: 100%;
  margin: 0 auto;
  font-size: calc(28 * 60rem / 750);
  letter-spacing: 0.04em;
  line-height: 1;
  color: var(--color_pink);
}

#lp_contents .accordion_btn .accordion_btn_icon {
  position: relative;
  width: calc(34 * 60rem / 750);
  height: calc(30 * 60rem / 750);
  background: url(../img/arrow.svg) no-repeat;
  background-size: 100%;
  content: "";
}

#lp_contents .accordion.open .accordion_btn_icon {
  transform: rotate(180deg);
}

#lp_contents .artist_blk {
  margin-top: calc(160 * 60rem / 750);
}

#lp_contents .artist_text {
  font-size: calc(32 * 60rem / 750);
  letter-spacing: 0.04em;
  color: var(--color_pink);
  font-weight: 300;
  line-height: 1;
}

#lp_contents .artist_name {
  margin-top: calc(15 * 60rem / 750);
  font-size: calc(62 * 60rem / 750);
  letter-spacing: 0.04em;
  color: var(--color_pink);
  font-weight: 300;
  line-height: 1;
}

#lp_contents .artist_img {
  width: calc(300 * 60rem / 750);
  margin: calc(30 * 60rem / 750) auto 0;
  border-radius: calc(30 * 60rem / 750);
}

#lp_contents .artist_img img {
  width: calc(300 * 60rem / 750);
  margin: 0 auto;
}

#lp_contents .artist_title {
  margin-top: calc(50 * 60rem / 750);
  font-size: calc(24 * 60rem / 750);
  letter-spacing: 0.2em;
}

#lp_contents .artist_detail {
  padding: 0 calc(70 * 60rem / 750);
  margin-top: calc(30 * 60rem / 750);
  font-size: calc(22 * 60rem / 750);
  line-height: calc(44 / 22);
  letter-spacing: 0.15em;
  text-align: justify;
}

#lp_contents .btn_comment {
  margin: calc(40 * 60rem / 750) auto 0;
}

#lp_contents .btn_comment a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: fit-content;
  margin: 0 auto;
  gap: calc(10 * 60rem / 750);
  padding-bottom: calc(13 * 60rem / 750);
  border-bottom: var(--color_pink) solid calc(2 * 60rem / 750);
}

#lp_contents .btn_comment a .text {
  font-size: calc(28 * 60rem / 750);
  line-height: 1;
  letter-spacing: 0.04em;
  color: var(--color_pink);
  font-weight: 300;
}

#lp_contents .btn_comment a .plus {
  position: relative;
  width: calc(22 * 60rem / 750);
  height: calc(22 * 60rem / 750);
}

#lp_contents .btn_comment a .plus:after,
#lp_contents .btn_comment a .plus:before {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: calc(2 * 60rem / 750);
  transform: translate(-50%,-50%);
  background-color: var(--color_pink);
  content: "";
}

#lp_contents .btn_comment a .plus:after {
  transform: translate(-50%, -50%) rotate(90deg);
}
/* ========================================================
                * sec 共通設定  *
========================================================= */
#lp_contents .sec {
  padding-top: calc(255 * 60rem / 750);
}

#lp_contents .sec_title {
  margin-bottom: calc(45 * 60rem / 750);
  font-size: calc(62 * 60rem / 750);
  line-height: 1;
  letter-spacing: 0.04em;
  color: var(--color_pink);
  text-align: center;
}

#lp_contents .note {
  font-size: calc(20 * 60rem / 750);
  margin-top: calc(36 * 60rem / 750);
}


#lp_contents .visual_blk {
  position: relative;
}

#lp_contents .visual_title {
  position: absolute;
  width: calc(698 * 60rem / 750);
  top: calc(-95 * 60rem / 750);
  left: 50%;
  transform: translateX(-50%);
  z-index: 5;
  mix-blend-mode: multiply;
}

#lp_contents .visual_slider_container {
  margin: 0 auto;
  width: calc(660 * 60rem / 750);
}

#lp_contents .visual_slider img {
  margin: 0 auto;
  width: calc(660 * 60rem / 750);
  border-radius: calc(40 * 60rem / 750);
}

#lp_contents .slick-dots {
  bottom: calc(-57 * 60rem / 750);
}

#lp_contents .slick-dots li {
  width: calc(100 * 60rem / 750);
  height: calc(4 * 60rem / 750);
  margin: 0 calc(10 * 60rem / 750);
}

#lp_contents .slick-dots li button {
  width: calc(100 * 60rem / 750);
  height: calc(4 * 60rem / 750);
  padding: 0;
  background-color: var(--color_lightpink);
}

#lp_contents .slick-dots li.slick-active button:before {
  background-color: var(--color_pink);
}

#lp_contents .slick-dots li button:before {
  top: calc(0 * 60rem / 750);
  font-size: calc(16 * 60rem / 750);
  line-height: 1;
  width: calc(100 * 60rem / 750);
  height: calc(4 * 60rem / 750);
  opacity: 1;
  color: transparent;
}

#lp_contents .item_name_eng {
  margin-top: calc(110 * 60rem / 750);
  font-weight: 300;
  font-size: calc(56 * 60rem / 750);
  text-align: center;
  letter-spacing: 0.04em;
  color: var(--color_pink);
}

#lp_contents .item_description {
  margin-top: calc(35 * 60rem / 750);
  font-size: calc(26 * 60rem / 750);
  line-height:calc(52/26);
}

#lp_contents .item_link_img {
  margin: calc(55 * 60rem / 750) auto 0;
  width: calc(750 * 60rem / 750);
}

#lp_contents .item_name {
  margin-top: calc(37 * 60rem / 750);
  font-size: calc(24 * 60rem / 750);
  line-height:calc(38.4/24);
  letter-spacing: 0.15em;
}

#lp_contents .item_credit {
  margin-top: calc(15 * 60rem / 750);
  font-size: calc(24 * 60rem / 750);
  line-height:calc(38.4/24);
  letter-spacing: 0.15em;
}

#lp_contents .item_credit span {
  display: inline-block;
}

#lp_contents .item_credit .limit {
  font-size: calc(22 * 60rem / 750);
}

#lp_contents .item_credit .tax {
  font-size: calc(20 * 60rem / 750);
}

#lp_contents .btn_buy {
  position: relative;
  margin: calc(35 * 60rem / 750) auto 0;
  width: calc(340 * 60rem / 750);
  line-height: 1;
  z-index: 2;
}

#lp_contents .btn_buy a {
  padding: calc(16 * 60rem / 750) calc(0 * 60rem / 750) calc(16 * 60rem / 750);
  font-size: calc(40 * 60rem / 750);
  font-weight: 300;
  text-transform: uppercase;
  color: var(--color_pink);
  border: var(--color_pink) solid calc(2 * 60rem / 750);
  background-color: var(--color_white);
  border-radius: calc(38 * 60rem / 750);
  letter-spacing: 0.04em;
  line-height: 1;
}

#lp_contents .item_var_list {
  margin: calc(120 * 60rem / 750) auto 0;
}

#lp_contents .item_var_list li:not(:first-of-type) {
  margin-top: calc(110 * 60rem / 750);
}

#lp_contents .item_var_list li .item_var_img_blk {
  position: relative;
}

#lp_contents .item_var_list li .item_var_img_blk img {
  margin: auto 0;
  width: calc(750 * 60rem / 750);
}

#lp_contents .btn_modal {
  position: absolute;
  top: calc(-40 * 60rem / 750);
  right: calc(70 * 60rem / 750);
  width: calc(80 * 60rem / 750);
  height: calc(80 * 60rem / 750);
}

#lp_contents .btn_modal_inner {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: calc(80 * 60rem / 750);
  height: calc(80 * 60rem / 750);
  border-radius: 50%;
  background-color: var(--color_pink);
  line-height: 0;
  z-index: 2;
}

#lp_contents .btn_modal_inner:before {
	content: '';
	display: block;
  background-color: rgba(247,198,189,0.4);
	position: absolute;
	top: 0%;
	right: 0%;
	z-index: 0;
  width: calc(80 * 60rem / 750);
  height: calc(80 * 60rem / 750);
	border-radius: 50%;
	animation: pulsateCircle 1.5s ease-out;  /* スピードなど */
	animation-iteration-count: infinite;
}

@keyframes pulsateCircle {
	0% {
		transform: scale(1, 1);
	}
	50% {
		opacity: 1;
	}
	100% {
		transform: scale(1.35, 1.35);
		opacity: 0;
	}
}

#lp_contents .btn_modal a {
  position: relative;
  width: calc(47 * 60rem / 750);
  height: calc(47 * 60rem / 750);
}

#lp_contents .btn_modal a:after,
#lp_contents .btn_modal a:before {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: calc(1.85 * 60rem / 750);
  transform: translate(-50%,-50%);
  background-color: var(--color_white);
  content: "";
}

#lp_contents .btn_modal a:after {
  transform: translate(-50%, -50%) rotate(90deg);
}

#lp_contents .item_var_name {
  margin-top: calc(35 * 60rem / 750);
  font-size: calc(36 * 60rem / 750);
  font-weight: 300;
  line-height: 1;
  letter-spacing: 0.04em;
  color: var(--color_pink);
}

#lp_contents .item_var_detail {
  margin-top: calc(15 * 60rem / 750);
  font-size: calc(24 * 60rem / 750);
  line-height: calc(42/24);
  letter-spacing: 0.15em;
}

#lp_contents .comment_blk {
  position: relative;
  width: calc(662 * 60rem / 750);
  margin: calc(160 * 60rem / 750) auto 0;
  background-color: var(--color_white);
  border: var(--color_pink) solid calc(2 * 60rem / 750);
  border-radius: calc(40 * 60rem / 750);
}

#lp_contents .comment_blk:before {
  position: absolute;
  top: calc(-46 * 60rem / 750);
  left: calc(98 * 60rem / 750);
  display: block;
  width: calc(60.5 * 60rem / 750);
  height: calc(49.5 * 60rem / 750);
  background: url(../img/fukidashi_decor.svg?260611) no-repeat;
  background-size: contain;
  z-index: 2;
  content: "";
}

#lp_contents .comment_blk:after {
  position: absolute;
  top: calc(0 * 60rem / 750);
  left: calc(99 * 60rem / 750);
  display: block;
  width: calc(60 * 60rem / 750);
  height: calc(2 * 60rem / 750);
  background-color: var(--color_white);
  z-index: 3;
  content: "";
}

/* #lp_contents .sec_eyepalette01 .comment_blk {
  background: url(../img/fukidashi01.svg) no-repeat;
  background-size: 100% 100%;
  background-position: center center;
}
#lp_contents .sec_eyepalette02 .comment_blk {
  background: url(../img/fukidashi02.svg) no-repeat;
  background-size: 100% 100%;
  background-position: center center;
}
#lp_contents .sec_lips .comment_blk {
  background: url(../img/fukidashi03.svg) no-repeat;
  background-size: 100% 100%;
  background-position: center center;
} */

#lp_contents .comment_title {
  padding: calc(30 * 60rem / 750) calc(55 * 60rem / 750) calc(30 * 60rem / 750);
  font-size: calc(40 * 60rem / 750);
  line-height: 1;
  letter-spacing: 0.04em;
  color: var(--color_pink);
  text-align: left;
  font-weight: 300;
}

#lp_contents .comment_text {
  padding: calc(30 * 60rem / 750) calc(55 * 60rem / 750) calc(36 * 60rem / 750);
  font-size: calc(22 * 60rem / 750);
  line-height: calc(44/22);
  letter-spacing: 0.15em;
  border-top: var(--color_pink) solid calc(2 * 60rem / 750);
  text-align: justify;
}

#lp_contents .sec_eyepalette02 .btn_modal {
  top: calc(-24 * 60rem / 750);
  right: calc(97 * 60rem / 750);
}

#lp_contents .sec_lips .btn_modal {
  top: calc(-5 * 60rem / 750);
  right: calc(206 * 60rem / 750);
}

#lp_contents .sec_lips .item_var_list li .item_var_img_blk img {
  width: calc(240 * 60rem / 750);
}

/* ========================================================
                      * Novelty  *
========================================================= */
#lp_contents .sec_novelty{
  padding-top: calc(160 * 60rem / 750);
}

#lp_contents .novelty_name {
  font-size: calc(24 * 60rem / 750);
  line-height: 1;
  letter-spacing: 0.15em;
}

#lp_contents .novelty_img {
  margin-top: calc(40 * 60rem / 750);
  width: calc(460 * 60rem / 750);
}

#lp_contents .novelty_text {
  margin-top: calc(50 * 60rem / 750);
  font-size: calc(22 * 60rem / 750);
  line-height: calc(44/22);
  letter-spacing: 0.15em;
}

#lp_contents .novelty_time {
  margin-top: calc(50 * 60rem / 750);
  font-size: calc(22 * 60rem / 750);
  line-height: calc(44/22);
  letter-spacing: 0.15em;
}

/* ========================================================
                * sec_releaseinformation  *
========================================================= */

#lp_contents .sec_preorder {
  padding-top: calc(150 * 60rem / 750);
}

#lp_contents .sec_preorder .sec_title,
#lp_contents .sec_releaseinformation .sec_title
{
  margin-bottom: calc(20 * 60rem / 750);
}

#lp_contents .sec_preorder .date,
#lp_contents .sec_releaseinformation .date {
  margin-top: calc(30 * 60rem / 750);
  font-size: calc(32 * 60rem / 750);
  letter-spacing: 0.04em;
  color: var(--color_pink);
}

#lp_contents .date dl {
  margin: 0 auto;
}

#lp_contents .date dl:first-of-type{
  width: calc(501 * 60rem / 750);
}

#lp_contents .date dl:nth-of-type(2){
  width: calc(504 * 60rem / 750);
}

#lp_contents .sec_preorder .blk .webstore {
  margin-top: calc(16 * 60rem / 750);
}

#lp_contents .sec_preorder .blk .webstore:nth-of-type(2) {
  margin-top: calc(22 * 60rem / 750);
}

#lp_contents .sec_releaseinformation {
  padding-top: calc(68 * 60rem / 750);
}

#lp_contents .sec_releaseinformation .webstore {
  margin-top: calc(22 * 60rem / 750);
}

#lp_contents .store {
  margin-top: calc(70 * 60rem / 750);
}

#lp_contents .webstore,
#lp_contents .store {
  font-size: calc(24 * 60rem / 750);
  letter-spacing: .04em;
  line-height: 1;
  font-weight: 300;
}

#lp_contents .webstore span,
#lp_contents .store span {
  font-size: calc(22 * 60rem / 750);
  letter-spacing: .1em;
  line-height: 2;
  display: block;
  font-weight: 300;
  text-transform: none;
  margin-top: calc(10 * 60rem / 750);
  color: var(--color_text);
}

#lp_contents .webstore span.txt_ja,
#lp_contents .store span.txt_ja {
  font-size: calc(20 * 60rem / 750);
  letter-spacing: .1em;
  line-height: 2;
  display: inline;
}

#lp_contents .btn_all {
  width: calc(600 * 60rem / 750);
  margin: calc(107 * 60rem / 750) auto 0;
  background: var(--color_white);
  border: var(--color_pink) solid calc(2 * 60rem / 750);
  border-radius: calc(60 * 60rem / 750);
}

#lp_contents .btn_all a {
  padding: calc(20 * 60rem / 750) 0 calc(20 * 60rem / 750);
  font-size: calc(24 * 60rem / 750);
  font-weight: 300;
  letter-spacing: .04em;
  line-height: 1;
  color: var(--color_pink);
}

#lp_contents .btn_all a span {
  display: block;
  margin-top: calc(8 * 60rem / 750);
  font-size: calc(44 * 60rem / 750);
  letter-spacing: .04em;
  font-weight: 300;
  line-height: 1;
  color: var(--color_pink);
}


@media (max-width: 769px) {
/* #lp_contents .btn_novelty {
  position: fixed;
  display: flex;
  flex-direction: column;
  gap: calc(10 * 60rem / 750);
  bottom: 18%;
  right: 0;
  border-radius: calc(20 * 60rem / 750) 0 0 calc(20 * 60rem / 750);
  z-index: 999;
  visibility: hidden;
  pointer-events: none;
  transform: translateX(40px);
  transition: 
    transform 0.6s cubic-bezier(0, 0, 0.2, 1),
    visibility 0.6s;
  background-color: var(--color_pink);
}

#lp_contents .btn_novelty.active {
  visibility: visible;
  pointer-events: auto;
  transform: translateX(0);
}

#lp_contents .btn_novelty.down {
  transform: translateX(0) translateY(calc(180 * 60rem / 750));
} */

#lp_contents .btn_novelty {
  position: fixed;
  display: flex;
  flex-direction: column;
  gap: calc(10 * 60rem / 750);
  bottom: calc(50 * 60rem / 750);
  right: 0;
  border-radius: calc(20 * 60rem / 750) 0 0 calc(20 * 60rem / 750);
  z-index: 999;
  
  /* 1. 初期状態は不透明度0、かつ右側に隠す（Y軸の初期値も0で明示） */
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateX(40px) translateY(0);
  
  /* 2. transitionにopacityを追加し、すべての変化を一括で滑らかにする */
  transition: 
    transform 0.6s cubic-bezier(0, 0, 0.2, 1),
    opacity 0.6s ease,
    visibility 0.6s;
  background-color: var(--color_pink);
  transition-delay: 0.5s;
}

/* 登場時（active）：右から滑らかにスライドイン */
#lp_contents .btn_novelty.active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(0) translateY(0);
}

/* 下スクロール時（down）：X軸（横位置）は0を維持したまま、下に移動 */
#lp_contents .btn_novelty.active.up {
  transform: translateX(0) translateY(calc(-180 * 60rem / 750));
}

#lp_contents .btn_novelty a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: calc(11 * 60rem / 750);
  padding: calc(25 * 60rem / 750) calc(10 * 60rem / 750) calc(20 * 60rem / 750);
  flex-direction: column;
}

#lp_contents .btn_novelty a .text {
  display: block;
  font-size: calc(30 * 60rem / 750);
  writing-mode: vertical-rl;
  text-orientation: mixed;
  color: var(--color_white);
  letter-spacing: 0.04em;
}

#lp_contents .btn_novelty a .plus {
  display: block;
  position: relative;
  width:calc(24 * 60rem / 750);
  height: calc(24 * 60rem / 750);
}

#lp_contents .btn_novelty a .plus:before,
#lp_contents .btn_novelty a .plus:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(24 * 60rem / 750);
  height: calc(2 * 60rem / 750);
  background-color: var(--color_white);
}

#lp_contents .btn_novelty a .plus:before {
  transform: translate(-50%, -50%);
}

#lp_contents .btn_novelty a .plus:after {
  transform: translate(-50%, -50%) rotate(90deg);
}
}

/* ========================================================
                        * modal  *
========================================================= */
#lp_contents .modal{
  display: none;
  height: 100vh;
  position: fixed;
  top: 50%;
  right: 50%;
  transform: translate(50%,-50%);
  width: 100%;
  z-index: 1000;
}

#lp_contents .modal__bg {
  height: 100vh;
  position: absolute;
  width: 100%;
  background: rgba(247,198,189,0.4);
}

#lp_contents .modal__content{
  background: var(--color_white);
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%,-50%);
  width: calc(660 * 60rem / 750);
  max-height: 80vh;
  overflow-y: scroll;
  overflow-x: clip;
  border-radius: calc(40 * 60rem / 750);
  scrollbar-width: none;
  overscroll-behavior: contain;
}
@media (max-width: 768px) {
  #lp_contents .modal__content{
  transform: translate(-50%,-50%);
  }
}

#lp_contents .modal__content::-webkit-scrollbar {
  display: none;
}

#lp_contents .modal_inner {
  padding: calc(115 * 60rem / 750) 0 calc(115 * 60rem / 750);
} 

#lp_contents .modal__content .js-modal-close{
  position: sticky;
  width: calc(60 * 60rem / 750);
  height: calc(60 * 60rem / 750);
  top: calc(30 * 60rem / 750);
  right: calc(30 * 60rem / 750);
  float: right;
  cursor: pointer;
  overflow: hidden;
  z-index: 999;
}

#lp_contents .modal__content .js-modal-close:before,
#lp_contents .modal__content .js-modal-close:after{
  content: '';
  display: block;
  width: calc(80 * 60rem / 750);
  height: calc(2 * 60rem / 750);
  transform: rotate(45deg);
  position: absolute;
  top: calc(30 * 60rem / 750);
  right: calc(-10 * 60rem / 750);
  background: var(--color_pink);
}

#lp_contents .modal__content .js-modal-close:after{
  transform: rotate(-45deg);
}

/* Novelty Modal */

/* Comment Modal */
#lp_contents .modal02 .modal_inner {
  padding: calc(135 * 60rem / 750) 0 calc(115 * 60rem / 750);
} 
#lp_contents .modal02 .comment_title {
  position: relative;
  padding: calc(0 * 60rem / 750) calc(60 * 60rem / 750) calc(30 * 60rem / 750);
}
#lp_contents .modal02 .comment_title:before {
  position: absolute;
  bottom: calc(-52 * 60rem / 750);
  left: 50%;
  transform: translateX(-50%);
  display: block;
  width: calc(660 * 60rem / 750);
  height: calc(54 * 60rem / 750);
  background: url(../img/decor02.svg) no-repeat;
  background-size: cover;
  content: "";
}
#lp_contents .modal02 .comment_text {
  border-top: none;
  padding: calc(0 * 60rem / 750) calc(55 * 60rem / 750) calc(0 * 60rem / 750);
  margin-top: calc(28 * 60rem / 750);
}
#lp_contents .modal02 .modal_inner .comment_text:nth-child(2) {
  margin-top: calc(82 * 60rem / 750);
}

/* Item Modal */
#lp_contents .modal .slick-prev, 
#lp_contents .modal .slick-next {
  position: fixed;
  top: calc(320 * 60rem / 750);
  z-index: 9999;
  width: calc(40 * 60rem / 750);
  height: calc(78 * 60rem / 750);
}

#lp_contents .modal .slick-prev {
  left: calc(60 * 60rem / 750);
}

#lp_contents .modal .slick-next {
  right: calc(60 * 60rem / 750);
}

#lp_contents .modal .slick-prev:before, 
#lp_contents .modal .slick-next:before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: calc(40 * 60rem / 750);
  height: calc(78 * 60rem / 750);
  background-size: 100%;
  content: "";
}

#lp_contents .modal .slick-prev:before {
  background: url(../img/prev.svg) no-repeat;
}

#lp_contents .modal .slick-next:before {
  background: url(../img/next.svg) no-repeat;
}

#lp_contents .modal_item_img {
  width: calc(400 * 60rem / 750);
  margin: 0 auto;
}

#lp_contents .modal_var_name {
  margin: calc(40 * 60rem / 750) auto 0;
  font-size: calc(36 * 60rem / 750);
  font-weight: 300;
  color: var(--color_pink);
  letter-spacing: 0.04em;
  line-height: 1;
}

#lp_contents .modal_text {
  margin: calc(16 * 60rem / 750) auto 0;
  padding: 0 calc(60 * 60rem / 750);
  font-size: calc(22 * 60rem / 750);
  text-align: justify;
}

#lp_contents .modal_sample {
  width: calc(480 * 60rem / 750);
  margin: calc(70 * 60rem / 750) auto 0;
}

#lp_contents .modal_colormap {
  width: calc(480 * 60rem / 750);
  margin: calc(80 * 60rem / 750) auto 0;
}

#lp_contents .modal .btn_buy {
  margin: calc(80 * 60rem / 750) auto 0;
}

#lp_contents .modal .btn_buy a {
  padding: calc(15 * 60rem / 750) calc(0 * 60rem / 750) calc(16 * 60rem / 750);
  color: var(--color_white);
  background-color: var(--color_pink);
  border: none;
}

/* ========================================================
                      * PCデザイン調整  *
========================================================= */
@media (min-width: 768px) {
#lp_contents .date_item span {
  height: 1px;
}
}
/* ========================================================
                      * JS 設定  *
========================================================= */

.ef1{
  opacity: 0;
  filter: blur(20px);
  will-change: filter;
  transition: opacity 0.7s ease, filter 0.7s ease 0.2s, transform 0.7s ease 0.2s;
}

.ef1.js-active.delay {
  opacity: 0;
  filter: blur(20px);
  will-change: filter;
  transition: opacity 0.7s ease, filter 0.7s ease 0.2s, transform 0.7s ease 0.2s;
  transition-delay: 1s;
}


.ef1.js-active,
.ef1.js-active.delay {
  opacity: 1;
  filter: blur(0);
}


.ef2 {
  transform: translateY(2rem);
  transition: translate 2s, opacity 1s, transform 1s;
  opacity: 0;
  pointer-events: none;
}

.ef2.js-active {
  opacity: 1;
  transform: translateY(0);
}
