@charset "UTF-8";
/* CSS Document */
body{
    width: 100%;
}
#top{
     width: 100%;
    height: 100vh;
    background-image: url("../img/bg.jpeg");
    background-repeat: no-repeat;
    background-size: cover;
    background-attachment: fixed;
    z-index: -10;
}
/*header*/
.headerLogo{
    display: flex;
    justify-content: space-between;
}
.logo{
    width: 100%;
    max-width: 100px;
    height: auto;
    padding: 26px 0 0 25px;
    position: fixed;
    top: 0;
    left: 0;
     z-index:70;
}
.cart{
    width: 12%;
    max-width: 68px;
    height: auto;
    padding: 26px 25px 0 0;
    position: fixed;
    top: 0;
    right: 0;
     z-index:70;
}
.mv{
    width: 100%;
}
@media screen and (min-width:769px){
.mv{
    position: relative;
    padding-top: 177px;
    }
}
.mv_text{
    width: fit-content;
    margin: 125px auto 50px;
}
@media screen and (min-width:769px){
    .mv_text{
        position: absolute;
        top:20%;
        left:7.5%;
    }
}
.mv_text h1{
    margin-bottom: 15px;
    font-size :clamp(64px,4vw,72px);
    font-family: "hiragino-mincho-pron", sans-serif;
    font-weight: bold;
    font-style: normal;
    line-height: 0.8em;
}
.mv_text h1 span{
    display: block;
    font-size: 0.4em;
}
.cc{
   text-align: right;
    font-size :clamp(12px,1vw,20px);
    margin-right:-2em;
}
.cc span{
    display: block;
    margin-right: -1em;
}
/*フェード*/
.js_img_fade {
    opacity: 0;
    visibility: hidden;
    transform: translateY(50px);
    transition: opacity 1s,visibility 1s, transform 1s;
}

.img_fade_scroll {
    opacity: 1;
    visibility: visible;
    transform: translateY(0px);
}
/* フェードイン用のCSS */
.slide-bottom {
   opacity: 0;
   transform: translateY(20px);
   transition: all 1.3s 0s ease-out;
 }
