@charset "UTF-8";

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

Celvoke 2026 Summer Collection

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


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

html {
  font-size: 62.5%;
  -ms-overflow-style: none;
}

body {
  -webkit-tap-highlight-color: transparent;
}

main {
  max-width: none;
}

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

#Wrap {
  width: 100% !important;
}

#Contents {
  margin-bottom: 0;
  padding-top: 0 !important;
}

.lp_contents a {
  text-decoration: none;
}

.lp_contents p, 
.lp_contents ul, 
.lp_contents ol, 
.lp_contents dl {
  margin: 0;
}

.topic-path {
  margin-right: 0;
  margin-left: 0;
}

/* ============================================================================
      Roots
============================================================================ */
:root {
  --rate-sp: 49rem / 750;
  --color-text:#000000;
  --color-white:#ffffff;
  --color-gray01: #f7f8f9;
  --color-gray02: #757575;
  --color-red:#de465b;
  --font-english: "ocr-b-std", monospace;
}

/* ============================================================================
      LP contents
============================================================================ */
.lp_contents {
  position: relative;
  z-index: 0;
  max-width: 100vw;
  z-index: 1;
  margin: 0 auto;
  font-weight: 400;
  font-style: normal;
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0.02em;
  font-feature-settings: "palt";
  color: var(--color-text);
  /* overflow: hidden; */
  background-color: var(--color-white);
}

@media screen and  (max-width:768px) {
.lp_contents {
  overflow: clip;
}
}

.lp_contents p, 
.lp_contents h2, 
.lp_contents h3, 
.lp_contents h4, 
.lp_contents h5,
.lp_contents li, 
.lp_contents span {
  font-family: "Noto Sans JP", sans-serif;
  color: var(--color-text);
  letter-spacing: 0.02em;
  text-align: center;
  font-weight: 400;
  font-feature-settings: "pkna";
}

#FooterWrap {
  position: relative;
  z-index: 2;
}

@media screen and  (max-width:768px) {
  #FooterWrap {
    z-index: 0;
  }
}

.lp_contents *,
.lp_contents *:before,
.lp_contents *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

.lp_contents ul,
.lp_contents li {
  list-style: none;
}

.lp_contents a:hover {
  opacity: 0.6;
}

@media screen and  (max-width:768px) {
.lp_contents a:hover {
  opacity: 1;
}
}

.lp_contents img {
  width: 100%;
}

.lp_contents figure {
  display: flex;
}

.lp_contents sup {
  font-size: 60%;
  vertical-align: 0.4rem;
}

.lp_contents a,
.lp_contents a:before,
.lp_contents a:after,
.lp_contents a img {
  transition: opacity .3s ease-in-out,
  color .3s ease-in-out,
  background-color .3s ease-in-out,
  background-image .3s ease-in-out,
  border-color .3s ease-in-out,
  text-shadow .3s ease-in-out,
  text-weight .3s ease-in-out;
}

.lp_contents h1 {
  padding: 0;
}

.lp_contents .en_font,
.lp_contents .btn a {
  font-family: var(--font-english);
  font-weight: 300;
}


/* ============================================================================
      Button Setting
============================================================================ */
.lp_contents .btn {
  width: fit-content;
  display: block;
  background: transparent;
  border: none;
  max-width: 100%;
  margin: 0 auto;
}

.lp_contents .btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  transition: all 0.1s ease-in-out;
  backface-visibility: hidden;
}

.lp_contents .btn a:hover {
  opacity: 0.6;
}

/* ============================================================================
      SECTION
============================================================================ */
.lp_contents .sec {
  position: relative;
  z-index: 1;
  height: auto;
  background-color: var(--color-white);
}

.lp_contents .sec_eyes {
  padding: calc(160 * (var(--rate-sp))) 0 calc(120 * (var(--rate-sp)));
}

.lp_contents .sec_liner,
.lp_contents .sec_lipdrop {
  background-color: var(--color-gray01);
}

.lp_contents .sec_liner {
  padding: calc(80 * (var(--rate-sp))) 0 calc(150 * (var(--rate-sp)));
}

.lp_contents .sec_blush {
  padding: calc(160 * (var(--rate-sp))) 0 calc(0 * (var(--rate-sp)));
}

.lp_contents .sec_lip {
  padding: calc(150 * (var(--rate-sp))) 0 calc(155 * (var(--rate-sp)));
}

.lp_contents .sec_lipdrop {
  padding: calc(80 * (var(--rate-sp))) 0 calc(150 * (var(--rate-sp)));
}

.lp_contents .sec_mkup {
  padding: calc(160 * (var(--rate-sp))) 0 calc(30 * (var(--rate-sp)));
}

.lp_contents .sec_releaseday {
  background-color: var(--color-gray01);
  padding: calc(163 * (var(--rate-sp))) calc(40 * (var(--rate-sp))) calc(155 * (var(--rate-sp)));
}
/* ============================================================================
      ACCORDION
============================================================================ */
.lp_contents .accordion {
  position: relative;
  z-index: 2;
}

.lp_contents .accordion_wrap {
  display: grid;
  position: relative;
  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;
  transition: opacity .8s;
  overflow: hidden; 
}

