﻿@charset "UTF-8";

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

CSS Snidel Beauty Kakao

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

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

html {
  font-size: calc(10 * (100vw/468));
  overflow-y: scroll;
}

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

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

}

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

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

@media screen and (max-width: 768px) {
  #share.move:not(.hidden) {
    translate: 0 calc(-190 * (var(--rate)));
  }
}

.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;
}

main {
  width: 100%;
  max-width: none;
}

.archive_area {
  position: relative;
}

/* ========================================================
                      * root *
========================================================= */
:root {
  --rate: 46.8rem/780;
  --color_white: #fff;
  --color_black: #000000;
  --color_text: #646464;
  --color_bg01:#f8e7e7;
  --color_bg02: #fbf0d1;
  --color_bg03:#f3eaf3;
  --color_pink:#ed7c9b;
  --color_yellow:#f7af0f;
  --color_purple:#c27db6;
  --font_ja: 'Lato', 'ryo-gothic-plusn', sans-serif;
  --font_en: "ivyora-display", serif;
  ; 
}

#Wrap {
  width: 100%;
}

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

#lp_contents * {
  box-sizing: border-box;
  font-feature-settings: "palt";
  line-height: 2;
  letter-spacing: 0.1em;
  text-align: center;
}

#lp_contents {
  width: 100%;
  max-width: 46.8rem;
  height: 100%;
  font-family: var(--font_ja);
  font-weight: 500;
  overflow-x: clip;
  color: var(--color_text);
  line-height: 2;
  background-color: var(--color_bg03);
}

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

#lp_contents .pcOnly {
  display: block;
}

#lp_contents .spOnly {
  display: none;
}

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

#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_inner {
  position: relative;
  z-index: 1;
  overflow: clip;
  background-color: var(--color_bg01);
  padding-bottom: calc(150 * (var(--rate)));
}

/* ========================================================
                      * PC *
========================================================= */
@media screen and (min-width: 768px){

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

  #lp_contents .grid_area .full_area {
    position: -webkit-sticky;
    position: sticky;
    display: grid;
    place-items: center;
    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;
  }

  #lp_contents .left_area a {
    width: 23.8rem;
    margin: 0 auto;
  }

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

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

  #lp_contents .right_area .menu_list {
    margin-top: 0rem;
    gap: 1rem;
  }

  #lp_contents .right_area .menu_list li {
    width: 9rem;
  }
  
  #lp_contents .right_area .menu_list li:nth-of-type(2) {
    width: 10.6rem;
  }
  
  #lp_contents .right_area .menu_list li .nav_name {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 3.2rem;
    margin-top:1.6rem;
    font-family: var(--font_en);
    font-size:1.4rem;
    font-weight: 700;
    line-height: calc(16.8/14);
    letter-spacing: 0.02em;
  }
  
  #lp_contents .right_area .menu_list li .nav_arrow {
    display: block;
    width: 2.5rem;
    height: 2.5rem;
    margin: 1.5rem auto 0;
  }

  #lp_contents .right_area .btn_checkall_pc {
    width: 23rem;
    height: 5.76rem;
    background-size: 100%;
  }
  
  #lp_contents .right_area .btn_checkall_pc a {
    padding: 0.5rem 0;
    font-family: var(--font_en);
    font-size: 2.2rem;
    font-weight: 700;
    letter-spacing: 0.025em;
    color: var(--color_white);
  }
}


/* ========================================================
                      * 共通設定  *
========================================================= */
#lp_contents h2 {
  line-height: 1;
}

#lp_contents .dashed span {
  position: relative;
  display: block;
  width: 100%;
}

#lp_contents .dashed br {
  line-height: 0;
}

#lp_contents .dashed span:before {
  width: 100%;
  height: calc(2 * (var(--rate)));
  left: 50%;
  transform: translateX(-50%);
  bottom: calc(-5 * (var(--rate)));
  background-size: calc(8 * var(--rate)) calc(2 * var(--rate));
  content: "";
  display: block;
  position: absolute;
}

#lp_contents .item_txt.dashed span,
#lp_contents .item_price.dashed span {
  width: fit-content;
  margin: 0 auto;
}

#lp_contents .dashed.pink span:before {
  background-image: linear-gradient(to right, var(--color_pink) 50%, transparent 50%);
  background-size: calc(8 * var(--rate)) calc(2 * var(--rate));
}

#lp_contents .dashed.yellow span:before {
  background-image: linear-gradient(to right, var(--color_yellow) 50%, transparent 50%);
  background-size: calc(8 * var(--rate)) calc(2 * var(--rate));
}

#lp_contents .dashed.purple span:before {
  background-image: linear-gradient(to right, var(--color_purple) 50%, transparent 50%);
  background-size: calc(8 * var(--rate)) calc(2 * var(--rate));
}

#lp_contents .sec {
  padding: calc(120 * (var(--rate))) 0 0 0;
}

#lp_contents .visual_blk {
  position: relative;
  z-index: 10;
}

#lp_contents .visual_blk:before {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  display: block;
  width: calc(780 * (var(--rate)));
  height: calc(600 * (var(--rate)));
  background: url(../img/yellow_gradation.png) no-repeat;
  background-size: 100%;
  content: "";
  z-index: 0;
}

#lp_contents .sec_title {
  position: relative;
  font-family: var(--font_en);
  font-weight: 400;
  font-size: calc(110 * (var(--rate)));
  text-align: center;
  letter-spacing: -0.02em;
  line-height: 1;
  z-index: 5;
}

