@charset "utf-8";





/*----- campaign -----*/

.campaign {

  background: url(../img/campaign/ttl_bg.webp) no-repeat center top,url(../img/campaign/bg.webp) no-repeat center top;

  background-size: 75rem,cover;

}

.campaign .box {

  padding-top: 3rem;

}

.campaign_ttl {

  width: 61rem;

}

.ttl_snow {

  width: 73.3rem;

  position: absolute;

  top: 1rem;

  left: 0;

  right: 0;

  margin: 0 auto;

}

.campaign_img {

  width: 71rem;

}

.campaign_add {

  width: 30rem;

}

.campaign_add02 {

  width: 23.6rem;

}



/*----- fan -----*/

#fan {

  background: #c1d6ff80;

  padding: 6rem 0 4.5rem 0;

}

#fan_ttl {

  width:35rem;

}

/* 以下slider */

.slider{

  opacity: 0;

  transition: 3s;

}

.fan_area {

  cursor: grab;

  margin: 0 1rem;

}

.fan_img {

  width: 26rem;

}

.slick-arrow {

  display: block;

  border: none;

  font-size: 0;

  position: absolute;

  z-index: 100;

  top: calc(50% - 4.6rem);

  width: 4.6rem;

  height: 9.2rem;

  cursor: pointer;

  transition: all 0.3s ease-in-out;

}

.slick-arrow:hover {

  opacity: 0.8;

}

.slick-prev {

  background: url(../img/common/prev.webp) no-repeat;

  background-size: 4.6rem;

  left: 2rem;

}

.slick-next {

  background: url(../img/common/next.webp) no-repeat;

  background-size: 4.6rem;

  right: 2rem;

}





/*----- secret -----*/

.secret_ttl {

  padding-left: 13rem;

}

.secret_bln {

  position: absolute;

  left: 0;

  top: -1.2rem;

  width: 12.6rem;

}

#secret01_img02 {

  width: 65rem;

}

.secret01_box {

  background: #FFF;

  box-shadow: 0 0.4rem 0.9rem #113f7e4d;

}

.secret01_box p {

  width: 40.5rem;

}

.secret01_img05 {

  width: 16.5rem;

}

.secret01_collapse::after, .attack_collapse::after {

  content:'';

  position: absolute;

  width: 1rem;

  height: 1.2rem;

  background: url(../img/secret/arw01.webp) no-repeat center top;

  background-size: 1rem;

  top: calc(50% - 0.6rem);

  right: 2rem;

  transition: 0.3s;

}

.attack_collapse::after {

  background: url(../img/secret/arw02.webp) no-repeat center top;

  background-size: 1rem;

  right: 0;

}

/*　closeというクラスがついたら形状変化　*/

.secret01_collapse.active::after, .attack_collapse.active::after {

  transform: rotate(90deg);

}

.attack_box {

  position: relative;

  background: #FFF;

  border: 0.3rem solid #58a9ff;

}

.attack_ttl {

  width: 18.8rem;

  position: absolute;

  top: -4rem;

  left: 2rem;

}

.attack_list li {

  border-bottom: 0.1rem dashed #CCC;

  margin-bottom: 0.5rem;

}

.attack_list li::before {

  content:"";

  display: inline-block;

  width: 2.9rem;

  height: 3rem;

  background: url(../img/secret/attack_check.webp) no-repeat center top;

  background-size: cover;

  margin: 0 1rem 0 0;

}

#secret02_img06 {

  width: 62.9rem;

}

#secret03_img01 {

  width: 49.4rem;

}

#secret03_img02 {

  width: 65.1rem;

}



/*----- price -----*/

#price {

  background: #073589 url(../img/price/bg.webp) no-repeat center top;

  background-size: 75rem;

  padding: 10rem 0 0 0;

}

#price_ttl {

  width: 40.6rem;

}

#price01 {

  width: 50.6rem;

}



/*----- parts -----*/

#parts {

  padding: 1rem 1rem 3rem 1rem;

}

#parts h3 {

  background: #58a9ff;

}

.parts_area {

  cursor: grab;

}

#parts_box {

  padding: 5.2rem 2rem 0 2rem;

}

#parts_box .slick-list {

  border: 2px solid #58a9ff;

}

#parts_box .slick-prev {

  left: -3rem;

}

#parts_box .slick-next {

  right: -3rem;

}

.parts_img {width:59rem;}

