@charset "UTF-8"; /**/

/* BASE */
.pB1 {
  padding-bottom: 1%;
}
.pB3 {
  padding-bottom: 3%;
}
.body_sph .pB3 {
  padding-bottom: 5%;
}
.pB5 {
  padding-bottom: 5%;
}
.pB7 {
  padding-bottom: 7%;
}
.body_sph .pB7 {
  padding-bottom: 5%;
}
.body_sph .w60 {
  width: 60%;
}
.body_sph .w85 {
  width: 85%;
}
.w90 {
  width: 90%;
}
.attention {
  text-align: right;
  font-size: 0.7em;
  color: #797979;
}
.body_sph p.attention {
  font-size: 0.65em;
}
.body_sph .contents_main {
  margin: 0;
}

/* Top Page */
#black_ww {
  text-align: center;
  background-color: #ffffff;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}
#black_ww h2 {
  font-family: "Noto Sans JP", sans-serif;
  margin: 0 3% 3%;
}
/* #black_ww h3 {
    font-family: "Noto Sans JP", sans-serif;
} */

/*========= FV ===============*/
#fv {
  position: relative;
  margin-bottom: 3%;
}
#fv img.fv__icon {
  position: absolute;
  top: 3%;
  left: 40%;
  width: 30%;
}
#fv .fv__attention {
  position: absolute;
  bottom: 18%;
  right: 3%;
  color: #fff;
}
p.fv__read {
  margin-top: 5%;
  margin-bottom: 0;
  font-size: 1.5em;
  line-height: 1.9em;
}
/*========= 口コミ ===============*/

#voice {
  background-color: #ededed;
  padding: 5% 2%;
}
#voice > img {
  width: 10%;
}
#voice h2 {
  font-size: 3em;
  font-weight: 500;
  margin-bottom: 1%;
}
#voice h3 {
  font-size: 1.7em;
  font-weight: 400;
  letter-spacing: 0.1em;
  margin-bottom: 7%;
  font-feature-settings: "palt";
}
#voice h3 span {
  display: block;
  font-size: 1em;
  font-weight: 400;
}
#voice ul {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: space-around;
}
#voice li {
  position: relative;
  width: 47%;
  padding: 5% 3% 4%;
  margin-bottom: 3%;
  text-align: left;
  font-size: 1em;
  background-color: #fff;
  border: 1px solid #333;
}
#voice li::before {
  content: "50代女性";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 1% 10%;
  border-radius: 30px;
  background-color: #333;
  color: #fff;
}
#voice li::after {
  content: "▼";
  position: absolute;
  top: 10%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #333;
}
#voice li span {
  font-weight: 600;
  display: inline;
}
#voice li:nth-child(2)::before {
  content: "40代女性";
}
/* 左から右へ文字が表示されるやつ */

#fv p.fv__slide {
  overflow: hidden; /*左右アニメーションで画面からはみ出る際に出る横スクロールバーを隠す*/
  line-height: 2em;
  margin-top: 1%;
}
/* 流れるテキスト */
.slide-in {
  overflow: hidden;
  display: inline-block;
}
.slide-in_inner {
  display: inline-block;
}

/*左右のアニメーション*/
.leftAnime {
  opacity: 0; /*事前に透過0にして消しておく*/
}

.slideAnimeLeftRight {
  animation-name: slideTextX100;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes slideTextX100 {
  from {
    transform: translateX(-100%); /*要素を左の枠外に移動*/
    opacity: 0;
  }

  to {
    transform: translateX(0); /*要素を元の位置に移動*/
    opacity: 1;
  }
}

.slideAnimeRightLeft {
  animation-name: slideTextX-100;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes slideTextX-100 {
  from {
    transform: translateX(100%); /*要素を右の枠外に移動*/
    opacity: 0;
  }

  to {
    transform: translateX(0); /*要素を元の位置に移動*/
    opacity: 1;
  }
}

/*========= スクロールダウンの→ ===============*/

/*スクロールダウン全体の場所*/
.scrolldown4 {
  /*描画位置※位置は適宜調整してください*/
  position: absolute;
  bottom: 1%;
  right: 50%;
  z-index: 11;
}

/*下からの距離が変化して全体が下→上→下に動く*/

/* 矢印の描写 */
.scrolldown4:before {
  content: "";
  position: absolute;
  bottom: -100px;
  right: 9px;
  width: 1px;
  height: 25px;
  background: #333;
  transform: skewX(35deg);
}

.scrolldown4:after {
  content: "";
  position: absolute;
  bottom: -100px;
  right: 0;
  width: 1px;
  height: 160px;
  background: #333;
}

/*========= レイアウトのためのCSS ===============*/

#mechanism p {
  font-size: 2.5em;
}
#mechanism p span {
  display: inline-block;
  padding: 0em 0.7em 0.1em 0.7em;
  margin-top: 1%;
  color: #fff;
  background-color: #6296ba;
}
#mechanism {
  position: relative;
  padding: 5% 0 10%;
}

/*========= STEP ===============*/

#step {
  background-image: url("../images/bg_step.jpg");
  padding: 7% 6%;
  margin-bottom: 10%;
}
#step .step01 {
  position: relative;
  z-index: 10;
}
#step .step02 {
  position: relative;
  z-index: 8;
}
#step .step03 {
  position: relative;
  z-index: 6;
}