#lp_contents .sec_title br {
  line-height: 1;
}

#lp_contents .sec_visual {
  position: absolute;
  top: calc(150 * (var(--rate)));
  left: 50%;
  transform: translateX(-50%);
  width: calc(780 * (var(--rate)));
  z-index: 0;
}

#lp_contents .sec_cloudbg {
  position: absolute;
  bottom: calc(-235 * (var(--rate)));
  left: 50%;
  transform: translateX(-50%);
  width: calc(780 * (var(--rate)));
  z-index: 0;
}

#lp_contents .sec_visual_text {
  position: relative;
  margin-top: calc(1110 * (var(--rate)));
  font-size: calc(32 * (var(--rate)));
  text-align: center;
  letter-spacing: 0.1em;
  line-height: calc(70.4/32);
  z-index: 2;
}

#lp_contents .item01 {
  margin-top: calc(130 * (var(--rate)));
}

#lp_contents .item02 {
  margin-top: calc(200 * (var(--rate)));
}

#lp_contents .item_img_blk {
  position: relative;  
}

#lp_contents .item_img_blk img {
  width: calc(660 * (var(--rate)));
  margin: 0 auto;
}

#lp_contents .item_img_decor {
  position: absolute;
  width: calc(228 * (var(--rate)));
  top: calc(53 * (var(--rate)));
}

#lp_contents .item01 .item_img_decor {
  left: calc(60 * (var(--rate)));
}

#lp_contents .item02 .item_img_decor {
  left: auto;
  right: calc(63 * (var(--rate)));
}

#lp_contents .btn_modal {
  position: absolute;
  width: calc(100 * (var(--rate)));
  height: calc(100 * (var(--rate)));
}

#lp_contents .item_name {
  width: fit-content;
  margin: calc(78 * (var(--rate))) auto 0;
  padding: calc(17 * (var(--rate))) 0 calc(18 * (var(--rate)));
  font-family: var(--font_en);
  font-size: calc(30 * (var(--rate)));
  text-align: center;
  letter-spacing: 0.05em;
  line-height: 1;
}

#lp_contents .item_txt {
  font-size: calc(32 * (var(--rate)));
  text-align: center;
  letter-spacing: 0.125em;
  line-height: 0.5;
  margin-top: calc(45 * (var(--rate)));
}

#lp_contents .item_price {
  margin-top: calc(45 * (var(--rate)));
  font-size: calc(33.6 * (var(--rate)));
  color: var(--color_text);
  text-align: center;
  letter-spacing: 0.1em;
  text-decoration-color: var(--color_text);
}

#lp_contents .btn_detail {
  position: relative;
  margin: calc(78 * (var(--rate))) auto 0;
  width: calc(480 * (var(--rate)));
  height: calc(120 * (var(--rate)));
  color: var(--color_white);
  z-index: 5;
}

#lp_contents .btn_detail a {
  padding: calc(31 * (var(--rate))) 0 calc(31 * (var(--rate)));
  font-family: var(--font_en);
  font-size: calc(48.4 * (var(--rate)));
  font-weight: 700;
  color: var(--color_white);
  letter-spacing: 0.025em;
  line-height: 1;
}

/* About Charm */
#lp_contents .about_charm_blk {
  position: relative;
  margin: calc(200 * (var(--rate))) auto 0;
  width: calc(740 * (var(--rate)));
  padding: calc(70 * (var(--rate))) 0 calc(60 * (var(--rate)));
}

_::-webkit-full-page-media, _:future, :root #lp_contents .about_charm_blk {
  padding: calc(70 * (var(--rate))) 0 calc(61 * (var(--rate)));
}

#lp_contents .charm_slider {
  margin: calc(40 * (var(--rate))) auto 0;
  width: calc(480 * (var(--rate)));
}

#lp_contents .charm_slider_img {
  margin: 0 auto;
  width: calc(480 * (var(--rate)));
}


#lp_contents .charm_slider_img {
  will-change: transform;
  backface-visibility: hidden;
  animation: charm-rotate 6s cubic-bezier(0.45, 0, 0.55, 1) infinite;
}
#lp_contents .sec_rouge_couture .charm_slider_img {
  transform-origin: calc(50% + (60 * var(--rate))) 0px;
}
#lp_contents .sec_lip_glaze .charm_slider_img {
  transform-origin: calc(50% + (120 * var(--rate))) 0px;
}
@keyframes charm-rotate {
  0% {
    transform: rotate(1deg);
  }
  25% {
    transform: rotate(-1.2deg);
  }
  50% {
    transform: rotate(1.1deg);
  }
  75% {
    transform: rotate(-1.2deg);
  }
  100% {
    transform: rotate(1deg);
  }
}
@keyframes charm-rotate {
  0% {
    transform: rotate(1deg);
  }
  25% {
    transform: rotate(-1.2deg);
  }
  50% {
    transform: rotate(1.1deg);
  }
  75% {
    transform: rotate(-1.2deg);
  }
  100% {
    transform: rotate(1deg);
  }
}

@-webkit-keyframes charm-rotate {
  0%, 100% { -webkit-transform: rotate(1deg); }
  25%, 75% { -webkit-transform: rotate(-1.2deg); }
  50% { -webkit-transform: rotate(1.1deg); }
}

#lp_contents .about_charm_title {
  width: calc(397 * (var(--rate)));
  margin: 0 auto;
}