/* 切り替えボタン */

.slick-dots {

  display: flex;

  flex-wrap: wrap;

  justify-content: space-between;

  position: absolute;

  top: 0;

  width: 59rem;

}

.slick-dots li {

  margin: 0;

  position: relative;

}

.slick-dots li::after {

  content: "FRONT";

  width: 100%;

  height: 100%;

  position: absolute;

  top: 0;

  left: 0;

  text-align: center;

  line-height: 5.2rem;

  transition: 0.3s;

  cursor: pointer;

  background: #e6ebf5;

  border-radius: 0.6rem 0.6rem 0 0;

}

.slick-dots li:hover::after {

  opacity: 0.8;

}

.slick-dots li:nth-child(1):after {

  content: "FRONT";

}

.slick-dots li:nth-child(2):after {

  content: "BACK";

}

.slick-dots li:nth-child(3):after {

  content: "FACE";

}

.slick-dots li.slick-active:after {

  color: #FFF;

  background: #58a9ff;

}

.slick-dots li button {

  width: 19rem;

  height: 5.2rem;

  visibility: hidden;

}



.diffrence_box {

  padding: 3rem 38.5rem 3rem 3rem;

  height: 26.6rem;

}

.diffrence_box:nth-child(2) {

  background: #FFF url(../img/parts/img01.webp) no-repeat right top;

  background-size: 35.5rem;

}

.diffrence_box:nth-child(3) {

  padding: 3rem 3rem 3rem 38.5rem;

  background: #FFF url(../img/parts/img02.webp) no-repeat left top;

  background-size: 35.5rem;

}

.diffrence_box:nth-child(4) {

  background: #FFF url(../img/parts/img03.webp) no-repeat right top;

  background-size: 35.5rem;

}



/*----- addprice -----*/

#addprice_box {

  padding: 32.4rem 3rem 6rem 3rem;

}

#addprice_bln {

  width:23.4rem;

  position: absolute;

  top: -3rem;

  left: 3rem;

}

#addprice_ttl {

  width:34.8rem;

  position: absolute;

  top: 7rem;

  left: 13rem;

  z-index: 1;

}

#addprice_img {

  width:31.7rem;

  position: absolute;

  top: -4.4rem;

  right: 0;

}

.addprice_txt {

  width:27.2rem;

}

.addprice_btn li {

  width:32rem;

  position: relative;

  overflow: hidden;

}

.addprice_btn li::after, #ep_btn::after {

  width: 100%;

  height: 100%;

  position: absolute;

  left: 0;

  top: -100%;

  content: "";

  display: block;

  background: linear-gradient(180deg, #fff 0%, transparent 100%);

  animation: sliderButton-anim 3s ease-out 0s infinite;

}

.addprice_btn li:last-child::after {

  animation-delay: 0.2s;

}

@keyframes sliderButton-anim {

  0% {top: -100%;}

  7% {top: 100%;}

  14% {top: 100%;}

  100% {top: 100%;}

}



/* 顔・VIO脱毛のスライド */

#position-modal, #position-modal02 {

  width: 100%;

  overflow: hidden;

}

#posi-modal-base, #posi-modal-cont, #posi-modal-base02, #posi-modal-cont02 {

  margin-left: -100vw;

  opacity: 0;

  -webkit-transition: opacity 0.2s ease-out;

  transition: opacity 0.2s ease-out;

  position: fixed;

}

#posi-modal-base, #posi-modal-base02 {

  width: 100%;

  height: 100vh;

  background: #000;

  opacity: 0.5;

  left: 0;

  top: 0;

  z-index: 100;

}

#posi-modal-cont, #posi-modal-cont02 {

  left: 50%;

  top: 50%;

  z-index: 110;

  -webkit-transform: translate(-50%, -50%);

          transform: translate(-50%, -50%);

}

#posi-modal-close, #posi-modal-close02 {

  position: absolute;

  right: 0;

  top: 0;

  width: 3.8rem;

  margin-right: -5rem;

  cursor: pointer;

  transition: opacity 0.2s ease-out;

}

#posi-modal-cont .posi-slide-wrap, #posi-modal-cont02 .posi-slide-wrap {

  width: 54rem;

}

#posi-modal-cont.vio .posi-slide-wrap:not(.vio), #posi-modal-cont.face .posi-slide-wrap:not(.face), #posi-modal-cont.ep .posi-slide-wrap:not(.ep) {

  display: none;

}

