@charset "UTF-8";

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

Yuri Ebihara Collaboration x FORGANICS

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


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

html {
  font-size: 62.5%;
  -ms-overflow-style: none;
  scrollbar-width: 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: 50rem / 750;
  --color-text:#000000;
  --color-white:#ffffff;
  --color-gray01: #a9aaaa;
  --color-gray02: #a7a7a7;
  --color-green:#55aa6b;
  --color-lightgreen:#edf2ed;
  --color-aqua:#8dd5e0;
  --color-orange:#f2a85f;
  --color-emerald:#55ad9c;
  --color-light-emerald:#89ceb8;
  --color-blue01:#78bbce;
  --color-blue02:#438eaf;
  --color-red:#d64363;
  --font-english: "century-gothic","ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN,HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;
}

/* ============================================================================
      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: "Roboto","ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN,HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;
  letter-spacing: 0.075em;
  font-feature-settings: "palt";
  color: var(--color-text);
  /* overflow: hidden; */
}

@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: "Roboto","ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN,HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;
  color: var(--color-text);
  letter-spacing: 0.1em;
  text-align: center;
  font-weight: 300;
}

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

.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_skincare {
  padding-top: calc(150 * (var(--rate-sp)));
}

.lp_contents .sec_handlipcare {
  padding-top: calc(200 * (var(--rate-sp)));
}

.lp_contents .sec_bodymist {
  padding-top: calc(192 * (var(--rate-sp)));
}

.lp_contents .sec_gift {
  padding-top: calc(200 * (var(--rate-sp)));
  position: relative;
  z-index: 2;
}

/* ============================================================================
      ACCORDION
============================================================================ */
.lp_contents .accordion {
  position: relative;
  z-index: 2;
}

.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: 0;
  transition: opacity .8s;
  min-height: calc(457 * (var(--rate-sp)));
  overflow: hidden; 
}

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

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

.lp_contents .accordion_btn {
  display: flex;
  align-items: center;
  gap: calc(10 * (var(--rate-sp)));
  margin: calc(45 * (var(--rate-sp))) auto 0;
  width: fit-content;
  height: calc(23 * (var(--rate-sp)));
  line-height: 1;
  border-bottom: var(--color-gray01) solid calc(2 * (var(--rate-sp)));
  text-align: center;
  cursor: pointer;
}

.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(20 * (var(--rate-sp)));
  letter-spacing: 0.075em;
  color: var(--color-gray01);
}

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

.lp_contents .accordion_btn .accordion_btn_icon:before,
.lp_contents .accordion_btn .accordion_btn_icon:after {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  transition: all 0.6s ease;
  border-bottom: 1px solid var(--color-gray01);
  width: calc(14 * (var(--rate-sp)));
  height: 0;
  z-index: 0;
}

.lp_contents .accordion_btn .accordion_btn_icon:before {
  transform: rotate(90deg);
}

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

/* ============================================================================
      MOVIE SETTING
============================================================================ */
.lp_contents .movie_wrap01 {
  margin: 0 auto;
  width: calc(630 * (var(--rate-sp)));
  height: calc(1120 * (var(--rate-sp)));
  overflow: hidden;
  position: relative;
}

.lp_contents .movie_wrap02 {
  margin: 0 auto;
  width: calc(630 * (var(--rate-sp)));
  height: calc(1120 * (var(--rate-sp)));
  overflow: hidden;
  position: relative;
}

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

.lp_contents .movie_wrap .movie_sound {
  position: absolute;
  bottom: calc(22 * (var(--rate-sp)));
  right: calc(27 * (var(--rate-sp)));
  width: calc(48 * (var(--rate-sp)));
  height: calc(40 * (var(--rate-sp)));
  z-index: 10;
  cursor: pointer;
}

.lp_contents .movie_wrap .movie_sound .btn_sound {
  display: none;
}

.lp_contents .movie_wrap .movie_sound .btn_sound.is-active {
  display: block;
}

/* ============================================================================
      SECTION：MV
============================================================================ */
.lp_contents .lead_area {
  padding: calc(105 * (var(--rate-sp))) 0 0 0;
}

.lp_contents .lead_title {
  font-family: var(--font-english);
  font-size: calc(56*(var(--rate-sp)));
  font-weight: 700;
}

.lp_contents .lead_subtitle01 {
  margin-top: calc(36 * (var(--rate-sp)));
  font-size: calc(26 * (var(--rate-sp)));
  font-weight: 300;
  line-height: calc(52 / 26);
}

.lp_contents .lead_subtitle02 {
  margin-top: calc(76 * (var(--rate-sp)));
  font-size: calc(32 * (var(--rate-sp)));
  line-height: calc(56 / 32);
}

.lp_contents .lead_area .accordion {
  margin: calc(115 * (var(--rate-sp))) auto 0;
}

.lp_contents .lead_area .accordion_inner {
  min-height: calc(425 * (var(--rate-sp)));
}

.lp_contents .lead_area .accordion_inner:before {
  background: linear-gradient(transparent, var(--color-white));
}

.lp_contents .lead_area .accordion_title {
  display: block;
  width: fit-content;
  margin: 0 auto;
  font-family: var(--font-english);
  text-transform: uppercase;
  font-size: calc(40*(var(--rate-sp)));
  font-weight: 700;
  line-height: 1;
  border-bottom: var(--color-text) solid calc(4*(var(--rate-sp)));
  padding-bottom: calc(12 * (var(--rate-sp)));
}

.lp_contents .lead_area .accordion_text {
  margin-top: calc(25*(var(--rate-sp)));
  font-size: calc(28*(var(--rate-sp)));
  line-height: calc(63/28);
}

.lp_contents .lead_area .accordion_title + .accordion_text {
  margin-top: calc(62 * (var(--rate-sp)));
}

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

.lp_contents .navigation_list ul {
  position: relative;
  display: flex;
  justify-content: space-between;
}

.lp_contents .navigation_list li {
  position: relative;
  width: calc(246*(var(--rate-sp)));
  height: calc(410*(var(--rate-sp)));
}

.lp_contents .navigation_list a {
  position: relative;
}

.lp_contents .navigation_name {
  position: absolute;
  bottom: calc(42*(var(--rate-sp)));
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  font-family: var(--font-english);
  text-transform: uppercase;
  font-size: calc(30*(var(--rate-sp)));
  letter-spacing: 0.075em;
  line-height: calc(45/30);
  text-align: center;
}

.lp_contents .navigation_arrow {
  position: absolute;
  bottom: calc(21*(var(--rate-sp)));
  left: 50%;
  transform: translateX(-50%);
  width: calc(18*(var(--rate-sp)));
  height: calc(11*(var(--rate-sp)));
  background: url(../img/page_arrow.svg) no-repeat;
  background-size: 100%;
  content: "";
}

/* ============================================================================
      SECTION：AROMA
============================================================================ */
.lp_contents .sec_aroma {
  padding: calc(140*(var(--rate-sp))) 0 calc(80*(var(--rate-sp))); 
}

.lp_contents .aroma_content {
  position: relative;
  padding-top: calc(100*(var(--rate-sp)));
}