#lp_contents .charm_slider_name {
  margin-top: calc(47 * (var(--rate)));
  font-size: calc(24 * (var(--rate)));
  letter-spacing: 0.025em;
}

#lp_contents .charm_text {
  display: flex;
  flex-direction: column;
  width: calc(580 * (var(--rate)));
  margin: calc(47 * (var(--rate))) auto 0;
  gap: calc(19 * (var(--rate)));
}

#lp_contents .charm_text span {
  position: relative;
  display: block;
  width: 100%;
  font-size: calc(28 * (var(--rate)));
  letter-spacing: 0.125em;
  line-height: 1;
  padding-bottom: calc(22 * var(--rate));
}


#lp_contents .note {
  margin-top: calc(50 * (var(--rate)));
  font-size: calc(24 * (var(--rate)));
  letter-spacing: 0.125em;
  font-weight: 300;
}

#lp_contents .about_charm_blk .slick-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  margin-top: calc(-47 * (var(--rate)));
  width: calc(24 * (var(--rate)));
  height:calc(62 * (var(--rate)));
}

#lp_contents .about_charm_blk .slick-prev {
  left: calc(-70 * (var(--rate)));
}

#lp_contents .about_charm_blk .slick-next {
  right: calc(-70 * (var(--rate)));
}

#lp_contents .about_charm_blk .slick-arrow::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../img/arrow01.svg) center center / cover no-repeat;
  content: "";
}

#lp_contents .about_charm_blk .slick-prev::before {
  transform: scaleX(-1);
}



/* ========================================================
                      * sec_mv  *
========================================================= */
#lp_contents .sec_mv {
  padding: 0;
}

#lp_contents .sec_mv .mv_blk {
  position: relative;
}

#lp_contents .sec_mv .sec_cloudbg {
  bottom: calc(-315 * (var(--rate)));
}

#lp_contents .mv_title {
  position: absolute;
  top: calc(85 * (var(--rate)));
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
}

#lp_contents .sec_mv .schedule {
  width: calc(413 * (var(--rate)));
  margin: calc(64 * (var(--rate))) auto 0;
  font-size: calc(32 * (var(--rate)));
  letter-spacing: 0.125em;
  color: var(--color_pink);
}

#lp_contents .sec_mv .schedule span {
  line-height: 2.2;
}

#lp_contents .accordion {
  position: relative;
  margin-top: calc(43 * (var(--rate)));
  z-index: 2;
}

#lp_contents .accordion_wrap {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows .8s;
}

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

#lp_contents .accordion_inner {
  position: relative;
  min-height: calc(520 * (var(--rate)));
  overflow: hidden;
}

#lp_contents .accordion_img {
  width: calc(474 * (var(--rate)));
  margin: 0 auto;
}

#lp_contents .accordion_text {
  font-size: calc(26 * (var(--rate)));
  letter-spacing: 0.1em;
  line-height: calc(57.2/26);
}

#lp_contents .accordion_inner .accordion_text {
  margin-top: calc(50 * (var(--rate)));
}

#lp_contents .accordion_inner .accordion_text:first-of-type {
  margin-top: calc(65 * (var(--rate)));
}

#lp_contents .accordion_btn {
  position: relative;
  width: calc(256 * (var(--rate)));
  height: calc(64 * (var(--rate)));
  margin: calc(72 * (var(--rate))) auto 0;
  line-height: 1;
  text-align: center;
  cursor: pointer;
  background: url(../img/open_btn.png) no-repeat;
  background-size: 100%;
  content: "";
}

#lp_contents .open .accordion_btn {
  margin: calc(60 * (var(--rate))) auto 0;
}

#lp_contents .accordion_btn span {
  position: absolute;
  left: 50%;
  top: 0;
  margin-left: calc(10 * (var(--rate)));
  margin-top: calc(-2 * (var(--rate)));
  transform: translateX(-50%);
  font-family: var(--font_en);
  font-size: calc(32 * (var(--rate)));
  letter-spacing: 0.1em;
  color: var(--color_white);
}

#lp_contents .accordion_btn span:before {
  position: absolute;
  top: calc(24 * (var(--rate)));
  left: calc(-43 * (var(--rate)));
  display: block;
  width: calc(21.5 * (var(--rate)));
  height: calc(16 * (var(--rate)));
  background: url(../img/icon_down.svg) no-repeat;
  background-size: 100%;
  animation: pagearrow 2s linear infinite;
  content: "";
}

#lp_contents .accordion_btn span.to_open:before {
  bottom: calc(-15 * (var(--rate)));
}

#lp_contents .open .accordion_btn .to_close:before {
  bottom: calc(55 * (var(--rate)));
  rotate: 180deg;
}

#lp_contents .accordion_btn .to_open,
#lp_contents .open .accordion_btn .to_close {
  display: block;
}

#lp_contents .open .accordion_btn .to_close {
  margin-left: calc(20 * (var(--rate)));
}

#lp_contents .open .accordion_btn .to_close:before {
  width: calc(23.3 * (var(--rate)));
  height: calc(23.3 * (var(--rate)));
  background: url(../img/icon_close.svg) no-repeat;
}

#lp_contents .accordion_btn .to_close,
#lp_contents .open .accordion_btn .to_open {
  display: none;
}

#lp_contents .menu_list {
  display: flex;
  justify-content: center;
  margin-top: calc(120 * (var(--rate)));
}

#lp_contents .menu_list li {
  width: calc(220 * (var(--rate)));
}