#posi-modal-cont .posi-slide *, #posi-modal-cont02 .posi-slide * {

  outline: none;

}

#posi-modal-cont .slick-arrow, #posi-modal-cont02 .slick-arrow {

  width: 3.1rem;

  height: 9.6rem;

  position: absolute;

  top: calc(50% - 4.8rem);

  color: transparent;

  font-size: 0;

  overflow: hidden;

  text-indent: 31px;

  cursor: pointer;

  transition: opacity 0.2s ease-out;

}

#posi-modal-cont .slick-arrow.hidden, #posi-modal-cont02 .slick-arrow.hidden {

  display: none !important;

}

#posi-modal-cont .slick-arrow.slick-next, #posi-modal-cont02 .slick-arrow.slick-next {

  background: url(../img/natural_sp/cont05_btn2.webp) no-repeat 0 0;

  background-size: cover;

  right: -3.1rem;

}

#posi-modal-cont .slick-arrow.slick-prev, #posi-modal-cont02 .slick-arrow.slick-prev {

  background: url(../img/natural_sp/cont05_btn.webp) no-repeat 0 0;

  background-size: cover;

  left: -3.1rem;

}

#posi-modal-close:hover, #posi-modal-cont .slick-arrow:hover, #posi-modal-close02:hover, #posi-modal-cont02 .slick-arrow:hover {

  opacity: 0.8;

}

.posi-slide li {width: 54rem;}



/*----- campaign02 -----*/

.campaign02 {

  background: url(../img/campaign02/bg.webp) no-repeat center top;

  background-size: cover;

}

.campaign02_ttl {

  width:71.8rem;

}

.campaign02_txt {

  width:37.7rem;

}

.notes_box {

  border: 1px solid #FFF;

  padding: 2rem 3rem;

  text-align: center;

}



/*----- triple_attack -----*/

#triple_attack {

  background: #0066c6 url(../img/triple_attack/bg.webp) no-repeat center top;

  background-size: contain;

}

#ta_txt {

  width:27.2rem;

}

#ta_txt02 {

  width:27.4rem;

}

#ta_bln01 {

  width:65rem;

}

.ta_img {

  height: 50.3rem;

  padding: 13rem 3rem 0 34.5rem;

}

#ta_img01 {

  background: url(../img/triple_attack/img01.webp) no-repeat center top;

  background-size: contain;

}

#ta_img02 {

  background: url(../img/triple_attack/img02.webp) no-repeat center top;

  background-size: contain;

}

#ta_img03 {

  background: url(../img/triple_attack/img03.webp) no-repeat center top;

  background-size: contain;

}

#ta_img01_ttl {

  width:33.4rem;

}

#ta_img01_txt {

  width:30.7rem;

}

#ta_img02_ttl {

  width:25.2rem;

}

#ta_img02_txt {

  width:31rem;

}

#ta_img03_ttl {

  width:33.5rem;

}

#ta_img03_txt {

  width:30.7rem;

}



#ta_bln02_ttl {

  width:47.1rem;

}

#ta_bln02 {

  width:65rem;

}



/*----- ep -----*/

#ep {

  background: #003f9a url(../img/electroporation/bg.webp) no-repeat center top;

  background-size: contain;

}

#ep_btn {

  width:59rem;

  position: relative;

  overflow: hidden;

}

#ep_img {

  width:27rem;

  margin: 0 1.5rem 0 0;

}

#ep_ttl {

  width:33.4rem;

}

#ep_txt {

  width:35.9rem;

}

#ep_electro {

  width:65rem;

}



/*----- reason -----*/

#reason {

  background: url(../img/reason/bg.webp) no-repeat center top;

  background-size: contain;

  height: 113.5rem;

}

.reason {width: 51.6rem;}



#reason_ttl01 {

  width: 64.3rem;

}

#reason_ttl02 {

  width: 58.2rem;

}

#reason_ttl03 {

  width: 64.4rem;

}



#reason_img01 {

  background: #FFF url(../img/reason/img01.webp) no-repeat center top;

  background-size: contain;

}

#reason_img02 {

  background: #FFF url(../img/reason/img02.webp) no-repeat center top;

  background-size: contain;

}

#reason_img03 {

  background: #FFF url(../img/reason/img03.webp) no-repeat center top;

  background-size: contain;

}