.lp_contents .aroma_sec_subtitle {
  position: relative;
  width: fit-content;
  margin: 0 auto;
  font-size: calc(30*(var(--rate-sp)));
  line-height: calc(60/30);
}

.lp_contents .aroma_sec_subtitle:before,
.lp_contents .aroma_sec_subtitle:after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: calc(120*(var(--rate-sp)));
  height: calc(2*(var(--rate-sp)));
  background-color: var(--color-green);
  content: "";
}

.lp_contents .aroma_sec_subtitle:before {
  left: calc(-140*(var(--rate-sp)));
}

.lp_contents .aroma_sec_subtitle:after {
  right: calc(-140*(var(--rate-sp)));
}

.lp_contents .aroma_sec_modal_name {
  font-size: calc(40*(var(--rate-sp)));
  line-height: calc(80/40);
}

.lp_contents .aroma_outer {
  padding-top: calc(1*(var(--rate-sp)));
  padding-bottom: calc(561 * (var(--rate-sp)));
}

.lp_contents .aroma_inner_blk {
  position: relative;
  margin: calc(130 * (var(--rate-sp))) auto 0;
  padding: calc(135 * (var(--rate-sp))) 0 calc(675 * (var(--rate-sp)));
  background-color: var(--color-lightgreen);
}

.lp_contents .aroma_inner_blk .float {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  margin-top: calc(115 * (var(--rate-sp)));
}

.lp_contents .sec_aroma .sec_title {
  position: absolute;
  top: calc(-46*(var(--rate-sp)));
  left: 50%;
  transform: translateX(-50%);
}

.lp_contents .sec_aroma .sec_text01 {
  font-size: calc(36*(var(--rate-sp)));
  line-height: calc(63/36);
  color: var(--color-green);
}

.lp_contents .sec_aroma .sec_text02 {
  margin-top: calc(40 * (var(--rate-sp)));
  font-size: calc(28*(var(--rate-sp)));
  line-height: calc(47/28);
  color: var(--color-green);
}

.lp_contents .sec_aroma .sec_graph {
  position: relative;
  width: calc(470*(var(--rate-sp)));
  margin: calc(50 * (var(--rate-sp))) auto 0;
}

.lp_contents .sec_aroma .modal_plus {
  position: absolute;
  right: calc(-90 * (var(--rate-sp)));
  bottom: calc(70 * (var(--rate-sp)));
  width: calc(90*(var(--rate-sp)));
  height: calc(90*(var(--rate-sp)));
  background: url(../img/icon_plus.png) no-repeat;
  background-size: 100%;
}

.lp_contents .aroma_inner_blk .accordion {
  margin: 0;
}

.lp_contents .aroma_inner_blk .accordion_wrap {
  padding-top: calc(60 * (var(--rate-sp)));
}

.lp_contents .aroma_inner_blk .accordion_inner {
  min-height: calc(0 * (var(--rate-sp)));
}

.lp_contents .aroma_inner_blk .accordion_text {
  margin-top: calc(35 * (var(--rate-sp)));
  font-size: calc(26*(var(--rate-sp)));
  line-height: calc(52/26);
}

.lp_contents .aroma_inner_blk .accordion_text:nth-of-type(1) {
  margin-top: 0;
}

.lp_contents .message_title {
  margin-top: calc(80 * (var(--rate-sp)));
  font-family: var(--font-english);
  font-weight: 300;
  font-size: calc(54 * (var(--rate-sp)));
  line-height: 1.25;
  color: var(--color-green);
}

.lp_contents .message_title span {
display: block;
font-family: var(--font-english);
font-size: calc(40*(var(--rate-sp)));
line-height: calc(80/40);
font-weight: 300;
color: var(--color-green);
}

.lp_contents .message {
  width: calc(660 * (var(--rate-sp)));
  margin: calc(55 * (var(--rate-sp))) auto;
  padding:calc(138 * (var(--rate-sp))) 0 calc(168 * (var(--rate-sp)));
  background-color: var(--color-lightgreen);
  border-radius: calc(20 * (var(--rate-sp)));
  white-space: nowrap;
}

.lp_contents .message .accordion {
  position: relative;
  margin: 0 auto 0;
}

.lp_contents .message .accordion:after,
.lp_contents .message .accordion:before {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  height: calc(50*(var(--rate-sp)));
  content: "";
}

.lp_contents .message .accordion:before {
  top: calc(-80*(var(--rate-sp)));
  width: calc(69*(var(--rate-sp)));
  background: url(../img/icon_quotation01.svg) no-repeat;
  background-size: 100%;
  content: "";
}

.lp_contents .message .accordion:after {
  bottom: calc(-110*(var(--rate-sp)));
  width: calc(68*(var(--rate-sp)));
  background: url(../img/icon_quotation02.svg) no-repeat;
  background-size: 100%;
  content: "";
}

.lp_contents .message .accordion_inner {
  min-height: calc(400 * (var(--rate-sp)));
}

.lp_contents .message .accordion_text {
  margin-top: calc(37 * (var(--rate-sp)));
  font-size: calc(26*(var(--rate-sp)));
  line-height: calc(52/26);
}

.lp_contents .message .accordion_text:nth-of-type(1) {
  margin-top: 0;
}

/* ============================================================================
      SKIN CARE / HAND LIP CARE / BODY MIST / GIFT COMMON
============================================================================ */
.lp_contents .visual_image {
  position: relative;
}

.lp_contents .sticky {
  position: -webkit-sticky;
  position: sticky;
  top: calc(250 * (var(--rate-sp)));
}

.lp_contents .sec_title {
  position: absolute;
  top: calc(-40*(var(--rate-sp)));
  left: 50%;
  transform: translateX(-50%);
  width: calc(750*(var(--rate-sp)));
  margin: 0 auto;
  z-index: 10;
}

.lp_contents .product_list {
  position: relative;
  padding: calc(65 * (var(--rate-sp))) 0 0 0;
  background-color: var(--color-white);
  z-index: 5;
}

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

.lp_contents .product_list li {
  padding-bottom: calc(5 * (var(--rate-sp)));
}

.lp_contents .product_title_group {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: calc(15*(var(--rate-sp)));
}

.lp_contents .product_title {
  display: block;
  width: fit-content;
  margin: 0;
  font-size: calc(34*(var(--rate-sp)));
  line-height: calc(51/34);
}

.lp_contents .product_title_group span {
  position: relative;
  width: calc(200*(var(--rate-sp)));
  height: calc(3*(var(--rate-sp)));
}

.lp_contents .product_title_group span:before,
.lp_contents .product_title_group span:after {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-bottom: calc(3*(var(--rate-sp))) solid;
  width: 100%;
  height: 0;
  z-index: 0;
}

.lp_contents .product .product_catch {
  position: relative;
  display: block;
  width: fit-content;
  margin: calc(16 * (var(--rate-sp))) auto 0;
  padding: calc(35 * (var(--rate-sp)))  calc(50 * (var(--rate-sp))) calc(30 * (var(--rate-sp)));
  border-radius: calc(20 * (var(--rate-sp)));
  border: solid var(--color-white) calc(4 * (var(--rate-sp)));
  font-size: calc(26*(var(--rate-sp)));
  line-height: calc(45.5/26);
  color: var(--color-white);
}