.lp_contents .sec_eyes .accordion_inner {
  min-height: calc(504 * 60rem / 750); 
}

.lp_contents .sec_mkup .accordion_inner {
  min-height: calc(464 * 60rem / 750);
}

.lp_contents .accordion_inner::before {
  position: absolute;
  bottom: calc(-1 * 60rem / 750);
  left: 0;
  width: 100%;
  height: calc(100 * 60rem / 750);
  background: linear-gradient(transparent, var(--color-white));
  content: "";
  z-index: 3;
}

.lp_contents .sec_eyes .accordion_inner::before {
  height: calc(504 * 60rem / 750);
}

.lp_contents .sec_mkup .accordion_inner::before {
  height: calc(464 * 60rem / 750);
}

.lp_contents .accordion.open .accordion_inner::before {
  display: none;
}

.lp_contents .accordion_btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: calc(50 * (var(--rate-sp)));
  margin: calc(0 * (var(--rate-sp))) auto 0;
  width: fit-content;
  height: fit-content;
  line-height: 1;
  text-align: center;
  cursor: pointer;
  position: absolute;
  left: 50%;
  transform: translate(-50%);
  bottom: calc(0 * (var(--rate-sp)));
  z-index: 5;
}

.lp_contents .accordion.open .accordion_btn {
  flex-direction: column-reverse;
  bottom: calc(30 * (var(--rate-sp)));
  gap: calc(30 * (var(--rate-sp)));
}

.lp_contents .accordion_btn .accordion_btn_text {
  display: block;
  width: fit-content;
  height: 100%;
  margin: 0 auto;
  font-family: var(--font-english);
  font-size: calc(30 * (var(--rate-sp)));
  letter-spacing: -0.16em;
  color: var(--color-text);
  text-transform: uppercase;
}

.lp_contents .accordion_btn .accordion_btn_icon {
  position: relative;
  display: block;
  width: calc(33 * (var(--rate-sp)));
  height: calc(33 * (var(--rate-sp)));
}

.lp_contents .accordion_btn .accordion_btn_icon:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  transition: all 0.6s ease;
  width: 100%;
  height: 100%;
  background: url(../img/icon_accordion_arrow.svg) no-repeat;
  background-size: contain;
  content: "";
  z-index: 0;
}

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

/* ============================================================================
      SECTION：MV
============================================================================ */

#lp_contents .movie_wrap {
  width: calc(750 * (var(--rate-sp)));
  height: calc(1000 * (var(--rate-sp)));
  margin: 0 auto;
  overflow: hidden;
  position: relative;
}

#lp_contents .movie_wrap iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  width: 100%;
  pointer-events: none;
  border: none;
}

/* ============================================================================
      NAVIGATION
============================================================================ */
.lp_contents .navigation_list {
  padding: calc(80 * (var(--rate-sp))) calc(25 * (var(--rate-sp))) 0 calc(25 * (var(--rate-sp)));
}

.lp_contents .navigation_list ul {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  column-gap: calc(34 * (var(--rate-sp)));
  row-gap: calc(80 * (var(--rate-sp)));
}

.lp_contents .navigation_list li {
  position: relative;
}

.lp_contents .navigation_list li:nth-of-type(5) {
  width: calc(225 * (var(--rate-sp)));
}

.lp_contents .navigation_list li:last-of-type {
  width: calc(195 * (var(--rate-sp)));
}

.lp_contents .navigation_list li:last-of-type a {
  margin-top: calc(80 * (var(--rate-sp)));
  margin-left: calc(22 * (var(--rate-sp)));
}

.lp_contents .navigation_list li:last-of-type a .navigation_name.name_upper{
  margin-left: calc(-88 * (var(--rate-sp)));
}

.lp_contents .navigation_list li:last-of-type a .navigation_name.name_lower {
margin-left: calc(39 * (var(--rate-sp)));
}

.lp_contents .navigation_list li img {
  width: calc(200*(var(--rate-sp)));
  margin: 0 auto;
}

.lp_contents .navigation_list a {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: center;
  gap: calc(0*(var(--rate-sp)));
}

.lp_contents .navigation_name_group {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-top: calc(40*(var(--rate-sp)));
}

.lp_contents .navigation_name {
  font-family: var(--font-english);
  text-transform: uppercase;
  font-size: calc(30*(var(--rate-sp)));
  letter-spacing: -0.16em;
  line-height: calc(30/30);
  text-align: center;
}

.lp_contents .name_lower {
  display: flex;
  align-items: center;
  gap: calc(14*(var(--rate-sp)));
  margin-left: calc(0*(var(--rate-sp)));
}

.lp_contents .navigation_arrow {
  margin-top: calc(-3 * (var(--rate-sp)));
  width: calc(15*(var(--rate-sp)));
  height: calc(15*(var(--rate-sp)));
  background: url(../img/icon_nav_arrow.svg) no-repeat;
  background-size: 100%;
  content: "";
}

/* SP Fixed Nav */