/*メインビジュアル*/
.mv_img{
    width: 86%;
    margin: 0 auto 65px;
    display: flex;
    justify-content: center;
}
@media screen and (min-width:769px){
    .mv_img{
        width: 38%;
    }
}
.mv_shampoo{
    width: 33%;
    max-width: 278px;
    height: auto;
    transform: rotate(-10deg);
    z-index: 1;
    filter:drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.5));
}
.mv_treatment{
    width: 33%;
     max-width: 278px;
    height: auto;
     transform: rotate(10deg);
     filter:drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.5));
}
/*ナビゲーション*/
.gnav{
    display: none;
    font-size: clamp(12px,1vw,16px);
}
@media screen and (min-width:769px){
    .gnav{
       display: block;
        position: fixed;
        top:40%;
        right: 5%;
    }
    .gnav ul li{
        margin-bottom: 70px;
    }
}
/*ナビゲーションボタン*/
.navIconBtn{
     width: 40px;
    height: 40px;
    background-image: url("../img/threePointLeader.png");
   background-size: 24px;
    background-position: center;
    background-repeat: no-repeat;
     cursor: pointer;
    margin: 0 25px 0 0;
     position: fixed;
    right: 0;
    bottom: 5%;
     z-index: 70;
}
@media screen and (min-width:769px){
    .navIconBtn{
        display: none;
    }
}
.navIconBtn.is-active{
    background-image: url("../img/close.png");
}
/*openメニュー*/
.menu{
    display: none;
    align-items: center;
    justify-content: center;
    width: 100vw;
    height: 100vh;
    background-color: #fffbef;
    position: fixed;
    top: 0;
    left:0;
    z-index:69;
}
@media screen and (min-width:769px){
    .menu{
        background-color: transparent;
    }
}
.menu.is-active{
    display: flex;
}
@media screen and (min-width:769px){
.navSp{
    display: none;
}
}
.navSp ul li{
    margin-bottom: 70px;
    font-size: clamp(12px,1vw,16px);
}
/*main*/
/*section1*/
#Features h2{
    width: 91%;
    margin: 0 auto;
    padding-top: 100px;
    margin-bottom: 62px;
    text-align: center;
    font-size: clamp(12px,1.5vw,24px);
}
@media screen and (min-width:769px){
    #Features h2{
        width: 70%;
        padding-top: 82px; 
    }
}
#Features .new{
    text-align: center;
    margin-bottom: 8px;
}
#Features .element{
    text-align: center;
    margin-bottom: 55px;
    font-size: 2.417em;
    font-size: clamp(29px,3vw,58px);
    font-weight: bold;
}
.circleBox{
    width: 67%;
    margin: 0 auto;
    margin-bottom: 30px;
}
.circle{
     width: 90px;
    height: 90px;
    border: 1px solid #545454;
    border-radius: 200px;
    padding: 20px 0 20px 0;
}
.triangle{
    width: 25%;
    height: auto;
    margin: 0 auto;
    margin-bottom: 45px;
}
.lead{
    width: 90%;
    margin: 0 auto;
    text-align: center;
    font-size: clamp(12px,2vw,25px);
    margin-bottom: 26px;
}
.strong{
    text-align: center;
    margin-bottom: 62px;
    font-size: 1.7em;
    font-size: clamp(20px,2vw,51px);
    font-family: "hiragino-mincho-pron", sans-serif;
    font-weight: bold;
    font-style: normal;
}
span.orange{
    color: #E59E24;
}
.bottleImage{
    display: flex;
    justify-content: center;
    width: 85%;
    margin: 0 auto;
    margin-bottom: 65px;
}
.Sbox{
    width: 50%;
}
.Sbox img{
    width: 44%;
    height: auto;
    margin: 0 auto;
    margin-bottom: 10px;
}
.Sbox p{
    width: 100%;
    text-align: center;
    font-size: clamp(12px,1vw,20px);
}
.Tbox{
    width: 50%;
}
.Tbox img{
    width: 45%;
    height: auto;
    margin: 0 auto;
    margin-bottom: 5px;
}
.Tbox p{
     width: 100%;
    text-align: center;
    font-size: clamp(12px,1vw,20px);
}
/*section2*/
.h2_EN{
    font-size: 1.3em;
    font-size: clamp(16px,2vw,30px);
}
#LimitedTimeScent h2,h3,.kinmokusei{
    text-align: center;
}
#LimitedTimeScent h2{
    width: 65%;
     position: relative;
     display: block;
    margin: auto;
     margin-bottom: 5em;
}
#LimitedTimeScent h2 :before{
    content: '';
  position: absolute;
  left: 50%;
  top: -15px;/*線の上下位置*/
  display: inline-block;
  width: 100%;/*線の長さ*/
  height: 0.5px;/*線の太さ*/
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);/*位置調整*/
  background-color: black;/*線の色*/
  border-radius: 1px;/*線の丸み*/
}
#LimitedTimeScent h2 :after{
    content: '';
  position: absolute;
  left: 50%;
  bottom: -15px;/*線の上下位置*/
  display: inline-block;
  width: 37%;/*線の長さ*/
  height: 0.5px;/*線の太さ*/
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);/*位置調整*/
  background-color: black;/*線の色*/
  border-radius: 1px;/*線の丸み*/
}
#LimitedTimeScent h3{
    font-size: 3.6em;
    font-weight: normal;
}
#LimitedTimeScent .kinmokusei{
    margin-bottom: 23px;
}
.leadS2{
    width: 62%;
    font-size: clamp(12px,2vw,15px);
    margin: 0 auto;
    margin-bottom: 95px;
}
.detailS{
    width: 52%;
    position: relative;
}
.contentS{
    display: flex;
    justify-content: space-around;
    margin-bottom: 100px;
}
.detailS h4{
    font-size: clamp(12px,2vw,16px);
    margin-bottom: 35px;
}
.detailS p{
    font-size: clamp(12px,2vw,16px);
}
.TSS{
    width: 100%;
    max-width: 392px;
    height: auto;
    position: absolute;
    bottom: 0;
}
.bottleSimg{
    width: 31%;
    max-width: 176px;
    height: auto;
}
.contentT{
    display: flex;
    justify-content:space-around;
    margin-bottom: 100px;
}
.detailT{
    width: 52%;
    position: relative;
}
.bottleTimg{
    width: 31%;
    max-width: 176px;
    height: auto;
}
.detailT h4{
    font-size: clamp(12px,2vw,16px);
    margin-bottom: 35px;
}
.detailT p{
    font-size: clamp(12px,2vw,16px);
}
.TTS{
    width: 100%;
    max-width: 392px;
    height: auto;
     position: absolute;
    bottom: 0;
}
.sampleImg{
    width: 80%;
    height: auto;
    margin: 0 auto;
    margin-bottom: 17px;
}
#LimitedTimeScent h5{
    width: 78%;
    height: auto;
    font-size: 1.1em;
    font-size: clamp(13px,2vw,20px);
    font-weight: normal;
    margin: 0 auto;
    text-align: center;
    margin-bottom: 12px;
}
#LimitedTimeScent p.asterisk{
    font-size: 0.83em;
    display: block;
    width: 79%;
    margin: 0 auto;
    margin-bottom: 47px;
    text-align: center;
}
/*section3*/
#HowToWash h2{
    width: fit-content;
    margin: 0 auto;
    margin-bottom: 100px;
    text-align: center;
    letter-spacing: 0.3em;
}
.h2_HowToWash{
    font-size: 1.3em;
    font-size: clamp(14px,2vw,30px);
}
.howToWashImg{
    width: 100%;
    aspect-ratio:189/222;
    margin-bottom: 95px;
}
.slider_wrap{          
    position: relative;
    width: 59%;
    max-width: 374px;
    margin: 0 auto;
    margin-bottom: 160px;
}
.slider_wrap::before{
    content: '';
    display: block;
    background: url("../img/flame.png") no-repeat;
    background-position: top center;
    background-size: 100% 100%;
    width: 100%;
    aspect-ratio:189/222;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%) scale(1.2);
    z-index: 50;
}
.slider{
    width: 100%;
    position: relative;
}
.howToWashImg img{
    object-fit: cover;
}
.howToWashText{
    text-align: center;
}
.prev_arrow{
    background: url("../img/next.png") no-repeat;
    background-size: contain;
    transform: rotate(180deg);
    width: 8%;
     aspect-ratio:1/1;
    border: none;
    z-index: 30;
    position: absolute;
    left: -22%;
    top: 35%;
}
.next_arrow{
    background: url("../img/next.png") no-repeat;
    background-size: contain;
    width: 8%;
    aspect-ratio:1/1;
    border: none;
     z-index: 30;
    position: absolute;
    right: -22%;
    top: 35%;
}
.howToWash_slider p{
    font-size: 1.1em;
    font-size: clamp(13px,2vw,20px);
    letter-spacing: 0.1em;
}
/*オーダーフォーム*/
#order{
    font-size: 12px;
    font-family: "hiragino-mincho-pron", sans-serif;
    font-weight: normal;
    font-style: normal;
    color: #707070;
    background-color: #FFFBEF;
}
.Flogo{
     width: 20%;
    max-width: 100px;
    height: auto;
    position: relative;
    top: 26px;
    left: 25px;
}
.Form {
  width: 81%;
  background-color: #FFFFFF;
  margin-top: 80px;
  margin-left: auto;
  margin-right: auto;
  max-width: 1527px;
 padding-bottom: 45px;
    margin-bottom: 50px;
}
@media screen and (max-width: 480px) {
  .Form {
    margin-top: 70px;
  }
}
.Form h1{
    padding-top: 45px;
    margin-bottom: 35px;
    text-align: center;
    position: relative;
}
.Form h1::after{
  content: "";
  position: absolute;
  left: 50%;
  bottom: -15px;/*線の上下位置*/
  display: inline-block;
  width: 82%;/*線の長さ*/
  height: 0.5px;/*線の太さ*/
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);/*位置調整*/
  background-color: black;/*線の色*/
  border-radius: 1px;/*線の丸み*/
  border-bottom: solid #707070 0.5px;
}
#fastFormItem{
      margin-bottom: 50px;
}
.ProductName{
    margin-right: 10px;
     font-size: 12px;
    font-size: clamp(12px,2vw,20px);
}
#select{
    font-size: 12px;
    font-size: clamp(12px,2vw,20px);
}
select#select{
    width: 75%;
}
.Form #lastFormItem{
    margin-bottom: 68px;
}
.Form h2{
    font-size: 12px;
    font-size: clamp(12px,2vw,20px);
    text-align: center;
    margin-bottom: 27px;
}
.Form .question{
    width: 82%;
    margin: 0 auto;
    margin-bottom: 68px;
    border-bottom: solid #707070 0.5px;
     border-top: solid #707070 0.5px;
     font-size: clamp(12px,2vw,20px);
}
.question p{
    margin-bottom: 12px;
}
.Q1{
    padding-top: 25px;
    margin-bottom: 56px;
}
.Q2{
    margin-bottom: 56px;
}
.Q3{
    margin-bottom: 56px;
}
.Form-Item {
  padding-top: 24px;
  padding-bottom: 24px;
  width: 82%;
    margin: 0 auto;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 480px) {
  .Form-Item {
    padding-left: 14px;
    padding-right: 14px;
    padding-top: 16px;
    padding-bottom: 16px;
    flex-wrap: wrap;
  }
}
.Form-Item:nth-child(5) {

}
.Form-Item-Label {
  width: 100%;
  max-width: 248px;
  letter-spacing: 0.05em;
  font-weight: bold;
  font-size: 18px;
}
@media screen and (max-width: 480px) {
  .Form-Item-Label {
    max-width: inherit;
    display: flex;
    align-items: center;
    font-size: 15px;
  }
}
.Form-Item-Label.isMsg {
  margin-top: 8px;
  margin-bottom: auto;
}
@media screen and (max-width: 480px) {
  .Form-Item-Label.isMsg {
    margin-top: 0;
  }
}
.Form-Item-Label-Required {
  border-radius: 6px;
  margin-right: 8px;
  padding-top: 8px;
  padding-bottom: 8px;
  width: 48px;
  display: inline-block;
  text-align: center;
  background: #545454;
  color: #fff;
  font-size: 14px;
}
@media screen and (max-width: 480px) {
  .Form-Item-Label-Required {
    border-radius: 4px;
    padding-top: 4px;
    padding-bottom: 4px;
    width: 32px;
    font-size: 10px;
  }
}
.Form-Item-Input {
  border: 1px solid #ddd;
  border-radius: 6px;
  margin-left: 40px;
  padding-left: 1em;
  padding-right: 1em;
  height: 48px;
  flex: 1;
  width: 100%;
  max-width: 410px;
  background: #eaedf2;
  font-size: 18px;
}
@media screen and (max-width: 480px) {
  .Form-Item-Input {
    margin-left: 0;
    margin-top: 18px;
    height: 40px;
    flex: inherit;
    font-size: 15px;
  }
}
.Form-Item-Textarea {
  border: 1px solid #ddd;
  border-radius: 6px;
  margin-left: 40px;
  padding-left: 1em;
  padding-right: 1em;
  height: 216px;
  flex: 1;
  width: 100%;
  max-width: 410px;
  background: #eaedf2;
  font-size: 18px;
}
@media screen and (max-width: 480px) {
  .Form-Item-Textarea {
    margin-top: 18px;
    margin-left: 0;
    height: 200px;
    flex: inherit;
    font-size: 15px;
  }
}
.Form-Btn {
  border-radius: 6px;
  margin-top: 32px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 20px;
  padding-bottom: 20px;
  width: 280px;
  display: block;
  letter-spacing: 0.05em;
  background: #545454;
  color: #fff;
  font-weight: bold;
  font-size: 20px;
}
@media screen and (max-width: 480px) {
  .Form-Btn {
    margin-top: 24px;
    padding-top: 8px;
    padding-bottom: 8px;
    width: 160px;
    font-size: 16px;
  }
}
#order footer{
    text-align: center;
}