.lp_contents .product .product_catch:before {
  position: absolute;
  bottom: calc(-35 * (var(--rate-sp)));
  width: calc(46*(var(--rate-sp)));
  height: calc(45*(var(--rate-sp)));
  content: "";
}

.lp_contents .product_visual_slider {
  width: calc(420 * var(--rate-sp)) !important;
  margin: calc(45 * var(--rate-sp)) auto 0;
  position: relative;
}

.lp_contents .product_visual_slider .slick-list {
  width: 100% !important;
  height: auto !important;
  overflow: visible;
}

.lp_contents .product_visual_slider .slick-track {
  width: 100% !important;
  transform: none !important;
}

/* 各スライド：すべて同じ位置に重ねる */
.lp_contents .product_visual_slider .slick-slide {
  width: calc(420 * var(--rate-sp)) !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  display: block !important;
}

.lp_contents .product_visual_slider .slick-active {
  position: relative !important;
  opacity: 1;
  z-index: 10;
}

.lp_contents .product .product_name {
  margin: calc(40*(var(--rate-sp))) auto 0;
  font-size: calc(28*(var(--rate-sp)));
  line-height: calc(42/28);
  font-weight: 300;
}

.lp_contents .product .product_price {
  margin: calc(10*(var(--rate-sp))) auto 0;
  font-family: var(--font-english);
  font-size: calc(24*(var(--rate-sp)));
  line-height: calc(45.5/24);
  letter-spacing: 0.075em;
}

.lp_contents .product .btn.btn_detail a {
  margin: calc(20*(var(--rate-sp))) auto 0;
  font-size: calc(24*(var(--rate-sp)));
  line-height: calc(42/24);
  letter-spacing: 0.075em;
  text-decoration: underline;
  text-underline-offset: calc(15*(var(--rate-sp)));
  text-decoration-thickness: calc(2*(var(--rate-sp)));
}

.lp_contents .note {
  margin: calc(40*(var(--rate-sp))) auto 0;
  font-size: calc(20*(var(--rate-sp)));
  line-height: calc(40/20);
  letter-spacing: 0.075em;
  color: var(--color-gray01);
}

/* ============================================================================
      SKIN CARE only
============================================================================ */
.lp_contents .sec_skincare .product_title_group span:before,
.lp_contents .sec_skincare .product_title_group span:after {
  border-color: var(--color-aqua);
}

.lp_contents .sec_skincare .product:nth-of-type(3) .product_title_group span {
  width: calc(140*(var(--rate-sp)));
}

.lp_contents .sec_skincare .product_catch {
  background-color: var(--color-aqua);
}

.lp_contents .sec_skincare .product_catch:before {
  background: url(../img/sec02_fukidashi.svg) no-repeat;
  background-size: 100%;
}

.lp_contents .sec_skincare .product:first-of-type .product_catch:before {
  right: calc(50 * (var(--rate-sp)));
}

.lp_contents .sec_skincare .product:nth-of-type(2) .product_catch:before {
  right: calc(25 * (var(--rate-sp)));
}

.lp_contents .sec_skincare .product:nth-of-type(3) .product_catch:before {
  right: calc(50 * (var(--rate-sp)));
}
/* ============================================================================
      HAND LIP CARE only
============================================================================ */
.lp_contents .sec_handlipcare .product_title_group span:before,
.lp_contents .sec_handlipcare .product_title_group span:after {
  border-color: var(--color-orange);
}

.lp_contents .sec_handlipcare .product:nth-of-type(1) .product_title_group span {
  width: calc(140*(var(--rate-sp)));
}

.lp_contents .sec_handlipcare .product_catch {
  background-color: var(--color-orange);
}

.lp_contents .sec_bodymist .product_catch {
  background-color: var(--color-light-emerald);
}

.lp_contents .sec_handlipcare .product_catch:before {
  background: url(../img/sec03_fukidashi.svg) no-repeat;
  background-size: 100%;
}

.lp_contents .sec_handlipcare .product:first-of-type .product_catch:before {
  right: calc(70 * (var(--rate-sp)));
}

.lp_contents .sec_handlipcare .product:nth-of-type(2) .product_catch:before {
  right: calc(115 * (var(--rate-sp)));
}

/* ============================================================================
      BODY MIST only
============================================================================ */
.lp_contents .sec_bodymist .sec_title {
  top: calc(147*(var(--rate-sp)));
}

.lp_contents .sec_bodymist .product_list {
  padding: calc(142 * (var(--rate-sp))) 0 calc(55 * (var(--rate-sp))) 0; 
}

.lp_contents .sec_bodymist .product_title_group span:before,
.lp_contents .sec_bodymist .product_title_group span:after {
  border-color: var(--color-emerald);
}

.lp_contents .sec_bodymist .product_catch:before {
  background: url(../img/sec04_fukidashi.svg) no-repeat;
  background-size: 100%;
  right: calc(100 * (var(--rate-sp)));
}
  
/* ============================================================================
      GIFT only
============================================================================ */
.lp_contents .sec_gift .sec_title {
  top: calc(167 * (var(--rate-sp)));
}

.lp_contents .sec_gift .product_visual_slider {
  margin-top: 0;
  width: 100% !important;
}

.lp_contents .sec_gift .product_visual_slider .slick-slide {
  width: 100% !important;
}

.lp_contents .sec_gift .gift_content {
  padding: calc(70 * (var(--rate-sp))) calc(50 * (var(--rate-sp))) calc(120 * (var(--rate-sp)));
  background: top center / 100% auto repeat-y url(../img/bg_gift.png) #fff;
}

.lp_contents .sec_gift .gift_title {
  font-size: calc(36*(var(--rate-sp)));
  line-height: calc(63/36);
  letter-spacing: 0.075em;
  color: var(--color-red);
  white-space: nowrap;
}

.lp_contents .sec_gift .gift_detail {
  margin-left: calc(14 * (var(--rate-sp)));
}

.lp_contents .sec_gift .gift_text {
  margin-top: calc(24 * (var(--rate-sp)));
  font-size: calc(28*(var(--rate-sp)));
  line-height: calc(49/28);
  letter-spacing: 0.075em;
  text-align: left;
  white-space: nowrap;
}

.lp_contents .sec_gift .gift_text span {
  display: inline-block;
  position: relative;
  width: fit-content;
  z-index: 1;
}

.lp_contents .sec_gift .gift_text span:before {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  display: block;
  width: 100%;
  height: calc(21 * (var(--rate-sp)));
  margin-top: calc(20 * (var(--rate-sp)));
  background-color: #eae78c;
  content: "";
  z-index: -1;
}

.lp_contents .sec_gift .gift_info {
  margin-top: calc(12*(var(--rate-sp)));
  font-size: calc(24*(var(--rate-sp)));
  line-height: calc(48/24);
  letter-spacing: 0.075em;
  text-align: left;
}