#lp_contents .menu_list li:nth-of-type(2) {
  width: calc(260 * (var(--rate)));
}

#lp_contents .menu_list li .nav_name {
  display: flex;
  justify-content: center;
  align-items: center;
  height: calc(75 * (var(--rate)));
  margin-top:calc(35 * (var(--rate)));
  font-family: var(--font_en);
  font-size: calc(34 * (var(--rate)));
  font-weight: 700;
  line-height: calc(36/34);
  letter-spacing: 0.02em;
  color: var(--color_pink);
}

#lp_contents .menu_list li .nav_arrow {
  display: block;
  width: calc(60 * (var(--rate)));
  height: calc(60 * (var(--rate)));
  margin: calc(40 * (var(--rate))) auto 0;
  background: url(../img/nav_arrow.png) no-repeat;
  background-size: 100%;
  content: "";
}

#lp_contents .fixed_nav {
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  /* opacity: 0; */
  translate: 0 100%;
  transition: opacity 0.6s .2s ease, translate 0.6s .2s ease;
}

#lp_contents .fixed_nav.is-visible {
  opacity: 1;
  translate: 0 0;
}

#lp_contents .fixed_nav .menu_list {
  display: flex;
  background-color: var(--color_white);
  margin-top: 0;
}

#lp_contents .fixed_nav .menu_list li {
  position: relative;
  width: calc(100%/3);
  padding-top: calc(20 * (var(--rate)));
}

#lp_contents .fixed_nav .menu_list li:not(:last-of-type):before {
  position: absolute;
  top: 0;
  right: 0;
  display: block;
  width: calc(2 * (var(--rate)));
  height: 100%;
  background-color: #d0d0d0;
  content: "";
}

#lp_contents .fixed_nav .menu_list li:first-of-type .nav_img {
  width: calc(85 * (var(--rate)));
}
#lp_contents .fixed_nav .menu_list li:nth-of-type(2) .nav_img {
  width: calc(104 * (var(--rate)));
}
#lp_contents .fixed_nav .menu_list li:nth-of-type(3) .nav_img {
  width: calc(180 * (var(--rate)));
}

#lp_contents .fixed_nav .menu_list .nav_name {
  margin-top:calc(-8 * (var(--rate)));
  font-family: var(--font_en);
  font-size: calc(24 * (var(--rate)));
  font-weight: 700;
  color: var(--color_pink);
}
/* ========================================================
                * Tailored Color Eye  *
========================================================= */
#lp_contents .sec_color_eye {
  padding-bottom: calc(80 * (var(--rate)));
}

#lp_contents .sec_color_eye .visual_blk:before {
  background: url(../img/yellow_gradation.png) no-repeat;
  background-size: 100%;
  content: "";
}

#lp_contents .sec_color_eye .sec_title {
  color: var(--color_yellow);
}

#lp_contents .sec_color_eye .sec_visual_text{
  color: var(--color_yellow);
}

#lp_contents .sec_color_eye .item01 {
  position: relative;
  z-index: 5;
  background-color: #fcf6df;
}

#lp_contents .sec_color_eye .item01:before {
  position: absolute;
  top: calc(-1090 * (var(--rate)));
  left: 50%;
  transform: translateX(-50%);
  display: block;
  width: calc(780 * (var(--rate)));
  height: calc(2346 * (var(--rate)));
  background: url(../img/bg01.png?260306) no-repeat;
  background-size: 100%;
  content: "";
  z-index: -1;
}

#lp_contents .sec_color_eye .item01 .btn_modal {
  right: calc(60 * (var(--rate)));
  bottom: calc(137 * (var(--rate)));
}

#lp_contents .sec_color_eye .item01 .btn_modal button {
  width: calc(100 * (var(--rate)));
    height: calc(100 * (var(--rate)));
  background: url(../img/plus01.png) no-repeat;
  background-size: 100%;
  border: none;
}

#lp_contents .sec_color_eye .item01 .item_name {
  width: calc(450 * (var(--rate)));
  color: var(--color_yellow);
  border: solid var(--color_yellow) calc(2 * (var(--rate)));
}

#lp_contents .sec_color_eye .item01 .item_price.dashed {
  text-decoration-color: var(--color_yellow);
}

#lp_contents .sec_color_eye .item01 .item_txt {
  color: var(--color_yellow);
}

#lp_contents .sec_color_eye .item01 .btn_detail {
  background: url(../img/item_yellow_btn.png) no-repeat;
  background-size: 100%;
}

#lp_contents .sec_color_eye .item02 {
  position: relative;
  padding-bottom: calc(160 * (var(--rate)));
  background: url(../img/bg02.png?260316) no-repeat;
  background-position: center calc(70 * (var(--rate)));
  background-size: 100%;
  content: "";
  z-index: 0;
}

#lp_contents .sec_color_eye .item02:before {
  position: absolute;
  top: calc(-208 * (var(--rate)));
  left: 50%;
  transform: translateX(-50%);
  display: block;
  width: calc(780 * (var(--rate)));
  height: calc(400 * (var(--rate)));
  background: url(../img/bg01_01.png) no-repeat;
  background-size: 100%;
  content: "";
}

#lp_contents .sec_color_eye .item02 .sec_visual_text{
  color: var(--color_pink);
}

#lp_contents .sec_color_eye .item02 .btn_modal {
  left: calc(60 * (var(--rate)));
  bottom: calc(137 * (var(--rate)));
}