.lp_contents .navigation_list.nav02 {
  position: fixed;
  bottom: 0;
  display: block;
  width: 100%;
  transform: translateY(100%);
  transition: all 0.6s 0.3s;
  z-index: 100;
  padding: 0;
  background-color: var(--color-white);
}

.lp_contents .navigation_list.nav02.active {
  transition: all 0.6s 0.3s;
  visibility: visible;
  transform: translateY(0);
  z-index: 100;
  background-color: var(--color-white);
}

.lp_contents .navigation_list.nav02 ul {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  column-gap: calc(0 * (var(--rate-sp)));
  row-gap: calc(0 * (var(--rate-sp)));
  border-top: var(--color-text) solid calc(2 * (var(--rate-sp)));

}

.lp_contents .navigation_list.nav02 li {
  position: relative;
  width: 50%;
  padding: calc(11 * (var(--rate-sp))) calc(0 * (var(--rate-sp)));
}

.lp_contents .navigation_list.nav02 li:before,
.lp_contents .navigation_list.nav02 li:after {
  position: absolute;
  display: block;
  background-color: var(--color-text);
  content: "";
}

.lp_contents .navigation_list.nav02 li:before {
  width: 100%;
  height: calc(2 * (var(--rate-sp)));
  bottom: 0;
  left: 0;
  right: 0;
}

.lp_contents .navigation_list.nav02 li:after {
  width: calc(2 * (var(--rate-sp)));
  height: 100%;
  top: 0;
  bottom: 0;
  right: 0;
}

.lp_contents .navigation_list.nav02 li:nth-of-type(5):before,
.lp_contents .navigation_list.nav02 li:nth-of-type(6):before{
  width: 0;
}

.lp_contents .navigation_list.nav02 li:nth-of-type(2):after,
.lp_contents .navigation_list.nav02 li:nth-of-type(4):after,
.lp_contents .navigation_list.nav02 li:nth-of-type(6):after {
  width: 0;
}

.lp_contents .navigation_list.nav02 li:nth-of-type(5) {
  width: 50%;
}

.lp_contents .navigation_list.nav02 li:last-of-type {
  width: 50%;
}

.lp_contents .navigation_list.nav02 li:last-of-type a {
  margin-top: calc(0 * (var(--rate-sp)));
  margin-left: calc(2 * (var(--rate-sp)));
}

.lp_contents .navigation_list.nav02 li img {
  width: calc(110*(var(--rate-sp)));
  margin: 0;
}

.lp_contents .navigation_list.nav02 a {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: calc(0 * (var(--rate-sp)));
  width: 100%;
  margin-left: calc(9 * (var(--rate-sp)));
}

.lp_contents .navigation_list.nav02 .navigation_name_group {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-top: calc(0*(var(--rate-sp)));
}

.lp_contents .navigation_list.nav02 li:first-of-type .navigation_name_group {
  margin-left: calc(39 * (var(--rate-sp)));
}

.lp_contents .navigation_list.nav02 li:nth-of-type(2) .navigation_name_group {
  margin-left: calc(9 * (var(--rate-sp)));
}

.lp_contents .navigation_list.nav02 li:nth-of-type(3) .navigation_name_group {
  margin-left: calc(33 * (var(--rate-sp)));
}

.lp_contents .navigation_list.nav02 li:nth-of-type(4) .navigation_name_group {
  margin-left: calc(24 * (var(--rate-sp)));
}

.lp_contents .navigation_list.nav02 li:nth-of-type(5) .navigation_name_group {
  margin-left: calc(41 * (var(--rate-sp)));
}

.lp_contents .navigation_list.nav02 li:nth-of-type(6) .navigation_name_group {
  margin-left: calc(79 * (var(--rate-sp)));
  margin-top: calc(39 * (var(--rate-sp)));
  flex-direction: row;
  gap: calc(15 * (var(--rate-sp)));
}

.lp_contents .navigation_list.nav02 .name_lower {
  gap: calc(14*(var(--rate-sp)));
  margin-left: calc(0*(var(--rate-sp)));
}

.lp_contents .navigation_list.nav02 .navigation_arrow {
  display: block;
  margin-top: calc(-3 * (var(--rate-sp)));
  width: calc(15*(var(--rate-sp)));
  height: calc(15*(var(--rate-sp)));
  background: url(../img/icon_nav_arrow.svg) no-repeat;
  background-size: 100%;
  content: "";
}

/* ============================================================================
      SECTION：COMMON
============================================================================ */
.lp_contents .visual_slider img {
  width: calc(750 * (var(--rate-sp)));  
}

/* visual_slider の dots */
.lp_contents .visual_slider .slick-dots {
  display: flex !important;
  justify-content: center;
  gap: calc(0 * (var(--rate-sp)));
  bottom: calc(20 * (var(--rate-sp)));
  width: fit-content;
  right: calc(15 * (var(--rate-sp)));
}

.lp_contents .slick-dotted.slick-slider {
  margin-bottom: 0 !important;
}

.lp_contents .visual_slider .slick-dots li {
  width: calc(60 * (var(--rate-sp)));
  height: calc(6 * (var(--rate-sp)));
  background: rgba(255,255,255,0.3);
  position: relative;
  overflow: hidden;
  margin: 0 calc(3.5 * (var(--rate-sp)));
}