.lp_contents .sec_gift .gift_note {
  margin-top: calc(23 * (var(--rate-sp)));
  font-size: calc(20*(var(--rate-sp)));
  line-height: calc(48/20);
  letter-spacing: 0.075em;
  text-align: left;
}

/* ============================================================================
      PROFILE
============================================================================ */
.lp_contents .sec_profile {
  padding: calc(150*(var(--rate-sp))) 0;
}

.lp_contents .profile_visual_group {
  position: relative;
  width: calc(670*(var(--rate-sp)));
  height: calc(1090*(var(--rate-sp)));
  margin: 0 auto;
}

.lp_contents .profile_visual_group .profile_visual_img {
  position: absolute;
  width: calc(400*(var(--rate-sp)));
}

.lp_contents .profile_visual_group .profile_visual_img:nth-of-type(1) {
  top: 0;
  left: 0;
}

.lp_contents .profile_visual_group .profile_visual_img:nth-of-type(2) {
  bottom: 0;
  right: 0;
}

.lp_contents .profile_outer {
  padding-top: calc(1*(var(--rate-sp)));
}

.lp_contents .profile_blk {
  position: relative;
  width: calc(622*(var(--rate-sp)));
  margin: calc(160*(var(--rate-sp))) auto 0;
  padding: calc(50 * var(--rate-sp)) calc(70 * var(--rate-sp));
  background-image: 
    /* 上の線 */
    linear-gradient(to right, var(--color-blue02) 50%, transparent 50%),
    /* 下の線 */
    linear-gradient(to right, var(--color-blue02) 50%, transparent 50%),
    /* 左の線 */
    linear-gradient(to bottom, var(--color-blue02) 50%, transparent 50%),
    /* 右の線 */
    linear-gradient(to bottom, var(--color-blue02) 50%, transparent 50%);
  
  /* 線分(12px) + 間隔(12px) = 24px */
  background-size: 
    calc(24 * var(--rate-sp)) calc(2 * var(--rate-sp)), /* 上下 */
    calc(24 * var(--rate-sp)) calc(2 * var(--rate-sp)), /* 下 */
    calc(2 * var(--rate-sp)) calc(24 * var(--rate-sp)), /* 左 */
    calc(2 * var(--rate-sp)) calc(24 * var(--rate-sp)); /* 右 */
    
  background-position: 
    0 0,                /* 上 */
    0 100%,             /* 下 */
    0 0,                /* 左 */
    100% 0;             /* 右 */
    
  background-repeat: repeat-x, repeat-x, repeat-y, repeat-y;
}

.lp_contents .profile_title {
  display: block;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: calc(-23 * (var(--rate-sp)));
  width: calc(190 * (var(--rate-sp)));
  margin: 0 auto;
  font-family: var(--font-english);
  font-size: calc(40 * (var(--rate-sp)));
  line-height: calc(50 / 40);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  background-color: var(--color-white);
}

.lp_contents .profile_name {
  font-family: var(--font-english);
  font-size: calc(56*(var(--rate-sp)));
  line-height: calc(84/56);
  letter-spacing: 0.05em;
}

.lp_contents .profile_sns {
  display: flex;
  justify-content: center;
  margin-top: calc(5 * (var(--rate-sp)));
  gap: calc(15 * (var(--rate-sp)));
}

.lp_contents .profile_sns_logo {
  width: calc(24*(var(--rate-sp)));
}

.lp_contents .profile_sns_account {
  font-family: var(--font-english);
  font-size: calc(24 * (var(--rate-sp)));
  line-height: 1;
  letter-spacing: 0.05em;
}

.lp_contents .profile_detail {
  margin-top: calc(50*(var(--rate-sp)));
  font-size: calc(24*(var(--rate-sp)));
  line-height: calc(42/24);
  text-align: justify;
}

.lp_contents .profile_interview {
  padding-top: calc(135*(var(--rate-sp)));
}

.lp_contents .profile_interview_title {
  position: relative;
  width: fit-content;
  margin: 0 auto;
  font-size: calc(30*(var(--rate-sp)));
  line-height: calc(59/30);
}

.lp_contents .profile_interview_title:before,
.lp_contents .profile_interview_title:after {
  position: absolute;
  top: calc(30*(var(--rate-sp)));
  display: block;
  width: calc(35*(var(--rate-sp)));
  height: calc(2*(var(--rate-sp)));
  background-color: var(--color-text);
  content: "";
}

.lp_contents .profile_interview_title:before {
  left:calc(-40*(var(--rate-sp)));
  transform: translateY(-50%) rotate(245deg);
}

.lp_contents .profile_interview_title:after {
  right: calc(-40 * (var(--rate-sp)));
  transform: translateY(-50%) rotate(115deg);
}

.lp_contents .comingsoon {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: calc(40 * (var(--rate-sp))) auto 0;
  width: calc(640 * (var(--rate-sp)));
  height: calc(360 * (var(--rate-sp)));;
  padding: calc(0 * (var(--rate-sp))) 0;
  background-color: #f5f5f5;
}

.lp_contents .comingsoon_text {
  font-family: var(--font-english);
  font-size: calc(40*(var(--rate-sp)));
}

.lp_contents .sec_profile .video_inner{
  margin: calc(45 * (var(--rate-sp))) auto 0;
  width: calc(640 * (var(--rate-sp)));
  height: calc(360 * (var(--rate-sp)));
  background-color: var(--color-gray02);
}

.lp_contents .sec_profile .video_container {
  width: 100%;
  margin: calc(45 * (var(--rate-sp))) auto 0;
  padding: 0 calc(55 * (var(--rate-sp))); /* スマホ時の左右余白 */
}

/* 動画の比率を維持する枠 */
.lp_contents .sec_profile .video_inner {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9; /* モダンブラウザで16:9を固定 */
  background-color: #000; /* 読み込み前の黒板 */
  overflow: hidden; /* 角丸をiframeにも適用させる */
}

/* iframeを枠いっぱいに広げる */
.lp_contents .sec_profile .video_inner iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
}

/* 古いブラウザ（iOSの旧バージョン等）への対策 */
@supports not (aspect-ratio: 16 / 9) {
  .lp_contents .video_inner {
    height: 0;
    padding-top: 56.25%; /* 9 / 16 = 56.25% */
  }
}

/* ============================================================================
      CAMPAIGN
============================================================================ */
.lp_contents .campaign {
  width: calc(684*(var(--rate-sp)));
  margin: 0 auto;
  padding: calc(60*(var(--rate-sp))) 0 calc(80*(var(--rate-sp)));
  border: var(--color-blue02) 4px solid;
}

