@charset "UTF-8";

/*//////////////////////////////////////////////////

Title : 2023 Summer ObyF CSS

//////////////////////////////////////////////////*/


/* ===================
       RESET
=================== */

main {
  max-width: 100%;
}

#Wrap {
  width: 100%;
}

footer {
  position: relative;
  z-index: 2;
  margin-top: 0;
}

a {
  text-decoration: none;
}

p, ul, ol, dl {
  margin: 0;
}

.topic-path {
  margin-right: 0;
  margin-left: 0;
}

#Wrap, .wrapTop, .wrapBottom {
  width: 100%;
}


/* ===================
      //RESET
=================== */


/* ===================
    LP CONTENTS
=================== */

.lp_contents {
  position: relative;
  z-index: 0;
  margin: auto;
  box-sizing: border-box;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", YuGothic, "游ゴシック体", "メイリオ", "Meiryo", sans-serif;
  font-feature-settings: "palt";
  font-style: normal;
  font-weight: 300;
  text-align: center;
  color: #474747;
}

.lp_contents * {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.lp_contents .lp_bg {
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100vw;
  height: 100%;
  background: url(../img/bg_pc.jpg) center center / cover no-repeat;
}

.lp_contents a {
  transition: opacity .4s ease-in-out;
}

.lp_contents a:hover {
  opacity: .8;
}

.lp_contents picture,
.lp_contents a {
  display: block;
}

.lp_contents img {
  width: 100%;
  height: auto;
  vertical-align: text-bottom;
}

.lp_contents .flexBox {
  display: flex;
}


/* ===================
    //LP CONTENTS
=================== */


/* ===================
        ANIME
=================== */

.ef.fadein {
  -webkit-mask-image: linear-gradient(-25deg, transparent, transparent 39.6666666667%, rgba(0, 0, 0, .02) 43.3333333333%, rgba(0, 0, 0, .08) 45%, rgba(0, 0, 0, .18) 46.6666666667%, rgba(0, 0, 0, .32) 48.3333333333%, rgba(0, 0, 0, .5) 50%, rgba(0, 0, 0, .68) 51.6666666667%, rgba(0, 0, 0, .82) 53.3333333333%, rgba(0, 0, 0, .92) 55%, rgba(0, 0, 0, .98) 56.6666666667%, #000 58.3333333333%, #000);
  mask-image: linear-gradient(-25deg, transparent, transparent 39.6666666667%, rgba(0, 0, 0, .02) 43.3333333333%, rgba(0, 0, 0, .08) 45%, rgba(0, 0, 0, .18) 46.6666666667%, rgba(0, 0, 0, .32) 48.3333333333%, rgba(0, 0, 0, .5) 50%, rgba(0, 0, 0, .68) 51.6666666667%, rgba(0, 0, 0, .82) 53.3333333333%, rgba(0, 0, 0, .92) 55%, rgba(0, 0, 0, .98) 56.6666666667%, #000 58.3333333333%, #000);
  -webkit-mask-size: 100% max(400%, 100vh);
  mask-size: 100% max(400%, 100vh);
  -webkit-mask-position: center 100%;
  mask-position: center 100%;
  -webkit-mask-repeat: none;
  mask-repeat: none;
  transform: translateZ(0);
  transition: -webkit-mask-position 1.4s linear;
  transition: mask-position 1.4s linear;
  transition: mask-position 1.4s linear, -webkit-mask-position 1.4s linear
}

.ef.fadein.effect {
  -webkit-mask-position: center 0;
  mask-position: center 0
}


/* ===================
       //ANIME
=================== */


/* ===================
       COMMON
=================== */

.lp_contents .sec_ttl {
  font-family: "muli", sans-serif;
  font-size: 2.6rem;
  font-weight: 400;
  font-style: normal;
  line-height: 2.1rem;
  letter-spacing: .1em;
  color: #92A9C5;
}

.lp_contents .title {
  font-size: 2.6rem;
  font-family: "muli", sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: .1em;
}

.lp_contents .sub_ttl {
  margin-top: 2rem;
  font-size: 1.6rem;
  letter-spacing: .1em;
  text-align: center;
}

.buy_btn a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 15rem;
  height: 3.2rem;
  margin-top: 3.5rem;
  /*padding: 0.2rem 0 0;*/
  font-size: 1.3rem;
  font-family: "muli", sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: .1em;
  line-height: normal;
  background-color: #474747;
  color: #fff;
}

.buy_btn a:hover {
  opacity: .7;
}


/* ===================
      //COMMON
=================== */


/* ===================
       MV AREA
=================== */

.mv_area {
  width: 100vw;
  height: 84rem;
  background: url(../img/mv_bg.jpg) center center no-repeat;
  background-size: cover;
}

.mv_area .main_logo {
  width: 8rem;
  margin: auto;
  padding-top: 22.8rem;
}

.mv_area .main_ttl {
  margin: 2rem auto 16rem;
  font-family: "muli", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 3.6rem;
  line-height: 6.3rem;
  letter-spacing: .08em;
  text-shadow: 0 0 24px #fff;
}

.mv_area .nav_menu {
  display: flex;
  justify-content: center;
  gap: 7rem;
}

.mv_area .nav_menu li {
  font-size: 1.6rem;
  line-height: 2.8rem;
  letter-spacing: .1em;
  text-align: center;
}

.mv_area .nav_menu li span {
  display: block;
  font-size: 1.4rem;
}

.mv_area .nav_menu li .link {
  position: relative;
  width: 13rem;
  height: 13rem;
  padding-top: 3.2rem;
  border-radius: 50%;
  background: #fff;
}

.mv_area .nav_menu li .link::after {
  content: "";
  position: absolute;
  bottom: 2.3rem;
  right: 0;
  left: 0;
  width: 1.4rem;
  height: .8rem;
  margin: auto;
  background: url(../img/arrow.png) no-repeat;
  background-size: 100%;
}

/* ===================
      //MV AREA
=================== */


/* ===================
     NEW AREA
=================== */

.new_area {
  margin: auto;
  padding: 10rem 0;
}

.new_fl {
  margin-bottom: 5.8rem;
}

.new_fl .sec_ttl {
  position: relative;
  margin: 0 auto 0.5rem;
}

.new_fl .sec_ttl::before {
  content: "";
  position: absolute;
  top: 4rem;
  left: 0;
  right: 0;
  width: 4.9rem;
  margin: auto;
  border-bottom: 2px solid #92A9C5;
}

.new_fl .scalp_spa_gel {
  display: flex;
  gap: 5rem;
  justify-content: center;
  margin: 2.5rem auto 0;
}

.new_fl .scalp_spa_gel .scalp_img {
  width: 33.8rem;
  margin-left: 2rem;
}

.new_fl .scalp_spa_gel .scalp_txt {
  width: 100%;
  max-width: 34rem;
  margin-top: 7rem;
  letter-spacing: .1em;
  text-align: left;
}

.scalp_spa_gel .scalp_txt .name {
  display: inline-block;
  padding-bottom: .5rem;
  border-bottom: 1px solid #474747;
  font-size: 1.6rem;
  letter-spacing: .1em;
}

.scalp_spa_gel .scalp_txt .price {
  margin-top: 1.3rem;
  font-size: 1.8rem;
}

.scalp_spa_gel .scalp_txt .descrption {
  margin-top: 2.8rem;
  font-size: 1.4rem;
  line-height: 2;
  letter-spacing: .1em;
}

.scalp_spa_gel .scalp_txt .buy_btn a {
  margin-top: 3.3rem;
}

/* ===================
      //NEW AREA
=================== */


/* ===================
       HOW TO
=================== */

.howto_area {
  width: 110rem;
  margin: auto;
  padding: 5rem 0;
  background-color: rgba(255, 255, 255, 0.5);
}

.howto_area .title {
  margin: 0 auto 3.1rem;
}

.howto_area .how_txt {
  font-size: 1.4rem;
  line-height: 2;
  letter-spacing: .1em;
  text-align: center;
}


/* ----  HOW TO STEP ---- */

.how_step {
  position: relative;
  display: flex;
  justify-content: center;
  gap: 9.5rem;
  margin: 3.5rem auto;
  counter-reset: howto_num;
}

.how_step li {
  position: relative;
  width: 14.4rem;
}

.how_step li::before {
  content: counter(howto_num);
  counter-increment: howto_num;
}

.how_step li::before {
  position: absolute;
  top: 1.2rem;
  left: -1.5rem;
  font-size: 2.6rem;
  font-family: "muli", sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: .1em;
  color: #C8C8C8;
}

.how_step p {
  font-size: 1.4rem;
  letter-spacing: .1em;
}

/* ----  スキャルプブラシ ---- */

.brush {
  display: flex;
  justify-content: center;
  gap: 1.5rem;
}

.brush .brush_img {
  position: relative;
}

.brush .brush_img .img_pho {
  width: 18rem;
}

.brush_img .icn_txt {
  position: absolute;
  top: -2.3rem;
  left: -5.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 8rem;
  height: 8rem;
  padding: 0.2rem 0 0;
  border: 1px solid #92A9C5;
  border-radius: 50%;
  font-size: 1.4rem;
  font-family: "muli", sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: .1em;
  line-height: normal;
  color: #92A9C5;
}

.brush .brush_txt {
  margin-top: 1.2rem;
  text-align: left;
}

.brush .brush_txt .descrption {
  font-size: 1.4rem;
  letter-spacing: .1em;
}

.brush .brush_txt .name {
  display: inline-block;
  margin-top: 1.6rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid #474747;
  font-size: 1.6rem;
  letter-spacing: .1em;
}

.brush .brush_txt .price {
  margin-top: 1.5rem;
  font-size: 1.8rem;
  letter-spacing: 0.08em;
}

/* ===================
      //HOW TO
=================== */


/* ===================
    BIG BOTTLE AREA
=================== */

.bottle_area {
  padding: 9rem 0 5rem;
  background: #fff;
}

/* ---- TAB AREA ---- */

.tab-area {
  display: flex;
  justify-content: center;
  gap: 4rem;
  margin-top: 5rem;
  font-size: 1.6rem;
  letter-spacing: .1em;
  cursor: pointer;
}

.tab {
  position: relative;
  width: 100%;
  max-width: 16rem;
  padding-bottom: 1.5rem;
  text-align: center;
  color: #A3A3A3;
  white-space: nowrap;
}

.tab.active {
  color: #474747;
}

.tab::after {
  content: "";
  position: absolute;
  right: 0;
  left: 0;
  bottom: 0;
  height: 1px;
  background: #A3A3A3;
}

.tab.active::after {
  bottom: -.9rem;
  border: none;
  height: 1rem;
  background: url(../img/tag_line_pc.png) no-repeat;
  background-size: 100%;
}

.bottle_area .panel-area {
  margin: 2rem auto 0;
}

.panel {
  display: none;
  text-align: center;
}

.panel.active {
  display: block;
  animation: fadein_anime 1s linear;
}

@keyframes fadein_anime {
  0% {
    opacity: 0;
    -webkit-mask-image: linear-gradient(-25deg, transparent, transparent 39.6666666667%, rgba(0, 0, 0, .02) 43.3333333333%, rgba(0, 0, 0, .08) 45%, rgba(0, 0, 0, .18) 46.6666666667%, rgba(0, 0, 0, .32) 48.3333333333%, rgba(0, 0, 0, .5) 50%, rgba(0, 0, 0, .68) 51.6666666667%, rgba(0, 0, 0, .82) 53.3333333333%, rgba(0, 0, 0, .92) 55%, rgba(0, 0, 0, .98) 56.6666666667%, #000 58.3333333333%, #000);
    mask-image: linear-gradient(-25deg, transparent, transparent 39.6666666667%, rgba (0, 0, 0, .02) 43.3333333333%, rgba(0, 0, 0, .08) 45%, rgba(0, 0, 0, .18) 46. 6666666667%, rgba(0, 0, 0, .32) 48.3333333333%, rgba(0, 0, 0, .5) 50%, rgba(0, 0, 0, .68) 51.6666666667%, rgba(0, 0, 0, .82) 53.3333333333%, rgba(0, 0, 0, .92) 55%, rgba(0, 0, 0, .98) 56.6666666667%, #000 58.3333333333%, #000);
    -webkit-mask-size: 100% max(400%, 100vh);
    mask-size: 100% max(400%, 100vh);
    -webkit-mask-position: center 100%;
    mask-position: center 100%;
    -webkit-mask-repeat: none;
    mask-repeat: none;
    transform: translateZ(0);
    transition: -webkit-mask-position 1.4s linear;
    transition: mask-position 1.4s linear;
    transition: mask-position 1.4s linear, -webkit-mask-position 1.4s linear
  }

  100% {
    opacity: 1;
    -webkit-mask-position: center 0;
    mask-position: center 0
  }
}


/* ---- //TAB AREA ---- */

.big_bottle {
  display: flex;
  flex-direction: row-reverse;
  justify-content: center;
  gap: 4rem;
  margin: 4.3rem auto 0;
}

.big_bottle .bottle_img {
  width: 20rem;
}

.big_bottle .bottle_txt {
  margin-top: 4.3rem;
  margin-left: 3rem;
  letter-spacing: .1em;
  text-align: left;
}

.big_bottle .bottle_txt .ttl {
  font-size: 2rem;
}

.big_bottle .bottle_txt .name {
  display: inline-block;
  margin-top: 2rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid #474747;
  font-size: 1.6rem;
}

.big_bottle .bottle_txt .price {
  margin-top: 1.3rem;
  font-size: 1.8rem;
}

.price {
  font-family: "muli", sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.08em;
}

.price span {
  display: inline-block;
  font-size: 1.2rem;
  letter-spacing: 0.08em;
}

.big_bottle .bottle_txt .descrption {
  margin-top: 3.1rem;
  font-size: 1.6rem;
  line-height: 2;
}

.big_bottle .bottle_txt .descrption li {
  position: relative;
  padding-left: 3rem;
  line-height: 2;
}

.big_bottle .bottle_txt .descrption li::before {
  content: "";
  transform: translateY(-50%);
  position: absolute;
  top: 50%;
  left: .3rem;
  width: 1.8rem;
  height: 1.4rem;
  background: url(../img/check.png) no-repeat;
  background-size: 100%;
}


/* ===================
    //BIG BOTTLE AREA
=================== */


/* ===================
   SUMMER KIT AREA
=================== */

.summer_kit_area {
  padding: 5.8rem 0 10rem;
  background: #fff;
}

.kit_fl {
  display: flex;
  justify-content: center;
  gap: 4.2rem;
  margin-top: 5.5rem;
  margin-left: 3rem;
}

.kit_fl .kit_img {
  position: relative;
}

.kit_fl .kit_img .icn_txt {
  position: absolute;
  top: -3.5rem;
  left: -3.4rem;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 9.6rem;
  height: 9.6rem;
  padding: 0.2rem 0 0;
  border: 1px solid #474747;
  border-radius: 50%;
  font-size: 1.32rem;
  font-family: "muli", sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: normal;
  letter-spacing: .1em;
  color: #474747;
}

.kit_fl .kit_img .kit_pho {
  width: 34.6rem;
}

.kit_fl .kit_txt {
  margin-left: 3rem;
  letter-spacing: .1em;
  text-align: left;
}

.kit_fl .kit_txt .name {
  display: inline-block;
  margin-top: .5rem;
  font-size: 1.6rem;
  padding-bottom: .2rem;
  border-bottom: 1px solid #474747;
}

.kit_fl .kit_txt .time {
  margin-top: 3rem;
  font-size: 1.6rem;
  font-weight: bold;
}

.kit_fl .kit_txt .price {
  margin-top: 1.3rem;
  font-size: 1.8rem;
}

.kit_fl .kit_txt .descrption {
  margin-top: 1rem;
  max-width: 30rem;
  width: 100%;
  font-size: 1.4rem;
  line-height: 2;
  letter-spacing: .1em;
}


/* ===================
   //SUMMER KIT AREA
=================== */


/* ===================
   INGREDIENTS AREA
=================== */

.ingredients_area {
  padding: 9.2rem 0 12rem;
}

.ingredients_area .sub_ttl {
  position: relative;
}

.ingredients_area .sub_ttl::before {
  content: "";
  position: absolute;
  top: 6.6rem;
  left: 0;
  right: 0;
  margin: auto;
  width: 6rem;
  border-bottom: 1px solid #474747;
}

.ingredients_area .component_inner {
  margin-top: 10rem;
}

.ingredients_area .ingred_ttl {
  font-size: 1.8rem;
  letter-spacing: .1em;
}

.ingredients_area .ingred_sub {
  width: 100%;
  max-width: 50rem;
  margin: 2.2rem auto 0;
  font-size: 1.4rem;
  line-height: 2;
  letter-spacing: .1em;
  text-align: justify;
}

.ingredients_area .component_inner .ingred_sub span {
  display: block;
  font-size: 1.2rem;
  letter-spacing: .1em;
  line-height: 0;
  text-align: right;
}

.component_inner .component_image {
  display: flex;
  justify-content: center;
  gap: 4.7rem;
  margin: 4rem auto 0;
}

.component_inner .component_image li {
  width: 10rem;
}

.component_inner .component_image li .ingredients_img {
  margin: auto;
  width: 9rem;
}

.component_inner .component_image li .li_txt {
  margin-top: 1.3rem;
  font-size: 1.2rem;
  line-height: 2;
  letter-spacing: .1em;
  text-align: center;
}

.ingredients_area .scent_inner {
  margin-top: 9.1rem;
}

.scent_inner .scent_point {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0 5rem;
  width: 61rem;
  margin: 3.2rem auto 0;
}

.scent_inner .scent_point li {
  position: relative;
  width: 17rem;
  height: 17rem;
  padding-top: 3.5rem;
  border: 1px solid #92A9C5;
  border-radius: 50%;
}

.scent_inner .scent_point li:nth-child(3) .point_icn {
  position: absolute;
  top: 15.4rem;
  right: -2.2rem;
  font-size: 1rem;
  letter-spacing: .1em;
}

.scent_inner .scent_point li:nth-child(4),
.scent_inner .scent_point li:nth-child(5) {
  margin-top: 2rem;
  padding-top: 2.5rem;
}

.scent_inner .scent_point .point_ttl {
  font-size: 1.5rem;
  letter-spacing: 0;
  color: #92A9C5;
}

.scent_inner .scent_point p {
  margin-top: 1rem;
  font-size: 1.2rem;
  line-height: 2.1rem;
  letter-spacing: .1em;
  text-align: center;
}

.ingredients_area .water_inner {
  margin-top: 9.5rem;
}

.water_inner .component_image {
  display: flex;
  justify-content: center;
  gap: 5.7rem;
  margin: 3.6rem auto 0;
}

.water_inner .component_image li .ingredients_img {
  width: 9rem;
  margin: auto;
}


/* ===================
  //INGREDIENTS AREA
=================== */


/* ===================
    REVIEW AREA
=================== */

.review_area {
  padding: 10rem 0 0;
  background: #fff;
}

.review_area .review_inner {
  width: 80rem;
  margin: 5.9rem auto 0;
}

.review_area .review_inner li:not(:first-child) {
  margin-top: 5.1rem;
}

.review_area .review_inner li {
  padding: 3.6rem 4rem;
  border: 1px solid #92A9C5;
  text-align: left;
}

.review_area .review_inner .rev_ttl {
  font-size: 1.8rem;
  font-weight: 300;
  letter-spacing: .1em;
  color: #92A9C5;
}

.review_area .review_inner .rev_txt {
  margin-top: 1.2rem;
  font-size: 1.4rem;
  line-height: 2;
  letter-spacing: .1em;
}

.review_area .review_inner .rev_name {
  margin-top: 2rem;
  font-size: 1.4rem;
  letter-spacing: .1em;
  color: #92A9C5;
}

.review_area .review_inner .rev_name a {
  display: inline-block;
  color: #92A9C5;
}

.rev_btn a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 5.4rem;
  height: 1.8rem;
  margin-left: .5rem;
  /*padding: 0.2rem 0 0;*/
  font-size: 1.08rem;
  font-family: "muli", sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: .1em;
  line-height: normal;
  background-color: #92A9C5;
  color: #fff;
}


/* ===================
    //REVIEW AREA
=================== */


/* ===================
     PICK UP AREA
=================== */

.pick_up_area {
  padding: 7.2rem 0 8rem;
  background: #fff;
}

.pick_up_area .pick_items {
  display: flex;
  justify-content: center;
  gap: 4.2rem;
  margin: 3rem auto 0;
}

.pick_up_area .pick_items li {
  width: 100%;
  max-width: 17.8rem;
}

.pick_up_area .pick_items .pick_img {
  width: 9.7rem;
  margin: auto;
}

.pick_up_area .pick_items .pick_txt {
  margin-top: 1.5rem;
}

.pick_up_area .pick_items .pick_txt .name {
  font-size: 1.4rem;
  letter-spacing: .06em;
  white-space: nowrap;
}

.pick_up_area .pick_items .pick_txt .price {
  margin-top: .5rem;
  font-size: 1.5rem;
  letter-spacing: .1em;
}

.pick_up_area .all_btn a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30rem;
  height: 6rem;
  margin: 7.7rem auto 0;
  font-size: 1.8rem;
  font-family: "muli", sans-serif;
  font-weight: 300;
  font-style: normal;
  letter-spacing: .1em;
  background-color: #474747;
  color: #fff;
}

.pick_up_area .all_btn a:hover {
  opacity: .7;
}


/* ===================
     //PICK UP AREA
=================== */


/*=======================================
               Responsive
========================================*/

/* Only for tablet */

@media screen and (min-width: 768px) and (max-width: 1200px) and (-webkit-min-device-pixel-ratio: 1) {
  html {
    font-size: calc(10* (100vw / 1200)) !important;
  }

  header,
  .contents,
  footer {
    min-width: 0;
  }

  .fixed .naviDetail .contentsArea .brandinfo li {
    margin: 0 16px;
  }

  .scent_inner .scent_point p {
    letter-spacing: .02em;
  }
}

/* Only for tablet */


/*=======================================
                    PC
========================================*/

@media screen and (min-width:768px) {
  .lp_contents .sp_only {
    display: none;
  }

  .cam_bnr_wrap {
    position: relative;
    z-index: 999;
  }
}


/*=======================================
                    SP
========================================*/

@media screen and (max-width: 767px) {

  /* ===================
      LP CONTENTS
  =================== */

  .lp_contents {
    font-weight: 300;
  }

  #Contents.cam_bnr__active_txt {
    margin-top: calc(225 * (100vw / 750)) !important;
  }

  footer {
    min-width: 0;
    margin-top: calc(-40* (100vw / 750));
  }

  .footer_app .footer_banner li .text,
  .footer_app .footer_banner li .link_text {
    font-size: 12px;
    letter-spacing: 0;
  }

  .footer_app .footer_banner li .link_text::after {
    top: 15px;
  }

  .lp_contents .pc_only {
    display: none;
  }

  .lp_contents .sp_only {
    display: block;
  }

  .lp_bg {
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100vw;
    height: 100%;
    margin: 0 calc(50% - 50vw);
    background: url(../img/bg_sp.jpg) center center / cover no-repeat;
  }

  /* ===================
      //LP CONTENTS
  =================== */

  /* ===================
        COMMON
  =================== */

  .lp_contents .sec_ttl {
    font-size: calc(40* (100vw / 750));
    line-height: 2;
  }

  .lp_contents .title {
    font-size: calc(40* (100vw / 750));
  }

  .lp_contents .sub_ttl {
    margin-top: calc(28* (100vw / 750));
    font-size: calc(26* (100vw / 750));
  }

  .buy_btn a {
    width: calc(270* (100vw / 750));
    height: calc(60* (100vw / 750));
    margin: calc(50* (100vw / 750)) auto 0;
    padding: 0;
    font-size: calc(26* (100vw / 750));
  }

  /* ===================
        //COMMON
  =================== */

  /* ===================
        MV AREA
  =================== */

  .mv_area {
    height: calc(1160* (100vw / 750));
  }

  .mv_area .main_logo {
    width: calc(100* (100vw / 750));
    padding-top: calc(225* (100vw / 750));
  }

  .mv_area .main_ttl {
    margin: calc(16* (100vw / 750)) auto calc(189* (100vw / 750));
    font-size: calc(52* (100vw / 750));
    line-height: 2;
    text-shadow: 0 0 12px #fff;
  }

  .mv_area .nav_menu {
    flex-wrap: wrap;
    gap: calc(50* (100vw / 750));
  }

  .mv_area .nav_menu li {
    font-size: calc(26* (100vw / 750));
    line-height: 2;
  }

  .mv_area .nav_menu li span {
    font-size: calc(22* (100vw / 750));
  }

  .mv_area .nav_menu li .link {
    width: calc(200* (100vw / 750));
    height: calc(200* (100vw / 750));
    padding-top: calc(40* (100vw / 750));
  }

  .mv_area .nav_menu li .link::after {
    bottom: calc(32* (100vw / 750));
    width: calc(20* (100vw / 750));
    height: calc(12* (100vw / 750));
  }

  /* ===================
        //MV AREA
  =================== */


  /* ===================
      NEW AREA
  =================== */

  .new_area {
    padding: calc(97* (100vw / 750)) 0 calc(120* (100vw / 750));
  }

  .new_fl {
    margin-bottom: calc(120* (100vw / 750));
  }

  .new_fl .sec_ttl {
    margin: 0 auto calc(10* (100vw / 750));
  }

  .new_fl .sec_ttl::before {
    top: calc(83* (100vw / 750));
    width: calc(75* (100vw / 750));
  }

  .new_fl .scalp_spa_gel {
    flex-wrap: wrap;
    justify-content: center;
    gap: inherit;
    width: calc(750* (100vw / 750));
    margin: calc(10* (100vw / 750)) auto 0;
  }

  .new_fl .scalp_spa_gel .scalp_img {
    width: calc(491* (100vw / 750));
    margin: auto;
  }

  .new_fl .scalp_spa_gel .scalp_txt {
    margin: calc(3* (100vw / 750)) auto 0;
    max-width: calc(590* (100vw / 750));
    text-align: center;
  }

  .scalp_spa_gel .scalp_txt .name {
    padding-bottom: calc(3* (100vw / 750));
    font-size: calc(26* (100vw / 750));
  }

  .scalp_spa_gel .scalp_txt .price {
    margin-top: calc(30* (100vw / 750));
    font-size: calc(28* (100vw / 750));
    text-align: center;
  }

  .scalp_spa_gel .scalp_txt .descrption {
    margin-top: calc(38* (100vw / 750));
    font-size: calc(24* (100vw / 750));
    text-align: justify;
  }

  .scalp_spa_gel .scalp_txt .buy_btn a {
    margin: calc(45* (100vw / 750)) auto 0;
  }

  /* ===================
        //NEW AREA
  =================== */

  /* ===================
         HOW TO
  =================== */

  .howto_area {
    width: calc(690* (100vw / 750));
    padding: calc(68* (100vw / 750)) 0 calc(75* (100vw / 750));
  }

  .howto_area .title {
    margin: 0 auto calc(29* (100vw / 750));
  }

  .howto_area .how_txt {
    max-width: calc(550* (100vw / 750));
    width: 100%;
    font-size: calc(24* (100vw / 750));
    margin: auto;
    text-align: left;
  }

  .how_step {
    flex-wrap: wrap;
    margin: calc(24* (100vw / 750)) auto;
    gap: 0 calc(90* (100vw / 750));
  }

  .how_step li {
    width: calc(219* (100vw / 750));
  }

  .how_step li:nth-child(3),
  .how_step li:nth-child(4) {
    margin-top: calc(-18* (100vw / 750));
  }

  .how_step li::before {
    top: calc(23* (100vw / 750));
    left: calc(-11* (100vw / 750));
    font-size: calc(32* (100vw / 750));
  }

  .how_step p {
    position: relative;
    right: calc(-40* (100vw / 750));
    font-size: calc(20* (100vw / 750));
  }

  .brush {
    flex-wrap: wrap;
    justify-content: center;
    flex-direction: column;
    align-items: center;
    gap: inherit;
    margin: calc(74* (100vw / 750)) auto 0;
  }

  .brush .brush_img .img_pho {
    width: calc(300* (100vw / 750));
    margin: auto;
  }

  .brush_img .icn_txt {
    top: calc(-60* (100vw / 750));
    left: calc(-37* (100vw / 750));
    width: calc(130* (100vw / 750));
    height: calc(130* (100vw / 750));
    padding: 0;
    font-size: calc(24* (100vw / 750));
  }

  .brush .brush_txt {
    margin-top: calc(17* (100vw / 750));
    text-align: center;
  }

  .brush .brush_txt .descrption {
    font-size: calc(22* (100vw / 750));
    text-align: center;
  }

  .brush .brush_txt .name {
    margin-top: calc(22* (100vw / 750));
    padding-bottom: 0;
    font-size: calc(26* (100vw / 750));
  }

  .brush .brush_txt .price {
    margin-top: calc(30* (100vw / 750));
    font-size: calc(28* (100vw / 750));
    text-align: center;
  }

  .price span {
    font-size: calc(22* (100vw / 750));
  }

  /* ===================
        //HOW TO
  =================== */

  /* ===================
      BIG BOTTLE AREA
  =================== */

  .bottle_area {
    padding: calc(107* (100vw / 750)) 0 calc(85* (100vw / 750));
  }

  /* ---- TAB AREA ---- */

  .tab-area {
    margin-top: calc(79* (100vw / 750));
    gap: calc(69* (100vw / 750));
    font-size: calc(24* (100vw / 750));
  }

  .tab {
    max-width: calc(162* (100vw / 750));
    padding-bottom: calc(16* (100vw / 750));
  }

  .tab.active::after {
    bottom: calc(-11* (100vw / 750));
    background: url(../img/tag_line_sp.png) no-repeat;
    background-size: 100%;
    height: calc(14* (100vw / 750));
  }


  .bottle_area .panel-area {
    margin: calc(30* (100vw / 750)) auto 0;
  }

  /* ---- //TAB AREA ---- */

  .big_bottle {
    flex-wrap: wrap;
    flex-direction: inherit;
    gap: inherit;
    width: calc(597* (100vw / 750));
    margin: calc(71* (100vw / 750)) auto 0;
  }

  .big_bottle .ttl {
    max-width: calc(597* (100vw / 750));
    width: 100%;
    font-size: calc(30* (100vw / 750));
    letter-spacing: .1em;
    text-align: center;
  }

  .big_bottle .bottle_img {
    width: calc(300* (100vw / 750));
    margin-top: calc(24* (100vw / 750));
  }

  .big_bottle .bottle_txt {
    margin: calc(24* (100vw / 750)) auto 0;
    text-align: center;
  }

  .big_bottle .bottle_txt .name {
    margin-top: calc(30* (100vw / 750));
    padding-bottom: 0;
    font-size: calc(26* (100vw / 750));
  }

  .big_bottle .bottle_txt .price {
    margin-top: calc(30* (100vw / 750));
    font-size: calc(28* (100vw / 750));
    text-align: center;
  }

  .big_bottle .bottle_txt .descrption {
    margin-top: calc(32* (100vw / 750));
    font-size: calc(24* (100vw / 750));
    text-align: left;
  }

  .big_bottle .bottle_txt .descrption li {
    padding-left: calc(50* (100vw / 750));
    letter-spacing: 0.08em;
  }

  .big_bottle .bottle_txt .descrption li::before {
    left: 0;
    width: calc(26* (100vw / 750));
    height: calc(20* (100vw / 750));
  }

  /* ===================
      //BIG BOTTLE AREA
  =================== */

  /* ===================
    SUMMER KIT AREA
  =================== */

  .summer_kit_area {
    padding: calc(62* (100vw / 750)) 0 calc(148* (100vw / 750));
  }

  .kit_fl {
    flex-wrap: wrap;
    margin: calc(82* (100vw / 750)) auto 0;
    justify-content: center;
    gap: inherit;
  }

  .kit_fl .kit_img .icn_txt {
    top: calc(-40* (100vw / 750));
    left: calc(-70* (100vw / 750));
    width: calc(160* (100vw / 750));
    height: calc(160* (100vw / 750));
    padding: 0;
    font-size: calc(24* (100vw / 750));
  }

  .kit_fl .kit_img .kit_pho {
    width: calc(522* (100vw / 750));
  }

  .kit_fl .kit_txt {
    margin: calc(36* (100vw / 750)) auto 0;
    text-align: center;
  }

  .kit_fl .kit_txt .name {
    margin-top: calc(20* (100vw / 750));
    font-size: calc(26* (100vw / 750));
    padding-bottom: 0;
  }

  .kit_fl .kit_txt .time {
    margin-top: calc(47* (100vw / 750));
    font-size: calc(26* (100vw / 750));
    text-align: center;
  }

  .kit_fl .kit_txt .price {
    margin-top: calc(28* (100vw / 750));
    font-size: calc(28* (100vw / 750));
    text-align: center;
  }

  .kit_fl .kit_txt .descrption {
    max-width: calc(590* (100vw / 750));
    margin-top: calc(20* (100vw / 750));
    font-size: calc(24* (100vw / 750));
    text-align: left;
  }

  /* ===================
    //SUMMER KIT AREA
  =================== */


  /* ===================
    INGREDIENTS AREA
  =================== */

  .ingredients_area {
    padding: calc(109* (100vw / 750)) 0 calc(140* (100vw / 750));
  }

  .ingredients_area .sub_ttl::before {
    width: calc(100* (100vw / 750));
    top: calc(112* (100vw / 750));
  }

  .ingredients_area .component_inner {
    margin-top: calc(137* (100vw / 750));
  }

  .ingredients_area .ingred_ttl {
    font-size: calc(28* (100vw / 750));
    line-height: 2;
  }

  .ingredients_area .ingred_sub {
    margin: calc(32* (100vw / 750)) auto 0;
    max-width: calc(590* (100vw / 750));
    font-size: calc(24* (100vw / 750));
  }

  .ingredients_area .component_inner .ingred_sub span {
    font-size: calc(18* (100vw / 750));
    line-height: 2.8;
  }

  .component_inner .component_image {
    flex-wrap: wrap;
    margin: calc(32* (100vw / 750)) auto 0;
    justify-content: center;
    gap: calc(49* (100vw / 750)) calc(109* (100vw / 750));
  }

  .component_inner .component_image li {
    width: calc(178* (100vw / 750));
  }

  .component_inner .component_image li .ingredients_img {
    width: calc(160* (100vw / 750));
  }

  .component_inner .component_image li .li_txt {
    margin-top: calc(17* (100vw / 750));
    font-size: calc(22* (100vw / 750));
    line-height: 1.8;
  }

  .ingredients_area .scent_inner {
    margin-top: calc(111* (100vw / 750));
  }

  .scent_inner .scent_point {
    width: calc(670* (100vw / 750));
    margin: calc(47* (100vw / 750)) auto 0;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: inherit;
  }

  .scent_inner .scent_point li {
    width: calc(310* (100vw / 750));
    height: calc(310* (100vw / 750));
    padding-top: calc(63* (100vw / 750));
  }

  .scent_inner .scent_point li:nth-child(3) .point_icn {
    top: calc(228* (100vw / 750));
    right: calc(-72* (100vw / 750));
    font-size: calc(18* (100vw / 750));
  }

  .scent_inner .scent_point li:nth-child(3) {
    margin-top: 0;
    margin-left: calc(179* (100vw / 750));
  }

  .scent_inner .scent_point li:nth-child(4),
  .scent_inner .scent_point li:nth-child(5) {
    margin-top: 0;
    padding-top: calc(44* (100vw / 750));
  }

  .scent_inner .scent_point .point_ttl {
    font-size: calc(26* (100vw / 750));
  }

  .scent_inner .scent_point p {
    margin-top: calc(18* (100vw / 750));
    font-size: calc(22* (100vw / 750));
    line-height: 1.8;
  }

  .ingredients_area .water_inner {
    margin-top: calc(128* (100vw / 750));
  }

  .water_inner .component_image {
    flex-wrap: wrap;
    justify-content: space-between;
    gap: calc(60* (100vw / 750)) 0;
    width: calc(420* (100vw / 750));
    margin: calc(48* (100vw / 750)) auto 0;
  }

  .water_inner .component_image li .ingredients_img {
    width: calc(160* (100vw / 750));
  }

  /* ===================
    //INGREDIENTS AREA
  =================== */


  /* ===================
      REVIEW AREA
  =================== */

  .review_area {
    padding: calc(98* (100vw / 750)) 0 0;
  }

  .review_area .review_inner {
    width: calc(690* (100vw / 750));
    margin: calc(36* (100vw / 750)) auto 0;
  }

  .review_area .review_inner li:not(:first-child) {
    margin-top: calc(79* (100vw / 750));
  }

  .review_area .review_inner li {
    padding: calc(50* (100vw / 750)) calc(60* (100vw / 750)) calc(57* (100vw / 750));
  }

  .review_area .review_inner .rev_ttl {
    font-size: calc(30* (100vw / 750));
    font-weight: 300;
  }

  .review_area .review_inner .rev_txt {
    margin-top: calc(24* (100vw / 750));
    font-size: calc(24* (100vw / 750));
  }

  .review_area .review_inner .rev_name {
    margin-top: calc(22* (100vw / 750));
    font-size: calc(20* (100vw / 750));
  }

  .rev_btn a {
    width: calc(90* (100vw / 750));
    height: calc(30* (100vw / 750));
    margin-left: calc(8* (100vw / 750));
    font-size: calc(18* (100vw / 750));
  }

  /* ===================
      //REVIEW AREA
  =================== */


  /* ===================
      PICK UP AREA
  =================== */

  .pick_up_area {
    padding: calc(104* (100vw / 750)) 0 calc(120* (100vw / 750));
  }

  .pick_up_area .pick_items {
    margin: calc(42* (100vw / 750)) auto 0;
    flex-wrap: nowrap;
    justify-content: center;
    gap: inherit;
    width: calc(650* (100vw / 750));
  }

  .pick_up_area .pick_items li {
    max-width: inherit;
    width: calc(217* (100vw / 750)) !important;
  }

  .pick_up_area .pick_items .pick_img {
    width: calc(147* (100vw / 750));
    margin: auto;
  }

  .pick_up_area .pick_items .pick_txt {
    margin-top: calc(30* (100vw / 750));
  }

  .pick_up_area .pick_items .pick_txt .name {
    font-size: calc(22* (100vw / 750));
  }

  .pick_up_area .pick_items .pick_txt .price {
    margin-top: calc(3* (100vw / 750));
    font-size: calc(24* (100vw / 750));
    letter-spacing: 0;
  }

  .pick_up_area .pick_items .pick_txt .price span {
    display: inline-block;
    font-size: calc(19* (100vw / 750));
  }

  .pick_up_area .all_btn a {
    margin: calc(100* (100vw / 750)) auto 0;
    width: calc(500* (100vw / 750));
    height: calc(100* (100vw / 750));
    font-size: calc(30* (100vw / 750));
    font-weight: 300;
  }

  /* ---- SLIDER ---- */

  .pick_up_area .slick_area .slick-prev {
    left: -4%;
    background-image: url(../img/left_sp.png);
  }

  .pick_up_area .slick_area .slick-prev,
  .pick_up_area .slick_area .slick-next {
    background-repeat: no-repeat;
    height: calc(40* (100vw / 750));
    width: calc(20* (100vw / 750));
    background-size: 100%;
  }

  .pick_up_area .slick_area .slick-prev:before,
  .pick_up_area .slick_area .slick-next:before {
    content: none;
  }

  .pick_up_area .slick_area .slick-next {
    right: -4%;
    background-image: url(../img/right_sp.png);
  }

  .pick_up_area .slick_area .slick-prev,
  .pick_up_area .slick_area .slick-next {
    top: 36%;
  }

  /* ---- //SLIDER ---- */

  /* ===================
      //PICK UP AREA
  =================== */

}