.lp_contents .visual_slider .slick-dots li button {
  display: none;
}

.lp_contents .visual_slider .slick-dots li .progress {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 0;
  background: var(--color-white)
}


.lp_contents .sec_title {
  display: block;
  margin: 0 auto;
  padding: 0 calc(5 * (var(--rate-sp)));
  white-space: nowrap;
  overflow: hidden;
  font-size: calc(70 * (var(--rate-sp)));
  color: var(--color-white);
  font-family: "ocr-b-std", monospace; 
  text-transform: uppercase;
  background-color: var(--color-red);
  line-height: 1;
  letter-spacing: -0.16em;
}


.lp_contents .sec_title_group {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.lp_contents .item_blk {
  margin-top: calc(80 * (var(--rate-sp)));
}

.lp_contents .item_img_blk {
  position: relative;
}

.lp_contents .modal_plus {
  position: absolute;
  display: block;
  bottom:calc(10 * (var(--rate-sp)));
  right: calc(40 * (var(--rate-sp)));
  width: calc(35 * (var(--rate-sp)));
  height: calc(35 * (var(--rate-sp)));
  background: url(../img/icon_zoomin.svg) no-repeat;
  background-size: contain;
  content: "";
}

.lp_contents .item_img {
  width: calc(750 * (var(--rate-sp)));
  margin: calc(80 * (var(--rate-sp))) auto 0;
}

.lp_contents .item_name {
  margin-top: calc(40 * (var(--rate-sp)));
  font-size: calc(30 * (var(--rate-sp)));
  line-height: 1;
}

.lp_contents .item_credit {
  display: flex;
  margin-top: calc(40 * (var(--rate-sp)));
  margin-left: calc(10 * (var(--rate-sp)));
  justify-content: center;
}

.lp_contents .item_label {
  display: block;
  padding: calc(17 * (var(--rate-sp))) calc(7 * (var(--rate-sp))) calc(5 * (var(--rate-sp)));
  margin-right: calc(20 * (var(--rate-sp)));
  height: calc(36 * (var(--rate-sp)));
  font-family: var(--font-english);
  font-size: calc(26 * (var(--rate-sp)));
  line-height: 0;
  letter-spacing: -0.16em;
  color: var(--color-text);
  border: 1px solid #000000;
  text-transform: uppercase;
}

.lp_contents .item_price {
  margin-top: calc(-5 * (var(--rate-sp)));
  font-size: calc(26 * (var(--rate-sp)));
}

.lp_contents .item_var_name {
  margin-top: calc(23 * (var(--rate-sp)));
  font-family: var(--font-english);
  font-size: calc(26 * (var(--rate-sp)));
  letter-spacing: -0.16em;
}

.lp_contents .item_text {
  margin-top: calc(75 * (var(--rate-sp)));
  font-size: calc(30 * (var(--rate-sp)));
  line-height: calc(45/30);
}

.lp_contents .sec_blush .item_text {
  margin-top: calc(60 * (var(--rate-sp)));
}

.lp_contents .sec_lip .item_text {
  margin-top: calc(65 * (var(--rate-sp)));
}

.lp_contents .sec_lipdrop .item_text {
  margin-top: calc(60 * (var(--rate-sp)));
}

.lp_contents .item_var_list {
  display: flex;
  flex-wrap: wrap;
  gap: calc(40 * (var(--rate-sp)));
  justify-content: center;
  margin-top: calc(80 * (var(--rate-sp)));
}

.lp_contents .sec_lip .item_var_list {
  margin-top: calc(70 * (var(--rate-sp)));
}

.lp_contents .item_var_img {
  width: calc(315 * (var(--rate-sp)));
  margin: 0 auto;
}

.lp_contents .item_var_text {
  margin: calc(30 * (var(--rate-sp))) auto 0;
  width: calc(315 * (var(--rate-sp)));
  font-size: calc(20 * (var(--rate-sp)));
  line-height: calc(30/20);
  text-align: justify;
}

.lp_contents .btn_more a {
  position: relative;
  margin-top: calc(65 * (var(--rate-sp)));
  font-size: calc(30 * (var(--rate-sp)));
}

.lp_contents .btn_more a span {
  margin-left: calc(-40 * (var(--rate-sp)));
}

.lp_contents .btn_more a:before {
  position: absolute;
  top: 50%;
  margin-top: calc(3 * (var(--rate-sp)));
  transform: translateY(-50%) rotate(274deg);
  right: calc(-46 * (var(--rate-sp)));
  display: block;
  width: calc(25 * (var(--rate-sp)));
  height: calc(25 * (var(--rate-sp)));
  background: url(../img/icon_nav_arrow.svg) no-repeat;
  background-size: contain;
  content: "";
}

/* ============================================================================
      SECTION：Eyes
============================================================================ */
.lp_contents .sec_eyes .item_var_name {
  margin-top: calc(30 * (var(--rate-sp)));
  font-size: calc(26 * (var(--rate-sp)));
  line-height: calc(26 / 30);
}

.lp_contents .sec_eyes .color_list {
  display: flex;
  flex-wrap: wrap;
  width: calc(670 * (var(--rate-sp)));
  margin: 0 auto;
  gap: calc(55 * (var(--rate-sp))) calc(40 * (var(--rate-sp)));
  padding: calc(75 * (var(--rate-sp))) calc(0 * (var(--rate-sp))) calc(145 * (var(--rate-sp)));
  justify-content: space-between;
}

.lp_contents .sec_eyes .color_list li:first-of-type{
width: calc(315 * (var(--rate-sp)));
}

.lp_contents .sec_eyes .color_list .color_list_item:first-of-type img {
  width: calc(194 * (var(--rate-sp)));
  margin: 0 auto;
}

.lp_contents .sec_eyes .color_info_blk {
  display: flex;
  align-items: center;
  gap: calc(15 * 60rem / 750);
}

.lp_contents .sec_eyes .color_list_item img {
  width: calc(70 * (var(--rate-sp)));
}

.lp_contents .sec_eyes .color_alphabet {
  font-family: var(--font-english);
  font-size: calc(26 * (var(--rate-sp)));
  line-height: 1;
  letter-spacing: -0.16em;
}

.lp_contents .sec_eyes .color_type {
  font-size: calc(26 * (var(--rate-sp)));
  line-height: 1;
  margin-left: calc(-14 * (var(--rate-sp)));
  margin-top: calc(-4 * (var(--rate-sp)));
}

.lp_contents .sec_eyes .color_text {
  margin-top: calc(35 * (var(--rate-sp)));
  width: calc(315 * (var(--rate-sp)));
  font-size: calc(20 * (var(--rate-sp)));
  line-height: calc(30/20);
  text-align: justify;
}
/* ============================================================================
      SECTION：Liner
============================================================================ */

/* ============================================================================
            MAKEUP
============================================================================ */
.lp_contents .mkup_visual_blk {
  position: relative;
}

.lp_contents .mkup_blk {
  margin-top: calc(80 * (var(--rate-sp)));
}

.lp_contents .mkup_blk:not(:first-of-type) {
  margin-top: calc(160 * (var(--rate-sp)));
}

.lp_contents .sec_mkup_num {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 5;
}

.lp_contents .sec_mkup_num span{
  padding: calc(15 * (var(--rate-sp))) calc(2 * (var(--rate-sp))) calc(10 * (var(--rate-sp))) calc(3 * (var(--rate-sp)));
  font-family: var(--font-english);
  font-size: calc(70 * (var(--rate-sp))) ;
  color: var(--color-white);
  background-color: var(--color-red);
  letter-spacing: -0.16em;
}

.lp_contents .mkup02 .sec_mkup_num span{
  padding: calc(15 * (var(--rate-sp))) calc(10 * (var(--rate-sp))) calc(10 * (var(--rate-sp))) calc(3 * (var(--rate-sp)));
}

.lp_contents .mkup_slider {
  position: relative;
}

.lp_contents .thumbnail {
  cursor: pointer;
  margin-top: calc(40 * (var(--rate-sp)));
}

.lp_contents .thumbnail .slick-track {
  width: calc(750 * (var(--rate-sp))) !important;
  transform: unset !important;
  display: flex;
  justify-content: center;
  gap: calc(20 * (var(--rate-sp)));
}

.lp_contents .thumbnail li {
  width: calc(130 * (var(--rate-sp))) !important;
}

.lp_contents .thumbnail .slick-current{
  outline: calc(4 * (var(--rate-sp))) solid #de465b;
  /* borderを消す（もし他で指定があれば） */
  border: none;
  /* アウトラインの位置を調整（画像の内側に少し入れたい場合はマイナスの値を指定） */
  outline-offset: calc(-4 * (var(--rate-sp)));
}


.lp_contents .mkup_slider .slider img {
  width: calc(750 * (var(--rate-sp)));
}

.lp_contents .sec_mkup .accordion_inner {
  padding: 0 calc(35 * (var(--rate-sp))) calc(150 * (var(--rate-sp))) calc(40 * (var(--rate-sp)));
}

.lp_contents .mkup_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: calc(40 * (var(--rate-sp)));
  margin: calc(80 * (var(--rate-sp))) auto 0;
  min-width: calc(670 * (var(--rate-sp)));
}