#step [class^="step0"] {
  background-color: #fff;
  padding: 8% 0% 5%;
  border-radius: 15px;
  margin-bottom: 7%;
}
#step [class^="step0"] p.step__number {
  color: #6296ba;
  font-size: 3em;
  line-height: 1;
}
#step [class^="step0"] p.step__number span {
  display: block;
  font-size: 1.5em;
  font-weight: bold;
}
#step [class^="step0"] img {
  width: 60%;
}
.step__bar {
  position: relative;
}
.step__bar ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 10%;
}
.step__bar li {
  background-color: #fff;
  border: 1px solid #ccc;
  display: flex;
  border-radius: 50%;
  height: 140px;
  width: 140px;
  flex-wrap: wrap;
  align-content: center;
  justify-content: center;
  font-size: 1.2em;
  z-index: 1;
}
#step h3 {
  font-size: 3.3em;
  line-height: 1.3;
  margin: 5%;
  font-weight: 500;
}
#step .step03 h3 {
  font-size: 2.6em;
  line-height: 1.3;
  margin: 5%;
}
#step h3 span {
  display: block;
  font-weight: 600;
  font-size: 1.2em;
  margin: 0;
}
#step p.step__explan {
  font-size: 1.3em;
  font-weight: 300;
  letter-spacing: 0.1em;
  font-feature-settings: "palt";
  font-family: "Noro Sans JP", sans-serif;
}
#step .step01 p.step__explan {
  margin: 7% 21%;
}
#step .step02 p.step__explan {
  margin: 7% 13%;
}
#step .step03 p.step__explan {
  margin: 7% 20%;
}
#step p.attention {
  padding-right: 3%;
}
.step02 .step__bar li:first-child,
.step03 .step__bar li:first-child,
.step03 .step__bar li:nth-child(2) {
  background-color: #6296ba;
  border: 1px solid #6296ba;
  color: #fff;
}
/* 完了したSTEPを青くする処理 */
.animation_done {
  animation: stepdone 0.5s;
  animation-fill-mode: forwards;
}
@keyframes stepdone {
  from {
    background-color: #fff;
  }

  to {
    background-color: #6296ba;
    border: 1px solid #6296ba;
    color: #fff;
  }
}
.animation_delay {
  animation-delay: 0.8s;
}

.arrow {
  display: flex;
  align-items: center;
  position: absolute;
  top: 50%;
  right: 50%;
  transform: translate(50%, 50%);
}

.arrow-line {
  width: 19em;
  height: 2px;
  background: linear-gradient(90deg, #ccc 50%, #6296ba 50%);
  background-size: 200% 100%;
  display: inline-block;
}
.changeColor_harf {
  width: 19em;
  height: 2px;
  background: linear-gradient(90deg, #ccc 50%, #6296ba 50%);
  background-size: 200% 100%;
  display: inline-block;
  animation: changeColorharf 2s forwards;
}
.changeColor_full {
  width: 16.5em;
  height: 2px;
  background: linear-gradient(90deg, #ccc 50%, #6296ba 50%);
  background-size: 200% 100%;
  display: inline-block;
  animation: changeColorfull 1.5s forwards;
}
.arrow-head {
  right: 7px;
  width: 16px;
  height: 15px;
  border-top: 3px solid #ccc;
  border-right: 3px solid #ccc;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
}
.arrow-head__change {
  animation: changeHeadColor 1s forwards;
}
@keyframes changeColorharf {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -50% 0;
  }
}
@keyframes changeColorfull {
  0% {
    background-position: -50% 0;
  }
  100% {
    background-position: -100% 0;
  }
}
@keyframes changeColor {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -100% 0;
  }
}

@keyframes changeHeadColor {
  0% {
    border-top: 3px solid #ccc;
    border-right: 3px solid #ccc;
  }
  99% {
    border-top: 3px solid #ccc;
    border-right: 3px solid #ccc;
  }
  100% {
    border-top: 3px solid #6296ba;
    border-right: 3px solid #6296ba;
  }
}
.changeslideColor {
  display: inline-block;
  color: transparent;
  background-image: linear-gradient(
    90deg,
    #6296ba,
    #6296ba 50%,
    black 50%,
    black
  );
  -webkit-background-clip: text;
  background-clip: text;
  background-size: 200% 100%;
  animation: changeslideColor 2.5s forwards cubic-bezier(0.25, 1, 0.5, 1);
}
@keyframes changeslideColor {
  0% {
    background-position: 100% 0;
  }
  100% {
    background-position: 0 0;
  }
}
/*========= スクロールダウンの→ ===============*/

/*スクロールダウン全体の場所*/
.step__scrolldown {
  /*描画位置※位置は適宜調整してください*/
  position: absolute;
  top: -5%;
  right: 50%;
}

/* 矢印の描写 */
.step__scrolldown:before {
  content: "";
  position: absolute;
  bottom: -100px;
  right: 9px;
  width: 1px;
  height: 25px;
  background: #333;
  transform: skewX(35deg);
}

.step__scrolldown:after {
  content: "";
  position: absolute;
  bottom: -100px;
  right: 0;
  width: 1px;
  height: 160px;
  background: #333;
}

/*========= 成分説明 ===============*/
#domestic h2 {
  margin: 10% 3% 2%;
}
.compo {
  position: relative;
  padding: 7% 0% 20%;
  margin: 3% 7% 25%;
  background-color: #333030;
  background-image: url("../images/bg_domestic.png");
  border-radius: 150px;
  color: #fff;
  font-family: "Noro Sans JP", sans-serif;
}
.compo > p {
  padding: 0% 9%;
  margin-bottom: 2em;
  font-weight: 300;
  font-size: 1.2em;
  line-height: 1.6;
}
.compo > p span {
  display: block;
}
.compo img {
  position: absolute;
  bottom: -18%;
  right: -3%;
  width: 90%;
}
.compo__mud {
  margin: 0 8%;
  text-align: left;
  background-image: url("../images/domestic_item01@2x.png");
  background-size: contain;
  background-repeat: no-repeat;
}
.compo__mud h3 {
  font-size: 2.7em;
  font-weight: 300;
  width: 67%;
  margin-left: auto;
  margin-bottom: auto;
}
.compo__mud h3 sup {
  display: inline-block;
  vertical-align: super;
  font-size: 0.3em;
  margin-left: -1.5em;
}
.compo__mud p {
  width: 62%;
  font-size: 0.85em;
  font-weight: 300;
  margin-left: auto;
  line-height: 1.7;
}
.compo__charcoal {
  margin: 1% 0 0 8%;
  padding-top: 7%;
  text-align: left;
  background-image: url("../images/domestic_item02@2x.png");
  background-position: right;
  background-size: contain;
  background-repeat: no-repeat;
}
.compo__charcoal h3 {
  font-size: 2.7em;
  font-weight: 300;
  margin-left: -0.5em;
  margin-bottom: auto;
}
.compo__charcoal h3 sup {
  display: inline-block;
  vertical-align: super;
  font-size: 0.3em;
  margin-left: -1.5em;
}
.compo__charcoal p {
  width: 60%;
  font-size: 0.9em;
  font-weight: 300;
  margin-right: auto;
  line-height: 1.7;
}
/*========= 実証 ===============*/

