@charset "UTF-8";
a {
  text-decoration: unset;
  color: #000;
  transition: opacity 0.3s ease-in-out;
}

a:hover {
  color: #000;
  opacity: 0.7;
  text-decoration: none !important;
}

a:focus {
  outline: none;
}

p {
  margin-top: 0;
  margin-bottom: 0;
}

h2, h3 {
  margin-bottom: 0;
}

ul {
  list-style-type: none;
  margin: 0;
  padding: 0;
}

.new-window-page-header {
  margin-bottom: 0;
}

img {
  max-width: 100%;
}

body.no-scroll {
  overflow: hidden;
  height: 100%;
}
body.loading {
  visibility: hidden;
}

main {
  position: relative;
  font-family: "A1 Mincho", "A-OTF A1明朝 Std", Georgia, 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-feature-settings: "palt";
  letter-spacing: 0.1em;
  line-height: 1.7;
  color: #000;
  background-color: #fff;
}
@media screen and (min-width: 681px) {
  main {
    padding-bottom: 109px;
    max-width: 680px;
    margin: 0 auto;
  }
}
main * {
  box-sizing: border-box;
}
main img {
  vertical-align: bottom;
}

@media screen and (min-width: 681px) {
  .bg::before {
    content: "";
    display: inline-block;
    width: 100vw;
    height: calc(100vh + 51px);
    background: linear-gradient(180deg, rgb(247, 249, 251), rgb(194, 209, 227));
    position: fixed;
    top: -51px;
  }
}

@media screen and (max-width: 1280px) {
  .header .menu {
    position: absolute;
    top: 54px;
    right: 33px;
    height: 36px;
    width: 45px;
    cursor: pointer;
    z-index: 200;
    transition: opacity 0.25s ease;
    transition: all 0.3s ease;
  }
}
@media screen and (max-width: 680px) {
  .header .menu {
    top: 18px;
    right: 14px;
    height: 20px;
    width: 25px;
  }
}
@media screen and (max-width: 1280px) {
  .header .menu.on .top {
    transform: translateY(14px) translateX(0) rotate(-45deg);
    background: #000;
  }
  .header .menu.on .middle {
    opacity: 0;
    background: #000;
  }
  .header .menu.on .bottom {
    transform: translateY(-14px) translateX(0) rotate(45deg);
    background: #000;
  }
}
@media screen and (max-width: 680px) {
  .header .menu.on .top {
    transform: translateY(8px) translateX(0) rotate(-45deg);
  }
  .header .menu.on .bottom {
    transform: translateY(-8px) translateX(0) rotate(45deg);
  }
}
@media screen and (max-width: 1280px) {
  .header .menu span {
    background: #000;
    border: none;
    height: 4px;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    transition: all 0.35s ease;
    cursor: pointer;
  }
  .header .menu span:nth-of-type(2) {
    top: 15px;
  }
  .header .menu span:nth-of-type(3) {
    top: 29px;
  }
}
@media screen and (max-width: 680px) {
  .header .menu span {
    height: 2px;
  }
  .header .menu span:nth-of-type(2) {
    top: 8px;
  }
  .header .menu span:nth-of-type(3) {
    top: 16px;
  }
}
@media screen and (max-width: 1280px) {
  .header__content {
    opacity: 0;
    pointer-events: none;
    transition: all 0.3s;
    height: 100%;
    position: fixed;
    z-index: 200;
    inset: 0;
    background: linear-gradient(180deg, rgb(247, 249, 251), rgb(194, 209, 227));
  }
  .header__content--open {
    opacity: 1;
    pointer-events: auto;
    overflow-y: auto;
  }
}
@media screen and (max-width: 1280px) {
  .header__inner {
    padding: 18.6666666667vw 8.5333333333vw;
  }
}
.header__title {
  font-family: "A1 Mincho", "A-OTF A1明朝 Std", Georgia, 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 1.08cqw;
  color: #000;
  position: fixed;
  transform: translateY(-50%);
  top: 50%;
  left: 2%;
  width: calc((100% - 740px) / 2);
}
@media screen and (max-width: 1280px) {
  .header__title {
    display: block;
    width: unset;
    margin-bottom: 91px;
    font-size: 29px;
    position: relative;
    transform: unset;
    top: unset;
    left: unset;
    color: #446b9c;
  }
}
@media screen and (max-width: 680px) {
  .header__title {
    margin-bottom: 13.3333333333vw;
    font-size: 4.2666666667vw;
  }
}
.header .nav {
  position: fixed;
  top: 10%;
  right: 10%;
}
@media screen and (max-width: 1280px) {
  .header .nav {
    display: block;
    position: relative;
    width: 71%;
    margin: 0 auto;
    transform: unset;
    top: unset;
    right: unset;
  }
}
.header .navList {
  display: flex;
  flex-direction: column;
  gap: 0.8vw;
  margin-bottom: 1.8vw;
}
@media screen and (max-width: 1280px) {
  .header .navList {
    gap: 8vw;
    margin-bottom: 12.8vw;
  }
}
.header .navList__link {
  font-family: "A1 Mincho", "A-OTF A1明朝 Std", Georgia, 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 1vw;
  transition: all 0.3s;
  color: #000 !important;
}
@media screen and (max-width: 1280px) {
  .header .navList__link {
    font-size: 36px;
  }
}
@media screen and (max-width: 680px) {
  .header .navList__link {
    font-size: 5.3333333333vw;
  }
}
.header .navButton a {
  font-size: 0.9vw;
  color: #fff;
  background-color: #8099c2;
  padding: 0.5vw;
  text-align: center;
  border-radius: 1vw;
  display: block;
  position: relative;
  min-width: 11.5vw;
}
@media screen and (max-width: 1280px) {
  .header .navButton a {
    font-size: 33px;
    border-radius: 36px;
    padding: 18px;
  }
}
@media screen and (max-width: 680px) {
  .header .navButton a {
    font-size: 4.8vw;
    border-radius: 5.3333333333vw;
    padding: 2.6666666667vw;
  }
}
.header .navButton a::before {
  content: "";
  width: 20px;
  height: 21px;
  display: inline-block;
  position: absolute;
  left: 10%;
  top: 50%;
  transform: translateY(-50%);
  background-size: contain;
  background-image: url(../images/cart.webp);
  background-repeat: no-repeat;
}
@media screen and (max-width: 1280px) {
  .header .navButton a::before {
    width: 36px;
    height: 38px;
  }
}
@media screen and (max-width: 680px) {
  .header .navButton a::before {
    width: 5.3333333333vw;
    height: 5.6vw;
  }
}

.page-footer {
  position: relative;
  z-index: 100;
  margin-top: 0;
}

.button a {
  color: #fff;
  font-size: 29px;
  background-color: #8099c2;
  border-radius: 63px;
  font-family: "游ゴシック体", "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  padding: 15px;
  display: block;
  max-width: 508px;
  text-align: center;
  margin: 0 auto;
}
@media screen and (max-width: 680px) {
  .button a {
    font-size: 4.2666666667vw;
    border-radius: 9.3333333333vw;
    padding: 2.1333333333vw;
    max-width: 74.6666666667vw;
  }
}
.button small {
  font-size: 25px;
}
@media screen and (max-width: 680px) {
  .button small {
    font-size: 3.7333333333vw;
  }
}
.button__arrow {
  display: inline-block;
  width: 16px;
  height: 24px;
  position: relative;
  margin-left: 9px;
}
@media screen and (max-width: 680px) {
  .button__arrow {
    width: 2.4vw;
    height: 3.4666666667vw;
    margin-left: 1.3333333333vw;
  }
}
.button__arrow::before, .button__arrow::after {
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  right: 0;
  width: 16px;
  height: 2px;
  background-color: #fff;
  transform-origin: calc(100% - 1px) 50%;
}
@media screen and (max-width: 680px) {
  .button__arrow::before, .button__arrow::after {
    width: 2.4vw;
    height: 0.2666666667vw;
    transform-origin: calc(100% - 0.5px) 50%;
    top: calc(50% - 0.5px);
  }
}
.button__arrow::before {
  transform: rotate(45deg);
}
.button__arrow::after {
  transform: rotate(-45deg);
}
.button--large a {
  max-width: 562px;
}
@media screen and (max-width: 680px) {
  .button--large a {
    max-width: 82.6666666667vw;
  }
}
.button--small a {
  font-size: 24px;
  padding: 7px;
  border-radius: 27px;
}
@media screen and (max-width: 680px) {
  .button--small a {
    font-size: 3.4666666667vw;
    padding: 1.0666666667vw;
    border-radius: 4vw;
  }
}
.button--small a .button__arrow {
  width: 11px;
  height: 18px;
}
@media screen and (max-width: 680px) {
  .button--small a .button__arrow {
    width: 1.6vw;
    height: 2.6666666667vw;
  }
}
.button--small a .button__arrow::before, .button--small a .button__arrow::after {
  width: 15px;
  height: 2px;
}
@media screen and (max-width: 680px) {
  .button--small a .button__arrow::before, .button--small a .button__arrow::after {
    width: 2.1333333333vw;
    height: 0.2666666667vw;
  }
}
.button--disabled a {
  background-color: #b9b9b9;
  pointer-events: none;
}

.separator {
  display: block;
  width: 100%;
  height: 2px;
  background-color: #000;
}
@media screen and (max-width: 680px) {
  .separator {
    height: 1px;
  }
}

.hero {
  padding: 69px 0;
}
@media screen and (max-width: 680px) {
  .hero {
    padding: 10.1333333333vw 0;
  }
}
.hero__title {
  text-align: center;
  margin-bottom: 54px;
  font-size: 47px;
}
@media screen and (max-width: 680px) {
  .hero__title {
    margin-bottom: 8vw;
    font-size: 6.9333333333vw;
  }
}
.hero__title img {
  display: block;
  margin: 0 auto 33px;
}
@media screen and (max-width: 680px) {
  .hero__title img {
    margin: 0 auto 4.8vw;
  }
}
.hero__img {
  margin-bottom: 36px;
}
@media screen and (max-width: 680px) {
  .hero__img {
    margin-bottom: 5.3333333333vw;
  }
}
.hero__bgText {
  background-color: #e3eaf2;
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 25px;
  padding: 7px 22px;
  line-height: 1.4;
  font-size: 29px;
}
@media screen and (max-width: 680px) {
  .hero__bgText {
    margin: 0 auto 3.7333333333vw;
    padding: 1.0666666667vw 3.2vw;
    font-size: 4.2666666667vw;
  }
}
.hero__text {
  text-align: center;
  font-size: 36px;
  margin-bottom: 18px;
}
@media screen and (max-width: 680px) {
  .hero__text {
    font-size: 5.3333333333vw;
    margin-bottom: 2.6666666667vw;
  }
}