.lp_contents .mkup_list li a {
  display: flex;
  align-items: center;
  gap: calc(20 * (var(--rate-sp)));
}

.lp_contents .mkup_item {
  display: flex;
  align-items: center;
  gap: calc(20 * (var(--rate-sp)));
}

.lp_contents .mkup_item_img {
  width: calc(140 * (var(--rate-sp)));
  margin: 0 auto;
}

.lp_contents .mkup_item_name {
  width: calc(155 * (var(--rate-sp)));
  font-size: calc(20 * (var(--rate-sp)));
  line-height: calc(30/20);
  text-align: left;
}

.lp_contents .mkup_step {
  width: calc(630 * (var(--rate-sp)));
  margin: calc(80 * (var(--rate-sp))) 0 0 calc(2 * (var(--rate-sp)));
}

.lp_contents .mkup_step li {
  margin-top: calc(13 * (var(--rate-sp)));
  font-size: calc(26 * (var(--rate-sp)));
  line-height: 1;
  text-align: justify;
}

.lp_contents .mkup_step li:first-of-type {
  margin-top: calc(0 * (var(--rate-sp)));
}

.lp_contents .plus_blk {
  position: relative;
  margin-top: calc(108 * (var(--rate-sp)));
  padding: calc(58 * (var(--rate-sp))) 0 calc(28 * (var(--rate-sp))) 0; 
  background-color: var(--color-gray01);
}