.demo {
  position: relative;
  background-color: #e0edf6;
  margin: 10% 5% 10%;
}
.demo > p {
  position: absolute;
  left: 50%;
  top: -10%;
  transform: translate(-50%, 0%);
  width: 100%;
}
.demo p span {
  background-color: #333;
  font-size: 3em;
  border-radius: 5px;
  padding: 0.1em 0.4em;
  margin: 1%;
  color: #fff;
}
.demo__wrapper {
  display: flex;
  padding: 10% 10% 3%;
  margin-top: 5%;
}
.demo__wrapper > div {
  padding: 4%;
}
.demo__after {
  position: relative;
}
.demo__after img.demo__after__absolute01 {
  position: absolute;
  width: 60%;
  top: -8%;
  right: -21%;
}
.demo__after img.demo__after__absolute02 {
  position: absolute;
  width: 13%;
  top: 35%;
  left: 30%;
}

/*========= うるおいなめらかな後肌感 ===============*/

#moisture {
  margin-bottom: 7%;
}
#moisture h3 {
  width: 60%;
  font-size: 1.5em;
  font-weight: 400;
  text-align: left;
  padding: 3% 3%;
  margin-bottom: 5%;
  line-height: 1.6;
  letter-spacing: 0.02em;
  background: linear-gradient(to left, rgba(255, 255, 255, 0), #fff 30%);
}
#moisture > div:first-of-type {
  position: relative;
  padding: 5% 0 0;
  background-image: url("../images/bg_moisture.png");
}
#moisture > div:first-of-type img {
  width: 70%;
  padding-right: 20%;
}
#moisture > div div.moisture__compo img {
  position: absolute;
  width: 20%;
}
#moisture > div div.moisture__compo img:first-of-type {
  top: 5%;
  right: 4%;
  width: 33%;
  padding: 0;
}
#moisture > div div.moisture__compo img:nth-of-type(2) {
  top: 22%;
  left: 4%;
  width: 33%;
  padding: 0;
}
#moisture > div div.moisture__compo img:nth-of-type(3) {
  bottom: 20%;
  right: 1%;
  width: 32%;
  padding: 0;
}
#moisture p.attention {
  position: absolute;
  bottom: 1em;
  right: 3%;
}

/*========= あなたはどっち ===============*/
#witch {
  padding: 5% 0 3%;
  background: linear-gradient(
    90deg,
    #a2a2a2 0%,
    #a2a2a2 50%,
    #d5e6f2 50%,
    #d5e6f2 100%
  );
}
#witch > p {
  margin-bottom: 1.3em;
  font-size: 1.8em;
}
#witch span.attention p {
  margin: 3% 2% 0;
}
#witch p span {
  display: inline-block;
  color: #fff;
  background-color: #6296ba;
  border-radius: 30px;
  padding: 0.2% 5% 0.5%;
  margin-bottom: 1.8%;
}
#witch > div {
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
#witch > div .left,
#witch > div .right {
  flex: 1;
}
#witch > div .left {
  position: relative;
}
#witch > div .left img:first-of-type {
  position: relative;
  width: 80%;
  z-index: 5;
}
#witch > div .left img.icon {
  position: absolute;
  width: 25%;
  top: -4%;
  left: 3%;
  z-index: 4;
}
#witch > div .right img {
  width: 69%;
  margin-right: 15%;
}
#witch dl {
  padding: 7% 7%;
  font-size: 1.1em;
}
#witch .left dl {
  color: #fff;
}
#witch .left dt {
  font-weight: 600;
  font-size: 1.1em;
  font-feature-settings: "palt";
  letter-spacing: 0.05em;
  color: #fff;
}
#witch .right dt {
  font-weight: 600;
  font-size: 1.1em;
  font-feature-settings: "palt";
  letter-spacing: 0.05em;
}
#witch dd {
  position: relative;
}
#witch dd a {
  display: block;
  text-decoration: none !important;
  border: 1px solid;
  width: 90%;
  padding: 2% 10%;
  margin: 5% auto;
  font-family: icomoon, "Noto Sans JP";
  font-size: 1em;
  transition: 0.2s;
}
#witch .right dd a {
  border-color: #333;
  color: #393939;
}
#witch .left dd a {
  border-color: #fff;
  color: #fff;
}
#witch dd a:after {
  content: "\3000";
  font-size: 1.5em;
  position: absolute;
  top: 5%;
  right: 20%;
}
#witch .right dd a:after {
  background: #0000
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23393939' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 0 10 7 3 15'/></svg>")
    center/50% auto no-repeat;
}
#witch .left dd a:after {
  background: #0000
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 0 10 7 3 15'/></svg>")
    center/50% auto no-repeat;
}
#witch .right dd a::after {
  -webkit-text-stroke: 1px #d5e6f2;
}
#witch .left dd a::after {
  -webkit-text-stroke: 1px #a2a2a2;
}
#witch dd a:hover {
  background-color: #fff;
}
#witch .left dd a:hover {
  color: #333;
}
#witch dd a:hover::after {
  -webkit-text-stroke: 1px #fff;
  transition: 0.2s;
}
/*========= 商品インクルード ===============*/
#cart .goods_set {
  display: flex;
  margin: 5% 10% 5% 4%;
}
#cart .img_box {
  flex: 0.8;
  padding-right: 3%;
}
#cart .name {
  font-weight: 500;
  font-size: 1.1em;
}
#cart .copy {
  display: none;
}
#cart .name_box {
  margin-bottom: 0.5em;
}
#cart .price2 {
  color: #0f78c3;
}
#cart .cp_discount {
  background-color: #0f78c3;
}
#cart .cp_limit {
  font-size: 0.8em;
}
#cart .price_box {
  font-size: 1.5em;
  margin-bottom: 1em;
}
#cart .icon_box {
  font-size: 0.9em;
}
#cart .txt_box {
  font-size: 1.1em;
  flex: 2;
  text-align: left;
}