#lp_contents .sec_color_eye .item02 .btn_modal button {
  width: calc(100 * (var(--rate)));
  height: calc(100 * (var(--rate)));
  background: url(../img/plus02.png) no-repeat;
  background-size: 100%;
  border: none;
}
#lp_contents .sec_color_eye .item02 .item_name {
  width: calc(400 * (var(--rate)));
  color: var(--color_pink);
  border: solid var(--color_pink) calc(2 * (var(--rate)));
}

#lp_contents .sec_color_eye .item02 .item_price.dashed {
  text-decoration-color: var(--color_pink);
}

#lp_contents .sec_color_eye .item02 .item_txt {
  color: var(--color_pink);
}

#lp_contents .sec_color_eye .item02 .btn_detail {
  background: url(../img/item_pink_btn.png) no-repeat;
  background-size: 100%;
}
/* ========================================================
                * Rouge Couture  *
========================================================= */
#lp_contents .sec_rouge_couture {
  padding-top: 0;
}

#lp_contents .sec_rouge_couture .visual_blk:before {
  background: url(../img/pink_gradation.png) no-repeat;
  background-size: 100%;
  content: "";
}

#lp_contents .sec_rouge_couture .sec_title {
  color: var(--color_pink);
}

#lp_contents .sec_rouge_couture .sec_visual {
  top: calc(80 * (var(--rate)));
}

#lp_contents .sec_rouge_couture .sec_cloudbg {
    bottom: calc(-68 * (var(--rate)));
  }

_::-webkit-full-page-media, _:future, :root #lp_contents .sec_rouge_couture .sec_cloudbg {
  bottom: calc(-65 * (var(--rate)));
}

#lp_contents .sec_rouge_couture .sec_visual_text{
  margin-top: calc(1180 * (var(--rate)));
  color: var(--color_pink);
}

#lp_contents .sec_rouge_couture .item_img_blk img {
  width: calc(780 * (var(--rate)));
}

#lp_contents .sec_rouge_couture .bg_group {
  position: relative;
  /* padding-bottom: calc(160 * (var(--rate))); */
  background: url(../img/bg03.png?260316) no-repeat;
  background-position: center calc(1100 * (var(--rate)));
  background-size: 100%;
  content: "";
  z-index: 0;
}

#lp_contents .sec_rouge_couture .item_name {
  width: calc(400 * (var(--rate)));
  margin: calc(60 * (var(--rate))) auto 0;
  color: var(--color_pink);
  border: solid var(--color_pink) calc(2 * (var(--rate)));
}

#lp_contents .sec_rouge_couture .item_txt {
  color: var(--color_pink);
}

#lp_contents .sec_rouge_couture .item_price.dashed {
  text-decoration-color: var(--color_pink);
}

#lp_contents .sec_rouge_couture .btn_detail {
  background: url(../img/item_pink_btn.png) no-repeat;
  background-size: 100%;
}

#lp_contents .sec_rouge_couture .about_charm_blk:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  mask-image: url("../img/about_frame01.svg");  
  mask-repeat: no-repeat;
  mask-position: top center;
  mask-size: contain;
  -webkit-mask-image: url("../img/about_frame01.svg");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: top center;
  -webkit-mask-size: contain;
  background: #f4b0c3;
  content: "";
}

#lp_contents .sec_rouge_couture .charm_slider_name {
  color: var(--color_pink);
}

#lp_contents .sec_rouge_couture .charm_text {
  color: var(--color_pink);
}

#lp_contents .sec_rouge_couture .note {
  color: var(--color_pink);
}

/* ========================================================
                * Lip Glaze *
========================================================= */
#lp_contents .sec_lip_glaze .visual_blk:before {
  background: url(../img/purple_gradation.png) no-repeat;
  background-size: 100%;
  content: "";
}

#lp_contents .sec_lip_glaze {
  background: url(../img/bg04.png?260316) no-repeat;
  background-position: center calc(700 * (var(--rate)));
  background-size: 100%;
  content: "";
}

#lp_contents .sec_lip_glaze .sec_title {
  color: var(--color_purple);
}

#lp_contents .sec_lip_glaze .sec_visual {
  top: calc(70 * (var(--rate)));
}

#lp_contents .sec_lip_glaze .sec_cloudbg {
  bottom: calc(-195 * (var(--rate)));
}

#lp_contents .sec_lip_glaze .sec_visual_text{
  margin-top: calc(1030 * (var(--rate)));
  color: var(--color_purple);
}

#lp_contents .sec_lip_glaze .item01 {
  margin-top: calc(90 * (var(--rate)));
}

#lp_contents .sec_lip_glaze .item_img_blk img {
  width: calc(730 * (var(--rate)));
}

#lp_contents .sec_lip_glaze .about_charm_blk:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  mask-image: url("../img/about_frame02.svg");  
  mask-repeat: no-repeat;
  mask-position: top center;
  mask-size: 100%;
  -webkit-mask-image: url("../img/about_frame02.svg");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: top center;
  -webkit-mask-size: 100%;
  background: #dab1d3;
  content: "";
}

#lp_contents .sec_lip_glaze .item_name {
  width: calc(400 * (var(--rate)));
  margin: calc(60 * (var(--rate))) auto 0;
  color: var(--color_purple);
  border: solid var(--color_purple) calc(2 * (var(--rate)));
}

#lp_contents .sec_lip_glaze .item_txt {
  color:var(--color_purple);
}

#lp_contents .sec_lip_glaze .item_price.dashed {
  text-decoration-color: var(--color_purple);
}