.reason_num {

  width: 17.5rem;

  position: absolute;

  top: -8.7rem;

  left: 0;

  right: 0;

  margin: 0 auto;

}

.reason_box {

  height: 50.6rem;

  padding: 11.5rem 0 0 0;

}

.reason_box h2 mark {

  width: max-content;

}

#reason_img03 .reason_box {

  padding: 11.5rem 0 0 33rem;

}



/*----- plan -----*/

#plan {

  background: #073589 url(../img/plan/bg.webp) no-repeat center top;

  background-size: contain;

  padding: 10rem 0 0 0;

}

#plan_ttl {

  width: 40.4rem;

}

#plan_ttl01 {

  width: 59.4rem;

}

#plan01 {

  width: 50.4rem;

}

#plan_ttl02 {

  width: 59.4rem;

}

#plan02 {

  width: 55.6rem;

}



/*----- discount -----*/

#discount {

  background: url(../img/discount/bg.webp) no-repeat center top;

  background-size: cover;

}

#discount .m_box {

  height: 112.2rem;

  padding-top: 6rem;

}

#discount_ttl {

  width: 55.4rem;

}

.discount_price {

  width: 36.7rem;

}



/*----- lead -----*/

.lead02_bg {

  background: url(../img/lead02/bg.svg) no-repeat center 6rem;

  background-size: 71rem;

}

.lead02_bg .box {

  padding-top: 16.6rem;

}

.l_ttl02 {

  width: 57.8rem;

}

.l_btn {

  width: 65rem;

  animation: buttonMove 0.5s ease infinite alternate;

}

@keyframes buttonMove {

  0% {

    transform: scale(0.9, 0.9) translateY(0);

  }

  100% {

    transform: scale(1, 1) translateY(-1.5rem);

  }

}

.l_txt {

  margin: 0 3rem 4rem 0;

}



/*----- promise -----*/

#promise_img01 {

  width: 52.2rem;

}

#promise_img02 {

  width: 63rem;

}

#promise_img03 {

  width: 57.4rem;

}

#promise_img04 {

  width: 54.8rem;

}



/*----- no1 -----*/

#no1_txt01 {

  width: 51.2rem;

}

#no1_ttl01 {

  width: 59rem;

}

#no1_txt02 {

  width: 57.3rem;

}

#no1_ttl02 {

  width: 66rem;

}





/*----- doctor -----*/

#doctor {

  background: url(../img/doctor/bg.webp) no-repeat center top;

  background-size: cover;

}

#doctor .m_box:after {

  content:"";

  display: block;

  width: 25.4rem;

  height: 52.9rem;

  background: url(../img/doctor/doctor.webp) no-repeat center top;

  background-size: cover;

  position: absolute;

  top: 81rem;

  right: 3rem;

}

#doctor_ttl01 {

  width: 66rem;

}

#doctor_txt {

  width: 48.2rem;

}

#doctor_ttl02 {

  width: 65rem;

}

/*----- flow -----*/

#flow_ttl01 {

  width: 42.2rem;

}

#flow_ttl02 {

  width: 29.9rem;

}

#flow_ttl03 {

  width: 64.8rem;

}

#flow_ttl04 {

  width: 31.7rem;

}

#flow_ttl05 {

  width: 48.2rem;

}

.flow_txt {

  position: relative;

  z-index: 1;

  top: -1.5rem;

}

.flow_txtdots {

  width: 0.6rem;

  margin: 0 0 0 2rem;

}

#flow_txt01 {

  width: 26.4rem;

}

#flow_txt02 {

  width: 42.3rem;

}

#flow_txt03 {

  width: 28.5rem;

}

#flow_txt04 {

  width: 30.2rem;

}

#flow_txt05 {

  width: 23.3rem;

}

.flow_img {

  width: 47.5rem;

  position: absolute;

  right: 0;

}

.flow_img01 {

  position: absolute;

  top: 0;

  left: 0;

  animation: sliderButton-anim 2s ease-out 0s infinite;

}

@keyframes sliderButton-anim {

  0% {opacity: 1;}

  49% {opacity: 1;}

  50% {opacity: 0;}

  100% {opacity: 0;}

}



/*----- shop -----*/

.shop_box, .shop_area, .shop_info {

  display: none;

}

#shop_list li:first-child h3 {

  border-radius: 0.9rem 0.9rem 0 0;

}

#shop_list li:last-child h3 {

  border-radius: 0 0 0.9rem 0.9rem;

}