#cart .btn {
  width: 50%;
  margin-left: auto;
  margin-top: 1em;
}
.body_sph #cart .btn {
  width: 80%;
}

#cart {
  font-family: icomoon, "Noto Sans JP";
  background-color: #ededed;
  padding: 4% 0;
  margin: 5% 0;
}
#cart .btn {
  width: 55%;
  margin-left: auto;
  margin-top: 1em;
  background-color: #333;
  position: relative;
  transition: 0.2s;
}
.body_sph #cart .btn {
  width: 80%;
}
#cart .btn:hover {
  opacity: 0.7;
}
#cart .btn p {
  margin-bottom: 0;
  color: #fff;
  text-align: center;
  padding: 4% 20% 5% 4%;
  font-size: 1.1em;
}
#cart .btn p::after {
  content: "\e96a"; /*矢印アイコン*/
  font-size: 1.5em;
  position: absolute;
  top: 10%;
  right: 5%;
  -webkit-text-stroke: 1px #333; /*背景と同じ色で線を付けて細く見せる*/
}

/* ふわっとアニメ */
/* 動作を適用する箇所 */
.fuwatAnime {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 2s; /* アニメ時間 */
  -ms-animation-duration: 2s;
  animation-duration: 2s;
  -webkit-transition-delay: 0.5s; /* 開始時間 */
  -ms-transition-delay: 0.5s;
  transition-delay: 0.5s;
  -webkit-animation-name: fuwatAnime; /* アニメ名 */
  -ms-animation-name: fuwatAnime;
  animation-name: fuwatAnime;
  visibility: visible !important;
}

.fuwatAnime2 {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 2.5s; /* アニメ時間 */
  -ms-animation-duration: 2.5s;
  animation-duration: 2.5s;
  -webkit-transition-delay: 1.5s; /* 開始時間 */
  -ms-transition-delay: 1.5s;
  transition-delay: 1.5s;
  -webkit-animation-name: fuwatAnime2; /* アニメ名 */
  -ms-animation-name: fuwatAnime2;
  animation-name: fuwatAnime2;
  visibility: visible !important;
}

.fadeIn_r_Anime {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 1.5s; /* アニメ時間 */
  -ms-animation-duration: 1.5s;
  animation-duration: 1.5s;
  -webkit-transition-delay: 0s; /* 開始時間 */
  -ms-transition-delay: 0s;
  transition-delay: 0s;
  -webkit-animation-name: fadeIn_r_Anime; /* アニメ名 */
  -ms-animation-name: fadeIn_r_Anime;
  animation-name: fadeIn_r_Anime;
  visibility: visible !important;
}

.fadeIn_l_Anime {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 1.5s; /* アニメ時間 */
  -ms-animation-duration: 1.5s;
  animation-duration: 1.5s;
  -webkit-transition-delay: 0s; /* 開始時間 */
  -ms-transition-delay: 0s;
  transition-delay: 0s;
  -webkit-animation-name: fadeIn_l_Anime; /* アニメ名 */
  -ms-animation-name: fadeIn_l_Anime;
  animation-name: fadeIn_l_Anime;
  visibility: visible !important;
}

.fadeIn_ru_Anime {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 1.5s; /* アニメ時間 */
  -ms-animation-duration: 1.5s;
  animation-duration: 1.5s;
  -webkit-transition-delay: -0.5s; /* 開始時間 */
  -ms-transition-delay: -0.5s;
  transition-delay: -0.5s;
  -webkit-animation-name: fadeIn_ru_Anime; /* アニメ名 */
  -ms-animation-name: fadeIn_ru_Anime;
  animation-name: fadeIn_ru_Anime;
  visibility: visible !important;
}