.lp_contents .campaign_subtitle {
  font-family: var(--font-english);
  font-size: calc(50*(var(--rate-sp)));
  color: var(--color-blue02);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.lp_contents .campaign_title {
  width: calc(600 * (var(--rate-sp)));
  font-family: var(--font-english);
  margin: calc(17 * (var(--rate-sp))) auto 0;
  padding: calc(1 * (var(--rate-sp)));
  font-size: calc(54 * (var(--rate-sp)));
  color: var(--color-white);
  text-transform: uppercase;
  background-color: var(--color-blue02);
  letter-spacing: 0.05em;
}

.lp_contents .campaign_date {
  font-family: var(--font-english);
  margin-top: calc(69 * (var(--rate-sp)));
  font-size: calc(36 * (var(--rate-sp)));
  text-transform: uppercase;
  text-decoration: underline;
  text-underline-offset: calc(17 * (var(--rate-sp)));
  text-decoration-thickness: calc(2 * (var(--rate-sp)));
  letter-spacing: 0.05em;
}

.lp_contents .campaign_text {
  font-family: var(--font-english);
  margin-top: calc(47 * (var(--rate-sp)));
  font-size: calc(32 * (var(--rate-sp)));
  letter-spacing: 0.05em;
}

.lp_contents .campaign_pointback {
  margin-top: calc(40 * (var(--rate-sp)));
  display: flex;
  justify-content: center;
  gap: calc(5 * (var(--rate-sp)));
  align-items: flex-end;
}

.lp_contents .campaign_pointback span {
  display: block;
  font-family: var(--font-english);
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1;
  color: var(--color-blue02);
  white-space: nowrap;
}

.lp_contents .campaign_pointback span:nth-of-type(1) {
  font-size: calc(120*(var(--rate-sp)));
}

.lp_contents .campaign_pointback span:nth-of-type(2) {
  font-size: calc(40*(var(--rate-sp)));
  margin-bottom: calc(10 * (var(--rate-sp)));
}

/* ============================================================================
      RELATED PRODUCT
============================================================================ */
.lp_contents .related_product {
  padding: calc(180 * (var(--rate-sp))) 0; 
}

.lp_contents .related_product .product_ttl {
  margin-bottom: calc(60 * (var(--rate-sp)));
  font-size: calc(40 * (var(--rate-sp)));
  line-height: 1;
  color: var(--color-text);
  text-align: center;
}

.lp_contents .related_product .product_slide {
  width: calc(440 * (var(--rate-sp))) !important;
  height: calc(750 * (var(--rate-sp)));
  padding: calc(57 * (var(--rate-sp))) calc(0 * (var(--rate-sp))) calc(50 * (var(--rate-sp)));
  margin: calc(20 * (var(--rate-sp))) calc(20 * (var(--rate-sp)));
  background-color: var(--color-white);
  border-radius:calc(20 * (var(--rate-sp)));
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.1);
}

.lp_contents .related_product .product_label {
  display: block;
  width: fit-content;
  margin: 0 auto;
  padding: calc(7 * (var(--rate-sp))) calc(30 * (var(--rate-sp))) calc(3 * (var(--rate-sp)));
  font-size: calc(22 * (var(--rate-sp)));
  line-height: 1;
  text-align: center;
  color: var(--color-gray01);
  border: calc(2 * (var(--rate-sp))) solid var(--color-gray01);
}

.lp_contents .related_product .product_catch {
  margin: calc(22 * (var(--rate-sp))) auto 0;
  font-size: calc(22 * (var(--rate-sp)));
}

.lp_contents .related_product .product_img_link {
  position: relative;
  display: block;
}

.lp_contents .related_product .product_img {
  width: calc(400 * (var(--rate-sp)));
  margin: calc(30 * (var(--rate-sp))) auto 0;
}

.lp_contents .related_product .product_limit_icon {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: calc(-15 * (var(--rate-sp)));
  right: calc(20 * (var(--rate-sp)));
  width: calc(130 * (var(--rate-sp)));
  height: calc(130 * (var(--rate-sp)));
  border-radius: 50%;
  background-color: var(--color-blue01);
}

.lp_contents .related_product .product_limit_icon span {
  font-size: calc(20 * (var(--rate-sp)));
  color: var(--color-white);
  line-height: calc(30/20);
}

.lp_contents .related_product .product_name {
  margin-top: calc(23 * (var(--rate-sp)));
  margin-bottom: calc(15 * (var(--rate-sp)));
  font-size: calc(26 * (var(--rate-sp)));
  line-height: calc(45.5/26);
  font-weight: 700;
}

.lp_contents .related_product .product_credit {
  font-family: var(--font-english);
  font-size: calc(22 * (var(--rate-sp)));
  color: var(--color-text);
  letter-spacing: 0.075em;
}

.lp_contents .related_product .product_slide .detail_btn a {
  margin-top: calc(24 * (var(--rate-sp)));
  padding-bottom: calc(3 * (var(--rate-sp)));
  font-size: calc(24 * (var(--rate-sp)));
  color: var(--color-text);
  border-bottom: calc(2 * (var(--rate-sp))) solid var(--color-text);
  line-height: 1;
}

.lp_contents .related_product .product_container {
  width: auto;
  margin: 0 auto;
}

.lp_contents .related_product .product_container .slick-track {
  margin-left: 0;
  padding: calc(0 * (var(--rate-sp))) 0;
}

.lp_contents .related_product .product_container .slick-dots {
  bottom: calc(-45 * (var(--rate-sp)));
}

.lp_contents .related_product .product_container .slick-dots li {
  width: calc(16 * (var(--rate-sp)));
  height: calc(16 * (var(--rate-sp)));
  margin: 0 calc(10 * (var(--rate-sp)));
}

.lp_contents .related_product .product_container .slick-dots li button {
  width: calc(16 * (var(--rate-sp)));
  height: calc(16 * (var(--rate-sp)));
  padding: 0;
  background-color: var(--color-white);
}

.lp_contents .related_product .product_container .slick-dots li button:before {
  top: calc(0 * (var(--rate-sp)));
  font-size: calc(16 * (var(--rate-sp)));
  line-height: 1;
  width: calc(16 * (var(--rate-sp)));
  height: calc(16 * (var(--rate-sp)));
  opacity: 1;
  border: calc(2 * (var(--rate-sp))) solid var(--color-gray01);
  border-radius: 50%;
  color: transparent;
}

.lp_contents .related_product .product_container .slick-dots li.slick-active button:before {
  background-color: var(--color-gray01);
}

.lp_contents .related_product .product_container .slick-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: calc(60 * (var(--rate-sp)));
  height: calc(60 * (var(--rate-sp)));
  z-index: 5;
}

.lp_contents .related_product .product_container .slick-prev {
  left: calc(105 * (var(--rate-sp)));
}

.lp_contents .related_product .product_container .slick-next {
  right: calc(105 * (var(--rate-sp)));
}

.lp_contents .related_product .product_container .slick-prev::before,
.lp_contents .related_product .product_container .slick-next::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 101%;
  height: 101%;
  background: url(../img/icon_slide_arrow.png) center center / contain no-repeat;
  content: "";
}

.lp_contents .related_product .product_container .slick-next::before {
  transform: scaleX(-1);
}

/* ============================================================================
        MODAL
============================================================================ */
.lp_contents .btn_fixed_group {
  position: fixed;
  display: flex;
  flex-direction: column;
  gap: calc(30 * (var(--rate-sp)));
  top: 50%;
  right: 0;
  z-index: 5;
  visibility: hidden;
  pointer-events: none;
  transform: translateX(40px);
  transition: 
    transform 0.6s cubic-bezier(0, 0, 0.2, 1),
    visibility 0.6s;
}

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