#lp_contents .sec_lip_glaze .btn_detail {
  background: url(../img/item_purple_btn.png) no-repeat;
  background-size: 100%;
}

#lp_contents .sec_lip_glaze .charm_slider_img {
  margin-top: calc(45 * (var(--rate)));
  width: calc(580 * (var(--rate)));
}

#lp_contents .sec_lip_glaze .charm_slider_name {
  color: var(--color_purple);
}

#lp_contents .sec_lip_glaze .charm_text span{
  color: var(--color_purple);
}

#lp_contents .sec_lip_glaze .note {
  color: var(--color_purple);
}

/* ========================================================
                      * Package  *
========================================================= */
#lp_contents .sec_pkg_design {
  position: relative;
  padding-top: calc(290 * (var(--rate)));
  padding-bottom: calc(100 * (var(--rate)));
  background-color: var(--color_bg01);
  z-index: 5;
}

#lp_contents .sec_pkg_design:before {
  position: absolute;
  top: calc(0 * (var(--rate)));
  left: 50%;
  transform: translateX(-50%);
  display: block;
  width: calc(780 * (var(--rate)));
  height: calc(460 * (var(--rate)));
  background: var(--color_bg03);
  background-size: 100%;
  content: "";
  z-index: -1;
}

#lp_contents .sec_pkg_design .sec_cloudbg {
  bottom: auto;
  top: calc(35 * (var(--rate)));
  z-index: -1;
}

#lp_contents .sec_pkg_design .sec_title{
  position: relative;
  font-size: calc(100 * (var(--rate)));
  line-height: 1;
  color: var(--color_pink);
}

#lp_contents .pkg_img {
  width: calc(580 * (var(--rate)));
  margin: calc(87 * (var(--rate))) auto 0;
}

#lp_contents .pkg_text {
  display: flex;
  flex-direction: column;
  width: calc(600 * (var(--rate)));
  margin: calc(-82 * (var(--rate))) auto 0;
  gap: calc(19 * (var(--rate)));
}

#lp_contents .pkg_text span {
  position: relative;
  display: block;
  width: 100%;
  font-size: calc(28 * (var(--rate)));
  letter-spacing: 0.125em;
  line-height: 1;
  padding-bottom: calc(22 * var(--rate));
  color: var(--color_pink);
  white-space: nowrap;
}

#lp_contents .pkg_text.dashed span:before {
  bottom: calc(2 * (var(--rate)));
}

/* ========================================================
                      * Kakao  *
========================================================= */
#lp_contents .sec_kakao {
  position: relative;
  padding: calc(200 * (var(--rate))) 0;
  background-color: var(--color_bg01);
  z-index: 5;
}

#lp_contents .sec_kakao::before {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  display: block;
  width: calc(780 * (var(--rate)));
  height: calc(1370 * (var(--rate)));
  background: url(../img/bg_kakao.png) no-repeat;
  background-size: 100%;
  content: "";
  z-index: -1;
}

#lp_contents .kakao_img {
  width: calc(780 * (var(--rate)));
  margin: 0 auto;
}

#lp_contents .kakao_title {
  position: relative;
  display: block;
  width: fit-content;
  margin: calc(50 * (var(--rate))) auto 0;
  font-size: calc(40 * (var(--rate)));
  letter-spacing: 0.05em;
  line-height: 1;
  color: var(--color_pink);
  font-weight: 700;
}

#lp_contents .kakao_title:before {
  width: 100%;
  height: calc(2 * (var(--rate)));
  left: 50%;
  transform: translateX(-50%);
  bottom: calc(-6 * var(--rate));
  background-size: calc(8 * var(--rate)) calc(2 * var(--rate));
  content: "";
  display: block;
  position: absolute;
  background-image: linear-gradient(to right, var(--color_pink) 50%, transparent 50%);
  background-size: calc(8 * var(--rate)) calc(2 * var(--rate));
}

#lp_contents .kakao_title span {
  display: inline-block;
  margin-left: calc(9 * (var(--rate)));
  font-size: calc(32 * (var(--rate)));
  color: var(--color_pink);
}

#lp_contents .kakao_text {
  margin: calc(50 * (var(--rate))) auto 0;
  width: calc(620 * (var(--rate)));
  font-size: calc(24 * (var(--rate)));
  text-align: left;
  line-height: calc(52/24);
}

#lp_contents .btn_checkall {
  margin: calc(115 * (var(--rate))) auto 0;
  width: calc(600 * (var(--rate)));
  height: calc(150 * (var(--rate)));
  background: url(../img/all_btn.png) no-repeat;
  background-size: 100%;
}

#lp_contents .btn_checkall a {
  padding: calc(12 * (var(--rate))) 0;
  font-family: var(--font_en);
  font-size: calc(58 * (var(--rate)));
  font-weight: 700;
  letter-spacing: 0.025em;
  color: var(--color_white);
}

#lp_contents .copyright_blk {
  margin: calc(80 * (var(--rate))) auto 0;
}

#lp_contents .copyright01 {
  margin: 0 auto;
  width: calc(500 * (var(--rate)));
}

#lp_contents .copyright02 {
  margin: calc(52 * (var(--rate))) auto 0;
  width: calc(160 * (var(--rate)));
}





/* ========================================================
                      * JS 設定  *
========================================================= */



@media screen and (min-width: 768px){


  /* 固定背景 */
.bgSetting {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100lvh;
}

.bgSetting .for_bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 1s;
}