#shop_list li:last-child h3.active {

  border-radius: 0;

}

.shop_ttl01, .shop_ttl02, .shop_ttl03 {

  position: relative;

  cursor: pointer;

}

.shop_ttl01::before, .shop_ttl01::after, .shop_ttl02::before, .shop_ttl02::after, .shop_ttl03::before, .shop_ttl03::after {

  content: "";

  display: block;

  background: #0143a4;

  border-radius: 0.2rem;

  position: absolute;

}

.shop_ttl03::before, .shop_ttl03::after {

  background: #FFF;

}

.shop_ttl01::before, .shop_ttl02::before, .shop_ttl03::before {

  width: 0.4rem;

  height: 2.4rem;

  top: calc(50% - 1.2rem);

  right: 4rem;

}

.shop_ttl01::after, .shop_ttl02::after, .shop_ttl03::after {

  width: 2.4rem;

  height: 0.4rem;

  top: calc(50% - 0.2rem);

  right: 3rem;

}

.shop_ttl01.active::before, .shop_ttl02.active::before, .shop_ttl03.active::before {

  display: none;

}



.shop_ttl01 {

  background: #FFF;

  padding: 1.5rem 3rem;

  margin: 0 0 0.2rem 0;

}

.shop_area {

  background: #FFFFFFCC;

  padding: 3rem;

  margin: 0 0 0.2rem 0;

}

.shop_ttl02 {

  background: #FFFFFFCC;

  padding: 1.5rem 3rem;

  margin: 0 0 0.2rem 0;

}

.shop_ttl03 {

  background: #0143a4;

  color: #FFF;

  padding: 1.5rem 3rem;

  margin: 0 0 0.2rem 0;

}

.shop_info {

  padding: 1.5rem 0 3rem 0;

}

.shop_search {

  width: 19.6rem;

}



/*----- faq -----*/

.faq_box h3 {

  position: relative;

}

.faq_box h3::before, .faq_box h3::after {

  content:"";

  display: inline-block;

  width: 8.6rem;

  height: 5.3rem;

}

.faq_box h3::before {

  background: url(../img/faq/ttl01.webp) no-repeat center top;

  background-size: cover;

  margin: 0 1rem 0 0;

}

.faq_box h3::after {

  background: url(../img/faq/ttl02.webp) no-repeat center top;

  background-size: cover;

  margin: 0 0 0 1rem;

}



/*アコーディオンタイトル*/

.faq_ttl {

  cursor: pointer;

  padding: 2rem 4rem 2rem 7rem;

  position: relative;

  background: #c1d6ff;

}

.faq_ttl::before {

  content: "";

  display: block;

  width: 4.1rem;

  height: 4rem;

  background: url(../img/faq/icon01.webp) no-repeat center top;

  background-size: 4.1rem;

  position: absolute;

  top: 1.5rem;

  left: 2rem;

}

/*アコーディオンで現れるエリア*/

.faq_info {

  display: none;/*はじめは非表示*/

  background: #FFF;

  padding: 1.5rem 0 0 7rem;

  position: relative;

}

.faq_info::before {

  content: "";

  display: block;

  width: 3.7rem;

  height: 3rem;

  background: url(../img/faq/icon02.webp) no-repeat center top;

  background-size: 3.7rem;

  position: absolute;

  top: 1.5rem;

  left: 2rem;

}



/*アイコンの＋と×*/

.faq_ttl::after {

  content:'';

  position: absolute;

  width: 0.8rem;

  height: 1rem;

  background: url(../img/faq/arw.webp) no-repeat center top;

  background-size: 0.8rem;

  top: calc(50% - 0.5rem);

  right: 2rem;

  transition: 0.3s;

}

/*　closeというクラスがついたら形状変化　*/

.faq_ttl.active::after {

  transform: rotate(90deg);

}



.f_notes_box {

  border: 1px solid #cccccc;

  padding: 3rem;

  color: #4d4d4d;

}



.dateNote{

  font-size: 14px;

  color: #ff0000;

  font-weight: 700;

  margin: 2rem 0;

}



#line_btn02{

  margin-top: 6rem;

  width: 22.4rem;

}



.none{

  display: none;

}



@media screen and (min-width:600px) {

}



@media screen and (max-width:599px) {

}
.dateNote {
  font-size: 14px;
  color: #ff0000;
  font-weight: 700;
  margin: 1rem 0;
}