.lp_contents .plus_title {
  position: absolute;
  top: calc(-30 * (var(--rate-sp)));
  left: calc(40 * (var(--rate-sp)));
  padding: calc(1 * (var(--rate-sp))) calc(7 * (var(--rate-sp))) 0 0;
  font-size: calc(50 * (var(--rate-sp)));
  line-height: 1;
  font-family: var(--font-english);
  text-transform: uppercase;
  border: var(--color-red) solid calc(4 * (var(--rate-sp)));
  color: var(--color-red);
  letter-spacing: -0.16em;
}

.lp_contents .plus_inner_blk {
  display: flex;
  justify-content: center;
  gap: calc(70 * (var(--rate-sp)));
}

.lp_contents .mkup_blk:nth-of-type(even) .plus_inner_blk {
  flex-direction: row-reverse;
  justify-content: flex-end;
  margin-left: calc(40 * (var(--rate-sp)));
  gap: calc(40 * (var(--rate-sp)));
}

.lp_contents .mkup_blk:nth-of-type(even) .plus_title {
  left: auto;
  right: calc(40 * (var(--rate-sp)));
}


.lp_contents .plus_inner_left {
  position: relative;
}

.lp_contents .plus_text {
  font-family: var(--font-english);
  font-size: calc(30 * (var(--rate-sp)));
  line-height: calc(45 / 30);
  text-align: left;
  letter-spacing: -0.16em;
}

.lp_contents .plus_text a {
  font-size: calc(30 * (var(--rate-sp)));
  text-transform: uppercase;
}

.lp_contents .plus_img_blk {
  width: 100%;
  margin-top: calc(72 * (var(--rate-sp)));
  display: flex;
}

.lp_contents .plus_item_img {
  position: absolute;
  right: calc(-70 * (var(--rate-sp)));
  bottom: calc(-10 * (var(--rate-sp)));
  width: calc(220 * (var(--rate-sp)));
}

.lp_contents .plus_img {
  width: calc(330 * (var(--rate-sp)));
  margin-top: calc(10 * (var(--rate-sp)));
}


/* ============================================================================
      NOVELTY
============================================================================ */
.lp_contents .sec_novelty {
  padding: calc(160 * (var(--rate-sp))) calc(40 * (var(--rate-sp))) calc(160 * (var(--rate-sp)));
}

.lp_contents .sec_novelty_inner {
  position: relative;
  padding: calc(80*(var(--rate-sp))) 0 calc(70*(var(--rate-sp))) 0;
  border: var(--color-red) solid calc(4*(var(--rate-sp)));
}

.lp_contents .sec_novelty .sec_title {
  position: absolute;
  top: calc(-30 * (var(--rate-sp)));
  left: 50%;
  transform: translateX(-50%);
  padding: calc(3 * (var(--rate-sp))) calc(5 * (var(--rate-sp)));
  font-size: calc(50 * (var(--rate-sp)));
  background-color: var(--color-red);
  color: var(--color-white);
}

.lp_contents .novelty_img {
  width: calc(450*(var(--rate-sp)));
  margin: 0 auto;
}

.lp_contents .novelty_subtitle {
  margin-top: calc(25 * (var(--rate-sp)));
  font-size: calc(30 * (var(--rate-sp)));
  line-height: calc(45 / 30);
  color: var(--color-red);
  font-weight: 500;
}

.lp_contents .novelty_info {
  margin-top: calc(27 * (var(--rate-sp)));
  font-size: calc(30*(var(--rate-sp)));
}

.lp_contents .note {
  margin-top: calc(24*(var(--rate-sp)));
  font-size: calc(20*(var(--rate-sp)));
  line-height: calc(30/20);
  color: var(--color-gray02);
}

/* ============================================================================
      RELEASE DAY
============================================================================ */
.lp_contents .sec_releaseday .sec_title {
  font-size: calc(50 * (var(--rate-sp)));
  padding: calc(4 * (var(--rate-sp))) calc(5 * (var(--rate-sp)));
}

.lp_contents table {
  margin: calc(75 * (var(--rate-sp))) auto 0;
  width: calc(670 * (var(--rate-sp)));
}

.lp_contents table tbody {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: calc(10 * (var(--rate-sp)));
  width: 100%;
}

.lp_contents table tr {
  width: 100%;
  display: flex;
  align-items: center;
  gap: calc(10 * (var(--rate-sp)));
}

.lp_contents table th {
  width: 50%;
  padding: calc(40*(var(--rate-sp))) 0;
  font-size: calc(30*(var(--rate-sp)));
  line-height: 1;
  background-color: var(--color-white);
  font-weight: 400;
  text-align: center;
}