.bgSetting .for_bg:nth-of-type(1) {
  background: url(../img/bg_pink.jpg) center center / cover no-repeat;
}

.bgSetting .for_bg:nth-of-type(2) {
  background: url(../img/bg_yellow.jpg) center center / cover no-repeat;
}

.bgSetting .for_bg:nth-of-type(3) {
  background: url(../img/bg_purple.jpg) center center / cover no-repeat;
}

.bgSetting .for_bg.selected {
  opacity: 1;
}

.btnSetting {
  position: relative;
  margin: 3rem auto 0;
}

.btn_checkall_pc {
  opacity: 0;
  transition: opacity 1s;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%);
}

.btn_checkall_pc.selected {
  opacity: 1;
}


.js-logo-svg {
  width: 100%;
  height: auto;
  display: block;
}

.js-logo-svg .cls-1 {
  transition: fill 1s ease; 
}

.js-logo-svg.pink .cls-1 {
  fill: var(--color_pink);
}

.js-logo-svg.yellow .cls-1 {
  fill: var(--color_yellow);
}

.js-logo-svg.purple .cls-1 {
  fill: var(--color_purple);
}

#lp_contents .right_area .nav_name {
  transition: color 1s ease;
}

#lp_contents .right_area .nav_name.pink {
  color: var(--color_pink);
}

#lp_contents .right_area .nav_name.yellow {
  color: var(--color_yellow);
}

#lp_contents .right_area .nav_name.purple {
  color: var(--color_purple);
}

#lp_contents .right_area .nav_arrow {
  transition: background-image 1s ease;
}

#lp_contents .right_area .nav_arrow.pink {
  background-image: url(../img/nav_arrow_pink.png);
}

#lp_contents .right_area .nav_arrow.yellow {
  background-image: url(../img/nav_arrow_yellow.png);
}

#lp_contents .right_area .nav_arrow.purple {
  background-image: url(../img/nav_arrow_purple.png);
}

}

/* ========================================================
                        * modal  *
========================================================= */
/* #lp_contents .modal{
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
} */

#lp_contents .modal {
  /* 初期状態 */
  display: none; 
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10000;
  
  /* アニメーションの準備 */
  background: none;
  border: none;
  opacity: 0;
  scale: 0.95;
  transition: opacity 0.3s ease-out, scale 0.3s ease-out;
  
  /* 中身を中央に寄せる（重要：これがないと scale の起点がズレます） */
  align-items: center;
  justify-content: center;
}

/* クラスが付与された時 */
#lp_contents .modal.is-visible {
  display: flex !important; /* JSの .show() は block になるため flex で上書き */
  opacity: 1;
  scale: 1;
}
/* Chrome, Safari用スクロールバー非表示 */
#lp_contents .modal__content::-webkit-scrollbar {
  display: none;
}

#lp_contents .modal__content{
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(740 * (var(--rate)));
  max-width: 100vw;
  max-height: calc(100dvh - (60 * var(--rate)));
  background-color: #fff;
  transform: translate(-50%,-50%);
  transition: transform 0.3s ease-out;
  overflow-y: scroll;
  scrollbar-width: none;
  overscroll-behavior: contain;
}


#lp_contents .modal_content::-webkit-scrollbar {
  display: none; /* Chrome, Safari */
}

@media (max-width: 768px) {
  #lp_contents .modal__content{
  transform: translate(-50%,-50%);
  }
}

/* 背景（オーバーレイ）のふわっとした出現 */
#lp_contents .modal__bg {
  height: 100vh;
  position: absolute;
  width: 100%;
  background: rgba(255, 255, 255, 0); /* 初期は透明 */
  transition: background-color 0.3s;
}

#lp_contents .modal.is-visible .modal__bg {
  background: rgba(255, 255, 255, 0.5); /* 開いたら指定の色に */
}

#lp_contents .modal_inner{
  padding: calc(120 * (var(--rate))) 0;
} 

#lp_contents .modal__content .js-modal-close{
  position: absolute;
  width: calc(42 * (var(--rate)));
  height: calc(42 * (var(--rate)));
  top: calc(25 * (var(--rate)));
  right: calc(30 * (var(--rate)));
  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(52 * (var(--rate)));
  height: calc(2 * (var(--rate)));
  transform: rotate(45deg);
  position: absolute;
  top: calc(20 * (var(--rate)));
  right: calc(-4 * (var(--rate)));
  background: var(--color_text);
}

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

#lp_contents .modal .slick-prev:before, 
#lp_contents .modal .slick-next:before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: calc(24 * (var(--rate)));
  height: calc(62 * (var(--rate)));
  background: url(../img/arrow02.svg) no-repeat;
  background-size: 100%;
  content: "";
}

#lp_contents .modal .slick-prev, 
#lp_contents .modal .slick-next {
  position: absolute;
  top: 0;
  margin-top: calc(406 * (var(--rate)));
  width: calc(24 * (var(--rate)));
  height: calc(62 * (var(--rate)));
  z-index: 9999;
}

#lp_contents .modal .slick-prev {
  left: calc(30 * (var(--rate)));
}

#lp_contents .modal .slick-next {
  right: calc(30 * (var(--rate)));
}

#lp_contents .modal .slick-next:before {
  transform: rotate(180deg);
}

#lp_contents .modal_slider {
  width: calc(580 * (var(--rate)));
  margin: 0 auto;
  overflow: hidden;
}