.fadeIn_lu_Anime {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 1.5s; /* アニメ時間 */
  -ms-animation-duration: 1.5s;
  animation-duration: 1.5s;
  -webkit-transition-delay: -0.5s; /* 開始時間 */
  -ms-transition-delay: -0.5s;
  transition-delay: -0.5s;
  -webkit-animation-name: fadeIn_lu_Anime; /* アニメ名 */
  -ms-animation-name: fadeIn_lu_Anime;
  animation-name: fadeIn_lu_Anime;
  visibility: visible !important;
}

/* 動作内容 */
@-webkit-keyframes fuwatAnime {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-200px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
  }
}
@-webkit-keyframes fuwatAnime2 {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-200px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
  }
}
/*大から実寸にフェードイン@-webkit-keyframes fuwatAnime2 {
 0% { opacity: 0; -webkit-transform: translateY(0) scale(0.5); }
 70% { opacity: 1; -webkit-transform: translateY(0) scale(1.2); }
 100% { opacity: 1; -webkit-transform: translateY(0) scale(1.0); }
}*/
@-webkit-keyframes fadeIn_r_Anime {
  0% {
    opacity: 0;
    -webkit-transform: translateX(300px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    width: 720px;
  }
}
@-webkit-keyframes fadeIn_l_Anime {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-300px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    width: 720px;
  }
}
@-webkit-keyframes fadeIn_ru_Anime {
  0% {
    opacity: 0;
    -webkit-transform: translateX(300px) translateY(200px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    width: 720px;
  }
}
@-webkit-keyframes fadeIn_lu_Anime {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-300px) translateY(200px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    width: 720px;
  }
}

@keyframes fuwatAnime {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-50px);
    -ms-transform: translateY(-50px);
    transform: translateY(-50px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@keyframes fuwatAnime2 {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-200px);
    -ms-transform: translateY(-200px);
    transform: translateY(-200px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
/*大から実寸にフェードイン@keyframes fuwatAnime2 {
 0% { opacity: 0; -webkit-transform: translateY(0) scale(0.5); -ms-transform: translateY(0) scale(0.5); transform: translateY(0) scale(0.5); }
 70% { opacity: 1; -webkit-transform: translateY(0) scale(1.2); -ms-transform: translateY(0) scale(1.2); transform: translateY(0) scale(1.2); }
 100% { opacity: 1; -webkit-transform: translateY(0) scale(1.0); -ms-transform: translateY(0) scale(1.0); transform: translateY(0) scale(1.0); }
}*/
@keyframes fadeIn_r_Anime {
  0% {
    opacity: 0.5; /* 透明 */
    -webkit-transform: translateX(300px);
    -ms-transform: translateX(300px);
    transform: translateX(300px); /*X軸（右横に）方向に300px */
  }
  100% {
    opacity: 1; /* 不透明 */
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
    width: ;
  }
}
@keyframes fadeIn_l_Anime {
  0% {
    opacity: 0.5;
    -webkit-transform: translateX(-300px);
    -ms-transform: translateX(-300px);
    transform: translateX(-300px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
    width: ;
  }
}
@keyframes fadeIn_ru_Anime {
  0% {
    opacity: 0.5;
    -webkit-transform: translateX(300px) translateY(200px);
    -ms-transform: translateX(300px) translateY(200px);
    transform: translateX(300px) translateY(200px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
    width: ;
  }
}
@keyframes fadeIn_lu_Anime {
  0% {
    opacity: 0.5;
    -webkit-transform: translateX(-300px) translateY(200px);
    -ms-transform: translateX(-300px) translateY(200px);
    transform: translateX(-300px) translateY(200px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
    width: ;
  }
}

@media screen and (max-width: 768px) {
  /*FV*/
  p.fv__read {
    font-size: 0.9em;
    margin-top: 1em;
    line-height: 1.7em;
  }
  #fv .fv__attention {
    font-size: 0.65em;
    bottom: 19%;
  }
  #fv p.fv__slide {
    margin-top: 1%;
  }
  p.attention {
    font-size: 0.45em;
    padding-right: 3%;
    margin-top: 3%;
  }
  /*    p{color: red;}*/
  #mechanism p {
    font-size: 1.3em;
  }
  /*口コミ*/
  #voice h2 {
    font-size: 2em;
  }
  #voice h3 {
    font-size: 1em;
  }
  #voice li {
    width: 48%;
    font-size: 0.65em;
    padding: 7% 3% 4%;
  }
  #voice li::before {
    left: 25%;
    transform: translate(-5%, -50%);
    padding: 1% 10%;
  }
  #voice li::after {
    top: 7%;
  }
  /*ステップ*/
  .step__bar li {
    height: 80px;
    width: 80px;
    font-size: 0.7em;
  }
  /* #step p.attention {padding-left: 10%;} */
  #step [class^="step0"] p.step__number {
    font-size: 1.5em;
    margin-bottom: 0.5em;
  }
  #step .step01 {
    z-index: 8;
  }
  #step .step01 p.step__explan {
    margin: 7% 12%;
  }
  #step .step02 {
    z-index: 7;
  }
  #step .step02 p.step__explan {
    margin: 7% 3%;
  }
  #step .step03 p.step__explan {
    margin: 7% 12%;
  }
  #step h3 {
    font-size: 2em;
  }
  #step .step03 h3 {
    font-size: 1.7em;
  }
  #step p.step__explan {
    font-size: 0.9em;
  }
  .step__scrolldown:before {
    bottom: -50px;
    right: 4px;
    height: 10px;
  }
  .step__scrolldown:after {
    bottom: -50px;
    height: 100px;
  }
  .scrolldown4 {
    z-index: 9;
  }
  .scrolldown4:before {
    bottom: -50px;
    right: 5px;
    height: 13px;
  }
  .scrolldown4:after {
    bottom: -50px;
    height: 80px;
  }
  .arrow-line {
    width: 16em;
  }
  .changeColor_harf {
    width: 16em;
  }
  .arrow-head {
    right: 0px;
    border-top: 2px solid #ccc;
    border-right: 2px solid #ccc;
  }
  .changeColor_full {
    width: 16em;
  }
  @keyframes changeHeadColor {
    0% {
      border-top: 2px solid #ccc;
      border-right: 2px solid #ccc;
    }
    99% {
      border-top: 2px solid #ccc;
      border-right: 2px solid #ccc;
    }
    100% {
      border-top: 2px solid #6296ba;
      border-right: 2px solid #6296ba;
    }
  }
  /*成分*/
  .compo {
    border-radius: 90px;
    padding: 10% 0% 20%;
    margin: 3% 3% 25%;
  }
  .compo > p {
    font-size: 0.6em;
    padding: 0 15%;
  }
  .compo__mud {
    margin: 0 3%;
    background-image: url(../images/domestic_item01@2x.png);
    background-size: 20%;
    background-position: 30px;
  }
  .compo__mud p {
    width: 60%;
    font-size: 0.6em;
  }
  .compo__mud h3 {
    width: 66%;
    font-size: 1.5em;
  }
  .compo__charcoal h3 {
    width: 66%;
    font-size: 1.5em;
  }
  .compo__charcoal {
    background-position: right;
    background-size: 54%;
  }
  .compo img {
    bottom: -21%;
    width: 80%;
  }
  /* .compo__charcoal h3 {font-size: 2em;} */
  .compo__charcoal p {
    width: 63%;
    font-size: 0.6em;
  }
  /*うるおい*/
  #moisture h3 {
    width: 65%;
    font-size: 0.9em;
  }
  #moisture > div:first-of-type img {
    width: 80%;
    padding-right: 25%;
  }
  #moisture > div div.moisture__compo img:nth-of-type(2) {
    top: 25%;
    left: 2%;
  }
  .demo__wrapper > div {
    margin-top: 5%;
  }
  .demo p span {
    font-size: 1.8em;
  }
  #witch > p {
    margin: 2% 0 5%;
    font-size: 1.1em;
  }
  #witch dt {
    font-size: 0.75em;
    padding-top: 1%;
  }
  #witch dt span {
    display: block;
  }
  #witch dd {
    font-size: 0.5em;
  }
  #witch dd a {
    width: 75%;
  }
  #witch dd a:after {
    font-size: 1.5em;
    top: 1%;
  }
  /* #witch span.attention p {margin: 3% 2% 0; font-size: 0.4em;} */
  #witch span.attention p {
    margin: 3% 2% 0%;
    font-size: 0.7em;
  }
  /*カート*/
  #cart .goods_set {
    margin: 7% 4%;
  }
  #cart .img_box {
    flex: 1;
    padding-right: 0%;
  }
  #cart .name {
    font-size: 1em;
  }
  #cart .txt_box {
    margin-left: 5%;
    font-size: 0.8em;
  }
}