.lp_contents .btn_fixed {
  border-radius: calc(16 * (var(--rate-sp))) 0 0 calc(16 * (var(--rate-sp)));
}

.lp_contents .btn_fixed a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: calc(10 * (var(--rate-sp)));
  padding: calc(20 * (var(--rate-sp)));
  flex-direction: column;
}

.lp_contents .btn_fixed a .text {
  display: block;
  font-family: var(--font-english);
  font-size: calc(36 * (var(--rate-sp)));
  text-transform: uppercase;
  writing-mode: vertical-rl;
  text-orientation: mixed;
}

.lp_contents .btn_fixed a .plus {
  position: relative;
  width: calc(26 * (var(--rate-sp)));
  height: calc(26 * (var(--rate-sp)));
}

.lp_contents .btn_fixed a .plus:before,
.lp_contents .btn_fixed a .plus:after {
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  right: 0px;
  bottom: 0px;
  width: calc(26 * (var(--rate-sp)));
  height: 0px;
  z-index: 0;
  margin: auto;
  border-bottom: calc(3 * (var(--rate-sp))) solid;
}

.lp_contents .btn_fixed a .plus:before {
  transform: rotate(90deg);
}

.lp_contents .btn_fixed.btn_nav {
  border-left: var(--color-blue02) calc(4 * (var(--rate-sp))) solid;
  border-top: var(--color-blue02) calc(4 * (var(--rate-sp))) solid;
  border-bottom: var(--color-blue02) calc(4 * (var(--rate-sp))) solid;
  background-color: var(--color-white);
}

.lp_contents .btn_fixed.btn_nav a .text {
  color: var(--color-blue02);
}

.lp_contents .btn_fixed.btn_nav a .plus::before,
.lp_contents .btn_fixed.btn_nav a .plus::after {
  border-color: var(--color-blue02);
}

.lp_contents .btn_fixed.btn_campaign {
  background-color: var(--color-blue02);
}

.lp_contents .btn_fixed.btn_campaign a .text {
  color: var(--color-white);
}

.lp_contents .btn_fixed.btn_campaign a .plus:before,
.lp_contents .btn_fixed.btn_campaign a .plus:after {
  border-color: var(--color-white);
}

/* Modal共通 */
.lp_contents .modal{
  display: none;
  visibility: visible;
  height: 100vh;
  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: 100vh;
  position: absolute;
  width: 100%;
}

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

.lp_contents .js-modal-close{
  position: absolute;
  width: calc(50 * (var(--rate-sp)));
  height: calc(50 * (var(--rate-sp)));
  top: calc(30 * (var(--rate-sp)));
  right: calc(30 * (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(60*(var(--rate-sp)));
  height: calc(2*(var(--rate-sp)));
  transform: rotate(45deg);
  background-color: var(--color-blue02);
  position: absolute;
  top: 50%;
  right: calc(-5 * (var(--rate-sp)));
}

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

.lp_contents #modal01 .js-modal-close:before,
.lp_contents #modal01 .js-modal-close:after{
  background-color: var(--color-green);
}

.lp_contents .modal_inner{
  padding:calc(120*(var(--rate-sp))) 0 calc(120*(var(--rate-sp)));
  overflow-y: scroll;
  height: auto;
  scrollbar-width: none;
  overscroll-behavior: contain;
} 
.lp_contents .modal_inner::-webkit-scrollbar {
  display: none;
}

/* Modal01 Aroma */
.lp_contents #modal01 .modal__content {
  background-color: #fbfff8;
}

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

.lp_contents #modal01 .modal_blk {
  padding-bottom: calc(30*(var(--rate-sp)));
}

.lp_contents #modal01 .modal_blk:last-of-type {
  padding-bottom: 0;
}

.lp_contents #modal01 .modal_title_blk {
  display: flex;
  justify-content: center;
  gap: calc(10*(var(--rate-sp)));
  width: calc(500*(var(--rate-sp)));
  margin: 0 auto;
}

.lp_contents #modal01 .modal_title_blk span {
  position: relative;
  width: 100%;
}

.lp_contents #modal01 .modal_title_blk span:before {
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  right: 0px;
  bottom: 0px;
  width: 100%;
  height: 0px;
  z-index: 0;
  margin: auto;
  border-bottom: calc(2 * (var(--rate-sp))) solid;
  border-color: var(--color-green);
}

.lp_contents #modal01 .modal_title {
  font-family: var(--font-english);
  font-size: calc(38*(var(--rate-sp)));
  font-weight: 700;
  color: var(--color-green);
  text-transform: uppercase;
}

.lp_contents #modal01 .modal_text {
  margin-top: calc(10*(var(--rate-sp)));
  font-size: calc(26*(var(--rate-sp)));
  line-height: calc(52/26);
  text-align: center;
}

/* Modal02 Menu */
.lp_contents #modal02 .modal_title {
  font-family: var(--font-english);
  font-size: calc(50*(var(--rate-sp)));
  color: var(--color-blue02);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.lp_contents #modal02 .modal_nav {
  margin: calc(20*(var(--rate-sp))) auto 0;
  width: calc(500*(var(--rate-sp)));
}

.lp_contents #modal02 .modal_nav ul {
  display: flex;
  flex-direction: column;
}

.lp_contents #modal02 .modal_nav ul li {
  padding: calc(20*(var(--rate-sp))) 0 calc(15*(var(--rate-sp))) 0;
  border-bottom: var(--color-blue02) solid calc(2*(var(--rate-sp)));
}

.lp_contents #modal02 .modal_nav ul li:last-of-type {
  border-bottom: none;
  padding-bottom: 0;
}

.lp_contents #modal02 .modal_nav ul li a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}

.lp_contents #modal02 .modal_nav ul li a .nav_link_inner {
  display: flex;
  flex-direction: column;
  gap:calc(5*(var(--rate-sp)));
}

.lp_contents #modal02 .modal_nav ul li a .nav_name_en {
  font-family: var(--font-english);
  font-size: calc(36*(var(--rate-sp)));
  text-transform: uppercase;
  letter-spacing: 0.09em;
}

.lp_contents #modal02 .modal_nav ul li a .nav_name_jp {
  font-size: calc(20*(var(--rate-sp)));
}

.lp_contents #modal02 .modal_nav ul li a .nav_arrow {
  display: block;
  position: absolute;
  right: calc(30*(var(--rate-sp)));
  width: calc(17*(var(--rate-sp)));
  height: calc(10*(var(--rate-sp)));
  background: url(../img/icon_nav_arrow.svg) no-repeat;
  background-size: contain;
  content: "";
}

/* Modal03 Campaign */
.lp_contents #modal03 .modal_inner {
  padding: calc(90 * (var(--rate-sp))) 0 calc(120 * (var(--rate-sp)));
  height: 70vh;
}

.lp_contents #modal03 .gift {
  position: relative;
}