.card {
  width: 93%;
  margin: 0 auto 73px;
}
@media screen and (max-width: 680px) {
  .card {
    min-width: 93.3333333333vw;
    margin: 0 auto 10.6666666667vw;
  }
}
.card__body {
  border: 2px solid #000;
  padding: 65px 36px 44px;
}
@media screen and (max-width: 680px) {
  .card__body {
    border: 1px solid #000;
    padding: 9.6vw 5.3333333333vw 6.4vw;
  }
}
.card__title {
  text-align: center;
  margin-bottom: 36px;
}
@media screen and (max-width: 680px) {
  .card__title {
    margin-bottom: 5.3333333333vw;
  }
}
.card__title span {
  font-size: 36px;
  padding-bottom: 4px;
  border-bottom: 2px solid #000;
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
@media screen and (max-width: 680px) {
  .card__title span {
    font-size: 5.3333333333vw;
    padding-bottom: 0.5333333333vw;
    border-bottom: 1px solid #000;
  }
}
.card__title small {
  font-size: 18px;
}
@media screen and (max-width: 680px) {
  .card__title small {
    font-size: 2.6666666667vw;
  }
}
.card__title .card__enTitle {
  display: block;
  margin-bottom: 7px;
}
@media screen and (max-width: 680px) {
  .card__title .card__enTitle {
    margin-bottom: 1.0666666667vw;
  }
}
.card__title .card__detailTitle {
  display: block;
  margin-top: 7px;
}
@media screen and (max-width: 680px) {
  .card__title .card__detailTitle {
    margin-top: 1.0666666667vw;
  }
}
.card__title--noBorder span {
  border-bottom: unset;
  padding-bottom: 0;
}
.card__subtitle {
  font-size: 36px;
  text-align: center;
  font-weight: 700;
}
@media screen and (max-width: 680px) {
  .card__subtitle {
    font-size: 5.3333333333vw;
  }
}
.card__lead {
  font-size: 36px;
  text-align: center;
  font-weight: 700;
}
@media screen and (max-width: 680px) {
  .card__lead {
    font-size: 5.3333333333vw;
  }
}
.card__lead--small {
  font-size: 29px;
}
@media screen and (max-width: 680px) {
  .card__lead--small {
    font-size: 4.2666666667vw;
  }
}
.card__img {
  text-align: center;
}
.card__text {
  font-size: 25px;
  text-align: center;
  font-weight: 700;
}
@media screen and (max-width: 680px) {
  .card__text {
    font-size: 3.7333333333vw;
  }
}
.card__note {
  font-size: 18px;
  letter-spacing: 0.05em;
  text-align: center;
  font-weight: 700;
}
@media screen and (max-width: 680px) {
  .card__note {
    font-size: 2.6666666667vw;
  }
}
.card--noSpacing {
  margin: 0 auto;
}
.card--noSpacing + .card .card__body {
  border-top: unset;
}

.accordion {
  position: relative;
}
.accordion__content {
  overflow: hidden;
  padding: 58px 33px 185px;
}
@media screen and (max-width: 680px) {
  .accordion__content {
    padding: 8.5333333333vw 4.8vw 27.2vw;
  }
}
.accordion__content::before {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #fff 80%, #fff 100%);
  bottom: 2px;
  left: 50%;
  transform: translateX(-50%);
  content: "";
  height: 363px;
  position: absolute;
  width: calc(100% - 4px);
}
@media screen and (max-width: 680px) {
  .accordion__content::before {
    bottom: 1px;
    height: 53.3333333333vw;
    width: calc(100% - 2px);
  }
}
.accordion__content--show::before {
  content: unset;
}
.accordion__content--dl {
  height: 718px;
}
@media screen and (max-width: 680px) {
  .accordion__content--dl {
    height: 105.6vw;
  }
}
.accordion__content--de {
  height: 762px;
}
@media screen and (max-width: 680px) {
  .accordion__content--de {
    height: 112vw;
  }
}
.accordion__content--dw20 {
  height: 736px;
}
@media screen and (max-width: 680px) {
  .accordion__content--dw20 {
    height: 108.2666666667vw;
  }
}
.accordion__content--dml {
  height: 725px;
}
@media screen and (max-width: 680px) {
  .accordion__content--dml {
    height: 106.6666666667vw;
  }
}
.accordion__content--sample {
  height: 1034px;
}
@media screen and (max-width: 680px) {
  .accordion__content--sample {
    height: 152vw;
  }
}
.accordion__content--study {
  height: 1055px;
}
@media screen and (max-width: 680px) {
  .accordion__content--study {
    height: 155.2vw;
  }
}
.accordion__content--newTechnology {
  height: 999px;
}
@media screen and (max-width: 680px) {
  .accordion__content--newTechnology {
    height: 146.9333333333vw;
  }
}
.accordion__content--ingredient {
  height: 1666px;
}
@media screen and (max-width: 680px) {
  .accordion__content--ingredient {
    height: 245.0666666667vw;
  }
}
.accordion__content--box {
  height: 1161px;
}
@media screen and (max-width: 680px) {
  .accordion__content--box {
    height: 170.6666666667vw;
  }
}
.accordion__content--container {
  height: 1414px;
}
@media screen and (max-width: 680px) {
  .accordion__content--container {
    height: 208vw;
  }
}
.accordion__content--fragrance {
  height: 1378px;
}
@media screen and (max-width: 680px) {
  .accordion__content--fragrance {
    height: 202.6666666667vw;
  }
}
.accordion__button {
  display: inline-block;
  color: #fff;
  background-color: #808080;
  position: absolute;
  bottom: 54px;
  left: 50%;
  transform: translateX(-50%);
  cursor: pointer;
  font-size: 25px;
  font-family: "游ゴシック体", "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  padding: 9px 27px;
  text-align: center;
  transition: all 0.8s;
  z-index: 1;
  min-width: 254px;
  border-radius: 27px;
}
@media screen and (max-width: 680px) {
  .accordion__button {
    bottom: 8vw;
    font-size: 3.7333333333vw;
    padding: 1.3333333333vw 4vw;
    min-width: 37.3333333333vw;
    border-radius: 4vw;
  }
}
.accordion__button::before {
  content: "もっと見る";
}
.accordion__button--detail::before {
  content: "詳細を見る";
}
.accordion__button--show::before {
  content: "閉じる";
}
.accordion__button--show .accordion__buttonIcon {
  background-size: contain;
  background-image: url(../images/minus.webp);
  background-repeat: no-repeat;
}
.accordion__buttonIcon {
  display: inline-block;
  vertical-align: middle;
  width: 33px;
  height: 33px;
  background-size: contain;
  background-image: url(../images/plus.webp);
  background-repeat: no-repeat;
}
@media screen and (max-width: 680px) {
  .accordion__buttonIcon {
    width: 4.8vw;
    height: 4.8vw;
  }
}

.set4Card .card__body {
  padding: 65px 0 44px;
}
@media screen and (max-width: 680px) {
  .set4Card .card__body {
    padding: 9.6vw 0 6.4vw;
  }
}
.set4Card .card__text {
  margin-bottom: 44px;
}
@media screen and (max-width: 680px) {
  .set4Card .card__text {
    margin-bottom: 6.4vw;
  }
}
.set4Card .card__img {
  margin: 0 36px 36px;
}
@media screen and (max-width: 680px) {
  .set4Card .card__img {
    margin: 0 5.3333333333vw 5.3333333333vw;
  }
}
.set4Card__bg {
  background-color: #e3eaf2;
  padding: 40px 0;
}
@media screen and (max-width: 680px) {
  .set4Card__bg {
    padding: 5.8666666667vw 0;
  }
}
.set4Card__lead {
  text-align: center;
  color: #446b96;
  font-size: 29px;
  margin-bottom: 29px;
}
@media screen and (max-width: 680px) {
  .set4Card__lead {
    font-size: 4.2666666667vw;
    margin-bottom: 4.2666666667vw;
  }
}
.set4Card__text {
  text-align: center;
  font-size: 25px;
}
@media screen and (max-width: 680px) {
  .set4Card__text {
    font-size: 3.7333333333vw;
  }
}

.productPointList {
  display: flex;
  flex-direction: column;
  gap: 65px;
  margin-bottom: 83px;
}
@media screen and (max-width: 680px) {
  .productPointList {
    gap: 9.6vw;
    margin-bottom: 12.2666666667vw;
  }
}
.productPointList__title {
  font-size: 36px;
  margin-bottom: 15px;
  text-align: center;
}
@media screen and (max-width: 680px) {
  .productPointList__title {
    font-size: 5.3333333333vw;
    margin-bottom: 2.1333333333vw;
  }
}
.productPointList__title span {
  font-size: 25px;
  display: inline-block;
  text-align: center;
  background-color: #ef7e7a;
  color: #fff;
  padding: 4px 18px;
  margin-bottom: 29px;
}
@media screen and (max-width: 680px) {
  .productPointList__title span {
    font-size: 3.7333333333vw;
    text-align: center;
    padding: 0.5333333333vw 2.6666666667vw;
    margin-bottom: 4.2666666667vw;
  }
}
.productPointList__borderTitle {
  font-size: 29px;
  padding-bottom: 4px;
  border-bottom: 2px solid #000;
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 29px;
}
@media screen and (max-width: 680px) {
  .productPointList__borderTitle {
    font-size: 4.2666666667vw;
    padding-bottom: 0.5333333333vw;
    border-bottom: 1px solid #000;
    margin: 0 auto 4.2666666667vw;
  }
}
.productPointList__text {
  text-align: center;
  font-size: 25px;
  letter-spacing: 0.06em;
  margin-bottom: 51px;
}
@media screen and (max-width: 680px) {
  .productPointList__text {
    font-size: 3.7333333333vw;
    margin-bottom: 7.4666666667vw;
  }
}
.productPointList__text:has(+ .productPointList__note) {
  margin-bottom: 22px;
}
@media screen and (max-width: 680px) {
  .productPointList__text:has(+ .productPointList__note) {
    margin-bottom: 3.2vw;
  }
}
.productPointList__note {
  text-align: center;
  font-size: 16px;
}
@media screen and (max-width: 680px) {
  .productPointList__note {
    font-size: 2.4vw;
  }
}
.productPointList__note:has(+ .productPointList__img, + .productPointBox) {
  margin-bottom: 44px;
}
@media screen and (max-width: 680px) {
  .productPointList__note:has(+ .productPointList__img, + .productPointBox) {
    margin-bottom: 6.4vw;
  }
}
.productPointList__img {
  text-align: center;
}
.productPointList__gif {
  width: 87%;
  margin: 0 auto;
}
.productPointList__gif p {
  text-align: end;
  font-size: 18px;
}
@media screen and (max-width: 680px) {
  .productPointList__gif p {
    font-size: 2.6666666667vw;
  }
}
.productPointList__content:first-of-type {
  margin-top: 54px;
}
@media screen and (max-width: 680px) {
  .productPointList__content:first-of-type {
    margin-top: 8vw;
  }
}
.productPointList__content:not(:last-of-type) {
  margin-bottom: 91px;
}
@media screen and (max-width: 680px) {
  .productPointList__content:not(:last-of-type) {
    margin-bottom: 13.3333333333vw;
  }
}
.productPointList__content .productPointList__img {
  margin-bottom: 51px;
}
@media screen and (max-width: 680px) {
  .productPointList__content .productPointList__img {
    margin-bottom: 7.4666666667vw;
  }
}
.productPointList--de .productPointList__title span {
  background-color: #fabc02;
}
.productPointList--dw20 .productPointList__title span {
  background-color: #8099c2;
}
.productPointList--dml .productPointList__title span {
  background-color: #f39551;
}

.productPointBox {
  background-color: #fdeceb;
  padding: 40px 18px 36px;
}
@media screen and (max-width: 680px) {
  .productPointBox {
    padding: 5.8666666667vw 2.6666666667vw 5.3333333333vw;
  }
}
.productPointBox--narrow {
  padding: 40px 18px;
}
@media screen and (max-width: 680px) {
  .productPointBox--narrow {
    padding: 5.8666666667vw 2.6666666667vw 3.2vw;
  }
}
.productPointBox--wide {
  padding: 54px 18px;
}
@media screen and (max-width: 680px) {
  .productPointBox--wide {
    padding: 8vw 2.6666666667vw;
  }
}
.productPointBox__title {
  text-align: center;
  font-size: 25px;
  margin-bottom: 18px;
}
@media screen and (max-width: 680px) {
  .productPointBox__title {
    font-size: 3.7333333333vw;
    margin-bottom: 2.6666666667vw;
  }
}
.productPointBox__img {
  text-align: center;
  margin-bottom: 15px;
}
@media screen and (max-width: 680px) {
  .productPointBox__img {
    margin-bottom: 2.1333333333vw;
  }
}
.productPointBox__img img {
  width: 54.5%;
}
.productPointBox__img--large img {
  width: 77.5%;
}
.productPointBox__text {
  text-align: center;
  font-size: 25px;
  margin-bottom: 22px;
}
@media screen and (max-width: 680px) {
  .productPointBox__text {
    font-size: 3.7333333333vw;
    margin-bottom: 3.2vw;
  }
}
.productPointBox__note {
  text-align: center;
  font-size: 16px;
}
@media screen and (max-width: 680px) {
  .productPointBox__note {
    font-size: 2.4vw;
  }
}
.productPointBox__note:has(+ .productPointBox__bg) {
  margin-bottom: 40px;
}
@media screen and (max-width: 680px) {
  .productPointBox__note:has(+ .productPointBox__bg) {
    margin-bottom: 5.8666666667vw;
  }
}
.productPointBox__bg {
  background-color: #fff;
  padding: 29px 15px;
}
@media screen and (max-width: 680px) {
  .productPointBox__bg {
    padding: 4.2666666667vw 2.1333333333vw;
  }
}
.productPointBox__bgTitle {
  text-align: center;
  font-size: 25px;
  margin-bottom: 7px;
}
@media screen and (max-width: 680px) {
  .productPointBox__bgTitle {
    font-size: 3.7333333333vw;
    margin-bottom: 1.0666666667vw;
  }
}
.productPointBox__bgTitle--pink {
  color: #f37e7a;
}
.productPointBox__bgImg {
  text-align: center;
}
.productPointBox__bgText {
  text-align: center;
  font-size: 25px;
}
@media screen and (max-width: 680px) {
  .productPointBox__bgText {
    font-size: 3.7333333333vw;
  }
}
.productPointBox--de {
  background-color: #fef5d9;
}
.productPointBox--dw20 {
  background-color: #ecf0f6;
}
.productPointBox--dw20 .productPointBox__img:not(:last-of-type) {
  margin-bottom: 40px;
}
@media screen and (max-width: 680px) {
  .productPointBox--dw20 .productPointBox__img:not(:last-of-type) {
    margin-bottom: 5.8666666667vw;
  }
}
.productPointBox--dml {
  background-color: #fdefe5;
}
.productPointBox--row {
  display: flex;
  gap: 54px;
  padding: 40px 29px;
  margin-bottom: 36px;
}
@media screen and (max-width: 680px) {
  .productPointBox--row {
    gap: 8vw;
    padding: 5.8666666667vw 4.2666666667vw;
    margin-bottom: 5.3333333333vw;
  }
}
.productPointBox--row .productPointBox__note {
  font-size: 15px;
}
@media screen and (max-width: 680px) {
  .productPointBox--row .productPointBox__note {
    font-size: 2.1333333333vw;
  }
}
.productPointBox__rowContent:not(:last-of-type) {
  position: relative;
}
.productPointBox__rowContent:not(:last-of-type)::before, .productPointBox__rowContent:not(:last-of-type)::after {
  content: "";
  display: inline-block;
  width: 2px;
  height: 40px;
  background-color: #000;
  position: absolute;
  top: 42%;
  right: -13%;
}
@media screen and (max-width: 680px) {
  .productPointBox__rowContent:not(:last-of-type)::before, .productPointBox__rowContent:not(:last-of-type)::after {
    width: 1px;
    height: 5.8666666667vw;
  }
}
.productPointBox__rowContent:not(:last-of-type)::before {
  transform: rotate(-45deg);
}
.productPointBox__rowContent:not(:last-of-type)::after {
  transform: rotate(45deg);
}
.productPointBox__rowContent .productPointBox__img img {
  width: 100%;
}
.productPointBox--column {
  display: flex;
  flex-direction: column;
  gap: 76px;
  padding: 40px 18px 51px;
}
@media screen and (max-width: 680px) {
  .productPointBox--column {
    gap: 11.2vw;
    padding: 5.8666666667vw 2.6666666667vw 7.4666666667vw;
  }
}

.ctaPoint {
  margin-bottom: 36px;
}
@media screen and (max-width: 680px) {
  .ctaPoint {
    margin-bottom: 5.3333333333vw;
  }
}
.ctaPoint__heading {
  display: flex;
  gap: 18px;
  align-items: center;
  justify-content: center;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 11px;
  font-size: 36px;
  gap: 2.6666666667vw;
}
@media screen and (max-width: 680px) {
  .ctaPoint__heading {
    margin: 0 auto 1.6vw;
    font-size: 5.3333333333vw;
  }
}
.ctaPoint__heading::before, .ctaPoint__heading::after {
  content: "";
  display: inline-block;
  width: 2px;
  height: 83px;
  background-color: #000;
  position: absolute;
  top: 50%;
}
@media screen and (max-width: 680px) {
  .ctaPoint__heading::before, .ctaPoint__heading::after {
    width: 1px;
    height: 12.2666666667vw;
  }
}
.ctaPoint__heading::before {
  left: -10%;
  transform: translateY(-50%) rotate(150deg);
}
.ctaPoint__heading::after {
  right: -10%;
  transform: translateY(-50%) rotate(30deg);
}
.ctaPoint__headingImg {
  display: block;
}
.ctaPoint__wrap {
  display: flex;
  gap: 54px;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 680px) {
  .ctaPoint__wrap {
    gap: 8vw;
  }
}
.ctaPoint__item:not(:last-of-type) {
  position: relative;
}
.ctaPoint__item:not(:last-of-type)::before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 25px;
  background-color: #808080;
  clip-path: polygon(0 0, 0 100%, 100% 50%);
  position: absolute;
  bottom: 23%;
  right: -45%;
}
@media screen and (max-width: 680px) {
  .ctaPoint__item:not(:last-of-type)::before {
    width: 2.6666666667vw;
    height: 3.7333333333vw;
  }
}
.ctaPoint__itemText {
  text-align: center;
  font-size: 25px;
}
@media screen and (max-width: 680px) {
  .ctaPoint__itemText {
    font-size: 3.7333333333vw;
  }
}
.ctaPoint__itemPoint {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #808080;
  min-width: 80px;
  aspect-ratio: 1/1;
  color: #fff;
  border-radius: 100%;
  font-size: 15px;
}
@media screen and (max-width: 680px) {
  .ctaPoint__itemPoint {
    min-width: 11.7333333333vw;
    font-size: 2.1333333333vw;
  }
}
.ctaPoint__itemPoint strong {
  display: block;
  text-align: center;
  font-size: 36px;
  line-height: 1;
}
@media screen and (max-width: 680px) {
  .ctaPoint__itemPoint strong {
    font-size: 5.3333333333vw;
  }
}
.ctaPoint__itemPoint--promo {
  background-color: #df626c;
  min-width: 98px;
  font-size: 18px;
}
@media screen and (max-width: 680px) {
  .ctaPoint__itemPoint--promo {
    min-width: 14.4vw;
    font-size: 2.6666666667vw;
  }
}
.ctaPoint__itemPoint--promo strong {
  font-size: 45px;
}
@media screen and (max-width: 680px) {
  .ctaPoint__itemPoint--promo strong {
    font-size: 6.6666666667vw;
  }
}