/* ===============================
   STEP 1〜3：アニメ完了後の完全固定状態
   =============================== */
/*========= STEP ===============*/

#step {
  background-image: url("../images/bg_step.jpg");
  padding: 7% 6%;
  margin-bottom: 10%;
}

/* z-index */
#step .step01 {
  position: relative;
  z-index: 10;
}
#step .step02 {
  position: relative;
  z-index: 8;
}
#step .step03 {
  position: relative;
  z-index: 6;
}

/* ステップ枠共通 */
#step [class^="step0"] {
  background-color: #fff;
  padding: 8% 0% 5%;
  border-radius: 15px;
  margin-bottom: 7%;
}

/* 番号 */
#step [class^="step0"] p.step__number {
  color: #6296ba;
  font-size: 2.5em;
  line-height: 1;
  margin-bottom: 30px;
}
#step [class^="step0"] p.step__number span {
  display: block;
  font-size: 1.5em;
  font-weight: bold;
}
#step [class^="step0"] img {
  width: 60%;
}

/* 丸ステップ ---------------------------------- */
.step__bar {
  position: relative;
}
.step__bar ul {
  display: flex;
  justify-content: space-between;
  margin: 0 10%;
}
.step__bar li {
  background-color: #fff;
  border: 1px solid #ccc;
  display: flex;
  border-radius: 50%;
  height: 140px;
  width: 140px;
  align-items: center;
  justify-content: center;
  font-size: 1.2em;
  color: #333;
}

/* ---------------------------------------------- */
/* ▼ 完了ステップを青くする最終状態（アニメなし） */
/* ---------------------------------------------- */

/* step01 → 1個目だけ青 */
.step01 .step__bar li:nth-child(1) {
  background-color: #6296ba;
  border-color: #6296ba;
  color: #fff;
}

/* step02 → 1〜2個目が青 */
.step02 .step__bar li:nth-child(-n + 2) {
  background-color: #6296ba;
  border-color: #6296ba;
  color: #fff;
}

/* step03 → 1〜3個すべて青 */
.step03 .step__bar li:nth-child(-n + 3) {
  background-color: #6296ba;
  border-color: #6296ba;
  color: #fff;
}

/* ------- ベース設定（丸） ------- */
.step__bar ul {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 40px;
  padding: 0px;
}

.step__bar li {
  list-style: none;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  border: 2px solid #ccc;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  color: #333;
  background: #fff;
  position: relative;
}