.lp_contents #modal03 .modal_title01 {
  display: flex;
  justify-content: center;
  gap: calc(10 * (var(--rate-sp)));
  position: relative;
  width: calc(560 * (var(--rate-sp)));
  margin: 0 auto calc(30 * (var(--rate-sp)));
}

.lp_contents #modal03 .modal_title01:before,
.lp_contents #modal03 .modal_title01:after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: block;
  width: calc(150 * (var(--rate-sp)));
  height: calc(2 * (var(--rate-sp)));
  background-color: #c0c0c0;
  content: "";
}

.lp_contents #modal03 .modal_title01:before {
  left:calc(0 * (var(--rate-sp)));
}

.lp_contents #modal03 .modal_title01:after {
  right:calc(0 * (var(--rate-sp)));
}

.lp_contents #modal03 .modal_title_en {
  display: flex;
  align-items: center;
  font-family: var(--font-english);
  font-size: calc(30 * (var(--rate-sp)));
  letter-spacing: 0.05em;
  color: var(--color-blue02);
  text-transform: uppercase;
}

.lp_contents #modal03 .modal_title_num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(40 * (var(--rate-sp)));
  height: calc(40 * (var(--rate-sp)));
  padding-left: calc(4 * (var(--rate-sp)));
  font-family: var(--font-english);
  font-size: calc(26.6 * (var(--rate-sp)));
  color: var(--color-white);
  border-radius: 50%;
  background-color: var(--color-blue02);
}

.lp_contents #modal03 .modal_title02 {
  width: calc(560 * (var(--rate-sp)));
  margin: 0 auto;
  padding: calc(10 * (var(--rate-sp)));
  font-family: var(--font-english);
  font-size: calc(46 * (var(--rate-sp)));
  color: var(--color-white);
  text-transform: uppercase;
  background-color: var(--color-red);
  letter-spacing: 0.05em;
  line-height: 1;
}

.lp_contents #modal03 .modal_text {
  font-family: var(--font-english);
  font-size: calc(26 * (var(--rate-sp)));
  margin: calc(20 * (var(--rate-sp))) auto 0;
  line-height: calc(45.5 / 26);
  letter-spacing: 0.05em;
}

.lp_contents #modal03 .modal_img {
  width: calc(466.5 * (var(--rate-sp)));
  margin-left: calc(57 * (var(--rate-sp)));
  margin-top: calc(-10 * (var(--rate-sp)));
}

.lp_contents #modal03 .note {
  position: absolute;
  bottom: calc(2 * (var(--rate-sp)));
  right: calc(110 * (var(--rate-sp)));
  font-size: calc(20 * (var(--rate-sp)));
  color: var(--color-text);
  margin: 0;
}

.lp_contents #modal03 .campaign {
  width: calc(560*(var(--rate-sp)));
  padding: calc(50*(var(--rate-sp))) 0 calc(0*(var(--rate-sp)));
  border: none;
}

.lp_contents #modal03 .campaign .modal_title01 {
  margin: 0 auto calc(20 * (var(--rate-sp)));
}

.lp_contents #modal03 .campaign_subtitle {
  font-size: calc(40 * (var(--rate-sp)));
}

.lp_contents #modal03 .campaign_title {
  width: calc(560 * (var(--rate-sp)));
  margin: calc(10 * (var(--rate-sp))) auto 0;
  padding: calc(8 * (var(--rate-sp)));
  font-size: calc(46 * (var(--rate-sp)));
  line-height: 1;
}

.lp_contents #modal03 .campaign_date {
  margin-top: calc(35 * (var(--rate-sp)));
  font-size: calc(32 * (var(--rate-sp)));
  text-underline-offset: calc(18 * (var(--rate-sp)));
  text-decoration-thickness: calc(3 * (var(--rate-sp)));
}

.lp_contents #modal03 .campaign_text {
  margin-top: calc(40 * (var(--rate-sp)));
  white-space: nowrap;
}

.lp_contents #modal03 .campaign_pointback {
  margin-top: calc(20 * (var(--rate-sp)));
  gap: calc(5 * (var(--rate-sp)));
}

.lp_contents #modal03 .campaign_pointback span:nth-of-type(1) {
  font-size: calc(100*(var(--rate-sp)));
}

.lp_contents #modal03 .campaign_pointback span:nth-of-type(2) {
  margin-bottom: calc(10 * (var(--rate-sp)));
}


/* ============================================================================
      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:before {
  background: center/160rem auto repeat url(../img/bg_pc.png);
  z-index: -1;
}

.lp_contents:after {
  background-color: var(--color-white);
  z-index: -2;
}

  .lp_contents .grid_area{
    display: grid;
    grid-template-columns: 1fr 50rem 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: 25rem;
    margin: 0 auto;
  }

  .lp_contents .lp_inner {
    grid-column: 2;
    width: 50rem;
    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;
  }

  .lp_contents .right_area .navlist_pc {
    display: flex;
    flex-direction: column;
    margin-top: -1rem;
    gap: 4rem;

  }

  .lp_contents .right_area .navlist_pc li {
    width: 20rem;
  }

  .lp_contents .right_area .navlist_pc li a {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  
  .lp_contents .right_area .navlist_pc li .nav_name {
    font-family: var(--font-english);
    font-size:1.8rem;
    line-height: 1;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    width: 13rem;
    text-align: left;
    white-space: nowrap;
  }
  
  .lp_contents .right_area .navlist_pc li .nav_arrow {
    display: block;
    width: 1rem;
    height: 0.61rem;
    margin: 0;
    background-image: url(../img/page_arrow.svg);
    background-size: contain;
    background-repeat: no-repeat;
  }

  .lp_contents .right_area .navlist_pc li:last-of-type {
    padding: 1rem;
    background-color: var(--color-blue02);
    border-radius: 0.8rem;
  }

  .lp_contents .right_area .navlist_pc li:last-of-type a{
    justify-content: center;
  }

  .lp_contents .right_area .navlist_pc li:last-of-type .nav_name {
    font-size: 1.8rem;
    color: var(--color-white);
    text-transform: uppercase;
  }

  .lp_contents .right_area .navlist_pc li .nav_plus {
    position: relative;
    width: 1.2rem;
    height: 1.2rem;
  }
  
  .lp_contents .right_area .navlist_pc li .nav_plus:before,
  .lp_contents .right_area .navlist_pc li .nav_plus:after {
    content: "";
    position: absolute;
    top: 0px;
    left: 0px;
    right: 0px;
    bottom: 0px;
    width: 1.2rem;
    height: 0px;
    z-index: 0;
    margin: auto;
    border-bottom: 0.1rem solid;
    border-color: var(--color-white);
  }
  
  .lp_contents .right_area .navlist_pc li .nav_plus:before {
    transform: rotate(90deg);
  }
}

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

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


/* ============================================================================
      ANIMATION
============================================================================ */