.dlCard .card__text {
  margin-bottom: 22px;
}
@media screen and (max-width: 680px) {
  .dlCard .card__text {
    margin-bottom: 3.2vw;
  }
}
.dlCard .card__img {
  margin-bottom: 58px;
}
@media screen and (max-width: 680px) {
  .dlCard .card__img {
    margin-bottom: 8.5333333333vw;
  }
}

.deCard .card__note {
  margin-bottom: 29px;
}
@media screen and (max-width: 680px) {
  .deCard .card__note {
    margin-bottom: 4.2666666667vw;
  }
}
.deCard .card__img {
  margin-bottom: 58px;
}
@media screen and (max-width: 680px) {
  .deCard .card__img {
    margin-bottom: 8.5333333333vw;
  }
}

.dw20Card .card__text {
  margin-bottom: 15px;
}
@media screen and (max-width: 680px) {
  .dw20Card .card__text {
    margin-bottom: 2.1333333333vw;
  }
}
.dw20Card .card__img {
  margin-bottom: 73px;
}
@media screen and (max-width: 680px) {
  .dw20Card .card__img {
    margin-bottom: 10.6666666667vw;
  }
}

.dmlCard .card__text {
  margin-bottom: 29px;
}
@media screen and (max-width: 680px) {
  .dmlCard .card__text {
    margin-bottom: 4.2666666667vw;
  }
}
.dmlCard .card__img {
  margin-bottom: 73px;
}
@media screen and (max-width: 680px) {
  .dmlCard .card__img {
    margin-bottom: 10.6666666667vw;
  }
}
.dmlCard .productPointList__img {
  margin-bottom: 36px;
}
@media screen and (max-width: 680px) {
  .dmlCard .productPointList__img {
    margin-bottom: 5.3333333333vw;
  }
}