/* ------- 丸と丸の間に横線を表示 ------- */
.step__bar li::after {
  content: "";
  position: absolute;
  right: -40px;
  top: 50%;
  width: 40px;
  height: 2px;
  background: #ccc;
  transform: translateY(-50%);
}

/* 最後の丸だけ横線なし */
.step__bar li:last-child::after {
  display: none;
}

/* ------- 進行状況の色（step01 / step02 / step03） ------- */

.step01 .step__bar li:nth-child(1),
.step02 .step__bar li:nth-child(-n + 2),
.step03 .step__bar li:nth-child(-n + 3) {
  background-color: #6296ba;
  border-color: #6296ba;
  color: #fff;
}

/* 線の色も進行に合わせて青に */
.step01 .step__bar li:nth-child(1)::after,
.step02 .step__bar li:nth-child(2)::after,
.step03 .step__bar li:nth-child(3)::after {
  background-color: #6296ba;
}

/* ============================================
   ▼ スマホ用レイアウト（〜768px）
   ============================================ */
@media (max-width: 768px) {
  /* --- セクション全体を縮小しない方法（推奨） --- */
  #step [class^="step0"] {
    padding: 12% 5% 10%;
    margin-bottom: 12%;
  }

  /* --- STEP番号 --- */
  #step [class^="step0"] p.step__number {
    font-size: 2.2em;
  }
  #step [class^="step0"] p.step__number span {
    font-size: 1.3em;
  }

  /* --- 画像縮小 --- */
  #step [class^="step0"] img {
    width: 80%;
  }

  /* --- 丸ステップ（ここが崩れの原因の本体） --- */
  .step__bar ul {
    gap: 13px;
    margin: 0 auto;
  }

  .step__bar li {
    width: 90px; /* ← スマホ用に固定140 → 90 に縮小 */
    height: 90px;
    font-size: 14px;
  }

  /* --- 丸と丸の間の線 --- */
  .step__bar li::after {
    right: -20px; /* ← PCでは -40px */
    width: 20px; /* ← PCでは 40px */
  }
}

@media print, screen and (min-width: 768px) {
  #black_ww {
    width: 720px;
    margin: 0 auto;
  }
}

/* =========================================================
   sample_view（商品パネル） PC表示
   ========================================================= */

/* ---------------------------------------
   ① 単品（spec） → panel に枠をつける
--------------------------------------- */
.spec {
  margin-block: 3%;
}

.spec .sample_view .c-panel__inner {
  display: flex;
  align-items: center;
  gap: 40px;

  padding: 30px;
  border: 0px solid #f7dce7;
  border-radius: 0;
  background: #f0f0f0;

  max-width: 900px;
  margin: 0px auto;
}

/* ---------------------------------------
   ② 複数（spec-lotion）→ 全体を１つの枠で囲む
      内部パネルは枠なしにする
--------------------------------------- */
.spec-lotion .sample_view {
  border: 15px solid #f7dce7; /* 外枠だけ */
  border-radius: 0;
  padding: 40px;

  background: #fff;
  max-width: 900px;
  margin: 40px auto;

  display: flex;
  flex-direction: column;
  gap: 40px;
}

/* 複数商品の内部パネルだけ枠を消す */
.spec-lotion .sample_view .c-panel__inner {
  border: none !important;
  padding: 0;
  margin: 0;
  background: transparent;
}

/* ---------------------------------------
   以下は共通部分（内部レイアウト）
--------------------------------------- */

.sample_view .c-panel__link {
  display: flex;
  flex: 1;
  gap: 30px;
  text-decoration: none;
  color: inherit;
}

.sample_view .c-panel__header {
  flex-shrink: 0;
  width: 180px;
}

.sample_view .c-panel__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* 価格 */
.sample_view .c-panel__price-wrapper .c-price {
  color: rgb(15, 120, 195);
  position: relative;
  top: -15px;
  font-size: 1.5em;
}

/* カートボタン位置 */
.sample_view .c-panel__action {
  margin-left: auto;
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

/* a・button 共通のボタン本体（挙動崩さない） */
.sample_view .c-panel__action a,
.sample_view .c-panel__action button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;

  padding: 14px 36px;

  background: #000 !important; /*ボタン色*/
  color: #fff !important;

  border-radius: 0px; /*ボタンの角*/
  border: none;

  font-size: 1.2rem;
  font-weight: bold;

  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
  transition: 0.25s ease;
}

/* hover */
.sample_view .c-panel__action a:hover,
.sample_view .c-panel__action button:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.15);
  opacity: 0.95;
}

/* 全角 ＞（フォールバック） */
.sample_view .c-panel__action a::after,
.sample_view .c-panel__action button::after {
  content: "＞";
  display: flex;
  align-items: center;
  justify-content: center;

  width: 28px;
  height: 28px;

  background: #fff;
  color: #4da9ff;

  font-size: 1rem;
  font-weight: bold;
  line-height: 1;

  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);

  margin-left: 12px;
}

.sample_view .c-panel__body,
.spec-lotion .c-panel__body {
  align-items: flex-start !important; /* 子要素を左揃え */
  text-align: left !important; /* テキストも左揃え */
}

/* ---------------------------------------
   btn（カート機能ボタン）専用
--------------------------------------- */
.sample_view .c-panel__action .btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  padding: 14px 36px !important;
  padding-right: 76px !important;

  background: #000 !important; /*ボタン色*/
  color: #fff !important;

  border-radius: 0px; /*ボタンの角*/
  border: none !important;

  font-size: 1.6rem !important;
  font-weight: bold !important;

  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1) !important;
}

