@charset "UTF-8";
@media screen and (min-width: 751px) {
  .pc-none {
    display: none; } }
@media screen and (max-width: 750px) {
  .pc-none {
    display: block; } }

@media screen and (min-width: 751px) {
  .sp-none {
    display: block; } }
@media screen and (max-width: 750px) {
  .sp-none {
    display: none; } }

.l-main {
  border-bottom: 1px solid #c8c8c8; }
  @media screen and (min-width: 751px) {
    .l-main {
      min-width: 1200px; } }

/*
*  .entrance
*/
.entrance {
  /*opacity: .5;*/
  margin: 0 auto;
  box-sizing: border-box; }
  @media screen and (min-width: 751px) {
    .entrance {
      display: flex;
      flex-wrap: nowrap;
      justify-content: flex-start;
      width: 100%;
      margin-bottom: 85px;
      border-bottom: 1px solid #f2f2f2; } }
  @media screen and (max-width: 750px) {
    .entrance {
      margin-bottom: 9vw; } }

@media screen and (min-width: 751px) {
  .entrance--picture {
    width: 50vw;
    height: auto; } }
@media screen and (min-width: 751px) and (max-width: 1200px) {
  .entrance--picture {
    width: 600px; } }
@media screen and (max-width: 750px) {
  .entrance--picture {
    width: 100%;
    height: 124.8vw; } }
.entrance--picture picture,
.entrance--picture img {
  width: 100%;
  height: 100%; }

.entrance__description {
  box-sizing: border-box; }
  @media screen and (min-width: 751px) {
    .entrance__description {
      width: 50%;
      padding: 6.6vw 0 0 4.4vw; } }
  @media screen and (max-width: 750px) {
    .entrance__description {
      width: 100%; } }

.entrance--title {
  font-family: "Noto Serif JP", serif;
  letter-spacing: 0.09em; }
  @media screen and (min-width: 751px) {
    .entrance--title {
      margin: 2.7vw 0;
      font-size: 2.1875vw;
      line-height: 1.2; } }
  @media screen and (min-width: 751px) and (max-width: 1200px) {
    .entrance--title {
      margin-bottom: 35px;
      font-size: 1.75rem; } }
  @media screen and (max-width: 750px) {
    .entrance--title {
      margin: 17px auto 12px;
      /*font-size: 5.33334vw;*/
      font-size: 20px;
      line-height: 1.3;
      text-align: center;
      letter-spacing: 0; } }
  .entrance--title span {
    text-transform: uppercase; }
  .entrance--title sup {
    position: relative;
    vertical-align: top; }
    @media screen and (min-width: 751px) {
      .entrance--title sup {
        top: 4px;
        left: -3px;
        font-size: .75rem; } }
    @media screen and (max-width: 750px) {
      .entrance--title sup {
        top: 0;
        font-size: 2.66667vw; } }

.entrance--name {
  font-family: "Noto Serif JP", serif; }
  @media screen and (min-width: 751px) {
    .entrance--name {
      margin-bottom: 10px;
      font-size: 1.5625vw;
      letter-spacing: .11em; } }
  @media screen and (min-width: 751px) and (max-width: 1200px) {
    .entrance--name {
      margin-bottom: 24px;
      font-size: 1.25rem; } }
  @media screen and (max-width: 750px) {
    .entrance--name {
      font-size: 14px;
      text-align: center;
      letter-spacing: 0.56px;
      line-height: 140%;
      margin-bottom: 8px; } }

.entrance--price {
  font-family: "Noto Serif JP", serif;
  line-height: 1; }
  @media screen and (min-width: 751px) {
    .entrance--price {
      margin-bottom: 3.3vw;
      font-size: 1.02vw;
      letter-spacing: .11em; } }
  @media screen and (min-width: 751px) and (max-width: 1200px) {
    .entrance--price {
      margin-bottom: 19px;
      font-size: .875rem; } }
  @media screen and (max-width: 750px) {
    .entrance--price {
      margin-bottom: 3.5vw;
      font-size: 12px;
      text-align: center;
      line-height: 100%;
      letter-spacing: 0.48px; } }

.entrance--date {
  line-height: 1; }
  @media screen and (min-width: 751px) {
    .entrance--date {
      font-size: 0.9vw;
      letter-spacing: .11em; } }
  @media screen and (min-width: 751px) and (max-width: 1200px) {
    .entrance--date {
      padding-left: 3px;
      font-size: .9375rem; } }
  @media screen and (max-width: 750px) {
    .entrance--date {
      margin-bottom: 2.4vw;
      font-size: 13px;
      text-align: center;
      letter-spacing: .06em;
      margin-top: 33px; } }

.entrance__icon {
  display: flex;
  flex-wrap: nowrap;
  justify-content: flex-start; }
  @media screen and (max-width: 750px) {
    .entrance__icon {
      margin-bottom: 2.4vw; } }

.entrance__icon li {
  border: 1px solid #c8c8c8;
  color: #878782;
  font-family: "Poppins", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  text-align: center;
  text-transform: uppercase;
  white-space: nowrap;
  box-sizing: border-box; }
  @media screen and (min-width: 751px) {
    .entrance__icon li {
      width: 86px;
      font-size: 0.85938vw;
      line-height: 1.2vw;
      margin: 15px 0 0; } }
  @media screen and (min-width: 751px) and (max-width: 1200px) {
    .entrance__icon li {
      width: 80px;
      font-size: .8125rem;
      line-height: 2vw; } }
  @media screen and (max-width: 750px) {
    .entrance__icon li {
      width: 19.26667vw;
      margin: 0 auto;
      padding: 0 2.66667vw;
      font-size: 2.66667vw;
      line-height: 4.8vw; } }

.entrance--notes {
  width: 100%;
  color: #878782;
  box-sizing: border-box; }
  @media screen and (min-width: 751px) {
    .entrance--notes {
      right: 40px;
      bottom: 30px;
      line-height: 1.4;
      position: absolute;
      font-size: .859375vw;
      text-align: right;
      letter-spacing: .04em; } }
  @media screen and (min-width: 751px) and (max-width: 1200px) {
    .entrance--notes {
      padding-right: 0;
      font-size: .6875rem;
      text-align: right; } }
  @media screen and (max-width: 750px) {
    .entrance--notes {
      font-size: 2.66667vw;
      text-align: center; } }

/*
*  .prod
*/
.prod {
  /*opacity: .5;*/ }
  @media screen and (min-width: 751px) {
    .prod {
      margin-bottom: 152px; } }
  @media screen and (max-width: 750px) {
    .prod {
      margin-bottom: 20.8vw; } }
  @media screen and (min-width: 751px) {
    .prod.second {
      margin-bottom: 70px; } }
  @media screen and (max-width: 750px) {
    .prod.second {
      margin-bottom: 70px; } }

@media screen and (min-width: 751px) {
  .prod__inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center;
    width: 1100px;
    margin: 0 auto; } }

.prod--copy {
  width: 100%;
  font-family: "Noto Serif JP", serif;
  text-align: center; }
  @media screen and (min-width: 751px) {
    .prod--copy {
      margin-bottom: 70px;
      font-size: 1.5rem;
      letter-spacing: .04em; } }
  @media screen and (max-width: 750px) {
    .prod--copy {
      font-size: 5.33334vw;
      line-height: 1.6;
      letter-spacing: .08em; } }

@media screen and (min-width: 751px) {
  .prod--picture {
    width: 50%;
    box-sizing: border-box;
    margin: 0 auto;
    text-align: center; } }
@media screen and (max-width: 750px) {
  .prod--picture {
    text-align: center;
    height: auto;
    margin: 40px auto 6vw;
    width: 80px; } }

.prod__description {
  box-sizing: border-box; }
  @media screen and (min-width: 751px) {
    .prod__description {
      width: 50%;
      padding-top: 5px; } }

@media screen and (min-width: 751px) {
  .prod--sub-copy {
    margin-bottom: 31px;
    font-size: .875rem;
    line-height: 1.71429; } }
@media screen and (max-width: 750px) {
  .prod--sub-copy {
    margin-bottom: 3vw;
    font-size: 3.73334vw;
    text-align: center;
    line-height: 1.64286; } }

@media screen and (min-width: 751px) {
  .prod--name {
    margin-bottom: 7px;
    font-size: 1rem;
    letter-spacing: .08em; } }
@media screen and (max-width: 750px) {
  .prod--name {
    margin-bottom: 2.6vw;
    font-size: 4.26667vw;
    text-align: center;
    letter-spacing: .04em; } }

@media screen and (min-width: 751px) {
  .prod--beauty-type {
    margin-bottom: 21px;
    font-size: .875rem;
    letter-spacing: .08em; } }
@media screen and (max-width: 750px) {
  .prod--beauty-type {
    margin-bottom: 6vw;
    font-size: 3.73334vw;
    text-align: center;
    letter-spacing: .04em; } }

@media screen and (min-width: 751px) {
  .prod--price {
    margin-bottom: 21px;
    font-size: .9375rem;
    letter-spacing: .08em; } }
@media screen and (max-width: 750px) {
  .prod--price {
    margin-bottom: 4.4vw;
    font-size: 3.73334vw;
    text-align: center;
    letter-spacing: .04em; } }

.prod--date {
  border: 1px solid #878782;
  box-sizing: border-box;
  color: #878782;
  text-align: center;
  box-sizing: border-box; }
  @media screen and (min-width: 751px) {
    .prod--date {
      width: 172px;
      margin-bottom: 18px;
      padding: 4px 0;
      border-radius: 15px;
      font-size: .75rem;
      letter-spacing: .16em; } }
  @media screen and (max-width: 750px) {
    .prod--date {
      width: 41.86667vw;
      margin: 0 auto 8vw;
      padding: 1vw 0;
      border-radius: 2.4vw;
      font-size: 3.2vw;
      letter-spacing: .1em; } }

@media screen and (min-width: 751px) {
  .cart-in {
    width: 340px;
    height: 50px; } }
@media screen and (max-width: 750px) {
  .cart-in {
    width: 80vw;
    margin: 0 auto; } }

.cart-in a {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  font-weight: 700;
  width: 100%;
  height: 100%;
  color: #fff;
  text-decoration: none;
  background-color: #878782;
  box-sizing: border-box;
  transition-duration: .3s;
  transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1); }
  @media screen and (min-width: 751px) {
    .cart-in a {
      border-radius: 2px;
      font-size: 1.125rem; } }
  @media screen and (max-width: 750px) {
    .cart-in a {
      border-radius: .53334vw;
      padding: 3.6vw 0;
      margin: 0 auto;
      font-size: 4.26667vw; } }
  .cart-in a:hover {
    color: #fff;
    background-color: #c8c8c8; }

.cart-in.reserve a {
  font-weight: bold; }
  @media screen and (max-width: 750px) {
    .cart-in.reserve a {
      padding: 5.2vw 0; } }

.l-main .cart-in a svg,
.l-main .cart-in a img {
  fill: #fff;
  transition-duration: .3s;
  transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1); }
  @media screen and (min-width: 751px) {
    .l-main .cart-in a svg,
    .l-main .cart-in a img {
      width: 30px;
      height: 30px; } }
  @media screen and (max-width: 750px) {
    .l-main .cart-in a svg,
    .l-main .cart-in a img {
      width: 7.46667vw;
      height: 7.46667vw;
      padding-right: 1.2vw; } }

.cart-in a:hover svg,
.cart-in a:hover img {
  fill: #fff; }

@media screen and (max-width: 750px) {
  .prod__notes {
    margin: 0 10vw; } }

.prod__notes li {
  padding-left: 1em;
  color: #878782;
  text-indent: -1em; }
  @media screen and (min-width: 751px) {
    .prod__notes li {
      font-size: .6875rem;
      letter-spacing: .04em;
      line-height: 1.8; } }
  @media screen and (max-width: 750px) {
    .prod__notes li {
      font-size: 2.66667vw;
      text-align: left;
      letter-spacing: .04em;
      line-height: 2; } }

.prod__notes li:before {
  content: "※"; }

/*
* .detail
*/
.detail {
  background: #FFFFF1;
  margin: 0 auto 65px;
  padding: 60px 0; }
  @media screen and (max-width: 750px) {
    .detail {
      padding: 50px 0; } }

.detail--title {
  width: 100%;
  font-family: "Noto Serif JP", serif;
  text-align: center; }
  @media screen and (min-width: 751px) {
    .detail--title {
      margin-bottom: 67px;
      font-size: 1.625rem;
      line-height: 1.61539;
      letter-spacing: .1em; } }
  @media screen and (max-width: 750px) {
    .detail--title {
      padding-bottom: 40px;
      font-size: 5.33vw;
      line-height: 160%;
      /* 32px */
      letter-spacing: 2px; } }

.detail--inner {
  background: #fff;
  border-radius: 10px;
  width: 1100px;
  box-sizing: border-box;
  padding: 50px 70px;
  margin: 0 auto; }
  @media screen and (max-width: 750px) {
    .detail--inner {
      width: 90%;
      padding: 50px 25px; } }
  .detail--inner__title {
    font-size: 20px;
    text-align: center;
    line-height: 140%;
    letter-spacing: 0.15em; }
    @media screen and (max-width: 750px) {
      .detail--inner__title {
        font-size: 16px; } }
    .detail--inner__title span {
      display: block;
      font-size: 14px;
      margin-top: 10px;
      letter-spacing: 0.05em; }
      @media screen and (max-width: 750px) {
        .detail--inner__title span {
          font-size: 13px;
          margin-bottom: 10px; } }

.detail--flex-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 30px 50px;
  justify-content: center;
  margin: 30px 0 0; }
  @media screen and (max-width: 750px) {
    .detail--flex-wrap {
      gap: 10px 0; } }
  .detail--flex-wrap .flexbox {
    width: calc(100% / 3 - 56px ); }
    @media screen and (max-width: 750px) {
      .detail--flex-wrap .flexbox {
        width: 100%; } }
    .detail--flex-wrap .flexbox span {
      display: block;
      text-align: center;
      padding: 30px;
      border: 1px solid #DCDCDC;
      border-radius: 50px;
      font-size: 14px; }
    .detail--flex-wrap .flexbox p {
      margin: 20px 0;
      font-size: 13px;
      line-height: 170%;
      letter-spacing: 0.52px; }

.inner-box2 {
  position: relative;
  margin: 40px auto; }
  @media screen and (max-width: 750px) {
    .inner-box2 {
      padding: 50px 25px 130px; } }

.inner-box2__img {
  position: absolute;
  right: 244.595px;
  top: 55px;
  max-width: 102px;
  display: block; }
  @media screen and (max-width: 750px) {
    .inner-box2__img {
      left: 0;
      right: 0;
      max-width: 102px;
      top: 53%;
      margin: 0 auto; } }

.detail--inner__txt {
  font-size: 14px;
  margin-top: 10px;
  letter-spacing: 0.05em;
  text-align: center;
  line-height: 170%;
  /* 23.8px */
  letter-spacing: 0.56px; }
  @media screen and (max-width: 750px) {
    .detail--inner__txt {
      font-size: 13px;
      text-align: left;
      width: 77%;
      margin: 20px auto; } }

sup {
  vertical-align: super;
  font-size: 10px; }

.detail--inner__note {
  font-size: 11px;
  line-height: 145%;
  /* 15.95px */
  letter-spacing: 0.44px;
  text-align: left;
  margin: 20px auto;
  width: 1100px; }
  @media screen and (max-width: 750px) {
    .detail--inner__note {
      text-align: left;
      width: 90%; } }

.note-left {
  text-align: left; }

/*
* .usage
*/
.usage {
  /*opacity: .5;*/
  margin: 0 auto;
  border: 1px solid #c8c8c8;
  text-align: center;
  box-sizing: border-box; }
  @media screen and (min-width: 751px) {
    .usage {
      width: 1100px;
      height: 232px;
      margin-bottom: 185px;
      padding-top: 60px; } }
  @media screen and (max-width: 750px) {
    .usage {
      width: 90.66667vw;
      min-height: 53.33334vw;
      margin-bottom: 60px; } }

@media screen and (min-width: 751px) {
  .usage--title {
    margin-bottom: 46px;
    font-size: 1.125rem;
    letter-spacing: .08em; } }
@media screen and (max-width: 750px) {
  .usage--title {
    margin-bottom: 7vw;
    padding-top: 10vw;
    font-size: 4.26667vw;
    letter-spacing: .04em; } }

.usage__list {
  display: table;
  margin: 0 auto; }
  @media screen and (max-width: 750px) {
    .usage__list {
      margin: 0 8vw; } }

.usage__list li {
  text-align: left; }
  @media screen and (min-width: 751px) {
    .usage__list li {
      margin-top: 16px;
      font-size: .875rem;
      letter-spacing: .04em; } }
  @media screen and (max-width: 750px) {
    .usage__list li {
      margin-top: 5vw;
      padding-left: 1.2em;
      font-size: 3.2vw;
      line-height: 1.66667;
      text-indent: -0.6em; } }
  .usage__list li:before {
    display: inline-block;
    content: "〇"; }
    @media screen and (min-width: 751px) {
      .usage__list li:before {
        margin-right: 10px; } }
    @media screen and (max-width: 750px) {
      .usage__list li:before {
        margin-right: 1vw; } }
  .usage__list li:first-child {
    margin-top: 0; }

/*
* .lineup
*/
.lineup {
  /*opacity: .5;*/ }
  @media screen and (min-width: 751px) {
    .lineup {
      margin-bottom: 234px; } }
  @media screen and (max-width: 750px) {
    .lineup {
      margin-bottom: 18vw; } }

.lineup__inner {
  position: relative;
  margin: 0 auto;
  border: 1px solid #007976;
  box-sizing: border-box; }
  @media screen and (min-width: 751px) {
    .lineup__inner {
      display: flex;
      flex-wrap: nowrap;
      justify-content: flex-start;
      width: 1100px;
      margin-bottom: 22px;
      padding: 95px 0 84px; } }
  @media screen and (max-width: 750px) {
    .lineup__inner {
      width: 90.66667vw;
      margin-bottom: 4.4vw;
      padding: 0 0 15vw; } }

.lineup--title {
  position: absolute;
  right: 0;
  left: 0;
  margin: 0 auto;
  font-family: "Noto Serif JP", serif;
  text-align: center;
  background-color: #fff; }
  @media screen and (min-width: 751px) {
    .lineup--title {
      top: -37px;
      width: 414px;
      font-size: 1.375rem;
      line-height: 1.63637; } }
  @media screen and (max-width: 750px) {
    .lineup--title {
      top: -9vw;
      width: 81.86667vw;
      font-size: 4.8vw;
      line-height: 1.77778;
      white-space: nowrap; } }
  .lineup--title sup {
    position: relative;
    top: 0;
    vertical-align: top; }
    @media screen and (min-width: 751px) {
      .lineup--title sup {
        font-size: .625rem; } }
    @media screen and (max-width: 750px) {
      .lineup--title sup {
        font-size: 2.66667vw; } }

@media screen and (min-width: 751px) {
  .lineup__item {
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-start; }
    .lineup__item:nth-of-type(1) {
      margin: 0 94px 0 57px; } }

@media screen and (min-width: 751px) {
  .lineup--item-image {
    margin-right: 36px;
    padding-top: 42px; } }
@media screen and (max-width: 750px) {
  .lineup--item-image {
    width: 18.6vw;
    margin: 0 auto 8vw; } }

@media screen and (min-width: 751px) {
  .lineup--item-name {
    margin-bottom: 29px;
    font-size: 1.125rem;
    letter-spacing: .04em; } }
@media screen and (max-width: 750px) {
  .lineup--item-name {
    margin-bottom: 5vw;
    font-size: 4.266667vw;
    text-align: center;
    letter-spacing: .08em; } }

@media screen and (min-width: 751px) {
  .lineup--item-copy {
    margin-bottom: 24px;
    font-size: .9375rem;
    letter-spacing: .12em;
    line-height: 1.75; } }
@media screen and (max-width: 750px) {
  .lineup--item-copy {
    margin-bottom: 4vw;
    font-size: 3.73334vw;
    text-align: center;
    letter-spacing: .08em;
    line-height: 1.64286; } }

@media screen and (min-width: 751px) {
  .lineup--item-text {
    margin-bottom: 32px;
    font-size: .8125rem;
    line-height: 1.69231;
    letter-spacing: .04em; } }
@media screen and (max-width: 750px) {
  .lineup--item-text {
    margin-bottom: 7vw;
    font-size: 3.2vw;
    text-align: center;
    line-height: 1.66667;
    letter-spacing: .04em; } }

@media screen and (max-width: 750px) {
  .lineup__item {
    padding-top: 17.6vw; } }

@media screen and (min-width: 751px) {
  .lineup .m-contents--default-btn {
    margin: 0; } }

.lineup--notes {
  margin: 0 auto; }
  @media screen and (min-width: 751px) {
    .lineup--notes {
      width: 1100px;
      font-size: .625rem;
      letter-spacing: .03em; } }
  @media screen and (max-width: 750px) {
    .lineup--notes {
      width: 84vw;
      padding-left: 1.3em;
      font-size: 2.66667vw;
      text-indent: -1.3em;
      line-height: 1.7;
      letter-spacing: .04em; } }

/*
* .prod--notes
*/
.prod--notes {
  margin: 0;
  box-sizing: border-box; }
  @media screen and (min-width: 751px) {
    .prod--notes {
      margin-bottom: 100px;
      padding: 34px 0 0 5px;
      width: 62%; } }
  @media screen and (max-width: 750px) {
    .prod--notes {
      width: 81%;
      margin: 0px auto 0; } }

.prod--notes li {
  color: #878782;
  letter-spacing: .04em; }
  @media screen and (min-width: 751px) {
    .prod--notes li {
      font-size: .6875rem;
      line-height: 1.81819;
      padding-left: 1em;
      text-indent: -1em; } }
  @media screen and (max-width: 750px) {
    .prod--notes li {
      margin-top: 1vw;
      font-size: 2.66667vw;
      line-height: 1.8; } }
  .prod--notes li:before {
    content: "※"; }
  .prod--notes li:first-child {
    margin-top: 0; }

/*
* .end-of-sale
*/
.end-of-sale {
  color: #e65096; }

.m--ingredients-btn {
  display: table;
  color: #878782;
  cursor: pointer;
  transition-duration: .3s;
  transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1); }
  @media screen and (min-width: 751px) {
    .m--ingredients-btn {
      margin: 0 0 27px 0;
      font-size: .8125rem; } }
  @media screen and (max-width: 750px) {
    .m--ingredients-btn {
      margin: 0 auto 5.8vw;
      font-size: 3.2vw; } }
  .m--ingredients-btn span {
    display: inline-block;
    padding-bottom: 2px;
    border-bottom: 1px solid #878782; }
  .m--ingredients-btn:hover {
    opacity: .6; }
  .m--ingredients-btn:after {
    display: inline-block;
    background: url("/contents/shared/images/icon_ingredients_btn.svg") no-repeat 0 0;
    background-size: 100% 100%;
    content: ""; }
    @media screen and (min-width: 751px) {
      .m--ingredients-btn:after {
        width: 16px;
        height: 16px;
        margin-left: 4px;
        vertical-align: -3px; } }
    @media screen and (max-width: 750px) {
      .m--ingredients-btn:after {
        width: 4vw;
        height: 4vw;
        margin-left: 1.06667vw;
        vertical-align: -1vw; } }

.m__ingredients-modal {
  display: none;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 2000;
  overflow: auto;
  margin: auto;
  padding: 10px;
  text-align: center;
  box-sizing: border-box;
  opacity: 0; }
  .m__ingredients-modal:after {
    display: inline-block;
    height: 100%;
    vertical-align: middle;
    content: ""; }
    @media screen and (min-width: 751px) {
      .m__ingredients-modal:after {
        margin-left: -0.05em; } }
    @media screen and (max-width: 750px) {
      .m__ingredients-modal:after {
        margin-left: -0.3em; } }

.m__ingredients-modal.is-opened {
  display: block;
  animation: fadeIn 0.3s cubic-bezier(0.645, 0.045, 0.355, 1) 0s 1 normal forwards; }

@keyframes fadeOut {
  0% {
    opacity: 1; }
  99% {
    opacity: 0; }
  100% {
    opacity: 0; } }
@keyframes fadeIn {
  0% {
    opacity: 0; }
  1% {
    opacity: 0; }
  100% {
    opacity: 1;
    transform: translateZ(1px); } }
.m__ingredients-modal-bg {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2001;
  width: 100%;
  height: 100%;
  background-color: rgba(135, 135, 130, 0.7);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px); }

.m__ingredients-modal-warp {
  display: inline-block;
  position: relative;
  z-index: 2002;
  margin: auto;
  vertical-align: middle;
  background-color: #fff;
  box-sizing: border-box;
  transform: translate3d(0, 0, 0); }
  @media screen and (min-width: 751px) {
    .m__ingredients-modal-warp {
      width: 800px;
      padding: 77px 102px 70px;
      border-radius: 2px; } }
  @media screen and (max-width: 750px) {
    .m__ingredients-modal-warp {
      width: 93.06667vw;
      padding: 13.33334vw 9.33334vw 11.33334vw; } }

.is-opened .m__ingredients-modal-warp {
  animation: zoomOut 0.3s cubic-bezier(0.645, 0.045, 0.355, 1) 0s 1 normal forwards; }

@keyframes zoomOut {
  0% {
    transform: scale(1.04); }
  100% {
    transform: scale(1); } }
.m--ingredients-modal-title {
  color: #c8c8c8;
  font-weight: bold;
  text-align: left; }
  @media screen and (min-width: 751px) {
    .m--ingredients-modal-title {
      font-size: .875rem;
      line-height: 1.5715; } }
  @media screen and (max-width: 750px) {
    .m--ingredients-modal-title {
      font-size: 3.73334vw; } }

.m--ingredients-modal-text {
  color: #2b2e38;
  text-align: left; }
  @media screen and (min-width: 751px) {
    .m--ingredients-modal-text {
      margin-top: 20px;
      font-size: .8125rem;
      line-height: 1.69231; } }
  @media screen and (max-width: 750px) {
    .m--ingredients-modal-text {
      margin-top: 5.33334vw;
      font-size: 3.46667vw;
      line-height: 1.69231; } }

.m--ingredients-modal-close {
  display: block;
  position: absolute;
  z-index: 2002;
  overflow: visible;
  margin: 0;
  padding: 0;
  border: 0;
  background: url("/contents/shared/images/icon_ingredients_close_btn.svg") no-repeat 0 0;
  background-size: 100% 100%;
  cursor: pointer;
  outline: 0;
  transition-duration: .3s;
  transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1); }
  @media screen and (min-width: 751px) {
    .m--ingredients-modal-close {
      top: 16px;
      right: 16px;
      width: 16px;
      height: 16px; } }
  @media screen and (max-width: 750px) {
    .m--ingredients-modal-close {
      top: 4.26667vw;
      right: 4.26667vw;
      width: 4.8vw;
      height: 4.8vw; } }
  .m--ingredients-modal-close:hover {
    opacity: .6; }

/*
* animation
*/
.entrance {
  opacity: 0; }

.entrance.is-animate {
  animation: fadeIn .6s ease-in-out 0s 1 normal forwards; }

@keyframes fadeInMove {
  0% {
    display: none;
    opacity: 0; }
  1% {
    display: block;
    top: 30px;
    opacity: 0; }
  100% {
    display: block;
    top: 0;
    opacity: 1; } }
.l-main > section {
  opacity: 0;
  position: relative;
  top: 30px;
  transition-duration: .6s;
  transition-delay: .2s;
  transition-timing-function: ease-in-out; }

.l-main > section.is-animate {
  opacity: 1;
  top: 0; }

/***/
.btn__cart a {
  transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1) 0s; }