/* ------------------------上から下表示させる------------------------ */
.lp_contents .js-fade.ef1 {
  opacity: 0;
  -webkit-animation: opa 1.8s cubic-bezier(0.51, 0.21, 0.41, 1) 0.4s 1 forwards;
          animation: opa 1.8s cubic-bezier(0.51, 0.21, 0.41, 1) 0.4s 1 forwards;
  -webkit-mask-image: linear-gradient(0deg, transparent, transparent 39.6666666667%, rgba(0, 0, 0, 0.02) 43.3333333333%, rgba(0, 0, 0, 0.08) 45%, rgba(0, 0, 0, 0.18) 46.6666666667%, rgba(0, 0, 0, 0.32) 48.3333333333%, rgba(0, 0, 0, 0.5) 50%, rgba(0, 0, 0, 0.68) 51.6666666667%, rgba(0, 0, 0, 0.82) 53.3333333333%, rgba(0, 0, 0, 0.92) 55%, rgba(0, 0, 0, 0.98) 56.6666666667%, #000 58.3333333333%, #000);
          mask-image: linear-gradient(0deg, transparent, transparent 39.6666666667%, rgba(0, 0, 0, 0.02) 43.3333333333%, rgba(0, 0, 0, 0.08) 45%, rgba(0, 0, 0, 0.18) 46.6666666667%, rgba(0, 0, 0, 0.32) 48.3333333333%, rgba(0, 0, 0, 0.5) 50%, rgba(0, 0, 0, 0.68) 51.6666666667%, rgba(0, 0, 0, 0.82) 53.3333333333%, rgba(0, 0, 0, 0.92) 55%, rgba(0, 0, 0, 0.98) 56.6666666667%, #000 58.3333333333%, #000);
  -webkit-mask-size: 100% max(300%, 100vh);
          mask-size: 100% max(300%, 100vh);
  -webkit-mask-repeat: none;
          mask-repeat: none;
  -webkit-mask-position: center 100%;
          mask-position: center 100%;
  transform: translateZ(0);
  transition: -webkit-mask-position 1.6s 0.4s linear;
  transition: mask-position 1.6s 0.4s linear;
  transition: mask-position 1.6s 0.4s linear, -webkit-mask-position 1.6s 0.4s linear;
  transition: mask-position 1.6s 0.4s linear, -webkit-mask-position 1.4s linear;
}

.lp_contents .js-fade.active.ef1 {
  animation: opa1 1s cubic-bezier(0.51, 0.21, 0.41, 1) 0s 1 forwards;
  -webkit-mask-position: center -100px;
          mask-position: center -100px;
  opacity: 1;
}

@keyframes opa1 {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

/* ------------------------Profile画像の動画------------------------ */
.lp_contents .js-fade.ef2 {
  opacity: 0;
  -webkit-transform: translateY(20px);
  transform: translateY(20px);
}

.lp_contents .js-fade.active.ef2 {
  opacity: 1;
  -webkit-transform: none;
  transform: none;
  transition: .5s ease;
}

.lp_contents .js-fade.ef2 img {
  opacity: 0;
  scale: 1.1;
}

.lp_contents .js-fade.active.ef2 img {
  opacity: 1;
  scale: 1;
  transition: 1.4s ease 0s;
}

/* ------------------------お花が降る------------------------ */
.lp_contents .fall_flower_area {
  position: relative;
  width: 100%;
}

.lp_contents .fall_flower {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%; /* 親要素の高さ一杯に広げる */
  pointer-events: none; /* コンテンツの操作を邪魔しない */
  z-index: 1; /* コンテンツの背面に配置 */
  overflow: hidden; /* エリア外に出たお花を隠す */
}

/* 左右30%の降下領域 */
.lp_contents .fall_flower_wrapper01,
.lp_contents .fall_flower_wrapper02 {
  position: absolute;
  top: 0;
  width: 25%;
  height: 100%;
}

.lp_contents .fall_flower_wrapper01 { left: 0; }
.lp_contents .fall_flower_wrapper02 { right: 0; }

/* お花本体のスタイル */
.lp_contents .petal {
  position: absolute;
  top: -5%; /* 枠外上部からスタート */
  width: calc(60 * var(--rate-sp));
  opacity: 0;
  pointer-events: none;
  transform-origin: center center;
}

.lp_contents .petal img {
  width: 100%;
  height: auto;
  display: block;
  /* 縮小時のぼやけ防止 */
  image-rendering: -webkit-optimize-contrast;
}

@keyframes fall {
  0% {
    top: -5%;
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  90% {
    opacity: 1;
  }
  100% {
    top: 100%;
    opacity: 0;
  }
}

@keyframes swing {
  0% {
    transform: translateX(-50%) rotate(0deg);
  }
  50% {
    /* ここで左右の振れ幅を調整（30px〜50px程度に広げるとより舞っている感が出ます） */
    transform: translateX(calc(-50% + 40px)) rotate(180deg);
  }
  100% {
    transform: translateX(calc(-50% - 40px)) rotate(360deg);
  }
}

/* ------------------------Loading------------------------ */
.lp_contents {
  opacity: 0;
  visibility: hidden;
}

/* ローディング完了後に表示させるクラス */
.lp_contents.is-visible {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.5s ease; /* ふんわり出す場合 */
}

#HeaderWrap {
  z-index: -1;
  position: relative;
  visibility: hidden; /* 最初は完全に隠す */
}

#loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10000;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transition: transform 1.2s cubic-bezier(0.19, 1, 0.22, 1);
  will-change: transform;
  display: block; /* 最初から表示 */
}

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

#loading:after {
  content: "";
  position: absolute;
  margin: auto;
  top: 50%;
  right: 0;
  left: 0;
  transform: translateY(-50%);
  width: 30.2rem;
  height: 15.6rem;
  background-image: url(../img/loading_logo_pc.svg);
  background-size: 100%;
  background-repeat: no-repeat, no-repeat;
  z-index: 1;
}

@media screen and (max-width: 768px) {
  #loading:before {
    background-image: url(../img/loading_sp02.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    content: "";
  }
  
  #loading:after {
    width: calc(417 * (var(--rate-sp)));
    height: calc(192 * (var(--rate-sp)));
    background-image: url(../img/loading_logo_sp.svg);
    background-size: 100%;
    background-repeat: no-repeat, no-repeat;
    z-index: 1;
  }
}

#loading.is-loaded {
  transform: translateY(-100%);
}

#HeaderWrap.is-show {
  z-index: 10;
  visibility: visible;
}

body.is-loading {
  overflow: hidden;
}

/* ------------------------幕が上がる（商品ビジュアル）------------------------ */
.lp_contents .visual_image.ef3 {
  position: relative;
  clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0 100%);
  transition: clip-path 0.8s ease;
}

.lp_contents .visual_image.ef3.active {
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}

.lp_contents .visual_image.ef3:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  transition: clip-path 0.8s ease 0.8s; 
}

.lp_contents .visual_image.ef3.active:before {
  clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
}

.lp_contents .sec_skincare .visual_image.ef3:before {
  background: url(../img/mask_blue.png) center center / contain no-repeat;
}

.lp_contents .sec_handlipcare .visual_image.ef3:before {
  background: url(../img/mask_orange.png) center center / contain no-repeat;
}
.lp_contents .sec_gift .visual_image.ef3:before {
  background: url(../img/mask_pink.png) center center / contain no-repeat;
}