.scentCard .card__text {
  font-size: 24px;
}
@media screen and (max-width: 680px) {
  .scentCard .card__text {
    font-size: 3.4666666667vw;
  }
}

.scentList {
  margin-top: 58px;
}
@media screen and (max-width: 680px) {
  .scentList {
    margin-top: 8.5333333333vw;
  }
}
.scentList__product {
  display: flex;
  align-items: flex-end;
}
.scentList__productName {
  writing-mode: vertical-rl;
  font-feature-settings: initial;
  font-size: 25px;
}
@media screen and (max-width: 680px) {
  .scentList__productName {
    font-size: 3.7333333333vw;
  }
}
.scentList__productNum {
  text-combine-upright: all;
}
.scentList__itemText {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  flex: auto;
  font-size: 25px;
  min-height: 297px;
}
@media screen and (max-width: 680px) {
  .scentList__itemText {
    font-size: 3.7333333333vw;
    min-height: 43.7333333333vw;
  }
}
.scentList__itemText small {
  font-size: 18px;
}
@media screen and (max-width: 680px) {
  .scentList__itemText small {
    font-size: 2.6666666667vw;
  }
}
.scentList__item {
  display: flex;
}
.scentList__item:nth-of-type(even) {
  flex-direction: row-reverse;
}
.scentList__item:first-of-type {
  margin-left: 33px;
}
@media screen and (max-width: 680px) {
  .scentList__item:first-of-type {
    margin-left: 4.8vw;
  }
}
.scentList__item:first-of-type .scentList__itemText {
  background-image: url(../images/scentBg_001-pc.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 680px) {
  .scentList__item:first-of-type .scentList__itemText {
    background-image: url(../images/scentBg_001-sp.webp);
  }
}
.scentList__item:nth-of-type(2) {
  margin-top: 44px;
  margin-right: 44px;
}
@media screen and (max-width: 680px) {
  .scentList__item:nth-of-type(2) {
    margin-top: 6.4vw;
    margin-right: 6.4vw;
  }
}
.scentList__item:nth-of-type(2) .scentList__itemText {
  background-image: url(../images/scentBg_002-pc.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 680px) {
  .scentList__item:nth-of-type(2) .scentList__itemText {
    background-image: url(../images/scentBg_002-sp.webp);
  }
}
.scentList__item:nth-of-type(3) {
  margin-top: 44px;
  margin-left: 47px;
}
@media screen and (max-width: 680px) {
  .scentList__item:nth-of-type(3) {
    margin-top: 6.4vw;
    margin-left: 6.9333333333vw;
  }
}
.scentList__item:nth-of-type(3) .scentList__itemText {
  background-image: url(../images/scentBg_003-pc.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 680px) {
  .scentList__item:nth-of-type(3) .scentList__itemText {
    background-image: url(../images/scentBg_003-sp.webp);
  }
}
.scentList__item:nth-of-type(4) {
  margin-top: 33px;
  margin-right: 76px;
}
@media screen and (max-width: 680px) {
  .scentList__item:nth-of-type(4) {
    margin-top: 4.8vw;
    margin-right: 11.2vw;
  }
}
.scentList__item:nth-of-type(4) .scentList__itemText {
  background-image: url(../images/scentBg_004-pc.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 680px) {
  .scentList__item:nth-of-type(4) .scentList__itemText {
    background-image: url(../images/scentBg_004-sp.webp);
  }
}

.pickUpCard .card__body {
  padding: 65px 25px 44px;
}
@media screen and (max-width: 680px) {
  .pickUpCard .card__body {
    padding: 9.6vw 3.7333333333vw 6.4vw;
  }
}
.pickUpCard .card__title {
  margin-bottom: 51px;
}
@media screen and (max-width: 680px) {
  .pickUpCard .card__title {
    margin-bottom: 7.4666666667vw;
  }
}

.pickUp {
  display: flex;
  gap: 18px;
  justify-content: center;
}
@media screen and (max-width: 680px) {
  .pickUp {
    gap: 2.6666666667vw;
  }
}
.pickUp__link {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
@media screen and (max-width: 680px) {
  .pickUp__link {
    gap: 2.6666666667vw;
  }
}
.pickUp__title {
  text-align: center;
  font-size: 25px;
  font-weight: 700;
}
@media screen and (max-width: 680px) {
  .pickUp__title {
    font-size: 3.7333333333vw;
  }
}
.pickUp__title span {
  font-size: 18px;
  position: relative;
  padding: 0 18px;
}
@media screen and (max-width: 680px) {
  .pickUp__title span {
    font-size: 2.6666666667vw;
    padding: 0 2.6666666667vw;
  }
}
.pickUp__title span::before, .pickUp__title span::after {
  content: "";
  display: inline-block;
  width: 2px;
  height: 18px;
  background-color: #000;
  position: absolute;
  top: 50%;
}
@media screen and (max-width: 680px) {
  .pickUp__title span::before, .pickUp__title span::after {
    width: 1px;
    height: 2.6666666667vw;
  }
}
.pickUp__title span::before {
  left: 0;
  transform: translateY(-50%) rotate(150deg);
}
.pickUp__title span::after {
  right: 0;
  transform: translateY(-50%) rotate(30deg);
}
.pickUp__img img {
  border-radius: 11px;
}
@media screen and (max-width: 680px) {
  .pickUp__img img {
    border-radius: 1.6vw;
  }
}
.pickUp__text {
  text-align: center;
  font-size: 24px;
  letter-spacing: 0.05em;
  font-weight: 700;
}
@media screen and (max-width: 680px) {
  .pickUp__text {
    font-size: 3.4666666667vw;
  }
}
.pickUp__arrow {
  display: inline-block;
  width: 24px;
  height: 16px;
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 680px) {
  .pickUp__arrow {
    width: 3.4666666667vw;
    height: 2.4vw;
  }
}
.pickUp__arrow::before, .pickUp__arrow::after {
  content: "";
  position: absolute;
  top: 0;
  left: calc(50% - 1px);
  width: 2px;
  height: 16px;
  background-color: #000;
  transform-origin: 50% calc(100% - 1px);
}
@media screen and (max-width: 680px) {
  .pickUp__arrow::before, .pickUp__arrow::after {
    width: 0.2666666667vw;
    height: 2.4vw;
    transform-origin: 50% calc(100% - 0.5px);
  }
}
.pickUp__arrow::before {
  transform: rotate(45deg);
}
.pickUp__arrow::after {
  transform: rotate(-45deg);
}

.sampleCard .card__body {
  padding: 65px 25px 116px;
}
@media screen and (max-width: 680px) {
  .sampleCard .card__body {
    padding: 9.6vw 3.7333333333vw 17.0666666667vw;
  }
}
.sampleCard__content01 {
  margin-bottom: 58px;
}
@media screen and (max-width: 680px) {
  .sampleCard__content01 {
    margin-bottom: 8.5333333333vw;
  }
}
.sampleCard__content01 .card__lead {
  margin-bottom: 51px;
}
@media screen and (max-width: 680px) {
  .sampleCard__content01 .card__lead {
    margin-bottom: 7.4666666667vw;
  }
}
.sampleCard__content01 .card__img {
  margin-bottom: 51px;
}
@media screen and (max-width: 680px) {
  .sampleCard__content01 .card__img {
    margin-bottom: 7.4666666667vw;
  }
}
.sampleCard__content01 .card__text {
  margin-bottom: 15px;
}
@media screen and (max-width: 680px) {
  .sampleCard__content01 .card__text {
    margin-bottom: 2.1333333333vw;
  }
}
.sampleCard .separator {
  margin-bottom: 58px;
}
@media screen and (max-width: 680px) {
  .sampleCard .separator {
    margin-bottom: 8.5333333333vw;
  }
}
.sampleCard__content02 .card__lead {
  margin-bottom: 22px;
}
@media screen and (max-width: 680px) {
  .sampleCard__content02 .card__lead {
    margin-bottom: 3.2vw;
  }
}
.sampleCard__content02 .card__img {
  margin-bottom: 22px;
}
@media screen and (max-width: 680px) {
  .sampleCard__content02 .card__img {
    margin-bottom: 3.2vw;
  }
}
.sampleCard__content02 .card__text {
  margin-bottom: 83px;
}
@media screen and (max-width: 680px) {
  .sampleCard__content02 .card__text {
    margin-bottom: 12.2666666667vw;
  }
}

.sampleBox {
  background-color: #ededed;
  padding: 51px 29px;
  margin-bottom: 44px;
}
@media screen and (max-width: 680px) {
  .sampleBox {
    padding: 7.4666666667vw 4.2666666667vw;
    margin-bottom: 6.4vw;
  }
}
.sampleBox__content:not(:last-of-type) {
  margin-bottom: 44px;
}
@media screen and (max-width: 680px) {
  .sampleBox__content:not(:last-of-type) {
    margin-bottom: 6.4vw;
  }
}
.sampleBox__img {
  text-align: center;
  margin-bottom: 22px;
}
@media screen and (max-width: 680px) {
  .sampleBox__img {
    margin-bottom: 3.2vw;
  }
}
.sampleBox__title {
  font-size: 36px;
  text-align: center;
  margin-bottom: 44px;
}
@media screen and (max-width: 680px) {
  .sampleBox__title {
    font-size: 5.3333333333vw;
    margin-bottom: 6.4vw;
  }
}
.sampleBox__subtitle {
  font-size: 36px;
  line-height: 1.4;
  letter-spacing: 0.05em;
  margin-bottom: 15px;
}
@media screen and (max-width: 680px) {
  .sampleBox__subtitle {
    font-size: 5.3333333333vw;
    margin-bottom: 2.1333333333vw;
  }
}
.sampleBox__detail {
  font-size: 22px;
  line-height: 1.4;
  letter-spacing: 0.05em;
  margin-bottom: 7px;
}
@media screen and (max-width: 680px) {
  .sampleBox__detail {
    font-size: 3.2vw;
    margin-bottom: 1.0666666667vw;
  }
}
.sampleBox__detail small {
  font-size: 18px;
}
@media screen and (max-width: 680px) {
  .sampleBox__detail small {
    font-size: 2.6666666667vw;
  }
}
.sampleBox__price {
  font-size: 25px;
  line-height: 1.4;
  margin-bottom: 7px;
}
@media screen and (max-width: 680px) {
  .sampleBox__price {
    font-size: 3.7333333333vw;
    margin-bottom: 1.0666666667vw;
  }
}
.sampleBox__note {
  font-size: 18px;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 680px) {
  .sampleBox__note {
    font-size: 2.6666666667vw;
  }
}
.sampleBox .separator {
  margin-bottom: 47px;
}
@media screen and (max-width: 680px) {
  .sampleBox .separator {
    margin-bottom: 6.9333333333vw;
  }
}

.review {
  background-color: #f7f3d0;
  padding: 36px 22px;
  margin-bottom: 36px;
}
@media screen and (max-width: 680px) {
  .review {
    padding: 5.3333333333vw 3.2vw;
    margin-bottom: 5.3333333333vw;
  }
}
.review__content {
  background-color: #fff;
  padding: 58px 29px 36px;
}
@media screen and (max-width: 680px) {
  .review__content {
    padding: 8.5333333333vw 4.2666666667vw 5.3333333333vw;
  }
}
.review__content:not(:last-of-type) {
  margin-bottom: 36px;
}
@media screen and (max-width: 680px) {
  .review__content:not(:last-of-type) {
    margin-bottom: 5.3333333333vw;
  }
}
.review__title {
  text-align: center;
  font-size: 36px;
  line-height: 1.7;
  margin-bottom: 62px;
}
@media screen and (max-width: 680px) {
  .review__title {
    font-size: 5.3333333333vw;
    margin-bottom: 9.0666666667vw;
  }
}
.review__title:has(+ .review__text) {
  margin-bottom: 36px;
}
@media screen and (max-width: 680px) {
  .review__title:has(+ .review__text) {
    margin-bottom: 5.3333333333vw;
  }
}
.review__text {
  font-size: 18px;
  margin-bottom: 62px;
  text-align: center;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 680px) {
  .review__text {
    font-size: 2.6666666667vw;
    margin-bottom: 9.0666666667vw;
  }
}
.review__note {
  text-align: end;
  font-size: 18px;
}
@media screen and (max-width: 680px) {
  .review__note {
    font-size: 2.6666666667vw;
  }
}

.studyCard__content01 {
  margin-bottom: 65px;
}
@media screen and (max-width: 680px) {
  .studyCard__content01 {
    margin-bottom: 9.6vw;
  }
}
.studyCard__content01 .card__lead {
  margin-bottom: 51px;
}
@media screen and (max-width: 680px) {
  .studyCard__content01 .card__lead {
    margin-bottom: 7.4666666667vw;
  }
}
.studyCard__content01 .card__img {
  margin-bottom: 51px;
}
@media screen and (max-width: 680px) {
  .studyCard__content01 .card__img {
    margin-bottom: 7.4666666667vw;
  }
}
.studyCard .separator {
  margin-bottom: 87px;
}
@media screen and (max-width: 680px) {
  .studyCard .separator {
    margin-bottom: 12.8vw;
  }
}
.studyCard__content02 .card__lead {
  margin-bottom: 22px;
}
@media screen and (max-width: 680px) {
  .studyCard__content02 .card__lead {
    margin-bottom: 3.2vw;
  }
}
.studyCard__content02 .card__text {
  margin-bottom: 40px;
}
@media screen and (max-width: 680px) {
  .studyCard__content02 .card__text {
    margin-bottom: 5.8666666667vw;
  }
}

.newTechnologyCard__content01 .card__lead {
  margin-bottom: 22px;
}
@media screen and (max-width: 680px) {
  .newTechnologyCard__content01 .card__lead {
    margin-bottom: 3.2vw;
  }
}
.newTechnologyCard__content01 .newTechnologyMovie {
  width: 78%;
}
.newTechnologyCard__content01 .card__img {
  margin-bottom: 58px;
}
@media screen and (max-width: 680px) {
  .newTechnologyCard__content01 .card__img {
    margin-bottom: 8.5333333333vw;
  }
}
.newTechnologyCard__content01 .card__note {
  margin-top: 22px;
}
@media screen and (max-width: 680px) {
  .newTechnologyCard__content01 .card__note {
    margin-top: 3.2vw;
  }
}
.newTechnologyCard__content02 .card__borderTitle {
  text-align: center;
  font-size: 25px;
  border-top: 2px solid #000;
  border-bottom: 2px solid #000;
  padding: 25px 0;
  margin-bottom: 45px;
  margin-top: 80px;
}
@media screen and (max-width: 680px) {
  .newTechnologyCard__content02 .card__borderTitle {
    font-size: 3.7333333333vw;
    border-top: 1px solid #000;
    border-bottom: 1px solid #000;
    padding: 3.7333333333vw 0;
    margin-bottom: 6.6666666667vw;
    margin-top: 11.7333333333vw;
  }
}
.newTechnologyCard__content02 .card__borderTitle span {
  font-size: 36px;
  padding: 0 47px;
  position: relative;
}
@media screen and (max-width: 680px) {
  .newTechnologyCard__content02 .card__borderTitle span {
    font-size: 5.3333333333vw;
    padding: 0 6.9333333333vw;
  }
}
.newTechnologyCard__content02 .card__borderTitle span::before, .newTechnologyCard__content02 .card__borderTitle span::after {
  content: "";
  width: 29px;
  height: 2px;
  background-color: #000;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 680px) {
  .newTechnologyCard__content02 .card__borderTitle span::before, .newTechnologyCard__content02 .card__borderTitle span::after {
    width: 4.2666666667vw;
    height: 1px;
  }
}
.newTechnologyCard__content02 .card__borderTitle span::before {
  left: 0;
}
.newTechnologyCard__content02 .card__borderTitle span::after {
  right: 0;
}
.newTechnologyCard__content02 .card__img {
  margin-bottom: 65px;
}
@media screen and (max-width: 680px) {
  .newTechnologyCard__content02 .card__img {
    margin-bottom: 9.6vw;
  }
}
.newTechnologyCard__content02 .card__text {
  margin-bottom: 15px;
}
@media screen and (max-width: 680px) {
  .newTechnologyCard__content02 .card__text {
    margin-bottom: 2.1333333333vw;
  }
}
.newTechnologyCard__content02 .card__note {
  margin-bottom: 58px;
}
@media screen and (max-width: 680px) {
  .newTechnologyCard__content02 .card__note {
    margin-bottom: 8.5333333333vw;
  }
}
.newTechnologyCard__content02 .button {
  margin-bottom: 80px;
}
@media screen and (max-width: 680px) {
  .newTechnologyCard__content02 .button {
    margin-bottom: 11.7333333333vw;
  }
}

.boxCard__content01 .card__lead {
  margin-bottom: 44px;
}
@media screen and (max-width: 680px) {
  .boxCard__content01 .card__lead {
    margin-bottom: 6.4vw;
  }
}
.boxCard__content01 .card__img {
  margin-bottom: 65px;
}
@media screen and (max-width: 680px) {
  .boxCard__content01 .card__img {
    margin-bottom: 9.6vw;
  }
}

.ingredientCard__content01 {
  margin-bottom: 73px;
}
@media screen and (max-width: 680px) {
  .ingredientCard__content01 {
    margin-bottom: 10.6666666667vw;
  }
}
.ingredientCard__content01 .card__lead {
  margin-bottom: 51px;
}
@media screen and (max-width: 680px) {
  .ingredientCard__content01 .card__lead {
    margin-bottom: 7.4666666667vw;
  }
}
.ingredientCard__content01 .card__subtitle {
  margin-bottom: 25px;
}
@media screen and (max-width: 680px) {
  .ingredientCard__content01 .card__subtitle {
    margin-bottom: 3.7333333333vw;
  }
}
.ingredientCard__content01 .card__img {
  margin-bottom: 44px;
}
@media screen and (max-width: 680px) {
  .ingredientCard__content01 .card__img {
    margin-bottom: 6.4vw;
  }
}
.ingredientCard__content01 .card__text {
  margin-bottom: 22px;
}
@media screen and (max-width: 680px) {
  .ingredientCard__content01 .card__text {
    margin-bottom: 3.2vw;
  }
}
.ingredientCard__content01 .card__note {
  margin-bottom: 58px;
}
@media screen and (max-width: 680px) {
  .ingredientCard__content01 .card__note {
    margin-bottom: 8.5333333333vw;
  }
}
.ingredientCard .box {
  background-color: #e7e7e7;
  padding: 58px 36px;
  margin-bottom: 44px;
}
@media screen and (max-width: 680px) {
  .ingredientCard .box {
    padding: 8.5333333333vw 5.3333333333vw;
    margin-bottom: 6.4vw;
  }
}
.ingredientCard .box__title {
  font-size: 29px;
  text-align: center;
  margin-bottom: 44px;
}
@media screen and (max-width: 680px) {
  .ingredientCard .box__title {
    font-size: 4.2666666667vw;
    margin-bottom: 6.4vw;
  }
}
.ingredientCard .box__imgBlock {
  margin-bottom: 54px;
  text-align: center;
}
@media screen and (max-width: 680px) {
  .ingredientCard .box__imgBlock {
    margin-bottom: 8vw;
  }
}
.ingredientCard .box .separator {
  margin-bottom: 47px;
}
@media screen and (max-width: 680px) {
  .ingredientCard .box .separator {
    margin-bottom: 6.9333333333vw;
  }
}
.ingredientCard .box .boxContent {
  display: flex;
  gap: 27px;
}
@media screen and (max-width: 680px) {
  .ingredientCard .box .boxContent {
    gap: 4vw;
  }
}
.ingredientCard .box .boxContent__imgBlock {
  flex: 0 0 35%;
}
.ingredientCard .box .boxContent__subtitle {
  font-size: 25px;
  margin-bottom: 11px;
}
@media screen and (max-width: 680px) {
  .ingredientCard .box .boxContent__subtitle {
    font-size: 3.7333333333vw;
    margin-bottom: 1.6vw;
  }
}
.ingredientCard .box .boxContent__text {
  font-size: 24px;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 680px) {
  .ingredientCard .box .boxContent__text {
    font-size: 3.4666666667vw;
  }
}
.ingredientCard .separator {
  margin-bottom: 80px;
}
@media screen and (max-width: 680px) {
  .ingredientCard .separator {
    margin-bottom: 11.7333333333vw;
  }
}
.ingredientCard__content02 .card__lead {
  margin-bottom: 69px;
}
@media screen and (max-width: 680px) {
  .ingredientCard__content02 .card__lead {
    margin-bottom: 10.1333333333vw;
  }
}
.ingredientCard__content02 .card__subtitle {
  margin-bottom: 22px;
}
@media screen and (max-width: 680px) {
  .ingredientCard__content02 .card__subtitle {
    margin-bottom: 3.2vw;
  }
}
.ingredientCard__content02 .card__img {
  margin-bottom: 44px;
}
@media screen and (max-width: 680px) {
  .ingredientCard__content02 .card__img {
    margin-bottom: 6.4vw;
  }
}
.ingredientCard__content02 .card__text {
  margin-bottom: 22px;
}
@media screen and (max-width: 680px) {
  .ingredientCard__content02 .card__text {
    margin-bottom: 3.2vw;
  }
}
.ingredientCard__content02 .card__note {
  margin-bottom: 69px;
}
@media screen and (max-width: 680px) {
  .ingredientCard__content02 .card__note {
    margin-bottom: 10.1333333333vw;
  }
}
.ingredientCard__content02 .button {
  margin-bottom: 54px;
}
@media screen and (max-width: 680px) {
  .ingredientCard__content02 .button {
    margin-bottom: 8vw;
  }
}

.containerCard__content .card__lead {
  margin-bottom: 47px;
}
@media screen and (max-width: 680px) {
  .containerCard__content .card__lead {
    margin-bottom: 6.9333333333vw;
  }
}
.containerCard__content .card__img {
  margin-bottom: 47px;
}
@media screen and (max-width: 680px) {
  .containerCard__content .card__img {
    margin-bottom: 6.9333333333vw;
  }
}
.containerCard__content .card__text {
  margin-bottom: 58px;
}
@media screen and (max-width: 680px) {
  .containerCard__content .card__text {
    margin-bottom: 8.5333333333vw;
  }
}
.containerCard .separator {
  margin-bottom: 65px;
}
@media screen and (max-width: 680px) {
  .containerCard .separator {
    margin-bottom: 9.6vw;
  }
}

.containerList {
  display: flex;
  flex-direction: column;
  gap: 58px;
}
@media screen and (max-width: 680px) {
  .containerList {
    gap: 8.5333333333vw;
  }
}
.containerList__title {
  font-size: 36px;
  margin-bottom: 15px;
}
@media screen and (max-width: 680px) {
  .containerList__title {
    font-size: 5.3333333333vw;
    margin-bottom: 2.1333333333vw;
  }
}
.containerList__title span {
  font-size: 25px;
  display: inline-block;
  text-align: center;
  margin-right: 25px;
  background-color: #e3eaf2;
  padding: 7px 18px;
}
@media screen and (max-width: 680px) {
  .containerList__title span {
    font-size: 3.7333333333vw;
    text-align: center;
    margin-right: 3.7333333333vw;
    padding: 1.0666666667vw 2.6666666667vw;
  }
}
.containerList__content {
  display: flex;
  align-items: stretch;
  gap: 25px;
}
@media screen and (max-width: 680px) {
  .containerList__content {
    gap: 3.7333333333vw;
  }
}
.containerList__img {
  flex: 0 1 48%;
}
.containerList__text {
  flex: auto;
}
.containerList__text p {
  font-size: 22px;
}
@media screen and (max-width: 680px) {
  .containerList__text p {
    font-size: 3.2vw;
  }
}

.banner {
  text-align: center;
}
.banner:not(:last-of-type) {
  margin-bottom: 36px;
}
@media screen and (max-width: 680px) {
  .banner:not(:last-of-type) {
    margin-bottom: 5.3333333333vw;
  }
}
.banner__heading {
  text-align: center;
  margin-bottom: 22px;
}
@media screen and (max-width: 680px) {
  .banner__heading {
    margin-bottom: 3.2vw;
  }
}
.banner__heading span {
  font-size: 25px;
  font-weight: 700;
  position: relative;
  padding: 0 29px;
}
@media screen and (max-width: 680px) {
  .banner__heading span {
    font-size: 3.7333333333vw;
    padding: 0 4.2666666667vw;
  }
}
.banner__heading span::before, .banner__heading span::after {
  content: "";
  display: inline-block;
  width: 2px;
  height: 36px;
  background-color: #000;
  position: absolute;
  top: 50%;
}
@media screen and (max-width: 680px) {
  .banner__heading span::before, .banner__heading span::after {
    width: 1px;
    height: 5.3333333333vw;
  }
}
.banner__heading span::before {
  left: 0;
  transform: translateY(-50%) rotate(150deg);
}
.banner__heading span::after {
  right: 0;
  transform: translateY(-50%) rotate(30deg);
}

.fragranceCard .card__title {
  line-height: 1.4;
  margin-bottom: 65px;
}
@media screen and (max-width: 680px) {
  .fragranceCard .card__title {
    margin-bottom: 9.6vw;
  }
}
.fragranceCard .card__img {
  margin-bottom: 65px;
}
@media screen and (max-width: 680px) {
  .fragranceCard .card__img {
    margin-bottom: 9.6vw;
  }
}

.modal__openButton {
  cursor: pointer;
  color: #fff;
  font-size: 29px;
  background-color: #8099c2;
  border-radius: 63px;
  font-family: "游ゴシック体", "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  padding: 15px;
  display: block;
  max-width: 508px;
  text-align: center;
  margin: 0 auto;
}
@media screen and (max-width: 680px) {
  .modal__openButton {
    font-size: 4.2666666667vw;
    border-radius: 9.3333333333vw;
    padding: 2.1333333333vw;
    max-width: 74.6666666667vw;
  }
}
.modal__openButtonArrow {
  display: inline-block;
  width: 16px;
  height: 24px;
  position: relative;
  margin-left: 9px;
}
@media screen and (max-width: 680px) {
  .modal__openButtonArrow {
    width: 2.4vw;
    height: 3.4666666667vw;
    margin-left: 1.3333333333vw;
  }
}
.modal__openButtonArrow::before, .modal__openButtonArrow::after {
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  right: 0;
  width: 16px;
  height: 2px;
  background-color: #fff;
  transform-origin: calc(100% - 1px) 50%;
}
@media screen and (max-width: 680px) {
  .modal__openButtonArrow::before, .modal__openButtonArrow::after {
    width: 2.4vw;
    height: 0.2666666667vw;
    transform-origin: calc(100% - 0.5px) 50%;
    top: calc(50% - 0.5px);
  }
}
.modal__openButtonArrow::before {
  transform: rotate(45deg);
}
.modal__openButtonArrow::after {
  transform: rotate(-45deg);
}
.modal__closeIcon {
  position: absolute;
  top: 15px;
  right: 15px;
  width: 24px;
  height: 24px;
  cursor: pointer;
  opacity: 0.6;
  transition: opacity 0.2s;
}
.modal__bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(0, 0, 0, 0.6);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.modal__bg.active {
  opacity: 1;
  visibility: visible;
  z-index: 1200;
}
.modal__body {
  position: relative;
  display: inline-block;
  max-width: 640px;
  width: 90%;
  max-height: 80vh;
}
.modal__content {
  border-radius: 8px;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.5);
  background: #fff;
  padding: 40px;
}
@media screen and (max-width: 680px) {
  .modal__content {
    padding: 30px 20px 20px;
  }
}
.modal__closeButton {
  margin-top: 40px;
  text-align: center;
  cursor: pointer;
  text-decoration: underline;
  font-size: 14px;
  color: #666;
  font-family: "游ゴシック体", "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
}

.fragranceModal__title {
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 20px;
  line-height: 1.4;
  letter-spacing: 0.15em;
  color: #446b96;
  border-bottom: 1px dashed #ddd;
  padding-bottom: 10px;
  font-family: "A1 Mincho", "A-OTF A1明朝 Std", Georgia, 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
}
@media screen and (max-width: 680px) {
  .fragranceModal__title {
    font-size: 16px;
  }
}
.fragranceModal__text {
  font-size: 14px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  margin-bottom: 15px;
  color: #333;
  font-family: "游ゴシック体", "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  text-align: left;
}

.eventCard .card__lead {
  margin-bottom: 65px;
}
@media screen and (max-width: 680px) {
  .eventCard .card__lead {
    margin-bottom: 9.6vw;
  }
}
.eventCard .card__lead strong {
  display: inline-block;
  position: relative;
  z-index: 1;
}
.eventCard .card__lead strong::before {
  content: "";
  display: inline-block;
  width: 100%;
  height: 15px;
  background-color: #e3eaf2;
  position: absolute;
  z-index: -1;
  bottom: 8%;
}
@media screen and (max-width: 680px) {
  .eventCard .card__lead strong::before {
    height: 2.1333333333vw;
  }
}

.event {
  position: relative;
  width: 97.5%;
  margin: 0 auto;
}
.event:has(.eventList--static) .swiper-button-next, .event:has(.eventList--static) .swiper-button-prev {
  display: none;
}

.swiper-navigation-icon {
  display: none;
}

.swiper-button-next, .swiper-button-prev {
  display: inline-block;
  width: 16px;
  height: 24px;
}
@media screen and (max-width: 680px) {
  .swiper-button-next, .swiper-button-prev {
    width: 2.4vw;
    height: 3.4666666667vw;
  }
}
.swiper-button-next::before, .swiper-button-next::after, .swiper-button-prev::before, .swiper-button-prev::after {
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  width: 16px;
  height: 4px;
  background-color: #000;
  transform-origin: calc(100% - 1px) 50%;
}
@media screen and (max-width: 680px) {
  .swiper-button-next::before, .swiper-button-next::after, .swiper-button-prev::before, .swiper-button-prev::after {
    width: 2.4vw;
    height: 0.5333333333vw;
    transform-origin: calc(100% - 0.5px) 50%;
    top: calc(50% - 0.5px);
  }
}
.swiper-button-next::before, .swiper-button-prev::before {
  transform: rotate(45deg);
}
.swiper-button-next::after, .swiper-button-prev::after {
  transform: rotate(-45deg);
}

.swiper-horizontal ~ .swiper-button-next {
  right: -25px;
}
@media screen and (max-width: 680px) {
  .swiper-horizontal ~ .swiper-button-next {
    right: -3.7333333333vw;
  }
}
.swiper-horizontal ~ .swiper-button-prev {
  left: -25px;
  transform: scale(-1, 1);
}
@media screen and (max-width: 680px) {
  .swiper-horizontal ~ .swiper-button-prev {
    left: -3.7333333333vw;
  }
}

.swiper-slide {
  height: unset;
}

.eventList--static {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 6%;
}
.eventList--static .eventList__item {
  flex: 0 1 47%;
}
.eventList__item {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  gap: 15px;
}
@media screen and (max-width: 680px) {
  .eventList__item {
    gap: 2.1333333333vw;
  }
}
.eventList__title {
  font-size: 25px;
  text-align: center;
  flex-grow: 1;
}
@media screen and (max-width: 680px) {
  .eventList__title {
    font-size: 3.7333333333vw;
  }
}
.eventList__text {
  font-size: 25px;
  text-align: center;
  flex-grow: 1;
  min-height: 73px;
}
@media screen and (max-width: 680px) {
  .eventList__text {
    font-size: 3.7333333333vw;
    min-height: 10.6666666667vw;
  }
}
.eventList .button {
  flex-grow: 1;
}

.exchangeMeetingCard .card__lead {
  margin-bottom: 51px;
}
@media screen and (max-width: 680px) {
  .exchangeMeetingCard .card__lead {
    margin-bottom: 7.4666666667vw;
  }
}
.exchangeMeetingCard .separator {
  margin-top: 44px;
}
@media screen and (max-width: 680px) {
  .exchangeMeetingCard .separator {
    margin-bottom: 6.4vw;
  }
}

.exchangeMeetingBlock:not(:last-of-type) {
  margin-top: 58px;
}
@media screen and (max-width: 680px) {
  .exchangeMeetingBlock:not(:last-of-type) {
    margin-bottom: 8.5333333333vw;
  }
}
.exchangeMeetingBlock__title {
  font-size: 25px;
  border-bottom: 2px solid #000;
  margin-bottom: 27px;
  padding-bottom: 13px;
}
@media screen and (max-width: 680px) {
  .exchangeMeetingBlock__title {
    font-size: 3.7333333333vw;
    border-bottom: 1px solid #000;
    margin-bottom: 4vw;
    padding-bottom: 1.8666666667vw;
  }
}
.exchangeMeetingBlock__title span {
  display: inline-block;
  width: 127px;
  text-align: center;
  border-left: 2px solid #000;
  border-right: 2px solid #000;
  margin-right: 36px;
}
@media screen and (max-width: 680px) {
  .exchangeMeetingBlock__title span {
    width: 18.6666666667vw;
    text-align: center;
    border-left: 1px solid #000;
    border-right: 1px solid #000;
    margin-right: 5.3333333333vw;
  }
}
.exchangeMeetingBlock__notice {
  display: flex;
  gap: 15px;
  align-items: center;
  justify-content: center;
  margin: 36px 0;
}
@media screen and (max-width: 680px) {
  .exchangeMeetingBlock__notice {
    gap: 2.1333333333vw;
    margin: 5.3333333333vw 0;
  }
}
.exchangeMeetingBlock__noticeLabel {
  width: 91px;
  height: 91px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 25px;
  color: #fff;
  background-color: #8099c2;
  flex: 0 0 91px;
}
@media screen and (max-width: 680px) {
  .exchangeMeetingBlock__noticeLabel {
    width: 13.3333333333vw;
    height: 13.3333333333vw;
    font-size: 3.7333333333vw;
    flex: 0 0 13.3333333333vw;
  }
}
.exchangeMeetingBlock__noticeTitle {
  font-size: 25px;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 680px) {
  .exchangeMeetingBlock__noticeTitle {
    font-size: 3.7333333333vw;
  }
}

.exchangeMeetingContent {
  display: flex;
  align-items: stretch;
  gap: 18px;
}
@media screen and (max-width: 680px) {
  .exchangeMeetingContent {
    gap: 2.6666666667vw;
  }
}
.exchangeMeetingContent__text {
  flex: auto;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 18px;
}
@media screen and (max-width: 680px) {
  .exchangeMeetingContent__text {
    gap: 2.6666666667vw;
  }
}
.exchangeMeetingContent__text p {
  font-size: 24px;
}
@media screen and (max-width: 680px) {
  .exchangeMeetingContent__text p {
    font-size: 3.4666666667vw;
  }
}
.exchangeMeetingContent .button p {
  font-size: 18px;
  font-family: "游ゴシック体", "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  text-align: center;
  margin-top: 11px;
}
@media screen and (max-width: 680px) {
  .exchangeMeetingContent .button p {
    font-size: 2.6666666667vw;
    margin-top: 1.6vw;
  }
}

.shopCard .card__title {
  margin-bottom: 40px;
}
@media screen and (max-width: 680px) {
  .shopCard .card__title {
    margin-bottom: 5.8666666667vw;
  }
}
.shopCard .card__text {
  margin-bottom: 22px;
  font-size: 29px;
}
@media screen and (max-width: 680px) {
  .shopCard .card__text {
    margin-bottom: 3.2vw;
    font-size: 4.2666666667vw;
  }
}
.shopCard .card__text:last-of-type {
  margin-bottom: 58px;
}
@media screen and (max-width: 680px) {
  .shopCard .card__text:last-of-type {
    margin-bottom: 8.5333333333vw;
  }
}
.shopCard .card__img {
  max-width: 435px;
  margin: 0 auto 65px;
}
@media screen and (max-width: 680px) {
  .shopCard .card__img {
    max-width: 64vw;
    margin: 0 auto 9.6vw;
  }
}
.shopCard .button a {
  font-size: 25px;
  padding: 7px;
  max-width: 435px;
}
@media screen and (max-width: 680px) {
  .shopCard .button a {
    font-size: 3.7333333333vw;
    padding: 1.0666666667vw;
    max-width: 64vw;
  }
}

.faqCard .card__body {
  padding: 65px 0 44px;
}
@media screen and (max-width: 680px) {
  .faqCard .card__body {
    padding: 9.6vw 0 6.4vw;
  }
}
.faqCard .card__title {
  margin-bottom: 40px;
}
@media screen and (max-width: 680px) {
  .faqCard .card__title {
    margin-bottom: 5.8666666667vw;
  }
}

.faqList {
  display: flex;
  flex-direction: column;
  gap: 22px;
}
@media screen and (max-width: 680px) {
  .faqList {
    gap: 3.2vw;
  }
}
.faqList__item--open .faqList__questionIcon::after {
  transform: translate(-50%, -50%);
}
.faqList__question {
  background-color: #dcdcdc;
  padding: 15px 36px 22px 22px;
  margin: 0 34px;
  min-height: 109px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 7px;
  cursor: pointer;
}
@media screen and (max-width: 680px) {
  .faqList__question {
    padding: 2.1333333333vw 5.3333333333vw 3.2vw 3.2vw;
    margin: 0 5.0666666667vw;
    min-height: 16vw;
    gap: 1.0666666667vw;
  }
}
.faqList__questionText {
  line-height: 1.6;
  font-size: 25px;
}
@media screen and (max-width: 680px) {
  .faqList__questionText {
    font-size: 3.7333333333vw;
  }
}
.faqList__questionIcon {
  position: relative;
  width: 22px;
  height: 22px;
}
@media screen and (max-width: 680px) {
  .faqList__questionIcon {
    width: 3.2vw;
    height: 3.2vw;
  }
}
.faqList__questionIcon::before, .faqList__questionIcon::after {
  content: "";
  display: inline-block;
  width: 22px;
  height: 2px;
  background-color: #000;
  position: absolute;
  left: 50%;
  top: 50%;
}
@media screen and (max-width: 680px) {
  .faqList__questionIcon::before, .faqList__questionIcon::after {
    width: 3.2vw;
    height: 1px;
  }
}
.faqList__questionIcon::before {
  transform: translate(-50%, -50%);
}
.faqList__questionIcon::after {
  transition: all 0.3s;
  transform: translate(-50%, -50%) rotate(-90deg);
}
.faqList__answer {
  overflow: hidden;
}
.faqList__answerContent {
  padding: 29px 0 22px;
}
@media screen and (max-width: 680px) {
  .faqList__answerContent {
    padding: 4.2666666667vw 0 3.2vw;
  }
}
.faqList__answerInner {
  margin: 0 34px;
}
@media screen and (max-width: 680px) {
  .faqList__answerInner {
    margin: 0 5.0666666667vw;
  }
}
.faqList__text {
  font-size: 24px;
}
@media screen and (max-width: 680px) {
  .faqList__text {
    font-size: 3.6vw;
  }
}
.faqList__text:not(:last-of-type) {
  margin-bottom: 1em;
}
.faqList__bg {
  background-color: #e9e9e9;
  padding: 25px 34px 54px;
  margin: 51px 0 36px;
}
@media screen and (max-width: 680px) {
  .faqList__bg {
    padding: 3.7333333333vw 5.0666666667vw 8vw;
    margin: 7.4666666667vw 0 5.3333333333vw;
  }
}
.faqList__bgTitle {
  text-align: center;
  font-size: 25px;
  margin-bottom: 22px;
}
@media screen and (max-width: 680px) {
  .faqList__bgTitle {
    font-size: 3.7333333333vw;
    margin-bottom: 3.2vw;
  }
}
.faqList__box {
  background-color: #fff;
  padding: 29px 18px 36px;
}
@media screen and (max-width: 680px) {
  .faqList__box {
    padding: 4.2666666667vw 18px 5.3333333333vw;
  }
}
.faqList__box:not(:last-of-type) {
  margin-bottom: 18px;
}
@media screen and (max-width: 680px) {
  .faqList__box:not(:last-of-type) {
    margin-bottom: 2.6666666667vw;
  }
}
.faqList__boxTitle {
  font-size: 25px;
  margin-bottom: 15px;
}
@media screen and (max-width: 680px) {
  .faqList__boxTitle {
    font-size: 3.7333333333vw;
    margin-bottom: 2.1333333333vw;
  }
}
.faqList__boxRoundTitle {
  display: block;
  width: -moz-max-content;
  width: max-content;
  min-width: 163px;
  background-color: #dcdcdc;
  border-radius: 18px;
  text-align: center;
  margin-bottom: 15px;
}
@media screen and (max-width: 680px) {
  .faqList__boxRoundTitle {
    min-width: 24vw;
    border-radius: 2.6666666667vw;
    margin-bottom: 2.1333333333vw;
  }
}
.faqList__boxArrowContent:not(:last-of-type) {
  position: relative;
  margin-bottom: 73px;
}
@media screen and (max-width: 680px) {
  .faqList__boxArrowContent:not(:last-of-type) {
    margin-bottom: 10.6666666667vw;
  }
}
.faqList__boxArrowContent:not(:last-of-type)::before, .faqList__boxArrowContent:not(:last-of-type)::after {
  content: "";
  position: absolute;
  bottom: -10%;
  left: calc(50% - 1px);
  width: 2px;
  height: 38px;
  background-color: #000000;
  transform-origin: 50% calc(100% - 1px);
}
@media screen and (max-width: 680px) {
  .faqList__boxArrowContent:not(:last-of-type)::before, .faqList__boxArrowContent:not(:last-of-type)::after {
    width: 1px;
    height: 5.6vw;
    left: calc(50% - 0.5px);
    transform-origin: 50% calc(100% - 0.5px);
  }
}
.faqList__boxArrowContent:not(:last-of-type)::before {
  transform: rotate(48deg);
}
.faqList__boxArrowContent:not(:last-of-type)::after {
  transform: rotate(-48deg);
}
.faqList__boxArrowContent .faqList__boxText:not(:last-of-type) {
  margin-bottom: 0;
}
.faqList__boxText {
  font-size: 24px;
}
@media screen and (max-width: 680px) {
  .faqList__boxText {
    font-size: 3.4666666667vw;
  }
}
.faqList__boxText:not(:last-of-type) {
  margin-bottom: 1em;
}
.faqList__boxText small {
  letter-spacing: 0.05em;
  line-height: 1;
  font-size: 18px;
}
@media screen and (max-width: 680px) {
  .faqList__boxText small {
    font-size: 2.6666666667vw;
  }
}
.faqList__boxWrap {
  display: flex;
  align-items: start;
  gap: 15px;
}
@media screen and (max-width: 680px) {
  .faqList__boxWrap {
    gap: 2.1333333333vw;
  }
}
.faqList__boxImg {
  margin: -91px 0 22px;
}
@media screen and (max-width: 680px) {
  .faqList__boxImg {
    margin: -13.3333333333vw 0 3.2vw;
  }
}
.faqList__boxWrapImg {
  flex: 0 1 228px;
}
@media screen and (max-width: 680px) {
  .faqList__boxWrapImg {
    flex: 0 1 33.6vw;
  }
}
.faqList__boxWrapText {
  flex: auto;
  letter-spacing: 0.05em;
  font-size: 24px;
}
@media screen and (max-width: 680px) {
  .faqList__boxWrapText {
    font-size: 3.4666666667vw;
  }
}
.faqList__step {
  padding: 29px 0 15px;
}
@media screen and (max-width: 680px) {
  .faqList__step {
    padding: 4.2666666667vw 0 2.1333333333vw;
  }
}
.faqList__stepTitle {
  letter-spacing: 0.09em;
  font-size: 25px;
  margin-bottom: 7px;
}
@media screen and (max-width: 680px) {
  .faqList__stepTitle {
    font-size: 3.7333333333vw;
    margin-bottom: 1.0666666667vw;
  }
}
.faqList__stepList {
  display: flex;
  flex-direction: column;
  gap: 36px;
}
@media screen and (max-width: 680px) {
  .faqList__stepList {
    gap: 5.3333333333vw;
  }
}
.faqList__stepListItem {
  padding-top: 29px;
  border-top: solid 2px #000;
}
@media screen and (max-width: 680px) {
  .faqList__stepListItem {
    padding-top: 4.2666666667vw;
    border-top: solid 1px #000;
  }
}
.faqList__stepListTitle {
  font-size: 25px;
  margin-bottom: 15px;
}
@media screen and (max-width: 680px) {
  .faqList__stepListTitle {
    font-size: 3.7333333333vw;
    margin-bottom: 2.1333333333vw;
  }
}
.faqList__stepListTitle span {
  display: inline-block;
  position: relative;
  z-index: 1;
}
.faqList__stepListTitle span::before {
  content: "";
  display: inline-block;
  width: 100%;
  height: 15px;
  background-color: #e3eaf2;
  position: absolute;
  z-index: -1;
  bottom: 8%;
}
@media screen and (max-width: 680px) {
  .faqList__stepListTitle span::before {
    height: 2.1333333333vw;
  }
}
.faqList__stepListText {
  letter-spacing: 0.09em;
  font-size: 24px;
}
@media screen and (max-width: 680px) {
  .faqList__stepListText {
    font-size: 3.4666666667vw;
  }
}
.faqList__link {
  color: #446b96;
  text-decoration: underline;
}
.faqList__link:hover {
  color: #446b96;
  text-decoration: underline !important;
}
.faqList__note {
  letter-spacing: 0.05em;
  font-size: 18px;
}
@media screen and (max-width: 680px) {
  .faqList__note {
    font-size: 2.6666666667vw;
  }
}
.faqList__note:has(+ .faqList__box) {
  margin-bottom: 44px;
}
@media screen and (max-width: 680px) {
  .faqList__note:has(+ .faqList__box) {
    margin-bottom: 6.4vw;
  }
}

.infoCard .card__title {
  margin-bottom: 40px;
}
@media screen and (max-width: 680px) {
  .infoCard .card__title {
    margin-bottom: 5.8666666667vw;
  }
}
.infoCard .card__img {
  margin-bottom: 29px;
}
@media screen and (max-width: 680px) {
  .infoCard .card__img {
    margin-bottom: 4.2666666667vw;
  }
}
.infoCard .card__text {
  margin-bottom: 33px;
}
@media screen and (max-width: 680px) {
  .infoCard .card__text {
    margin-bottom: 4.8vw;
  }
}
.infoCard .lineButton a {
  display: block;
  background-color: #06c055;
  padding: 22px;
  font-size: 29px;
  font-family: "游ゴシック体", "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  color: #fff;
  border-radius: 40px;
  text-align: center;
  max-width: 562px;
  margin: 0 auto;
}
@media screen and (max-width: 680px) {
  .infoCard .lineButton a {
    padding: 3.2vw;
    font-size: 4.2666666667vw;
    border-radius: 5.8666666667vw;
    max-width: 82.6666666667vw;
  }
}

.myPageButton {
  margin-bottom: 44px;
}
@media screen and (max-width: 680px) {
  .myPageButton {
    margin-bottom: 6.4vw;
  }
}
.myPageButton a {
  display: block;
  width: 83%;
  max-width: 562px;
  margin: 0 auto;
  border: 2px solid #000;
  color: #000;
  padding: 22px;
  font-size: 29px;
  font-family: "游ゴシック体", "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  border-radius: 40px;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 680px) {
  .myPageButton a {
    max-width: 82.6666666667vw;
    border: 1px solid #000;
    padding: 3.2vw;
    font-size: 4.2666666667vw;
    border-radius: 5.8666666667vw;
  }
}
.myPageButton__arrow {
  display: inline-block;
  width: 16px;
  height: 24px;
  position: relative;
  margin-left: 9px;
}
@media screen and (max-width: 680px) {
  .myPageButton__arrow {
    width: 2.4vw;
    height: 3.4666666667vw;
    margin-left: 1.3333333333vw;
  }
}
.myPageButton__arrow::before, .myPageButton__arrow::after {
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  right: 0;
  width: 16px;
  height: 2px;
  background-color: #000;
  transform-origin: calc(100% - 1px) 50%;
}
@media screen and (max-width: 680px) {
  .myPageButton__arrow::before, .myPageButton__arrow::after {
    width: 2.4vw;
    height: 1px;
    top: calc(50% - 0.5px);
    transform-origin: calc(100% - 0.5px) 50%;
  }
}
.myPageButton__arrow::before {
  transform: rotate(45deg);
}
.myPageButton__arrow::after {
  transform: rotate(-45deg);
}

.pageTop {
  text-align: center;
}
.pageTop a {
  color: #000;
  font-size: 25px;
  font-weight: 700;
  position: relative;
  padding-right: 27px;
}
@media screen and (max-width: 680px) {
  .pageTop a {
    font-size: 3.7333333333vw;
    padding-right: 4vw;
  }
}
.pageTop a::after {
  content: "";
  display: inline-block;
  background-color: #000;
  width: 18px;
  height: 11px;
  clip-path: polygon(0 100%, 50% 0, 100% 100%);
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
}
@media screen and (max-width: 680px) {
  .pageTop a::after {
    width: 2.6666666667vw;
    height: 1.6vw;
  }
}