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

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

@media screen and (min-width: 768px) {
  br.pc-none {
    display: none; } }
@media screen and (max-width: 767px) {
  br.pc-none {
    display: inline; } }

@media screen and (min-width: 768px) {
  br.sp-none {
    display: inline; } }
@media screen and (max-width: 767px) {
  br.sp-none {
    display: none; } }

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

/*
* animation
*/
@keyframes fadeIn {
  0% {
    display: none;
    opacity: 0; }
  1% {
    display: block;
    opacity: 0; }
  100% {
    display: block;
    opacity: 1;
    transform: translateZ(1px); } }
.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 {
  position: relative;
  opacity: 0;
  top: 30px;
  transition-duration: .6s;
  transition-delay: .2s;
  transition-timing-function: ease-in-out;
  box-sizing: border-box;
  letter-spacing: 0.56px; }
  @media screen and (max-width: 767px) {
    .l-main section {
      /*width: 90%;*/
      margin: 0 auto; } }
  @media screen and (min-width: 768px) {
    .l-main section {
      font-size: 0.875rem; } }

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

.l-main section,
.l-main section *,
.l-main section *::before,
.l-main section *::after {
  box-sizing: border-box; }

/*詳細ボタン*/
.btn__more a {
  display: inline-block;
  position: relative;
  box-sizing: border-box;
  cursor: pointer;
  width: 100%;
  text-align: center;
  text-decoration: none;
  background-color: transparent;
  border: 1px solid #c8c8c8;
  transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
  max-width: 80vw;
  margin: 0 auto;
  border-radius: 7.33333vw; }
  @media screen and (min-width: 768px) {
    .btn__more a {
      max-width: 340px;
      border-radius: 25px; } }
  .btn__more a:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    background-image: url(../images/icon-arrow-gray.svg);
    background-position: center;
    background-repeat: no-repeat;
    transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    right: 6.93333vw;
    width: 1.73333vw;
    height: 13.6vw;
    background-size: 1.73333vw auto; }
    @media screen and (min-width: 768px) {
      .btn__more a:before {
        right: 26px;
        width: 6px;
        height: 48px;
        background-size: 6px auto; } }
  .btn__more a span {
    display: inline-block;
    color: #3c3c3c;
    transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    font-size: 3.73333vw;
    line-height: 13.6vw; }
    @media screen and (min-width: 768px) {
      .btn__more a span {
        font-size: 14px;
        line-height: 48px; } }
  @media screen and (min-width: 768px) {
    .btn__more a:hover {
      color: #fff;
      background-color: #c8c8c8; }
      .btn__more a:hover:before {
        background-image: url(../images/icon-arrow-white.svg); }
      .btn__more a:hover span {
        color: #fff; } }

.product__description__more {
  text-align: center;
  margin: 10px auto; }

.cart-in + .product__description__more,
.cart-in + .product__description__more + .product__description__more {
  margin: 15px auto 10px; }
  @media screen and (max-width: 767px) {
    .cart-in + .product__description__more,
    .cart-in + .product__description__more + .product__description__more {
      text-align: center !important; } }

@media screen and (min-width: 768px) {
  .btn__setitem {
    margin-bottom: 20px !important; } }

@media screen and (max-width: 767px) and (min-width: 767px) {
  .l-main .prod--picture img {
    width: revert-layer !important; } }
/*
* カートインボタン
*/
@media screen and (min-width: 768px) {
  .cart-in {
    width: 340px;
    height: 50px; } }
@media screen and (max-width: 767px) {
  .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: 768px) {
    .cart-in a {
      border-radius: 2px;
      font-size: 1.125rem; } }
  @media screen and (max-width: 767px) {
    .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: 767px) {
    .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: 768px) {
    .l-main .cart-in a svg,
    .l-main .cart-in a img {
      width: 30px;
      height: 30px; } }
  @media screen and (max-width: 767px) {
    .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; }

/*
* 全成分ボタン
*/
.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: 768px) {
    .m--ingredients-btn {
      margin: 0 0 27px 0;
      font-size: .8125rem; } }
  @media screen and (max-width: 767px) {
    .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: 768px) {
      .m--ingredients-btn:after {
        width: 16px;
        height: 16px;
        margin-left: 4px;
        vertical-align: -3px; } }
    @media screen and (max-width: 767px) {
      .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: 768px) {
      .m__ingredients-modal:after {
        margin-left: -0.05em; } }
    @media screen and (max-width: 767px) {
      .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: 768px) {
    .m__ingredients-modal-warp {
      width: 800px;
      padding: 77px 102px 70px;
      border-radius: 2px; } }
  @media screen and (max-width: 767px) {
    .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: 768px) {
    .m--ingredients-modal-title {
      font-size: .875rem;
      line-height: 1.5715; } }
  @media screen and (max-width: 767px) {
    .m--ingredients-modal-title {
      font-size: 3.73334vw; } }

.m--ingredients-modal-text {
  color: #2b2e38;
  text-align: left; }
  @media screen and (min-width: 768px) {
    .m--ingredients-modal-text {
      margin-top: 20px;
      font-size: .8125rem;
      line-height: 1.69231; } }
  @media screen and (max-width: 767px) {
    .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: 768px) {
    .m--ingredients-modal-close {
      top: 16px;
      right: 16px;
      width: 16px;
      height: 16px; } }
  @media screen and (max-width: 767px) {
    .m--ingredients-modal-close {
      top: 4.26667vw;
      right: 4.26667vw;
      width: 4.8vw;
      height: 4.8vw; } }
  .m--ingredients-modal-close:hover {
    opacity: .6; }

/*
*  .entrance
*/
.entrance {
  /*opacity: .5;*/
  margin: 0 auto;
  box-sizing: border-box; }
  @media screen and (min-width: 768px) {
    .entrance {
      display: flex;
      flex-wrap: nowrap;
      justify-content: flex-start;
      align-items: center;
      width: 100%;
      margin-bottom: 140px;
      border-bottom: 1px solid #f2f2f2; } }
  @media screen and (max-width: 767px) {
    .entrance {
      margin-bottom: 9.3333333333vw; } }
  @media screen and (min-width: 768px) {
    .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: 767px) {
    .entrance--picture {
      width: 100%;
      height: 124.8vw; } }
  .entrance--picture picture,
  .entrance--picture img {
    width: 100%;
    height: 100%; }
  .entrance--title {
    font-family: "Noto Serif JP", serif;
    letter-spacing: 0.1em;
    font-size: 2.1875vw;
    margin: 0 0 2.7vw; }
    .entrance--title rt {
      font-size: 14px;
      letter-spacing: 0.1em;
      margin-bottom: 4px; }
      @media screen and (max-width: 767px) {
        .entrance--title rt {
          font-size: 2.6666666667vw;
          margin-bottom: 0.2666666667vw; } }
    @media screen and (min-width: 768px) {
      .entrance--title {
        margin: 0 0 2.7vw;
        line-height: 160%; } }
    @media screen and (min-width: 751px) and (max-width: 1200px) {
      .entrance--title {
        /*margin-bottom: 35px;
        font-size: 1.75rem;*/
        font-size: clamp(24px, 1.015626vw, 100px); } }
    @media screen and (max-width: 767px) {
      .entrance--title {
        margin: 17px auto 13px;
        font-size: 5.3333333333vw;
        line-height: 160%;
        text-align: center; } }
    .entrance--title span {
      text-transform: uppercase; }
    .entrance--title sup {
      position: relative;
      vertical-align: top; }
      @media screen and (min-width: 768px) {
        .entrance--title sup {
          top: 4px;
          left: -3px;
          font-size: .75rem; } }
      @media screen and (max-width: 767px) {
        .entrance--title sup {
          top: 0;
          font-size: 2.66667vw; } }
  .entrance__description {
    box-sizing: border-box; }
    @media screen and (min-width: 768px) {
      .entrance__description {
        width: 50vw;
        padding: 0 0 0 4.4vw; } }
    @media screen and (min-width: 751px) and (max-width: 1200px) {
      .entrance__description {
        width: 50%; } }
    @media screen and (max-width: 767px) {
      .entrance__description {
        width: 100%; } }
    .entrance__description__name {
      font-family: "Noto Serif JP", serif; }
      @media screen and (min-width: 768px) {
        .entrance__description__name {
          margin-bottom: 1.8vw;
          font-size: 1.5625vw;
          letter-spacing: .11em; } }
      @media screen and (min-width: 751px) and (max-width: 1200px) {
        .entrance__description__name {
          /*margin-bottom: 24px;
          font-size: 1.25rem;*/
          font-size: clamp(17px, 1.015626vw, 100px); } }
      @media screen and (max-width: 767px) {
        .entrance__description__name {
          margin-bottom: 1.8vw;
          font-size: 3.73334vw;
          text-align: center;
          letter-spacing: .06em; } }
      .entrance__description__name:has(.tag) {
        display: flex;
        align-items: center;
        gap: 10px; }
        @media screen and (max-width: 767px) {
          .entrance__description__name:has(.tag) {
            justify-content: center; } }
      .entrance__description__name .tag {
        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;
        padding: 3px 0;
        font-size: 11px;
        display: inline-block;
        width: 64px;
        letter-spacing: 0.44px; }
        @media screen and (max-width: 767px) {
          .entrance__description__name .tag {
            font-size: 2.6666666667vw; } }
    .entrance__description__price {
      font-family: "Noto Serif JP", serif;
      line-height: 1; }
      @media screen and (min-width: 768px) {
        .entrance__description__price {
          margin-bottom: 3.15vw;
          font-size: 1.171875vw;
          letter-spacing: .11em; } }
      @media screen and (min-width: 751px) and (max-width: 1200px) {
        .entrance__description__price {
          font-size: .875rem; } }
      @media screen and (max-width: 767px) {
        .entrance__description__price {
          margin-bottom: 3.15vw;
          font-size: 3.1vw;
          text-align: center;
          letter-spacing: 0.06em; } }
    .entrance__description__date {
      line-height: 1;
      font-family: normal;
      /*font-family: "Noto Serif JP", serif;*/ }
      @media screen and (min-width: 768px) {
        .entrance__description__date {
          font-size: 1.015625vw;
          letter-spacing: 0.16em;
          margin-top: 3.221875vw; } }
      @media screen and (min-width: 751px) and (max-width: 1200px) {
        .entrance__description__date {
          font-size: clamp(11px, 1.015626vw, 9999px); } }
      @media screen and (max-width: 767px) {
        .entrance__description__date {
          margin-top: 5.3333333333vw;
          margin-bottom: 2.4vw;
          font-size: 13px;
          text-align: center;
          letter-spacing: .06em;
          margin-top: 13px; } }
  .entrance .entrance__icon {
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-start;
    gap: 10px; }
    @media screen and (max-width: 767px) {
      .entrance .entrance__icon {
        margin-bottom: 2.4vw;
        justify-content: center; } }
    .entrance .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;
      padding: 3px 0;
      font-size: 11px; }
      @media screen and (min-width: 768px) {
        .entrance .entrance__icon li {
          width: 64px;
          font-size: 11px;
          /*line-height: 1.2vw;*/
          margin: 15px 0 0; } }
      @media screen and (min-width: 751px) and (max-width: 1200px) {
        .entrance .entrance__icon li {
          /*width: 80px;
          font-size: .8125rem;*/ } }
      @media screen and (max-width: 767px) {
        .entrance .entrance__icon li {
          width: 19.26667vw;
          padding: 0 2.66667vw;
          font-size: 2.66667vw;
          line-height: 4.8vw; } }
  .entrance .prod--notes {
    margin: 20px 0 0; }
    @media screen and (min-width: 768px) {
      .entrance .prod--notes {
        max-width: 490px;
        width: 100%;
        margin-bottom: 0;
        padding: 0; } }
    @media screen and (max-width: 767px) {
      .entrance .prod--notes {
        width: 90%;
        margin: 33px auto 0;
        padding-top: 0; } }
    .entrance .prod--notes li {
      padding-left: 1em;
      text-indent: -1em; }

.entrance--notes {
  width: 100%;
  color: #878782;
  box-sizing: border-box; }
  @media screen and (min-width: 768px) {
    .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: 767px) {
    .entrance--notes {
      font-size: 2.66667vw;
      text-align: center; } }

/*
*  .prod base
*/
.prod_ancho {
  padding: 0 0 80px; }
  @media screen and (max-width: 767px) {
    .prod_ancho {
      padding: 0 0 13.3333333333vw;
      width: 80%; } }

@media screen and (min-width: 768px) {
  .prod.second {
    margin-bottom: 70px; } }
@media screen and (max-width: 767px) {
  .prod.second {
    margin-bottom: 70px; } }
@media screen and (max-width: 767px) {
  .prod .cart-in {
    width: 100%; } }

@media screen and (min-width: 768px) {
  .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;
  line-height: 170%;
  letter-spacing: 2.4px; }
  @media screen and (min-width: 768px) {
    .prod--copy {
      margin-bottom: 30px;
      font-size: 1.5rem; } }
  @media screen and (max-width: 767px) {
    .prod--copy {
      font-size: 4.8vw;
      line-height: 1.6;
      letter-spacing: .08em;
      margin: 0 auto 20px; } }

.prod--copy--text {
  text-align: center;
  line-height: 170%;
  letter-spacing: 0.56px;
  margin-bottom: 20px; }

.prod--copy--note {
  text-align: center;
  font-size: 0.625rem;
  line-height: 145%;
  letter-spacing: 0.56px; }
  @media screen and (max-width: 767px) {
    .prod--copy--note {
      text-align: left;
      font-size: 2.9333333333vw; } }

.prod--name {
  line-height: 160%; }
  @media screen and (min-width: 768px) {
    .prod--name {
      font-size: 1rem;
      letter-spacing: .08em; } }
  @media screen and (max-width: 767px) {
    .prod--name {
      font-size: 4.26667vw;
      text-align: center;
      letter-spacing: .04em; }
      .prod--name .prod--beauty-type {
        display: inline-block;
        font-size: 3.8vw; } }
  .prod--name span {
    font-size: 0.875rem; }
    @media screen and (max-width: 767px) {
      .prod--name span {
        font-size: 2.9333333333vw; } }

.prod--type {
  font-size: 0.875rem;
  font-weight: 300;
  line-height: 100%;
  letter-spacing: 0.56px; }
  @media screen and (max-width: 767px) {
    .prod--type {
      text-align: center;
      font-size: 3.7333333333vw; } }

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

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

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

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

.prod--sales--name {
  font-size: 0.6875rem;
  line-height: 145%;
  letter-spacing: 0.04em; }
  @media screen and (max-width: 767px) {
    .prod--sales--name {
      font-size: 2.9333333333vw; } }

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

.prod__inner .prod--notes {
  width: 100% !important;
  margin-bottom: 0 !important;
  padding: 0; }
  @media screen and (max-width: 767px) {
    .prod__inner .prod--notes {
      padding: 0; } }
  .prod__inner .prod--notes li {
    color: #3C3C3C !important;
    font-size: 11px !important;
    line-height: 145% !important;
    /* 15.95px */
    letter-spacing: 0.44px !important;
    padding-left: 1em;
    text-indent: -1em; }

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

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

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

.ing--notes li {
  position: relative;
  padding-left: 1.5em;
  text-indent: -1.5em;
  font-size: .6875rem;
  letter-spacing: .04em;
  line-height: 1.8; }
  @media screen and (max-width: 767px) {
    .ing--notes li {
      font-size: 2.9333333333vw;
      text-align: left;
      letter-spacing: .04em;
      line-height: 145%; } }
.ing--notes.num li {
  padding-left: 2em;
  text-indent: -2em; }

.ing--notes-txt {
  font-size: .6875rem;
  text-align: left;
  line-height: 1.8; }
  @media screen and (max-width: 767px) {
    .ing--notes-txt {
      font-size: 2.66667vw;
      text-align: left;
      line-height: 2; } }

/*
* .usage
*/
.usage {
  /*opacity: .5;*/
  margin: 0 auto;
  padding: 60px 30px;
  border: 1px solid #c8c8c8;
  text-align: center;
  box-sizing: border-box;
  max-width: 1100px;
  width: 100%; }
  @media screen and (max-width: 767px) {
    .usage {
      padding: 40px 25px; } }

@media screen and (min-width: 768px) {
  .usage--title {
    margin-bottom: 20px;
    font-size: 1.125rem;
    letter-spacing: .08em; } }
@media screen and (max-width: 767px) {
  .usage--title {
    margin-bottom: 15px;
    font-size: 4.26667vw;
    letter-spacing: .04em; } }

.usage__list {
  display: table;
  width: fit-content;
  margin: 0 auto; }

.usage__list li {
  text-align: left;
  line-height: 170%;
  padding-left: 1.6em;
  text-indent: -1.6em; }
  @media screen and (min-width: 768px) {
    .usage__list li {
      font-size: .875rem; } }
  @media screen and (max-width: 767px) {
    .usage__list li {
      /*margin-top: 5vw;*/
      padding-left: 1.2em;
      font-size: 3.7333333333vw;
      line-height: 1.66667;
      text-indent: -1em;
      letter-spacing: 0.56px; } }
  .usage__list li:before {
    /*display: inline-block;*/
    content: "・"; }
    @media screen and (min-width: 768px) {
      .usage__list li:before {
        margin-right: 10px; } }
    @media screen and (max-width: 767px) {
      .usage__list li:before {
        /*margin-right: 1vw;*/ } }
  .usage__list li:first-child {
    margin-top: 0; }

/*アンカーレイアウト*/
.prod_ancho .btn__more {
  margin-bottom: 15px; }
  @media screen and (max-width: 767px) {
    .prod_ancho .btn__more a {
      margin-bottom: 0; } }
  @media screen and (max-width: 767px) {
    .prod_ancho .btn__more a span {
      /*line-height: 50px!important;*/ } }
  .prod_ancho .btn__more a:before {
    display: inline-block;
    position: absolute;
    background: url("/contents/shared/images/icon_arrow_select_down.svg") no-repeat 50% 50%;
    /*background-size: 100% 100%;*/
    content: "";
    transition-duration: .3s;
    transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1); }
    @media screen and (min-width: 768px) {
      .prod_ancho .btn__more a:before {
        top: 37%;
        right: 6%;
        width: 25px;
        height: 13px; } }
    @media screen and (max-width: 767px) {
      .prod_ancho .btn__more a:before {
        top: 33%;
        right: 8%;
        width: 3vw;
        height: 4vw; } }
  .prod_ancho .btn__more a:hover:before {
    background: url("/contents/shared/images/icon_arrow_select_down_white.svg") no-repeat 50% 50%; }

.anchor__col {
  max-width: 720px;
  width: 100%;
  margin: 70px auto 0; }
  @media screen and (max-width: 767px) {
    .anchor__col {
      margin: 40px auto 0; } }
  .anchor__col .ing--notes {
    margin-top: 20px; }
    .anchor__col .ing--notes li {
      text-align: left; }

.anchor__col-inner {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: flex-start;
  max-width: 720px;
  width: 100%;
  gap: 20px;
  margin: 0 auto; }
  @media screen and (max-width: 767px) {
    .anchor__col-inner {
      gap: 60px;
      flex-wrap: wrap; } }

.anchor--category {
  order: 3;
  border: 1px solid #e7e5e6;
  text-align: center;
  box-sizing: border-box;
  background-color: #deebf7; }
  @media screen and (min-width: 768px) {
    .anchor--category {
      width: 100px;
      margin: 0 75px;
      padding: 7px 0;
      font-size: .75rem;
      border-radius: 2px; } }
  @media screen and (max-width: 767px) {
    .anchor--category {
      width: 18.66667vw;
      margin: 0 5.86667vw;
      padding: 1vw 0;
      font-size: 2.4vw; } }

.anchor--prod {
  transition-duration: .3s;
  transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1);
  max-width: 310px;
  width: 100%;
  text-align: center;
  z-index: 1;
  /*画像*/ }
  @media screen and (max-width: 767px) {
    .anchor--prod {
      width: 100%;
      max-width: 100%; } }
  .anchor--prod [class^="anchor_item"] {
    margin-bottom: 30px !important; }
  .anchor--prod .anchor_item01 {
    max-width: 92px; }
  .anchor--prod .anchor_item02 {
    max-width: 310px;
    margin-top: 54px; }
  @media screen and (max-width: 767px) {
    .anchor--prod .anchor_item01 {
      max-width: 73px; }
    .anchor--prod .anchor_item02 {
      max-width: 249px;
      margin-top: 0; } }
  .anchor--prod .caption {
    width: 100%; }
  .anchor--prod .prod--name {
    line-height: 156%;
    margin: 5px 0; }
    @media screen and (max-width: 767px) {
      .anchor--prod .prod--name {
        font-size: 4.2666666667vw;
        line-height: 1;
        margin: 0 0 10px; } }
    .anchor--prod .prod--name span {
      font-size: 0.875rem; }
      @media screen and (max-width: 767px) {
        .anchor--prod .prod--name span {
          font-size: 2.9333333333vw; } }
  @media screen and (max-width: 767px) {
    .anchor--prod .prod--type {
      font-size: 3.7333333333vw;
      line-height: 100%; } }
  .anchor--prod .prod--price {
    font-size: 0.875rem;
    line-height: 170%;
    margin-top: 5px;
    margin-bottom: 0; }
    @media screen and (max-width: 767px) {
      .anchor--prod .prod--price {
        font-size: 4vw;
        margin-top: 10px;
        margin-bottom: 15px;
        line-height: 1; } }
  .anchor--prod .cart-in {
    position: relative;
    z-index: 10; }
    @media screen and (min-width: 768px) {
      .anchor--prod .cart-in {
        width: 100%; } }
    .anchor--prod .cart-in a {
      pointer-events: auto; }

/*
* .プレゼント
*/
.ltd-present {
  width: 970px;
  margin: 0 auto 140px;
  background: #fff;
  border: 1px solid #C8C8C8;
  padding: 32px 0 60px;
  line-height: 1.57; }
  @media screen and (max-width: 767px) {
    .ltd-present {
      width: 90%;
      padding: 12vw 22px 12vw;
      margin: 0 auto 18.6666666667vw !important; } }
  .ltd-present .ltd-preset--title {
    margin-bottom: 32px !important; }
    @media screen and (min-width: 768px) {
      .ltd-present .ltd-preset--title {
        margin-bottom: 10px !important;
        left: -11px;
        position: relative; } }
  .ltd-present h3 {
    text-align: center;
    font-size: 18px;
    font-style: normal;
    font-weight: 300;
    line-height: 156%;
    letter-spacing: 0.72px;
    margin-bottom: 50px; }
    @media screen and (max-width: 767px) {
      .ltd-present h3 {
        font-size: 4.2666666667vw;
        margin-bottom: 20px;
        line-height: 156%;
        /* 24.96px */
        letter-spacing: 0.64px; } }
  .ltd-present .prod--notes {
    width: 100%;
    padding: 0;
    margin: 30px auto 0;
    width: fit-content; }
    @media screen and (max-width: 767px) {
      .ltd-present .prod--notes {
        margin: 20px auto 0; } }
    .ltd-present .prod--notes li {
      color: #3c3c3c; }

.ltd-preset--title {
  text-align: center;
  text-transform: uppercase;
  line-height: 1;
  letter-spacing: .155em; }
  @media screen and (min-width: 768px) {
    .ltd-preset--title {
      margin-bottom: 20px;
      font-size: 1.5rem; } }
  @media screen and (max-width: 767px) {
    .ltd-preset--title {
      font-size: 5.33334vw; } }

.ltd-preset--title:before {
  background: url("/topics/limited/assets/images/icon_present.svg") no-repeat 0 0;
  background-size: 100% 100%;
  content: ""; }
  @media screen and (min-width: 768px) {
    .ltd-preset--title:before {
      display: inline-block;
      width: 60px;
      height: 60px;
      vertical-align: -19px; } }
  @media screen and (max-width: 767px) {
    .ltd-preset--title:before {
      display: block;
      width: 16vw;
      height: 16vw;
      margin: 0 auto -2vw; } }

.flex-box-top {
  width: 840px;
  display: flex;
  margin: 0 auto;
  align-items: flex-start;
  justify-content: center;
  flex-wrap: wrap;
  gap: 40px;
  font-size: 0.875rem;
  text-align: center; }
  @media screen and (max-width: 767px) {
    .flex-box-top {
      width: 100%;
      gap: 20px; } }
  .flex-box-top .gwp-preset-item {
    flex: 1; }
    @media screen and (max-width: 767px) {
      .flex-box-top .gwp-preset-item {
        width: 80vw;
        margin: 0 auto;
        flex: 0 0 100%; } }
    .flex-box-top .gwp-preset-item:nth-of-type(1) img {
      width: 67px;
      max-width: 100px; }
      @media screen and (max-width: 767px) {
        .flex-box-top .gwp-preset-item:nth-of-type(1) img {
          width: 13.3333333333vw; } }
    .flex-box-top .gwp-preset-item:nth-of-type(2) img {
      width: 250px;
      max-width: 100%; }
      @media screen and (max-width: 767px) {
        .flex-box-top .gwp-preset-item:nth-of-type(2) img {
          width: 66.6666666667vw; } }
  .flex-box-top .gwp-preset-txt {
    font-weight: 300;
    line-height: 170%;
    letter-spacing: 0.56px;
    padding-left: 1.5em;
    text-indent: -1.5em;
    font-size: 0.875rem;
    text-align: left;
    margin-bottom: 20px; }
    @media screen and (max-width: 767px) {
      .flex-box-top .gwp-preset-txt {
        font-size: 3.7333333333vw; } }
  .flex-box-top .product__description__more {
    margin: 20px auto 0; }

/*
* .worries
*/
.worries {
  background: linear-gradient(180deg, #FFF 0%, #FBF1D8 100%);
  padding-bottom: 40px; }
  @media screen and (max-width: 767px) {
    .worries {
      padding-bottom: 35px; } }
  .worries--inr {
    margin: 0 auto;
    max-width: 1100px;
    width: 100%;
    box-sizing: border-box;
    text-align: center; }
    @media screen and (max-width: 767px) {
      .worries--inr {
        width: 90%; } }
  .worries--box {
    max-width: 588px;
    margin: 0 auto 20px;
    padding: 40px 10px;
    background: #fff;
    border: solid 1px #FFD400;
    border-radius: 10px; }
    @media screen and (max-width: 767px) {
      .worries--box {
        padding-inline: 54px; } }
    .worries--box--list {
      width: fit-content;
      margin: 0 auto; }
      .worries--box--list li {
        font-size: 0.875rem;
        line-height: 170%;
        letter-spacing: 0.56px;
        text-indent: -1.6em;
        padding-left: 1.6em;
        margin-bottom: 6px;
        text-align: left; }
        @media screen and (max-width: 767px) {
          .worries--box--list li {
            font-size: 3.7333333333vw; } }
        .worries--box--list li:last-child {
          margin-bottom: 0; }
        .worries--box--list li::before {
          display: inline-block;
          content: "";
          position: relative;
          top: 2px;
          background: url(../images/check.svg) no-repeat 0 0;
          background-size: 100% 100%;
          width: 16px;
          height: 16px;
          margin-right: 8px; }
  .worries .inner__txt01 {
    font-size: 1.25rem;
    text-align: center;
    line-height: 157%;
    letter-spacing: 0.8px; }
    @media screen and (max-width: 767px) {
      .worries .inner__txt01 {
        font-size: 4.8vw; } }
  .worries .inner__txt02 {
    margin-bottom: 20px;
    line-height: 170%; }
    @media screen and (max-width: 767px) {
      .worries .inner__txt02 {
        font-size: 3.7333333333vw; } }
    .worries .inner__txt02 span {
      font-size: 1.125rem;
      font-style: normal;
      font-weight: 300;
      line-height: 157%;
      letter-spacing: 0.72px; }
      @media screen and (max-width: 767px) {
        .worries .inner__txt02 span {
          font-size: 4.8vw; } }
  .worries__arrow {
    margin: 30px 0;
    text-align: center; }
    .worries__arrow img {
      width: 35px; }
      @media screen and (max-width: 767px) {
        .worries__arrow img {
          width: 35px !important; } }
  .worries h2 {
    font-family: "Noto Serif JP";
    font-size: 1.375rem;
    font-style: normal;
    font-weight: 400;
    line-height: 180%;
    letter-spacing: 2.2px; }
    @media screen and (max-width: 767px) {
      .worries h2 {
        font-size: 5.3333333333vw;
        line-height: 150%; } }
    @media screen and (max-width: 767px) {
      .worries h2 span {
        display: inline-block;
        margin-bottom: 20px; } }

/*アンバサダー*/
.amb {
  margin-top: 60px;
  text-align: center; }
  @media screen and (max-width: 767px) {
    .amb {
      margin-top: 50px; } }
  .amb picture {
    width: 100%;
    margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    .amb p {
      font-size: 3.4666666667vw; } }

/*
* .prod
*/
.prod.prod01 {
  background: #FBF1D8;
  padding-top: 42px;
  margin-top: -2px; }
  @media screen and (max-width: 767px) {
    .prod.prod01 {
      padding-top: 37px; } }

.prod02 {
  background: #EEF1BD; }
  .prod02--copy {
    font-size: 1.625rem;
    line-height: 150%;
    letter-spacing: 2.6px;
    margin-bottom: 60px;
    font-family: "Noto Serif JP";
    text-align: center; }
    @media screen and (max-width: 767px) {
      .prod02--copy {
        font-size: 5.3333333333vw;
        line-height: 150%;
        letter-spacing: 2px;
        margin-bottom: 8vw; } }
    .prod02--copy span {
      display: block;
      margin-top: 20px;
      font-size: 1rem;
      line-height: 100%;
      letter-spacing: 0.64px;
      font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif; }
      @media screen and (max-width: 767px) {
        .prod02--copy span {
          font-size: 3.7333333333vw;
          line-height: 170%;
          letter-spacing: 0.56px; } }
  @media screen and (max-width: 767px) {
    .prod02 .prod--picture {
      width: 66.4vw;
      max-width: 100%; } }

.prod {
  text-align: center;
  margin: 0 auto;
  padding: 80px 0 60px;
  box-sizing: border-box;
  /*処方*/
  /*.detail--ing{
  	display: flex;
  	justify-content: center;
  	gap:20px;
  	flex-wrap: wrap;
  	margin-bottom: 20px;
  	box-sizing: border-box;
  	@include mq{
  		gap:15px;
  	}
  	> li{
  		width: 225px;
  		text-align: center;
  		padding: 0 10px;
  		height: 70px;
  		border: 1px solid #DCDCDC;
  		border-radius: 50px;
  		font-size: rem(14);
  		line-height: 170%;
  		box-sizing: border-box;
  		display: flex;
  		align-items: center;
  		justify-content: center;
  		@include mq{
  			width: auto;
  			flex:0 0 calc(50% - 8px);
  		} 
  	}
  	&.sec{
  		> li{
  			width: 350px;
  			@include mq{
  				max-width: 350px;
  				width: 100%;
  				flex: 0 0 100%;
  			} 
  		}
  	}
  }*/ }
  @media screen and (max-width: 767px) {
    .prod {
      padding: 70px 0 50px;
      width: 100% !important; } }
  @media screen and (max-width: 767px) {
    .prod .inr {
      width: 90%;
      margin: 0 auto; } }
  .prod .prod-box {
    max-width: 1100px;
    width: 100%;
    margin: 0 auto;
    margin-bottom: 60px; }
    @media screen and (max-width: 767px) {
      .prod .prod-box {
        margin-bottom: 30px; } }
    .prod .prod-box-inr {
      background: #fff;
      border-radius: 10px; }
      @media screen and (min-width: 768px) {
        .prod .prod-box-inr {
          padding: 50px 70px; } }
      @media screen and (max-width: 767px) {
        .prod .prod-box-inr {
          padding: 50px 18px; } }
    .prod .prod-box:last-child {
      margin-bottom: 0; }
  .prod .prod--copy {
    font-size: 1.375rem;
    line-height: 180%; }
    @media screen and (max-width: 767px) {
      .prod .prod--copy {
        font-size: 4.8vw; } }
  .prod .prod__inner {
    width: 100%; }
    .prod .prod__inner .prod__description, .prod .prod__inner .product__description__more {
      text-align: left; }
  .prod .prod--picture img {
    max-width: 100px; }
    @media screen and (max-width: 767px) {
      .prod .prod--picture img {
        max-width: 19.4666666667vw; } }
  .prod .cart-in a, .prod .product__description__more a {
    max-width: 310px !important; }
  .prod .shoho-list {
    margin: 0 auto;
    width: fit-content; }
    .prod .shoho-list li {
      padding-left: 1.2em;
      text-indent: -1.2em;
      letter-spacing: 0.56px; }
      @media screen and (max-width: 767px) {
        .prod .shoho-list li {
          font-size: 3.7333333333vw;
          line-height: 170%;
          width: fit-content;
          margin-bottom: 6px;
          text-align: left; } }
      .prod .shoho-list li:before {
        content: "○\00A0"; }
      .prod .shoho-list li:last-child {
        margin-bottom: 0; }
  .prod.prod02 .prod--picture img {
    max-width: 349px; }
    @media screen and (max-width: 767px) {
      .prod.prod02 .prod--picture img {
        width: 66.4vw;
        max-width: 100%; } }
  @media screen and (max-width: 767px) {
    .prod .prod--name {
      font-size: 4.2666666667vw; } }
  .prod .prod--name small {
    font-size: 0.875rem; }
    @media screen and (max-width: 767px) {
      .prod .prod--name small {
        font-size: 3.7333333333vw; } }
  .prod .prod--type {
    margin-bottom: 20px; }
  .prod .prod--price {
    margin-bottom: 24px; }
  .prod .detail--inner__title {
    margin: 0 auto 30px;
    position: relative;
    box-sizing: border-box;
    font-size: 1.25rem;
    letter-spacing: 2px;
    max-width: 600px;
    width: 100%; }
    @media screen and (max-width: 767px) {
      .prod .detail--inner__title {
        font-size: 4.2666666667vw;
        letter-spacing: 0.64px;
        width: auto;
        line-height: 170%; } }
  .prod .detail--inner__title02 {
    font-size: 1.25rem;
    text-align: center;
    line-height: 140%;
    letter-spacing: 2px;
    margin-bottom: 20px; }
    @media screen and (max-width: 767px) {
      .prod .detail--inner__title02 {
        font-size: 4.2666666667vw;
        letter-spacing: 0.64px; } }
    .prod .detail--inner__title02 span {
      display: block;
      font-size: 0.6875rem;
      line-height: 145%;
      letter-spacing: 0.44px;
      margin-top: 10px; }
  .prod .detail-note {
    max-width: 1100px;
    margin: 0 auto 60px;
    font-size: 0.625rem;
    text-align: left; }
    @media screen and (max-width: 767px) {
      .prod .detail-note {
        margin: 0 auto 40px; } }
  @media screen and (max-width: 767px) {
    .prod .detail--inner__title + .detail--txt {
      text-align: center; } }
  .prod .ing--notes {
    margin-top: 20px; }
    .prod .ing--notes li {
      text-align: left; }
  @media screen and (max-width: 767px) {
    .prod .btn__setitem {
      margin-bottom: 15px !important; } }

.num-ttl {
  width: fit-content;
  display: flex; }

.num-ttl span, .mask-num {
  width: 23px;
  height: 23px;
  background: #FFD400;
  border-radius: 50px;
  font-family: Poppins;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  line-height: 1; }
  @media screen and (max-width: 767px) {
    .num-ttl span, .mask-num {
      width: 6.1333333333vw;
      height: 6.1333333333vw;
      font-size: 3.4666666667vw; } }

/*ポイント*/
.prod-box.point .ing--notes {
  display: flex;
  gap: 11px; }
  @media screen and (max-width: 767px) {
    .prod-box.point .ing--notes {
      margin-bottom: 15px; } }

.point-list li {
  margin-bottom: 40px; }
  .point-list li:last-child {
    margin-bottom: 0; }
  @media screen and (max-width: 767px) {
    .point-list li {
      margin-bottom: 20px; } }
.point-list h3 {
  font-size: 1.125rem;
  line-height: 167%;
  letter-spacing: 0.72px;
  font-family: "Noto Serif JP";
  align-items: center;
  gap: 9px;
  margin: 0 auto 15px; }
  @media screen and (max-width: 767px) {
    .point-list h3 {
      flex-direction: column;
      gap: 5px;
      font-size: 4.2666666667vw; } }
  .point-list h3 + p {
    line-height: 170%;
    letter-spacing: 0.56px; }
    @media screen and (max-width: 767px) {
      .point-list h3 + p {
        font-size: 3.7333333333vw; } }
.point-list-seibun {
  font-size: 0.75rem;
  line-height: 170%;
  letter-spacing: 0.48px;
  margin-top: 5px; }
  @media screen and (max-width: 767px) {
    .point-list-seibun {
      font-size: 3.2vw; } }
.point-list + .ing--notes {
  text-align: center;
  margin-top: 30px; }
  .point-list + .ing--notes li {
    text-align: center; }

/*使用イメージ*/
@media screen and (max-width: 767px) {
  .use-box .prod-box-inr {
    padding-inline: 28px !important; } }
.use-box h3 {
  font-size: 18px;
  line-height: 100%;
  letter-spacing: 0.72px;
  text-align: center;
  margin-top: 43px;
  margin-bottom: 20px; }
  @media screen and (max-width: 767px) {
    .use-box h3 {
      font-size: 4.2666666667vw;
      line-height: 140%; } }
  .use-box h3 + p {
    text-align: center;
    margin-bottom: 43px; }
    @media screen and (max-width: 767px) {
      .use-box h3 + p {
        line-height: 170%;
        font-size: 3.7333333333vw;
        margin-left: calc(50% - 50vw);
        margin-right: calc(50% - 50vw);
        margin-bottom: 32px; } }
.use-box .detail--inner__title02 + p {
  font-weight: 300;
  line-height: 170%;
  /* 23.8px */
  letter-spacing: 0.56px;
  margin-bottom: 46px; }
  @media screen and (max-width: 767px) {
    .use-box .detail--inner__title02 + p {
      line-height: 170%;
      font-size: 3.2vw; } }
.use-box .usage__list__img {
  display: flex;
  justify-content: center;
  gap: 40px;
  max-width: 900px;
  margin: 0 auto; }
  @media screen and (max-width: 767px) {
    .use-box .usage__list__img {
      flex-wrap: wrap;
      gap: 30px; } }
  .use-box .usage__list__img li {
    flex: 1; }
    @media screen and (max-width: 767px) {
      .use-box .usage__list__img li {
        flex: 0 0 100%;
        gap: 30px; } }
    .use-box .usage__list__img li picture {
      margin-bottom: 20px; }
      .use-box .usage__list__img li picture + p {
        width: fit-content;
        margin: 0 auto;
        text-align: left;
        line-height: 170%;
        letter-spacing: 0.56px; }
        @media screen and (max-width: 767px) {
          .use-box .usage__list__img li picture + p {
            line-height: 170%;
            font-size: 3.7333333333vw; } }

.sheet-box {
  max-width: 840px;
  margin: 0 auto 60px; }
  @media screen and (max-width: 767px) {
    .sheet-box {
      margin: 0 auto 13.3333333333vw; } }
  .sheet-box h3 {
    max-width: 450px;
    width: 100%;
    margin: 0 auto 30px;
    text-align: center;
    padding: 16.5px;
    background: #fff;
    font-size: 1.125rem;
    line-height: 100%;
    letter-spacing: 0.72px;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border-radius: 50px; }
    @media screen and (max-width: 767px) {
      .sheet-box h3 {
        font-size: 4.2666666667vw;
        line-height: 170%;
        margin-bottom: 20px;
        padding: 8px; } }
  .sheet-box h4 {
    font-family: "Noto Serif JP";
    font-size: 1.375rem;
    font-weight: 400;
    line-height: 180%;
    letter-spacing: 2.2px; }
    @media screen and (max-width: 767px) {
      .sheet-box h4 {
        font-size: 4.2666666667vw;
        line-height: 170%;
        margin-bottom: 20px;
        letter-spacing: 0;
        margin-left: calc(50% - 50vw);
        margin-right: calc(50% - 50vw); } }
  @media screen and (min-width: 768px) {
    .sheet-box picture {
      margin-top: 30px; } }
  .sheet-box .ing--notes {
    width: fit-content;
    margin: 30px auto 0; }
    @media screen and (max-width: 767px) {
      .sheet-box .ing--notes {
        margin-top: 20px; } }

.sozai-wrap {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 40px;
  width: fit-content;
  margin: 0 auto; }
  @media screen and (max-width: 767px) {
    .sozai-wrap {
      gap: 20px;
      text-align: center; } }
  .sozai-wrap img {
    max-width: 180px;
    width: 100%; }
    @media screen and (max-width: 767px) {
      .sozai-wrap img {
        flex: 0 0 100%;
        max-width: 140px;
        margin: 0 auto; } }
  .sozai-wrap p {
    font-size: 0.875rem;
    line-height: 170%;
    /* 23.8px */
    letter-spacing: 0.56px;
    text-align: left; }
    @media screen and (max-width: 767px) {
      .sozai-wrap p {
        font-size: 3.7333333333vw;
        flex: 0 0 100%;
        text-align: center; } }

/*
* .detail
*/
.detail--txt {
  font-size: 0.875rem;
  line-height: 170%;
  text-align: center;
  letter-spacing: 0.56px; }
  @media screen and (max-width: 767px) {
    .detail--txt {
      text-align: left;
      font-size: 3.7333333333vw; } }
  .detail--txt strongth {
    font-weight: 600; }

.detail--note {
  font-size: 0.625rem;
  text-align: center; }
  @media screen and (max-width: 767px) {
    .detail--note {
      text-align: left;
      font-size: 11px; } }

.detail--inner {
  background: #fff;
  border-radius: 10px;
  width: 1100px;
  box-sizing: border-box;
  padding: 50px 70px;
  margin: 0 auto; }
  @media screen and (max-width: 767px) {
    .detail--inner {
      padding: 50px 20px;
      max-width: 100%;
      width: 100%; } }
  .detail--inner__title {
    font-size: 20px;
    text-align: center;
    line-height: 140%;
    letter-spacing: 0.15em;
    margin-bottom: 20px; }
    @media screen and (max-width: 767px) {
      .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: 767px) {
        .detail--inner__title span {
          font-size: 13px; } }
  .detail--inner .detail--txt {
    margin-bottom: 20px; }

.detail--inner__txt {
  font-size: 14px;
  letter-spacing: 0.05em;
  text-align: center;
  line-height: 170%;
  /* 23.8px */
  letter-spacing: 0.56px; }
  @media screen and (max-width: 767px) {
    .detail--inner__txt {
      font-size: 3.4666666667vw;
      text-align: left;
      margin: 20px auto;
      width: fit-content; } }

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

.detail--inner__note {
  font-size: 11px;
  line-height: 145%;
  /* 15.95px */
  letter-spacing: 0.44px;
  text-align: center;
  margin-top: 20px;
  text-indent: -1em;
  padding-left: 1em; }
  @media screen and (max-width: 767px) {
    .detail--inner__note {
      text-align: left;
      width: fit-content;
      margin: 25px auto 0; } }

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

.mask-use-wrap {
  display: flex;
  justify-content: center;
  gap: 43px;
  align-items: center;
  flex-wrap: wrap; }
  @media screen and (max-width: 767px) {
    .mask-use-wrap {
      gap: 20px; } }
  .mask-use-wrap img {
    max-width: 232px;
    width: 100%; }
  @media screen and (max-width: 767px) {
    .mask-use-wrap .mask-use-txt {
      flex: 0 0 100%; } }
  .mask-use-wrap .mask-use-txt li {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 20px;
    text-align: left; }
    .mask-use-wrap .mask-use-txt li:last-child {
      margin-bottom: 0; }
    .mask-use-wrap .mask-use-txt li p {
      line-height: 170%;
      /* 23.8px */
      letter-spacing: 0.56px; }
      @media screen and (max-width: 767px) {
        .mask-use-wrap .mask-use-txt li p {
          font-size: 3.7333333333vw;
          flex: 1; } }
      .mask-use-wrap .mask-use-txt li p strong {
        color: #AE8D76;
        font-size: 1rem;
        font-weight: 600;
        letter-spacing: 0.64px; }

/*
* .fragrance
*/
@media screen and (max-width: 767px) {
  .fragrance .detail--inner__txt {
    margin: 0;
    font-size: 3.7333333333vw; } }
.fragrance--inr__title {
  position: relative;
  width: fit-content;
  padding: 0 120px;
  margin: 0 auto; }
  @media screen and (max-width: 767px) {
    .fragrance--inr__title {
      padding: 0; } }
.fragrance--img {
  width: 90px;
  height: 90px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%); }
  .fragrance--img:nth-of-type(1) {
    left: 0; }
  .fragrance--img:nth-of-type(2) {
    right: 0; }
  @media screen and (max-width: 767px) {
    .fragrance--img {
      max-width: 24vw !important;
      height: auto;
      position: relative;
      top: auto;
      transform: initial;
      margin-top: 20px; }
      .fragrance--img:nth-of-type(1) {
        left: -5px; }
      .fragrance--img:nth-of-type(2) {
        right: -5px; } }

/*
* 使用方法
*/
.usage--inr {
  max-width: 710px;
  margin: 0 auto; }
  .usage--inr .prod--name {
    text-align: left;
    margin-bottom: 10px; }

.usage--title {
  font-size: 1.125rem;
  line-height: 100%;
  letter-spacing: 0.72px;
  margin-bottom: 25px; }

.usage__list.mb {
  margin-bottom: 25px; }

/*
* .prod--notes
*/
.prod--notes {
  margin: 0 auto;
  box-sizing: border-box;
  max-width: 1100px;
  width: 100%; }
  @media screen and (min-width: 768px) {
    .prod--notes {
      margin-bottom: 70px;
      padding: 100px 0 0 5px; } }
  @media screen and (max-width: 767px) {
    .prod--notes {
      margin-bottom: 90px;
      padding: 50px 0 0 0; } }

.prod--notes li {
  color: #878782;
  letter-spacing: 0.56px; }
  @media screen and (min-width: 768px) {
    .prod--notes li {
      font-size: .6875rem;
      line-height: 1.81819; } }
  @media screen and (max-width: 767px) {
    .prod--notes li {
      padding-left: 1em;
      text-indent: -1em;
      font-size: 2.9333333333vw;
      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; }

/*
* .s_product
*/
.s_product {
  padding: 100px 0 0; }
  @media screen and (max-width: 767px) {
    .s_product {
      padding: 13.3333333333vw 0 0; } }
  .s_product .anchor__col {
    margin: 0 auto; }
    @media screen and (max-width: 767px) {
      .s_product .anchor__col {
        width: 80%; } }
  .s_product .anchor__col-inner {
    flex-wrap: wrap;
    gap: 100px; }
    @media screen and (max-width: 767px) {
      .s_product .anchor__col-inner {
        gap: 50px; } }
    .s_product .anchor__col-inner .anchor--prod .caption {
      margin-bottom: 20px; }
    .s_product .anchor__col-inner .anchor--prod .btn__more a {
      margin: 0; }
    @media screen and (max-width: 767px) {
      .s_product .anchor__col-inner .anchor--prod {
        max-width: 100%; }
        .s_product .anchor__col-inner .anchor--prod a {
          width: 80vw; }
        .s_product .anchor__col-inner .anchor--prod .prod--name {
          font-size: 4.2666666667vw !important;
          line-height: 1;
          margin-bottom: 11px; }
        .s_product .anchor__col-inner .anchor--prod .prod--type {
          font-size: 3.7333333333vw !important;
          line-height: 1; }
        .s_product .anchor__col-inner .anchor--prod .prod--price {
          font-size: 4vw !important;
          line-height: 1;
          margin-top: 20px; } }
  @media screen and (max-width: 767px) {
    .s_product .prod--notes {
      width: 90%; } }