.lp_contents table td {
  width: 50%;
  padding: calc(40*(var(--rate-sp))) 0;
  font-size: calc(30*(var(--rate-sp)));
  line-height: 1;
  background-color: var(--color-white);
  color: var(--color-red);
  text-align: center;
}

.lp_contents .sec_releaseday .note {
  margin-top: calc(30*(var(--rate-sp)));
}

.lp_contents .sec_releaseday .note a {
  text-decoration: underline;
}

.lp_contents .btn_all {
  padding: calc(160*(var(--rate-sp))) 0;
}

.lp_contents .btn_all a {
  position: relative;
}

.lp_contents .btn_all a span {
  margin-left: calc(-50 * (var(--rate-sp)));
  font-family: var(--font-english);
  font-size: calc(30*(var(--rate-sp)));
  line-height: 1;
  letter-spacing: -0.16em;
  color: var(--color-red);
  text-transform: uppercase;
}

.lp_contents .btn_all a:before {
  position: absolute;
  top: 0;
  right: calc(-52 * (var(--rate-sp)));
  width: calc(25 * (var(--rate-sp)));
  height: calc(30 * (var(--rate-sp)));
  transform: rotate(270deg);
  mask-image: url(../img/icon_nav_arrow.svg);
  mask-repeat: no-repeat;
  mask-position: 50% 50%;
  mask-size: 100%;
  -webkit-mask-image: url(../img/icon_nav_arrow.svg);
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: 50% 50%;
  -webkit-mask-size: 100%;
  background: var(--color-red);
  content: "";
}
/* ============================================================================
      CONCEPT
============================================================================ */
.lp_contents .concept_area {
  padding-bottom: calc(30*(var(--rate-sp)));
}

.lp_contents .concept_img {
  width: 100%;
  margin: 0 auto;
}

.lp_contents .concept_title {
  display: block;
  margin: calc(55*(var(--rate-sp))) auto 0;
  font-family: var(--font-english);
  font-size: calc(50*(var(--rate-sp)));
  line-height: calc(50/30);
  letter-spacing: -0.16em;
  white-space: nowrap;
  overflow: hidden;
}

.lp_contents .concept_text {
  margin-top: calc(60*(var(--rate-sp)));
  font-family: "ocr-b-std", "Noto Sans JP", sans-serif;
  font-size: calc(26*(var(--rate-sp)));
  line-height: calc(39/26);
}

.lp_contents .concept_text span {
  display: inline-block;
  font-family: var(--font-english);
  font-size: calc(26 * (var(--rate-sp)));
  letter-spacing: -0.16em;
}

.lp_contents .concept_logo {
  width: calc(668*(var(--rate-sp)));
  margin: calc(152*(var(--rate-sp))) auto 0;
}


/* ============================================================================
        MODAL
============================================================================ */

/* Modal共通 */
.lp_contents .modal{
  display: none;
  visibility: visible;
  height: 100dvh;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  z-index: 105;
}

.lp_contents .modal__bg{
  background: rgb(230, 230, 230,0.5);
  height: 100dvh;
  position: absolute;
  width: 100%;
}

.lp_contents .modal__content{
  background: var(--color-white);
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%,-50%);
  width: calc(750*(var(--rate-sp)));
  /* max-height:100vh; */
  /* overflow-y: scroll; */
  /* overflow: hidden; */
}

.lp_contents .js-modal-close{
  position: absolute;
  width: calc(60 * (var(--rate-sp)));
  height: calc(60 * (var(--rate-sp)));
  top: calc(40 * (var(--rate-sp)));
  right: calc(40 * (var(--rate-sp)));
  float: right;
  cursor: pointer;
  overflow: hidden;
  z-index: 999;
}

.lp_contents .js-modal-close:before,
.lp_contents .js-modal-close:after{
  content: '';
  display: block;
  width: calc(80 * (var(--rate-sp)));
  height: calc(2 * (var(--rate-sp)));
  transform: rotate(45deg);
  background-color: var(--color-text);
  position: absolute;
  top: 50%;
  right: calc(-10 * (var(--rate-sp)));
}

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

.lp_contents .modal_inner{
  display: flex;
  align-items: center;
  /* padding:calc(60*(var(--rate-sp))) 0 calc(120*(var(--rate-sp))); */
  overflow-y: scroll;
  height: 100dvh;
  scrollbar-width: none;
  overscroll-behavior: contain;
} 
.lp_contents .modal_inner::-webkit-scrollbar {
  display: none;
}

@media screen and  (min-width:768px) {
  .lp_contents .modal_inner{
    height: 75vh;
  }
}

.lp_contents .modal_zoom_area {
  position: relative;
  margin: 0 auto;
  width: calc(750 * (var(--rate-sp)));
  overflow: hidden;
}

.lp_contents .modal_zoom_area img {
  margin: 0 auto;
  width: calc(750 * (var(--rate-sp)));
}