/* btnだけ：SVG矢印 */
.sample_view .c-panel__action .btn::after {
  content: "";
  width: 30px;
  height: 30px;

  position: absolute;
  right: 16px;

  display: flex;
  align-items: center;
  justify-content: center;

  border-radius: 50%;
  background: #000000
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='5 3 9 7 5 11'/></svg>")
    center/14px no-repeat;

  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

/* ---------------------------------------
   スマホ用
--------------------------------------- */

@media (max-width: 768px) {
  /* ▼ パネル全体（枠・内側余白・レイアウト） */
  .sample_view .c-panel__inner,
  .spec-lotion .c-panel__inner {
    flex-direction: row; /* ← 画像とテキストを横並びにする */
    align-items: flex-start; /* ← 上揃え */
    gap: 16px; /* ← 画像とテキストの間のスペース */
    padding: 20px !important; /* ← 内側の余白 */
    border-width: 0px !important; /* ← 枠の太さ（スマホ用に細く） */
  }

  /* ▼ 商品画像コンテナ（枠の中の画像の幅） */
  .sample_view .c-panel__header,
  .spec-lotion .c-panel__header {
    width: 120px !important; /* ← 画像の表示幅（PC 260px → SP 120px） */
    flex-shrink: 0;
    margin: 0 !important;
  }

  /* ▼ 商品画像そのもののサイズ */
  .sample_view .c-panel__header img,
  .spec-lotion .c-panel__header img {
    width: 100%; /* ← コンテナ幅に合わせる */
    height: auto; /* ← 縦比率を保持 */
  }

  /* ▼ テキスト部分（商品名・価格を含む） */
  .sample_view .c-panel__body,
  .spec-lotion .c-panel__body {
    flex: 1; /* ← なるべく広く取る */
    gap: 6px; /* ← 商品名と価格の間のスペース */
    margin-top: 0 !important;
  }

  /* ▼ カートボタンの位置 */
  .sample_view .c-panel__action,
  .spec-lotion .c-panel__action {
    align-self: flex-start; /* ← テキストの左上に合わせる */
    margin-top: 12px; /* ← テキストとの間の余白 */
  }

  /* ▼ カートボタンそのもの（テキストの大きさ・余白・角丸） */
  .sample_view .c-panel__action .btn,
  .spec-lotion .c-panel__action .btn {
    font-size: 1rem !important; /* ← ボタン内テキストの大きさ */
    padding: 12px 24px !important; /* ← ボタンの上下左右の余白 */
    padding-right: 48px !important; /* ← 矢印アイコンのための余白 */
    border-radius: 0px !important; /* ← ← ボタンの角の丸み（ここを0にすると四角） */
    line-height: 1.2 !important;
  }

  /* ▼ ボタン右側の丸アイコン（矢印） */
  .sample_view .c-panel__action .btn::after,
  .spec-lotion .c-panel__action .btn::after {
    width: 22px; /* ← 丸アイコンの横幅 */
    height: 22px; /* ← 丸アイコンの縦幅 */
    right: 14px; /* ← ボタン右端との距離 */
    background-size: 12px 12px; /* ← 矢印アイコンのサイズ */
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
  }

  /* ▼ 商品名と価格の文字（サイズ・行間） */
  .sample_view .c-panel__name,
  .spec-lotion .c-panel__name,
  .spec-lotion .c-price {
    font-size: 1rem !important; /* ← 商品名・価格の文字サイズ */
    line-height: 1.4 !important; /* ← 行間（狭くしたり広くしたりできる） */
  }
  .sample_view .c-price {
    font-size: 2rem !important; /* ← 商品名・価格の文字サイズ */
    line-height: 1.4 !important; /* ← 行間（狭くしたり広くしたりできる） */
  }

  /* ▼ 商品画像の高さを固定して並びの高さを揃える */
  .sample_view .c-panel__header img,
  .spec-lotion .c-panel__header img {
    height: 120px !important; /* ← 画像の高さを固定（変えるとレイアウト調整できる） */
    object-fit: contain !important; /* ← 画像が切れないように収める */
  }
}

@media (max-width: 768px) {
  .sample_view .c-panel {
    padding: 16px;
    border-width: 8px;
    max-width: 100%;
  }

  .sample_view .c-panel__inner {
    gap: 12px;
    padding: 16px !important;
  }

  .sample_view img {
    max-width: 80%; /* 画像がデカすぎる場合 */
  }

  .sample_view {
    zoom: 0.85; /* 全体縮小：最終手段 */
  }
  .scrolldown4 {
    bottom: 5%; /* ←表示位置が下すぎる場合ここで調整 */
    right: 50%;
    transform: translateX(50%); /* ←横ズレ補正する一行 */
  }

  .scrolldown4:before {
    bottom: -40px; /* ←短くしてはみ出し防止 */
    right: 4px;
    height: 10px;
  }

  .scrolldown4:after {
    bottom: -40px; /* ←同じく短く */
    height: 60px;
  }
  .sample_view .c-panel__name,
  .spec-lotion .c-panel__name,
  .spec-lotion .c-price {
    font-size: 1.5rem !important;
  }
  .sample_view .c-price {
    font-size: 3rem !important;
  }
  .sample_view .c-panel__action .btn,
  .spec-lotion .c-panel__action .btn {
    font-size: 1.7rem !important;
  }
  .sample_view .c-panel__inner {
    padding: 24px !important;
  }
  .sample_view .c-panel {
    padding: 16px 0;
  }
}

.c-panel__desc {
  display: none;
}