.btn__cart a, .btn__reserve a {
  width: 100%;
  text-align: center;
  text-decoration: none;
  background-color: #878782;
  border-radius: 2px;
  display: inline-block; }

.btn__cart a span, .btn__modal a, .btn__more a:before, .remodal-close:before, .voice__list li p {
  background-repeat: no-repeat; }

.btn__cart a span {
  display: inline-block;
  padding-left: 32px;
  font-weight: 700;
  color: #fff;
  font-size: 18px;
  line-height: 50px;
  letter-spacing: .1em;
  background-image: url(../../assets/images/icon-cart.svg);
  background-size: 20px auto;
  background-position: left center; }
  @media screen and (max-width: 750px) {
    .btn__cart a span {
      padding-left: 8vw;
      font-size: 4.2666666667vw;
      /*line-height: 14.6666666667vw;*/
      line-height: 1.2;
      background-size: 5.3333333333vw auto;
      padding-top: 10px;
      padding-bottom: 10px; } }

.btn__more a, .btn__more a span {
  display: inline-block;
  -webkit-transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1) 0s; }

.btn__more a {
  width: 100%;
  max-width: 340px;
  text-align: center;
  text-decoration: none;
  background-color: transparent;
  border: 1px solid #c8c8c8;
  border-radius: 25px;
  position: relative;
  transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
  box-sizing: border-box; }
  @media screen and (max-width: 750px) {
    .btn__more a {
      max-width: 80vw;
      border-radius: 7.33333vw; } }