.lp_contents .zoom-btn {
  position: absolute;
  bottom: calc(50 * (var(--rate-sp)));
  right: calc(40 * (var(--rate-sp)));
  width: calc(35 * (var(--rate-sp)));
  height: calc(35 * (var(--rate-sp)));
  border: none;
  background-color: transparent;
  background-image: url('../img/icon_zoomin.svg');
  background-size: contain;
  background-repeat: no-repeat;
  cursor: pointer;
  z-index: 100;
}

.lp_contents .zoom-btn.change {
  background-image: url('../img/icon_zoomout.svg');
}
/* ============================================================================
      PC SETTING
============================================================================ */
@media screen and  (min-width:768px) {
  .pc_only {
    display: block;
  }

  .sp_only {
    display: none;
  }

.lp_contents:after,
.lp_contents:before {
  content: "";
  position: fixed;
  pointer-events: none;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100vh;
}


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

  .lp_contents .grid_area .full_area {
    position: -webkit-sticky;
    position: sticky;
    display: grid;
    pointer-events: all;
    height: 100vh;
  }

  .lp_contents .left_area {
    top: 0;
    grid-column: 1;
    -webkit-clip-path: border-box;
    clip-path: border-box;
    align-items: center;
    place-items: flex-start;
  }

  .lp_contents .left_area a .logo01 {
    position: absolute;
    right: 0;
    top: 0;
    width: 2.5rem;
    margin-right: 1rem;
    margin-top: 2.3rem;
  }

  .lp_contents .left_area a .logo02 {
    position: absolute;
    left: 0;
    top: 0;
    width: 28.2rem;
    margin-left: 2.3rem;
    margin-top: 2.3rem;
  }

  .lp_contents .lp_inner {
    grid-column: 2;
    width: 49rem;
    position: relative;
    z-index: 1;
    margin: 0 auto;
    overflow: clip;
    background-color: var(--color-white);
  }

  .lp_contents .right_area {
    top: 0;
    grid-column: 3;
    -webkit-clip-path: border-box;
    clip-path: border-box;
    place-items: flex-end;
  }

  .lp_contents .right_inner {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100vw;
    height: 100vh;
  }

  .lp_contents .navigation_list.nav03 {
    position: absolute;
    bottom: 2rem;
    right: 0;
    padding: 0;
    transform: translate(100%, 0);
    transition: transform 0.5s;
  }

  .lp_contents .navigation_list.nav03.show {
    transform: translate(0, 0) !important;
  }
  
  .lp_contents .navigation_list.nav03 ul {

    position: relative;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: space-between;
    gap: 0;
  }
  
  .lp_contents .navigation_list.nav03 li {
    position: relative;
    width: 27.2rem;
    padding: 1rem 1rem 1rem 0;
    border-bottom: var(--color-text) solid 0.1rem;
  }

    
  .lp_contents .navigation_list.nav03 li:last-of-type {
    border-bottom: none;
  }
  
  .lp_contents .navigation_list.nav03 li:nth-of-type(5) {
    width: 100%;
  }
  
  .lp_contents .navigation_list.nav03 li:last-of-type {
    width: 100%;
  }
  
  .lp_contents .navigation_list.nav03 li:last-of-type a {
    margin-top: 0rem;
    margin-left: 0rem;
    justify-content: flex-end;
    padding-top: 2rem;
  }
  
  .lp_contents .navigation_list.nav03 li img {
    width: 5.8rem;
    margin: 0;
  }
  
  .lp_contents .navigation_list.nav03 a {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
  }

  .lp_contents .navigation_list.nav03 a span {
    font-family: var(--font-english);
    letter-spacing: -0.16em;
  }
  
  .lp_contents .navigation_list.nav03 .navigation_name_group {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-top: 0;
  }
  
  .lp_contents .navigation_list.nav03 .navigation_name {
    font-size: 1.5rem;
    line-height: calc(19.17 / 15);
    text-align: center;
    display: flex;
    align-items: center;
    gap: 1.5rem;
}
  
  .lp_contents .navigation_list.nav03 .navigation_arrow {
    display: block;
    margin-top: 0rem;
    width: 1rem;
    height: 1rem;
    background: url(../img/icon_nav_arrow.svg) no-repeat;
    background-size: 100%;
    content: "";
  }

}

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

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


/* ============================================================================
      ANIMATION
============================================================================ */
.js-fade.ef1 {
  opacity: 0.4;
  filter: blur(10px);
  will-change: opacity, filter;
}

.js-fade.ef1.active {
  animation: fade-blur .8s ease-out forwards;
}

@keyframes fade-blur {
  0% {
    opacity: 0.4;
    filter: blur(10px);
  }
  40% {
    opacity: 0.8;
    filter: blur(2px);
  }
  100% {
    opacity: 1;
    filter: blur(0);
  }
}

.js-fade.ef2 {
  width: 0;
}

.js-fade.ef2.active {
  animation: typing 1.5s steps(var(--chars)) forwards;
}

@keyframes typing {
  from { 
    width: 0; 
  }
  to { 
    /* 1ch（1文字分）× 文字数で計算 */
    width: calc(var(--chars) * 0.6em); 
    border-color: transparent; 
  }
}