#lp_contents .modal_img {
  width: calc(580 * (var(--rate)));
  height: calc(580 * (var(--rate)));
  margin: 0 auto;
  overflow: hidden;
}

#lp_contents #modal01 .modal_img {
  background-color: var(--color_bg02);
}

#lp_contents #modal02 .modal_img {
  background-color: var(--color_bg01);
}

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

#lp_contents .modal_zoom_area img {
  width: calc(580 * (var(--rate)));
}

#lp_contents .zoom-btn {
  position: absolute;
  bottom: calc(25 * (var(--rate)));
  right: calc(25 * (var(--rate)));
  width: calc(60 * (var(--rate)));
  height: calc(60 * (var(--rate)));
  border: none;
  background-color: transparent;
  background-size: contain;
  background-repeat: no-repeat;
  cursor: pointer;
  z-index: 100;
}

#lp_contents #modal01 .zoom-btn {
  background-image: url('../img/icon_zoomin_yellow.png');
}

#lp_contents #modal01 .zoom-btn.change {
  background-image: url('../img/icon_zoomout_yellow.png');
}

#lp_contents #modal02 .zoom-btn {
  background-image: url('../img/icon_zoomin_pink.png');
}

#lp_contents #modal02 .zoom-btn.change {
  background-image: url('../img/icon_zoomout_pink.png');
}

#lp_contents .modal_thumbnail {
  position: relative;
  width: calc(180 * (var(--rate))) !important;
}

#lp_contents .modal_thumbnail li {
  width: calc(80 * (var(--rate))) !important;
  height: auto;
  cursor: pointer;
}

#lp_contents .modal_thumbnail li img {
  width: calc(80 * (var(--rate))) !important;
}

#lp_contents .modal_thumbnail li:first-of-type {
  margin: 0 calc(10 * (var(--rate))) 0 0 !important;
}

#lp_contents .modal_thumbnail .slick-list {
  padding: 0 !important;
}

#lp_contents .modal_thumbnail .slick-track {
  transform: unset !important;
}

#lp_contents .modal .slick-dots li {
  width: calc(14 * (var(--rate)));
  height: calc(14 * (var(--rate)));
  margin: 0 calc(10 * (var(--rate)))
}

#lp_contents .modal .slick-dots {
  position: absolute;
  top: calc(710 * (var(--rate))) !important;
  bottom: auto;
  right: calc(-200 * (var(--rate))) !important;
}

#lp_contents .modal .slick-dots li button {
  width: calc(14 * (var(--rate)));
  height: calc(14 * (var(--rate)));
  padding: 0;
}

#lp_contents .modal .slick-dots li button:before {
  display: block;
  line-height: 1;
  font-size: 0;
  width: calc(14 * (var(--rate)));
  height: calc(14 * (var(--rate)));
  border-radius: 50%;
  opacity: 1;
}

#lp_contents #modal01 .slick-dots li button:before {
  background-color: #fde7b7;
}

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

#lp_contents #modal02 .slick-dots li button:before {
  background-color: #fad8e1;
}

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

#lp_contents .modal_detail_blk {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: calc(580 * (var(--rate)));
  margin: 0 auto;
  border-bottom: var(--color_yellow) calc(2 * (var(--rate))) solid;
}

#lp_contents #modal01 .modal_detail_blk {
  border-bottom: var(--color_yellow) calc(2 * (var(--rate))) solid;
}

#lp_contents #modal02 .modal_detail_blk {
  border-bottom: var(--color_pink) calc(2 * (var(--rate))) solid;
}

#lp_contents .modal_var_name {
  padding-bottom: calc(42 * (var(--rate)));
  padding-top: calc(62 * (var(--rate)));
  font-family: var(--font_en);
  font-size: calc(28 * (var(--rate)));
  letter-spacing: 0.025em;
  line-height: calc(42 / 28);
  text-align: left;
}

#lp_contents #modal01 .modal_var_name {
  color: var(--color_yellow);
}

#lp_contents #modal02 .modal_var_name {
  color: var(--color_pink);
}

#lp_contents .modal_color_map {
  width: calc(100 * (var(--rate)));
  margin: calc(60 * (var(--rate))) auto 0;
}

#lp_contents .modal_text {
  width: calc(520* (var(--rate)));
  margin: calc(40 * (var(--rate))) auto 0;
  font-size: calc(24 * (var(--rate)));
  letter-spacing: 0.1em;
  line-height: calc(52.8/24);
  text-align: left;
}

#lp_contents .modal .btn_detail {
  margin: calc(65 * (var(--rate))) auto 0;
  width: calc(480 * (var(--rate)));
  height: calc(120 * (var(--rate)));
  color: var(--color_white);
}

#lp_contents .modal .btn_detail a {
  padding: calc(31 * (var(--rate))) 0 calc(31 * (var(--rate)));
  font-family: var(--font_en);
  font-size: calc(48.4 * (var(--rate)));
  font-weight: 700;
  color: var(--color_white);
  letter-spacing: 0.025em;
  line-height: 1;
}

#lp_contents #modal01 .btn_detail {
  background: url(../img/item_yellow_btn.png) no-repeat;
  background-size: 100%;
}

#lp_contents #modal02 .btn_detail {
  background: url(../img/item_pink_btn.png) no-repeat;
  background-size: 100%;
}


#lp_contents .modal_copyright {
  width: calc(500 * (var(--rate)));
  margin: calc(60 * (var(--rate))) auto 0;
}