.btn__more a:before {
  content: "";
  display: block;
  width: 6px;
  height: 48px;
  background-image: url(../images/icon-arrow-gray.svg);
  background-size: 6px auto;
  background-position: center;
  position: absolute;
  right: 26px;
  top: 0;
  transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1) 0s; }
  @media screen and (max-width: 750px) {
    .btn__more a:before {
      width: 1.73333vw;
      height: 13.6vw;
      background-size: 1.73333vw auto;
      right: 6.93333vw; } }

.btn__more a span {
  color: #3c3c3c;
  font-size: 14px;
  line-height: 48px;
  transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1) 0s; }
  @media screen and (max-width: 750px) {
    .btn__more a span {
      font-size: 3.73333vw;
      line-height: 13.6vw; } }

@media screen and (min-width: 768px) {
  .btn__more a:hover {
    color: #fff;
    background-color: #c8c8c8; } }
@media screen and (min-width: 768px) {
  .btn__more a:hover:before {
    background-image: url(../images/icon-arrow-white.svg); } }
@media screen and (min-width: 768px) {
  .btn__more a:hover span {
    color: #fff; } }
@media screen and (max-width: 750px) {
  .product__description__more {
    text-align: center;
    /*max-width: 300px;*/
    margin: 10px auto; } }

/***/
.mt-15 {
  margin-top: 15px; }

.mt-40 {
  margin-top: 40px; }

.mb-40 {
  margin-bottom: 40px; }

/***/
.anchor-area {
  width: 920px;
  margin: 0 auto 65px; }
  @media screen and (max-width: 750px) {
    .anchor-area {
      width: 90%; } }
  .anchor-area .flexbox {
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
    justify-content: center; }
  .anchor-area .flexbox-inner {
    width: calc(100% / 3 - 27px);
    text-align: center; }
    @media screen and (max-width: 750px) {
      .anchor-area .flexbox-inner {
        width: calc(100% / 2 - 27px); } }
  .anchor-area .flexbox-inner a {
    color: #3c3c3c;
    text-decoration: none;
    cursor: pointer; }
  .anchor-area .item-image {
    display: block;
    width: 100%;
    margin: 0 auto 15px; }
  .anchor-area .item-image01 {
    width: 60px !important; }
  .anchor-area .item-image02 {
    width: 67px !important; }
  .anchor-area .item-image03 {
    width: 67px !important; }

.anchor-arrow {
  max-width: 18px;
  display: block;
  margin: 15px auto 0;
  text-align: center; }

.anchor__item-name {
  font-size: 16px;
  line-height: 170%; }
  @media screen and (max-width: 750px) {
    .anchor__item-name {
      font-size: 14px; } }

.anchor__item-price {
  line-height: 170%;
  font-size: 14px;
  margin-bottom: 15px;
  display: block; }
  @media screen and (max-width: 750px) {
    .anchor__item-price {
      margin-bottom: 5px; } }

/***/
.sec02 {
  text-align: center;
  margin: 130px auto 150px; }
  @media screen and (max-width: 750px) {
    .sec02 {
      width: 90%;
      margin: 90px auto 95px; } }
  .sec02 img {
    max-width: 728px;
    margin: 0 auto; }

/*

h3{
	font-size: 22px;
	line-height: 170%;
	letter-spacing: 0.88px;
	margin: 30px auto;
	@include mq {
		font-size: 16px;
		letter-spacing: 0.64px;
	}
}
*/
.sec02 p {
  font-size: 14px;
  line-height: 170%;
  /* 23.8px */
  letter-spacing: 0.56px; }

/***/
.sec04 {
  margin: 200px auto 65px; }
  @media screen and (max-width: 750px) {
    .sec04 {
      margin: 115px auto 10.8vw; } }

.detail--inner__subtitle {
  text-align: center; }
  @media screen and (min-width: 751px) {
    .detail--inner__subtitle {
      text-align: center;
      margin-top: 40px;
      line-height: 100%;
      /* 20px */
      letter-spacing: 0.8px;
      padding: 15px 62px; } }

.detail--inner__subtitle span {
  border-radius: 20px;
  background: #FEF1BD;
  font-size: 20px;
  line-height: 100%;
  /* 20px */
  letter-spacing: 0.8px;
  padding: 10px 62px; }
  @media screen and (max-width: 750px) {
    .detail--inner__subtitle span {
      font-size: 16px;
      display: block;
      border-radius: 50px;
      padding: 10px 20px;
      box-sizing: border-box; } }

.detail--inner .img01 {
  max-width: 334px;
  margin: 30px auto;
  display: block; }

.detail--inner .img02 {
  max-width: 454px;
  margin: 30px auto;
  display: block; }
  @media screen and (max-width: 750px) {
    .detail--inner .img02 {
      margin: 30px auto 0; } }

.detail--inner .img03 {
  max-width: 616px;
  margin: 30px auto; }

.flex2 .flexbox {
  width: calc(100% / 2 - 160px); }
  @media screen and (max-width: 750px) {
    .flex2 .flexbox {
      width: 100%; } }

.detail2 {
  background: #EBF7FC; }

.detail2 .detail--inner__subtitle span {
  background: #C3E4F2; }

.inner-box2__img1 {
  position: absolute;
  left: 284.595px;
  top: 55px;
  max-width: 90px;
  display: block; }
  @media screen and (max-width: 750px) {
    .inner-box2__img1 {
      left: 25%;
      top: 117px;
      max-width: 75.017px; } }

.inner-box2__img2 {
  position: absolute;
  right: 284.595px;
  top: 55px;
  max-width: 90px;
  display: block; }
  @media screen and (max-width: 750px) {
    .inner-box2__img2 {
      right: 25%;
      top: 117px;
      max-width: 75.017px; } }

.usage2 {
  height: auto;
  padding: 40px;
  font-size: 14px; }
  .usage2 .flex-box {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 60px; }
    @media screen and (max-width: 750px) {
      .usage2 .flex-box {
        gap: 19px; } }
    .usage2 .flex-box img {
      max-width: 128px;
      display: block; }
      @media screen and (max-width: 750px) {
        .usage2 .flex-box img {
          width: 100%;
          max-width: 86px;
          display: block; } }
  .usage2 .pink {
    color: #E35493;
    line-height: 170%;
    font-size: 14px;
    margin-top: 22px; }
  .usage2 .note {
    font-size: 11px;
    line-height: 170%;
    letter-spacing: 0.44px;
    margin-top: 5px; }
  .usage2 p {
    line-height: 170%; }
  .usage2 .box {
    text-align: left; }
    .usage2 .box ul li {
      position: relative;
      padding-left: 20px;
      letter-spacing: 0.56px;
      line-height: 170%;
      font-size: 14px; }
    .usage2 .box ul li:before {
      position: absolute;
      content: "・";
      left: 0; }

@media screen and (min-width: 751px) {
  .sec04 .prod--notes {
    margin-bottom: 0; } }

/***/
@media screen and (max-width: 750px) {
  .sec05 .product__description__more {
    text-align: center;
    margin: 10px auto; } }
.sec05 .prod--notes {
  margin-bottom: 0; }
.sec05.prod {
  margin: 135px 0 65px; }
  @media screen and (max-width: 750px) {
    .sec05.prod {
      margin: 50px 0 10.8vw; } }

/***/
.sec06 {
  width: 1100px;
  margin: 0 auto 185px; }
  @media screen and (max-width: 750px) {
    .sec06 {
      width: 90%;
      margin: 0 auto 100px; } }
  .sec06 .flex-box {
    display: flex;
    flex-wrap: wrap;
    gap: 60px;
    justify-content: center;
    align-items: flex-start;
    margin-top: 50px; }
    @media screen and (max-width: 750px) {
      .sec06 .flex-box {
        gap: 20px 0px; } }
    .sec06 .flex-box img {
      display: block;
      max-width: 100%; }
  .sec06 .box01 {
    width: 520px;
    border: 2px solid #FEF1BD;
    padding: 66px 60px;
    box-sizing: border-box; }
    @media screen and (max-width: 750px) {
      .sec06 .box01 {
        width: 100%;
        margin: 0 auto;
        padding: 25px; } }
    .sec06 .box01 ul {
      border-bottom: 2px solid #FEF1BD; }
  .sec06 .box02 {
    width: 520px;
    border: 2px solid #C2EAEE;
    padding: 66px 60px;
    position: relative;
    box-sizing: border-box; }
    @media screen and (max-width: 750px) {
      .sec06 .box02 {
        width: 100%;
        margin: 0 auto;
        padding: 25px; } }
    .sec06 .box02 ul {
      border-bottom: 2px solid #C2EAEE; }
  .sec06 ul {
    border-bottom: 2px solid #C2EAEE;
    width: 100%;
    margin: 0 auto;
    padding: 0 20px 35px;
    box-sizing: border-box; }
    @media screen and (max-width: 750px) {
      .sec06 ul {
        padding: 0 0 30px; } }
    .sec06 ul li {
      position: relative;
      padding: 4px 0 4px 30px;
      font-size: 14px;
      letter-spacing: 0.56px;
      line-height: 170%; }
      @media screen and (max-width: 750px) {
        .sec06 ul li {
          font-size: 12px; } }
    .sec06 ul li:before {
      position: absolute;
      content: "";
      background: url("../images/icon-check.svg") center no-repeat;
      background-size: 15px;
      left: 0;
      height: 17px;
      width: 20px; }
  .sec06 .cart-in, .sec06 .btn__more a {
    width: 100%; }

.sec06__item-name {
  text-align: center;
  font-size: 16px;
  line-height: 156%;
  letter-spacing: 0.64px; }

.sec06__item-price {
  text-align: center;
  font-size: 14px;
  line-height: 170%;
  letter-spacing: 0.56px; }

.sec06__item-text {
  text-align: left;
  font-size: 14px;
  line-height: 170%;
  margin: 6px auto 20px;
  letter-spacing: 0.56px;
  width: 340px;
  margin: 0 auto; }
  @media screen and (max-width: 750px) {
    .sec06__item-text {
      width: 100%;
      text-align: center;
      margin: 5px auto 16px; } }

.sec06__item-note {
  position: absolute;
  font-size: 11px;
  bottom: 5%;
  right: 12%; }
  @media screen and (max-width: 750px) {
    .sec06__item-note {
      bottom: 1.5%;
      left: 7%; } }

@media screen and (min-width: 751px) {
  .sec06 .cart-in, .sec06 .product__description__more {
    width: 340px !important;
    margin: 15px auto; } }

/***/
.detail3 {
  background: #EBF7FC; }

.detail--imgflex-wrap1 {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 70px; }
  .detail--imgflex-wrap1 .flexbox {
    width: 350px; }
    @media screen and (max-width: 750px) {
      .detail--imgflex-wrap1 .flexbox {
        width: 100%; } }
  .detail--imgflex-wrap1 img {
    max-width: 350px;
    display: block; }
    @media screen and (max-width: 750px) {
      .detail--imgflex-wrap1 img {
        width: 80% !important;
        margin: 0 auto; } }
  .detail--imgflex-wrap1 p {
    margin-top: 30px;
    font-size: 13px;
    line-height: 170%;
    letter-spacing: 0.52px; }

.detail--imgflex-wrap2 {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 45px; }
  @media screen and (max-width: 750px) {
    .detail--imgflex-wrap2 {
      gap: 10px;
      align-items: unset; } }
  .detail--imgflex-wrap2 .flexbox {
    width: 125px; }
  .detail--imgflex-wrap2 img {
    max-width: 125px;
    display: block; }
  .detail--imgflex-wrap2 p {
    margin-top: 30px;
    font-size: 13px;
    line-height: 170%;
    letter-spacing: 0.52px; }
    @media screen and (max-width: 750px) {
      .detail--imgflex-wrap2 p {
        font-size: 11px;
        text-align: center; } }
  .detail--imgflex-wrap2 sup {
    font-size: 10px; }

@media screen and (max-width: 750px) {
  .detail--imgflex-wrap1 .detail3-img02 {
    width: 100% !important; } }

/***/
@media screen and (min-width: 751px) {
  .sec07.prod {
    margin-bottom: 65px; } }
@media screen and (max-width: 750px) {
  .sec07.prod {
    margin-bottom: 10.8vw; } }
.sec07.prod .prod--notes {
  margin-bottom: 0; }

/***/
@media screen and (min-width: 751px) {
  .usage.usage02 {
    margin-bottom: 150px; } }
@media screen and (max-width: 750px) {
  .usage.usage02 {
    margin-bottom: 26vw; } }

/***/
.sec08 .prod__inner {
  border: 1px solid #C8C8C8;
  padding: 20px 0; }
  @media screen and (max-width: 750px) {
    .sec08 .prod__inner {
      width: 90%;
      margin: 0 auto;
      padding: 20px 0 30px; } }
.sec08 .prod--picture {
  padding: 0; }
  @media screen and (max-width: 750px) {
    .sec08 .prod--picture {
      width: 70% !important;
      margin: 0 auto 6vw;
      padding-left: 20%; } }

.sec08 .prod--picture img {
  width: 290px;
  margin: 0 auto;
  display: block; }

.sec08 .prod--price {
  font-size: 14px;
  line-height: 170%; }
  @media screen and (max-width: 750px) {
    .sec08 .prod--price {
      font-size: 3.1vw; } }

.prod--topic {
  margin-bottom: 25px;
  font-size: 14px;
  line-height: 1.7;
  letter-spacing: 0.56px; }
  @media screen and (max-width: 750px) {
    .prod--topic {
      margin-bottom: 5.6vw;
      font-size: 3.1vw;
      text-align: center; } }

.anchor--prod {
  cursor: pointer; }

.mt-0 {
  margin-top: 0px !important; }

.t-center {
  text-align: center; }

.w-100 {
  width: 100% !important; }

@media screen and (max-width: 750px) {
  .detail--inner__txt02 {
    width: 100% !important;
    text-align: center; } }

.sec02_ttl {
  font-size: 20px;
  text-align: center;
  line-height: 140%;
  letter-spacing: 0.15em;
  margin: 30px auto; }
  @media screen and (max-width: 750px) {
    .sec02_ttl {
      font-size: 16px; } }

@media screen and (max-width: 750px) {
  .sec09 .btn__more a span {
    font-size: 3.333vw;
    line-height: 48px; } }
@media screen and (max-width: 750px) {
  .sec09 .btn__more a:before {
    right: 16px;
    height: 48px; } }

.add-kit {
  margin: 165px auto 0; }
  @media screen and (max-width: 750px) {
    .add-kit {
      margin: 115px auto 0; } }
