/*!*********************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[2]!./node_modules/import-glob-loader/index.js!./app/src/scss/style.scss ***!
  \*********************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
/* ------------------------------
* foundation
------------------------------ */
/* ------------------------------
* color
------------------------------ */
/* ------------------------------
* font-family
------------------------------ */
/* ------------------------------
* font-weight
------------------------------ */
/* ------------------------------
* font-size
------------------------------ */
/* ------------------------------
* headerHeight
------------------------------ */
/* ------------------------------
* イージング
------------------------------ */
/* ------------------------------
* text-shadow
------------------------------ */
/* ------------------------------
* メディアクエリ
------------------------------ */
/* ------------------------------
* A Modern CSS Reset
------------------------------ */
*,
*::after,
*::before {
  box-sizing: border-box;
}

blockquote,
body,
dd,
dl,
figure,
h1,
h2,
h3,
h4,
h5,
p {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  box-sizing: border-box;
}

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

body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

a {
  text-decoration: none;
  color: inherit;
}
a:visited {
  color: inherit;
}
a:active {
  color: inherit;
}

button,
input,
select,
textarea {
  vertical-align: middle;
  outline: none;
  box-sizing: border-box;
  font-family: initial;
}

table {
  border-spacing: 0;
}

img,
picture {
  max-width: 100%;
  display: block;
  object-fit: cover;
  font-family: "object-fit: cover;";
}

iframe {
  max-width: 100%;
}

/* ------------------------------
* html
------------------------------ */
html {
  font-size: 62.5%;
}
@media screen and (min-width: 640px) {
  html {
    font-size: 62.5%;
  }
}
@media screen and (min-width: 768px) {
  html {
    font-size: 62.5%;
  }
}
@media screen and (min-width: 1024px) {
  html {
    font-size: 62.5%;
  }
}
@media screen and (min-width: 1280px) {
  html {
    font-size: 62.5%;
  }
}
@media screen and (min-width: 1536px) {
  html {
    font-size: 62.5%;
  }
}

/* ------------------------------
* body
------------------------------ */
body {
  overflow-x: hidden;
  background-color: #fff;
  color: #2b2b2b;
  font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.9;
  font-feature-settings: "palt" 1;
}

.case .body__wrapper {
  overflow: hidden;
}

/* ------------------------------
* selection
------------------------------ */
/* ------------------------------
* layout
------------------------------ */
/* ------------------------------
* footer
------------------------------ */
.footer {
  background: linear-gradient(to right, #007fa1, #009f9b);
  padding: 1.2rem 0 0.7rem;
}
@media screen and (min-width: 768px) {
  .footer {
    padding: 3rem 0 2.6rem;
  }
}
.footer-guide {
  margin-bottom: 1.5rem;
  color: #fff;
  font-size: 1.2rem;
  letter-spacing: 0.05em;
  text-decoration: underline;
  text-align: center;
  cursor: pointer;
}
.footer-copy {
  max-width: 130rem !important;
  margin: 0 auto;
  color: #fff;
  font-size: 1.2rem;
  letter-spacing: 0.21em;
  line-height: 1.3;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .footer-copy {
    line-height: 1.9;
  }
}

/* ------------------------------
* header
------------------------------ */
/* ------------------------------
* main
------------------------------ */
.main {
  overflow: hidden;
}

/* ------------------------------
* sidebar
------------------------------ */
/* ------------------------------
* component
------------------------------ */
/* ------------------------------
* btn
------------------------------ */
/* ------------------------------
* cart
------------------------------ */
.cart-btn {
  display: block;
  position: relative;
  width: 100%;
  max-width: 30rem !important;
  height: 6rem;
  border-radius: 4rem;
  border: none;
  padding: 0;
  margin: 1.5rem auto 0;
  font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
}
@media screen and (min-width: 768px) {
  .cart-btn {
    max-width: 35rem !important;
    height: 6rem;
    border-radius: 3rem;
    margin-top: 2.8rem;
  }
}
.cart-btn a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 1.2rem;
  width: 100%;
  height: 100%;
  background-size: 200% 100%;
  background-position: 100% 0;
  border-radius: 6rem;
  color: #fff;
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  overflow: hidden;
  transition: background-position 0.3s ease-in-out;
}
.cart-btn a:hover {
  background-position: 0% 0;
}
.cart-btn a::before {
  display: block;
  width: 2rem;
  height: 2rem;
  background: url(./images/cart_icon.svg) no-repeat;
  background-size: 100% auto;
  content: "";
}
.cart-btn a::after {
  content: "";
  position: absolute;
  top: -100px;
  left: -100px;
  width: 50px;
  height: 50px;
  background-image: linear-gradient(100deg, rgba(255, 255, 255, 0) 10%, rgb(255, 255, 255) 100%, rgba(255, 255, 255, 0) 0%);
}
.cart-btn a:hover::after {
  animation-name: shiny;
  animation-duration: 0.6s;
  animation-timing-function: ease-in-out;
  animation-fill-mode: forwards;
}

@keyframes shiny {
  0% {
    transform: scale(0) rotate(25deg);
    opacity: 0;
  }
  20% {
    transform: scale(1) rotate(25deg);
    opacity: 1;
  }
  100% {
    transform: scale(50) rotate(25deg);
    opacity: 0;
  }
}
.cart-btn-red a {
  background-image: linear-gradient(to right, #bf4ea5, #a6193f, #bf4ea5);
}
.cart-btn-blue a {
  background-image: linear-gradient(to right, #009f9b, #007fa1, #009f9b);
}
.cart-clone {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 1.2rem;
  color: transparent;
  border-radius: 4rem;
  padding: 0;
  overflow: hidden;
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  .cart-clone {
    max-width: 35rem !important;
    border-radius: 3rem;
  }
}
.cart-clone::before {
  display: block;
  width: 2rem;
  height: 2rem;
  background: url(./images/cart_icon.svg) no-repeat;
  background-size: 100% auto;
  content: "";
}
.cart-clone::after {
  content: "";
  position: absolute;
  top: -100px;
  left: -100px;
  width: 50px;
  height: 50px;
  background-image: linear-gradient(100deg, rgba(255, 255, 255, 0) 10%, rgb(255, 255, 255) 100%, rgba(255, 255, 255, 0) 0%);
}
.cart-btn:hover .cart-clone::after {
  animation-name: shiny;
  animation-duration: 0.6s;
  animation-timing-function: ease-in-out;
  animation-fill-mode: forwards;
}
@keyframes shiny {
  0% {
    transform: scale(0) rotate(25deg);
    opacity: 0;
  }
  20% {
    transform: scale(1) rotate(25deg);
    opacity: 1;
  }
  100% {
    transform: scale(50) rotate(25deg);
    opacity: 0;
  }
}

/* ------------------------------
* form
------------------------------ */
.form-table {
  max-width: 80rem;
  margin: 0 auto 4rem;
}
.form-row {
  display: flex;
  align-items: flex-start;
}
.form-row + .form-row {
  margin-top: 2rem;
}
.form-name {
  width: 40%;
}
.form-data {
  flex: 1;
}
.form-data input {
  font-size: 1.6rem;
}
.form-data input[type=text], .form-data input[type=email], .form-data input[type=tel] {
  width: 100%;
}
.form-data textarea {
  width: 100%;
  height: 30rem;
  resize: none;
}
.form-submit {
  display: block;
  width: 20rem;
  height: 4rem;
  margin: 0 auto;
  font-size: 2rem;
}

/* ------------------------------
* lead
------------------------------ */
.lead {
  margin-bottom: 1.5rem;
  font-size: 2.2rem;
  letter-spacing: 0.1em;
}

/* ------------------------------
* modal
------------------------------ */
.modal {
  position: fixed;
  display: flex;
  align-items: center;
  justify-content: center;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  height: 100dvh;
  padding: 5%;
  z-index: 9999;
  background: rgba(0, 0, 0, 0.7);
  pointer-events: none;
  opacity: 0;
}
.modal.is-show {
  pointer-events: auto;
  opacity: 1;
}
.modal-container {
  position: relative;
  background-color: #fffffa;
  padding: 8rem 5% 8rem;
  width: 100%;
  max-height: 100%;
  overflow-y: auto;
}
@media screen and (min-width: 768px) {
  .modal-container {
    max-width: 130rem;
    margin: 0 auto;
    padding: 6rem 5%;
  }
}
.modal-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 3rem;
  height: 3rem;
  background: transparent;
  border: none;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .modal-close {
    top: 1.5rem;
    right: 2rem;
    width: 4rem;
    height: 4rem;
  }
}
.modal-close::before, .modal-close::after {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 0.2rem;
  background-color: #753945;
  content: "";
  translate: -50% -50%;
}
.modal-close::before {
  rotate: 45deg;
}
.modal-close::after {
  rotate: -45deg;
}
.modal-note {
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .modal-note {
    margin: 4rem auto;
    width: 42rem;
  }
}
.modal-note img {
  width: auto;
  height: 1.7rem;
  margin: 0 auto;
  max-width: none;
}
@media screen and (min-width: 768px) {
  .modal-note img {
    width: 100%;
    height: auto;
  }
}
.modal-catch {
  margin: 0px auto 4rem;
}
@media screen and (min-width: 768px) {
  .modal-catch {
    width: 33.6rem;
    margin-bottom: 6.1rem;
  }
}
.modal-catch img {
  width: auto;
  height: 1.6rem;
  margin: 0 auto;
  max-width: none;
}
@media screen and (min-width: 768px) {
  .modal-catch img {
    width: 100%;
    height: auto;
  }
}
.modal-block {
  display: flex;
  flex-direction: column;
  gap: 5rem 0;
}
@media screen and (min-width: 1024px) {
  .modal-block {
    flex-direction: row;
    align-items: flex-start;
    gap: 0 6%;
  }
}
.modal-table {
  flex: 1;
}
.modal-table-row {
  display: flex;
  padding: 1.7rem 2.7%;
  flex-direction: column;
  gap: 1rem;
  border-top: 1px solid rgba(150, 110, 119, 0.5);
}
@media screen and (min-width: 768px) {
  .modal-table-row {
    flex-direction: row;
    gap: 2rem;
  }
}
.modal-table-row:last-child {
  border-bottom: 1px solid rgba(150, 110, 119, 0.5);
}
.modal-table-name {
  width: 14rem;
  color: #753945;
  font-size: 1.4rem;
  letter-spacing: 0.15em;
}
.modal-table-data {
  flex: 1;
  color: #753945;
  font-size: 1.4rem;
  letter-spacing: 0.17em;
}
.modal-list {
  margin-top: -0.7rem;
}
@media screen and (min-width: 1024px) {
  .modal-list {
    width: 45.9%;
  }
}
.modal-item {
  position: relative;
  padding-left: 1.8rem;
  color: #753945;
}
.modal-item + .modal-item {
  margin-top: 3rem;
}
.modal-item::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "■";
  font-size: 1.6rem;
}
.modal-lead {
  margin-bottom: 1.2rem;
  font-size: 1.6rem;
  letter-spacing: 0.15em;
  line-height: 1.75;
}
@media screen and (min-width: 768px) {
  .modal-lead {
    margin-bottom: 1.7rem;
    line-height: 1.9;
  }
}
.modal-text {
  font-size: 1.4rem;
  letter-spacing: 0.15em;
  line-height: 1.81;
}
.modal-text-sm {
  display: block;
  font-size: 1.3rem;
  letter-spacing: 0.15em;
}
.modal-text-note {
  display: flex;
  align-items: flex-start;
}
.modal-text-note:before {
  flex: none;
  content: attr(data-text);
}
.modal-text-note > * {
  flex: 1;
}
.modal-text + .modal-text {
  margin-top: 1.9rem;
}

/* ------------------------------
* text
------------------------------ */
.text {
  font-size: 1.6rem;
  letter-spacing: 0.16em;
  line-height: 2;
}
.text-xl {
  font-size: 2rem;
  letter-spacing: 0.15em;
  line-height: 1.75;
}
@media screen and (min-width: 768px) {
  .text-xl {
    line-height: 1.85;
  }
}
.text-lg {
  font-size: 1.8rem;
  line-height: 1.95;
}
@media screen and (min-width: 768px) {
  .text-lg {
    line-height: 1.85;
  }
}
.text-sm {
  font-size: 1.4rem;
  letter-spacing: 0.1em;
}
.text-xs {
  font-size: 1.2rem;
}
.text-center {
  text-align: center;
}
.text-white {
  color: #fff;
}
.text-yellow {
  color: #ffe600;
}
.text-red {
  color: #753945;
}
.text + .text {
  margin-top: 1rem;
}

/* ------------------------------
* title
------------------------------ */
.title {
  margin-bottom: 5rem;
  font-size: 3.5rem;
  text-align: center;
}

/* ------------------------------
* project
------------------------------ */
/* ------------------------------
* beautiful
------------------------------ */
.beautiful {
  position: relative;
  padding: 8rem 0 10rem;
}
@media screen and (min-width: 768px) {
  .beautiful {
    padding: 14.8rem 0 14.1rem;
  }
}
.beautiful-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -10;
}
.beautiful-bg img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
}
.beautiful-head {
  margin: 0 auto 4.5rem;
}
@media screen and (min-width: 768px) {
  .beautiful-head {
    margin-bottom: 7.6rem;
    width: 85.3rem;
    translate: -0.5rem 0;
  }
}
.beautiful-head img {
  width: 100%;
}
.beautiful-block {
  position: relative;
  background-color: #fffffa;
  max-width: 130.5rem;
  border-radius: 8rem 8rem 0 0;
  padding: 6rem 6% 8rem;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .beautiful-block {
    border-radius: 25rem 25rem 0 0;
    padding: 12rem 7.5% 20.6rem;
  }
}
@media screen and (min-width: 1280px) {
  .beautiful-block {
    border-radius: 35rem 35rem 0 0;
    padding: 12rem 11.5% 20.6rem;
  }
}
.beautiful-badge {
  position: absolute;
  top: -3.5rem;
  right: -1.1%;
  width: 11rem;
}
@media screen and (min-width: 768px) {
  .beautiful-badge {
    width: 22rem;
    top: -4.5rem;
    right: 1%;
  }
}
@media screen and (min-width: 1024px) {
  .beautiful-badge {
    top: -2.5rem;
    right: 12.9%;
  }
}
.beautiful-badge img {
  width: 100%;
}
.beautiful-title {
  position: relative;
  padding-top: 6rem;
  margin: 0px auto 4rem;
}
@media screen and (min-width: 768px) {
  .beautiful-title {
    padding-top: 7.6rem;
    width: 39rem;
    margin-bottom: 10.4rem;
  }
}
.beautiful-title::before {
  position: absolute;
  top: 0;
  left: 50%;
  width: 7.9rem;
  height: 4.5rem;
  background: url(./images/crown_red.svg) no-repeat;
  background-size: 100% auto;
  translate: -50% 0;
  content: "";
}
@media screen and (min-width: 768px) {
  .beautiful-title::before {
    width: 7.9rem;
    height: 4.5rem;
  }
}
.beautiful-title img {
  width: auto;
  height: 2.2rem;
  margin: 0 auto;
  max-width: none;
}
@media screen and (min-width: 768px) {
  .beautiful-title img {
    height: auto;
    max-width: 100%;
  }
}
.beautiful-list {
  position: relative;
}
.beautiful-line {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 27.1rem;
  translate: -52% -71.5%;
  z-index: 0;
}
@media screen and (min-width: 768px) {
  .beautiful-line {
    translate: -60% -62.5%;
  }
}
@media screen and (min-width: 1024px) {
  .beautiful-line {
    width: 78.4%;
    translate: -62% -57.5%;
  }
}
.beautiful-line img {
  width: 100%;
}
.beautiful-item {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 2rem 0;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .beautiful-item {
    gap: 3rem 0;
  }
}
@media screen and (min-width: 1024px) {
  .beautiful-item {
    flex-direction: row;
    gap: 0 3.3%;
  }
}
@media screen and (min-width: 768px) {
  .beautiful-item:nth-child(2n+1) {
    margin-left: 5%;
  }
}
@media screen and (min-width: 1024px) {
  .beautiful-item:nth-child(2n+1) {
    margin-left: 10%;
  }
}
@media screen and (min-width: 768px) {
  .beautiful-item:nth-child(2n) {
    margin-right: 9.3%;
  }
}
@media screen and (min-width: 1024px) {
  .beautiful-item:nth-child(2n) {
    flex-direction: row-reverse;
    margin-right: 8.3%;
  }
}
@media screen and (min-width: 1280px) {
  .beautiful-item:nth-child(2n) {
    translate: -4.6% 0;
  }
}
.beautiful-item + .beautiful-item {
  margin-top: 8rem;
}
@media screen and (min-width: 1024px) {
  .beautiful-item + .beautiful-item {
    margin-top: 11.1rem;
  }
}
.beautiful-pic {
  position: relative;
  z-index: 0;
}
@media screen and (min-width: 768px) {
  .beautiful-pic {
    width: clamp(30rem, 40.692%, 36rem);
    border-radius: 0 5rem 0 5rem;
  }
}
.beautiful-item:nth-child(2) .beautiful-pic {
  margin-left: auto;
}
@media screen and (min-width: 1024px) {
  .beautiful-item:nth-child(2) .beautiful-pic {
    margin-left: 0;
  }
}
.beautiful-thumb {
  width: 55%;
}
@media screen and (min-width: 768px) {
  .beautiful-thumb {
    width: 100%;
  }
}
.beautiful-item:nth-child(1) .beautiful-thumb {
  margin-left: 3.5rem;
}
@media screen and (min-width: 768px) {
  .beautiful-item:nth-child(1) .beautiful-thumb {
    margin-left: 0;
  }
}
.beautiful-item:nth-child(2) .beautiful-thumb {
  margin-left: auto;
  margin-right: 5.8rem;
}
@media screen and (min-width: 768px) {
  .beautiful-item:nth-child(2) .beautiful-thumb {
    margin-right: auto;
  }
}
.beautiful-thumb img {
  width: 100%;
  border-radius: 0 5rem 0 5rem;
}
.beautiful-icon {
  position: absolute;
  top: 0.1rem;
  color: #aa2633;
  writing-mode: vertical-rl;
  font-size: 1.8rem;
  letter-spacing: 0.12em;
  line-height: 1.3;
  white-space: nowrap;
}
@media screen and (min-width: 768px) {
  .beautiful-icon {
    font-size: 2.5rem;
  }
}
.beautiful-item:nth-child(1) .beautiful-icon {
  left: 0;
}
@media screen and (min-width: 768px) {
  .beautiful-item:nth-child(1) .beautiful-icon {
    left: -5.6rem;
  }
}
.beautiful-item:nth-child(2) .beautiful-icon {
  right: 0;
}
@media screen and (min-width: 768px) {
  .beautiful-item:nth-child(2) .beautiful-icon {
    left: calc(100% + 2rem);
    right: auto;
  }
}
.beautiful-icon-indent {
  display: block;
  margin-top: 5.4rem;
}
.beautiful-subList {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .beautiful-subList {
    flex: 1;
  }
}
@media screen and (min-width: 768px) and (min-width: 1024px) {
  .beautiful-item:nth-child(1) .beautiful-subList {
    margin-top: 7.1rem;
  }
}
@media screen and (min-width: 768px) and (min-width: 1024px) {
  .beautiful-item:nth-child(2) .beautiful-subList {
    margin-top: 16.9rem;
  }
}
.beautiful-subItem {
  color: #753945;
  font-size: 1.6rem;
  letter-spacing: 0.16em;
  line-height: 1.85;
}
@media screen and (min-width: 768px) {
  .beautiful-subItem {
    font-size: 1.8rem;
    line-height: 1.6;
  }
}
.beautiful-subItem + .beautiful-subItem {
  margin-top: 2rem;
}
.beautiful-subItem-note {
  display: flex;
  align-items: flex-start;
}
.beautiful-subItem-note::before {
  content: attr(data-text);
}
.beautiful-butterfly {
  position: absolute;
  z-index: 1;
}
.beautiful-butterfly-01 {
  top: -3.1rem;
  left: 11.7%;
  width: 5.4rem;
}
@media screen and (min-width: 768px) {
  .beautiful-butterfly-01 {
    top: -7.1rem;
    left: 11.7%;
    width: 13.4rem;
  }
}
.beautiful-butterfly-02 {
  top: 1rem;
  left: 11%;
  width: 2.2rem;
}
@media screen and (min-width: 768px) {
  .beautiful-butterfly-02 {
    top: 4.5rem;
    left: 13%;
    width: 10rem;
  }
}
.beautiful-butterfly-03 {
  top: 2.7rem;
  left: 5.35%;
  width: 3.4rem;
}
@media screen and (min-width: 768px) {
  .beautiful-butterfly-03 {
    top: 7.2rem;
    left: 8.35%;
    width: 8.2rem;
  }
}
.beautiful-butterfly-04 {
  bottom: 0.4rem;
  left: 2.3%;
  width: 5.7rem;
}
@media screen and (min-width: 768px) {
  .beautiful-butterfly-04 {
    bottom: -2.6rem;
    left: -25.7%;
    width: 13.2rem;
  }
}
@media screen and (min-width: 1024px) {
  .beautiful-butterfly-04 {
    bottom: -2.6rem;
    left: -25.7%;
    width: 13.2rem;
  }
}
.beautiful-butterfly-05 {
  bottom: -1.1rem;
  left: 15.7%;
  width: 2.1rem;
}
@media screen and (min-width: 768px) {
  .beautiful-butterfly-05 {
    bottom: -7.1rem;
    left: -9.3%;
    width: 5.1rem;
    opacity: 0.3;
  }
}
@media screen and (min-width: 1024px) {
  .beautiful-butterfly-05 {
    left: -1.3%;
    opacity: 1;
  }
}
.beautiful-butterfly-06 {
  bottom: -2.2rem;
  right: 10.6%;
  width: 6rem;
}
@media screen and (min-width: 768px) {
  .beautiful-butterfly-06 {
    bottom: -6.7rem;
    right: -40.4%;
    width: 19.3rem;
  }
}
@media screen and (min-width: 1024px) {
  .beautiful-butterfly-06 {
    bottom: -8.7rem;
  }
}
.beautiful-butterfly-07 {
  bottom: -3.7rem;
  right: 26.3%;
  width: 3.3rem;
  opacity: 0.3;
}
@media screen and (min-width: 768px) {
  .beautiful-butterfly-07 {
    bottom: -10.9rem;
    right: -4.7%;
    width: 8.7rem;
  }
}
@media screen and (min-width: 1024px) {
  .beautiful-butterfly-07 {
    opacity: 1;
  }
}

/* ------------------------------
* cause
------------------------------ */
.cause {
  position: relative;
  padding: 8rem 0 10rem;
}
@media screen and (min-width: 768px) {
  .cause {
    padding: 11.6rem 0 13.2rem;
  }
}
@media screen and (min-width: 1630px) {
  .cause {
    padding: 11.6rem 0 13.2rem;
  }
}
.cause-bg {
  position: absolute;
  bottom: 0;
  left: 0%;
  width: 100%;
  height: calc(100% + 23rem);
  translate: -26% 0;
  height: calc(100% + 27rem);
  z-index: -10;
}
@media screen and (min-width: 768px) {
  .cause-bg {
    height: calc(100% + 27rem);
    translate: none;
  }
}
@media screen and (min-width: 1630px) {
  .cause-bg {
    height: calc(100% + 16.6vw);
  }
}
.cause-bg img {
  position: absolute;
  max-width: none;
  width: auto;
  min-width: 100%;
  height: 100%;
  top: 0;
}
@media screen and (min-width: 1630px) {
  .cause-bg img {
    width: 100%;
    height: auto;
  }
}
.cause-text {
  position: relative;
  margin-bottom: 3rem;
  color: #492720;
  font-size: 1.8rem;
  text-align: center;
  letter-spacing: 0.12em;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .cause-text {
    margin-bottom: 3.1rem;
    font-size: 2rem;
  }
}
.cause-catch {
  position: relative;
  width: 30rem;
  margin: 0 auto 3rem;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .cause-catch {
    width: 56.8rem;
    left: -0.8rem;
    margin-bottom: 7.8rem;
  }
}
.cause-catch img {
  width: 100%;
}
.cause-note {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 0.3rem;
  width: 100vw;
  left: 50%;
  margin-bottom: 1.6rem;
  color: #492720;
  font-size: 1.8rem;
  text-align: center;
  letter-spacing: 0.13em;
  z-index: 1;
  translate: -50% 0;
  white-space: nowrap;
}
@media screen and (min-width: 768px) {
  .cause-note {
    margin-bottom: 1.6rem;
    font-size: 2rem;
  }
}
.cause-note::before, .cause-note::after {
  display: block;
  width: 5.5rem;
  height: 1px;
  margin-top: 0.2rem;
  background-color: #aa6152;
  content: "";
}
@media screen and (min-width: 768px) {
  .cause-note::before, .cause-note::after {
    width: 3.4rem;
    margin-top: 0;
  }
}
.cause-note::before {
  rotate: -290deg;
}
@media screen and (min-width: 768px) {
  .cause-note::before {
    rotate: -299.788deg;
  }
}
.cause-note::after {
  rotate: 290deg;
}
@media screen and (min-width: 768px) {
  .cause-note::after {
    rotate: 299.788deg;
  }
}
.cause-btn {
  display: block;
  position: relative;
  width: 34rem;
  height: 10rem;
  border-radius: 6rem;
  border: none;
  padding: 0;
  margin: 0 auto;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .cause-btn {
    width: 55rem;
    height: 12rem;
  }
}
.cause-btn a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  border-radius: 6rem;
  background: linear-gradient(to right, #bf4ea5, #a6193f, #bf4ea5);
  background-size: 200% 100%;
  background-position: 100% 0;
  padding-top: 0.5rem;
  overflow: hidden;
  transition: background-position 0.3s ease-in-out;
}
.cause-btn a:hover {
  background-position: 0% 0;
}
.cause-btn a img {
  width: 20rem;
}
@media screen and (min-width: 768px) {
  .cause-btn a img {
    width: 23.2rem;
  }
}
.cause-btn a::after {
  content: "";
  position: absolute;
  top: -100px;
  left: -100px;
  width: 50px;
  height: 50px;
  background-image: linear-gradient(100deg, rgba(255, 255, 255, 0) 10%, rgb(255, 255, 255) 100%, rgba(255, 255, 255, 0) 0%);
}
.cause-btn a:hover::after {
  animation-name: shiny;
  animation-duration: 0.6s;
  animation-timing-function: ease-in-out;
  animation-fill-mode: forwards;
}

@keyframes shiny {
  0% {
    transform: scale(0) rotate(25deg);
    opacity: 0;
  }
  20% {
    transform: scale(1) rotate(25deg);
    opacity: 1;
  }
  100% {
    transform: scale(50) rotate(25deg);
    opacity: 0;
  }
}
.cause-btn-butterfly {
  position: absolute;
  bottom: -2.8rem;
  right: 4.7%;
  width: 6.6rem;
  z-index: 1;
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  .cause-btn-butterfly {
    bottom: -3.5rem;
    right: 7.7%;
    width: 8.4rem;
    z-index: 1;
  }
}
.cause-butterfly {
  position: absolute;
  z-index: 0;
}
.cause-butterfly-01 {
  top: -9.1rem;
  right: -2%;
  width: 3.8rem;
}
@media screen and (min-width: 768px) {
  .cause-butterfly-01 {
    top: -10.1rem;
    right: 6%;
    width: 7.4rem;
  }
}
@media screen and (min-width: 1024px) {
  .cause-butterfly-01 {
    right: 11%;
  }
}
@media screen and (min-width: 1280px) {
  .cause-butterfly-01 {
    right: 16%;
  }
}
.cause-butterfly-02 {
  top: -0.7rem;
  right: 0.2%;
  width: 5.3rem;
}
@media screen and (min-width: 768px) {
  .cause-butterfly-02 {
    top: -3.7rem;
    right: 0.2%;
    width: 10.6rem;
  }
}
@media screen and (min-width: 1024px) {
  .cause-butterfly-02 {
    right: 5.2%;
  }
}
@media screen and (min-width: 1280px) {
  .cause-butterfly-02 {
    right: 10.2%;
  }
}
.cause-butterfly-03 {
  top: 5.2rem;
  right: 11.8%;
  width: 2.2rem;
  opacity: 0.56;
}
@media screen and (min-width: 768px) {
  .cause-butterfly-03 {
    top: 6.2rem;
    right: 16.8%;
    width: 4.7rem;
  }
}
@media screen and (min-width: 1024px) {
  .cause-butterfly-03 {
    right: 11.8%;
  }
}
@media screen and (min-width: 1280px) {
  .cause-butterfly-03 {
    right: 16.8%;
  }
}
.cause-butterfly-04 {
  top: 8.8rem;
  right: 2%;
  width: 1.6rem;
}
@media screen and (min-width: 768px) {
  .cause-butterfly-04 {
    top: 9.8rem;
    right: 2%;
    width: 4.2rem;
  }
}
@media screen and (min-width: 1024px) {
  .cause-butterfly-04 {
    right: 7%;
  }
}
@media screen and (min-width: 1280px) {
  .cause-butterfly-04 {
    right: 12%;
  }
}
.cause-butterfly-05 {
  top: 12.6rem;
  right: 8.1%;
  width: 3.2rem;
}
@media screen and (min-width: 768px) {
  .cause-butterfly-05 {
    top: 14.6rem;
    right: 4.1%;
    width: 7.5rem;
  }
}
@media screen and (min-width: 1024px) {
  .cause-butterfly-05 {
    right: 9.1%;
  }
}
@media screen and (min-width: 1280px) {
  .cause-butterfly-05 {
    right: 14.1%;
  }
}
.cause-butterfly-06 {
  top: 22.6rem;
  right: 11.6%;
  width: 1.4rem;
}
@media screen and (min-width: 768px) {
  .cause-butterfly-06 {
    top: 25.8rem;
    right: 1.6%;
    width: 6.4rem;
  }
}
@media screen and (min-width: 1024px) {
  .cause-butterfly-06 {
    right: 6.6%;
  }
}
@media screen and (min-width: 1280px) {
  .cause-butterfly-06 {
    right: 11.6%;
  }
}
.cause-butterfly-07 {
  top: 32.5rem;
  right: 2.2%;
  width: 4.2rem;
}
@media screen and (min-width: 768px) {
  .cause-butterfly-07 {
    top: 33.5rem;
    right: 4.2%;
    width: 12.5rem;
  }
}
@media screen and (min-width: 1024px) {
  .cause-butterfly-07 {
    right: 9.2%;
  }
}
@media screen and (min-width: 1280px) {
  .cause-butterfly-07 {
    right: 14.2%;
  }
}
.cause-butterfly-08 {
  top: 43.3rem;
  right: -1.96%;
  width: 2.6rem;
}
@media screen and (min-width: 768px) {
  .cause-butterfly-08 {
    top: 40.3rem;
    right: -4.96%;
    width: 13.3rem;
  }
}
@media screen and (min-width: 1024px) {
  .cause-butterfly-08 {
    right: 0.04%;
  }
}
@media screen and (min-width: 1280px) {
  .cause-butterfly-08 {
    right: 5.04%;
  }
}
.cause-butterfly-09 {
  top: 48.2rem;
  right: 10.84%;
  width: 2.5rem;
  opacity: 0.41;
}
@media screen and (min-width: 768px) {
  .cause-butterfly-09 {
    top: 51.5rem;
    right: 1.84%;
    width: 6.7rem;
  }
}
@media screen and (min-width: 1024px) {
  .cause-butterfly-09 {
    right: 6.84%;
  }
}
@media screen and (min-width: 1280px) {
  .cause-butterfly-09 {
    right: 11.84%;
  }
}
.cause-butterfly-10 {
  top: 56.7rem;
  right: 9.4%;
  width: 5.5rem;
}
@media screen and (min-width: 768px) {
  .cause-butterfly-10 {
    top: 62.7rem;
    right: 2.4%;
    width: 9.3rem;
  }
}
@media screen and (min-width: 1024px) {
  .cause-butterfly-10 {
    right: 7.4%;
  }
}
@media screen and (min-width: 1280px) {
  .cause-butterfly-10 {
    right: 12.4%;
  }
}

/* ------------------------------
* efficacy
------------------------------ */
.efficacy {
  position: relative;
  padding: 8rem 0 6rem;
}
@media screen and (min-width: 768px) {
  .efficacy {
    padding: 11.5rem 0 3.7rem;
  }
}
.efficacy-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -10;
}
.efficacy-bg img {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
}
.efficacy-sub {
  position: relative;
  padding-top: 6rem;
  margin-bottom: 3.5rem;
  color: #fff;
  font-size: 1.8rem;
  letter-spacing: 0.17em;
  text-align: center;
  line-height: 1.75;
}
@media screen and (min-width: 768px) {
  .efficacy-sub {
    padding-top: 6.8rem;
    margin-bottom: 3.4rem;
    font-size: 2rem;
    line-height: 1.9;
  }
}
.efficacy-sub::before {
  position: absolute;
  top: 0;
  left: 50%;
  width: 7.9rem;
  height: 4.5rem;
  background: url(./images/crown.svg) no-repeat;
  background-size: 100% auto;
  translate: -50% 0;
  content: "";
}
@media screen and (min-width: 768px) {
  .efficacy-sub::before {
    width: 7.9rem;
    height: 4.5rem;
  }
}
.efficacy-sub span {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 2rem;
}
@media screen and (min-width: 1280px) {
  .efficacy-sub span {
    gap: 0 5.6rem;
  }
}
.efficacy-sub span::before, .efficacy-sub span::after {
  display: block;
  flex: 1;
  height: 1px;
  background-color: rgba(255, 255, 255, 0.5);
  content: "";
}
@media screen and (min-width: 768px) {
  .efficacy-sub span::before, .efficacy-sub span::after {
    flex: none;
    width: 20rem;
  }
}
.efficacy-title {
  width: 33rem;
  margin: 0 auto 3.5rem;
}
@media screen and (min-width: 768px) {
  .efficacy-title {
    width: 97.4rem;
    margin-bottom: 2.6rem;
  }
}
.efficacy-title img {
  width: 100%;
}
.efficacy-list {
  display: flex;
  flex-direction: column;
  gap: 4rem 0;
  margin-top: 4rem;
  margin-bottom: 4rem;
}
@media screen and (min-width: 768px) {
  .efficacy-list {
    max-width: 93.4rem;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 6rem 3%;
    margin: 6.2rem auto 5.6rem;
  }
}
@media screen and (min-width: 1280px) {
  .efficacy-list {
    max-width: 138.6rem;
    gap: 0 1.3%;
  }
}
.efficacy-item {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 768px) {
  .efficacy-item {
    width: 48.5%;
  }
}
@media screen and (min-width: 1280px) {
  .efficacy-item {
    flex: 1;
  }
}
.efficacy-thumb {
  padding: 0.5rem;
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 0 3rem 0 3rem;
  margin-bottom: 1.3rem;
}
@media screen and (min-width: 768px) {
  .efficacy-thumb {
    margin-bottom: 2.4rem;
  }
}
.efficacy-thumb img {
  width: 100%;
  border-radius: 0 3rem 0 3rem;
}
.efficacy-name {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #4c3833;
  margin-bottom: 0.5rem;
  font-size: 2.2rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  translate: -1.4rem 0;
}
.efficacy-name-sm {
  font-size: 1.6rem;
  letter-spacing: 0.15em;
}
.efficacy-name-icon {
  position: relative;
  display: block;
  width: 2.3rem;
  height: 2.3rem;
  background: url(./images/dia.svg) no-repeat;
  background-size: 100% auto;
  margin-right: 0.8rem;
  content: "";
  clip-path: polygon(50% 0%, 57% 32%, 72% 41%, 100% 50%, 70% 58%, 67% 67%, 50% 100%, 37% 62%, 21% 58%, 0% 50%, 32% 39%, 33% 40%);
  overflow: hidden;
  rotate: -45deg;
  opacity: 0;
  transition: rotate 0.3s ease-in-out, opacity 0.3s ease-in-out;
}
.efficacy-name-icon.is-show {
  opacity: 1;
  rotate: 0deg;
}
.efficacy-name-icon::after {
  content: "";
  display: block;
  position: absolute;
  top: -100px;
  left: -100px;
  width: 50px;
  height: 50px;
  background-image: linear-gradient(100deg, rgba(255, 255, 255, 0) 10%, rgb(255, 255, 255) 100%, rgba(255, 255, 255, 0) 0%);
}
.efficacy-name-icon.is-show::after {
  animation-name: shiny;
  animation-duration: 0.6s;
  animation-timing-function: ease-in-out;
  animation-fill-mode: forwards;
}

@keyframes shiny {
  0% {
    transform: scale(0) rotate(25deg);
    opacity: 0;
  }
  20% {
    transform: scale(1) rotate(25deg);
    opacity: 1;
  }
  100% {
    transform: scale(50) rotate(25deg);
    opacity: 0;
  }
}
.efficacy-subList {
  flex: 1;
  width: 100%;
  background-color: rgba(255, 255, 255, 0.31);
  border-radius: 2.2rem;
  padding: 2rem 5%;
}
@media screen and (min-width: 768px) {
  .efficacy-subList {
    padding: 2.6rem 6.7% 3rem;
  }
}
.efficacy-subItem {
  display: flex;
  align-items: flex-start;
  gap: 0 0.3rem;
  color: #4c3833;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
}
@media screen and (min-width: 768px) {
  .efficacy-subItem {
    gap: 0;
  }
}
.efficacy-subItem::before {
  content: attr(data-text);
}
.efficacy-after {
  color: #4c3833;
  font-size: 1.6rem;
  letter-spacing: 0.16em;
  font-weight: 600;
  line-height: 1.75;
  text-align: center;
  z-index: 1;
}
.efficacy-after span {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem 0;
}
.efficacy-after span::before, .efficacy-after span::after {
  position: relative;
  display: block;
  width: 2.3rem;
  height: 2.3rem;
  background: url(./images/dia.svg) no-repeat;
  background-size: 100% auto;
  content: "";
}
.efficacy-after span::before {
  margin-right: 1.5rem;
}
.efficacy-after span::after {
  margin-left: 0.2rem;
}
.efficacy-butterfly {
  z-index: 1;
}
.efficacy-butterfly-01 {
  margin-right: auto;
  margin-left: auto;
  width: 8.5rem;
  margin-bottom: 1.5rem;
}
@media screen and (min-width: 768px) {
  .efficacy-butterfly-01 {
    translate: 19% 0;
  }
}

/* ------------------------------
* hero
------------------------------ */
.hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  position: relative;
  height: 100vh;
  height: 100dvh;
  padding: 10rem 5% 5.5%;
}
@media screen and (min-width: 768px) {
  .hero {
    min-height: 70rem;
  }
}
.hero-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -10;
}
.hero-pic {
  position: absolute;
  width: 100%;
  height: 100%;
}
.hero-pic img {
  position: absolute;
  width: 100%;
  height: 100%;
}
.hero-title {
  width: 37.4rem;
  max-width: 107%;
}
@media screen and (min-width: 768px) {
  .hero-title {
    width: clamp(10rem, 100%, 89.1rem);
    margin-bottom: -3.7rem;
  }
}
.hero-title img {
  width: 100%;
}
.hero-list {
  max-width: 35rem;
  width: 100%;
  display: flex;
  justify-content: center;
  gap: 0 5%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .hero-list {
    max-width: none;
    gap: 0 2.9%;
  }
}
.hero-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  flex: 1;
}
@media screen and (min-width: 768px) {
  .hero-item {
    flex: none;
    width: 20rem;
  }
}
.hero-icon {
  width: 70%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .hero-icon {
    width: 100%;
  }
}
.hero-icon img {
  width: 100%;
}
.hero-label {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 3rem;
  background-color: #aa2633;
  border-radius: 1.5rem;
  color: #fff;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  font-weight: 300;
}
@media screen and (min-width: 768px) {
  .hero-label {
    width: 18.5rem;
  }
}

/* ------------------------------
* info
------------------------------ */
.info {
  position: relative;
  padding: 8rem 0 6rem;
  z-index: 0;
}
@media screen and (min-width: 768px) {
  .info {
    padding: 19.8rem 0 20.6rem;
  }
}
.info-bg {
  position: absolute;
  top: -25rem;
  left: 0;
  width: 100%;
  height: 135.6rem;
  height: 91%;
  z-index: -10;
}
@media screen and (min-width: 640px) {
  .info-bg {
    height: 94%;
  }
}
@media screen and (min-width: 768px) {
  .info-bg {
    height: 91%;
  }
}
@media screen and (min-width: 1024px) {
  .info-bg {
    top: auto;
    bottom: 28.5%;
  }
}
@media screen and (min-width: 1536px) {
  .info-bg {
    height: 83.7vw;
  }
}
.info-bg img {
  position: absolute;
  min-width: 100%;
  width: auto;
  max-width: none;
  height: 100%;
  top: 0;
  left: 50%;
  translate: -20% 0;
}
@media screen and (min-width: 768px) {
  .info-bg img {
    translate: -30% 0;
  }
}
@media screen and (min-width: 1024px) {
  .info-bg img {
    translate: -61% 0;
  }
}
@media screen and (min-width: 1280px) {
  .info-bg img {
    translate: -50% 0;
  }
}
@media screen and (min-width: 768px) {
  .info-container {
    max-width: 130.3rem;
    margin: 0 auto;
  }
}
.info-block {
  display: flex;
  flex-direction: column;
  gap: 3rem 0;
  margin-bottom: 3rem;
}
@media screen and (min-width: 768px) {
  .info-block {
    gap: 4rem 0;
  }
}
@media screen and (min-width: 1024px) {
  .info-block {
    flex-direction: row;
    align-items: flex-start;
    gap: 0 5%;
    margin-bottom: 8.9rem;
  }
}
.info-box {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .info-box {
    flex: 1;
  }
}
.info-catch {
  margin-bottom: 4rem;
  overflow: visible;
}
@media screen and (min-width: 768px) {
  .info-catch {
    width: 51rem;
    margin-bottom: 4.6rem;
  }
}
.info-catch img {
  width: auto;
  height: 4.4rem;
  max-width: none;
}
@media screen and (min-width: 768px) {
  .info-catch img {
    width: 100%;
    height: auto;
  }
}
.info-text {
  font-size: 1.4rem;
  letter-spacing: 0.15em;
  line-height: 2;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .info-text {
    font-size: 1.6rem;
    letter-spacing: 0.12em;
    line-height: 1.75;
  }
}
.info-text + .info-text {
  margin-top: 2.7rem;
}
.info-thumb {
  width: 100%;
  margin: 0 auto;
}
@media screen and (min-width: 1024px) {
  .info-thumb {
    width: 37.5%;
    opacity: 0;
  }
}
.info-thumb img {
  width: 100%;
}
.info-thumb-sp {
  margin-bottom: 2rem;
}
@media screen and (min-width: 1024px) {
  .info-thumb-sp {
    display: none;
  }
}
.info-thumb-sp img {
  width: 100%;
}
.info-after {
  background-color: #913657;
  border-radius: 3rem;
  padding: 3rem 6% 4rem;
}
@media screen and (min-width: 768px) {
  .info-after {
    border-radius: 5.8rem;
    padding: 3.5rem 3% 4.2rem 6.4%;
  }
}
.info-lead {
  color: #fff;
  margin-bottom: 2rem;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .info-lead {
    margin-bottom: 2.8rem;
    font-size: 2rem;
  }
}
@media screen and (min-width: 1024px) {
  .info-lead {
    text-align: left;
  }
}
.info-list {
  margin: 0;
}
.info-item {
  position: relative;
  display: flex;
  gap: 0 0.8rem;
  padding-left: 0.4em;
  color: #fff;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  line-height: 1.75;
}
@media screen and (min-width: 768px) {
  .info-item {
    font-size: 1.6rem;
    padding-left: 1em;
    line-height: 1.8;
  }
}
.info-item + .info-item {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .info-item + .info-item {
    margin-top: 0.2rem;
  }
}
.info-item:before {
  position: absolute;
  top: 0;
  left: -0.54em;
  content: "・";
}
.info-item-year {
  flex: none;
  letter-spacing: 0.1em;
}
.info-item-text {
  letter-spacing: 0.15em;
}

/* ------------------------------
* offer
------------------------------ */
.offer {
  position: relative;
  padding: 6rem 0 10rem;
}
@media screen and (min-width: 768px) {
  .offer {
    padding: 13.4rem 0 21.5rem;
  }
}
.offer-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -10;
}
.offer-bg img {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
}
.offer-sub {
  position: relative;
  padding-top: 6rem;
  color: #753945;
  font-size: 1.8rem;
  letter-spacing: 0.17em;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .offer-sub {
    padding-top: 6.6rem;
    margin-bottom: 2.8rem;
    font-size: 2rem;
  }
}
.offer-sub::before {
  position: absolute;
  top: 0;
  left: 50%;
  width: 7.9rem;
  height: 4.5rem;
  background: url(./images/crown.svg) no-repeat;
  background-size: 100% auto;
  translate: -50% 0;
  content: "";
}
@media screen and (min-width: 768px) {
  .offer-sub::before {
    width: 7.9rem;
    height: 4.5rem;
  }
}
.offer-container {
  position: relative;
}
.offer-title {
  width: 40rem;
  margin: 0 auto 8rem;
}
@media screen and (min-width: 768px) {
  .offer-title {
    width: 68.6rem;
    margin-bottom: 11.1rem;
  }
}
.offer-title img {
  width: 100%;
}
.offer-item {
  display: flex;
  flex-direction: column-reverse;
  gap: 5rem 0;
}
@media screen and (min-width: 768px) {
  .offer-item {
    flex-direction: row;
    gap: 0 8%;
  }
}
@media screen and (min-width: 1280px) {
  .offer-item {
    gap: 0 15%;
  }
}
.offer-item + .offer-item {
  margin-top: 12rem;
}
@media screen and (min-width: 768px) {
  .offer-item + .offer-item {
    margin-top: 17.1rem;
  }
}
@media screen and (min-width: 768px) {
  .offer-item:nth-child(2n) {
    flex-direction: row-reverse;
  }
}
.offer-box {
  flex: 1;
  margin-top: -1.1rem;
}
.offer-name {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem 0;
  margin-bottom: 2rem;
}
@media screen and (min-width: 768px) {
  .offer-name {
    gap: 1.5rem 0;
    align-items: flex-start;
  }
}
@media screen and (min-width: 1024px) {
  .offer-name {
    flex-direction: row;
    align-items: center;
    gap: 0 2.7rem;
    margin-top: 1.7rem;
    margin-bottom: 4.1rem;
  }
}
.offer-name-lg {
  width: auto;
  height: 2.74rem;
}
.offer-name-sm {
  width: auto;
  height: 1.33rem;
}
.offer-name-sp {
  display: flex;
}
@media screen and (min-width: 768px) {
  .offer-name-sp {
    display: none;
  }
}
.offer-name-pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .offer-name-pc {
    display: flex;
  }
}
.offer-text {
  color: #753945;
  font-size: 1.6rem;
  letter-spacing: 0.145em;
  line-height: 1.9;
}
.offer-text + .offer-text {
  margin-top: 0.7rem;
}
.offer-description {
  color: #fff;
  font-size: 1.4rem;
  letter-spacing: 0.15em;
  line-height: 1.9;
}
.offer-description + .offer-description {
  margin-top: 0.7rem;
}
.offer-inner {
  background: #7f6d57;
  border-radius: 3.3rem;
  padding: 3rem 6%;
  margin-top: 3rem;
}
@media screen and (min-width: 768px) {
  .offer-inner {
    padding: 2.3rem 7.1% 2.9rem;
    margin-top: 2.9rem;
  }
}
.offer-lead {
  position: relative;
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  padding: 0 0 0.6rem 2.8rem;
  margin-bottom: 1.8rem;
  border-bottom: 1px solid #fff;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .offer-lead {
    padding-left: 4.7rem;
  }
}
.offer-lead::before {
  position: absolute;
  top: 0.5rem;
  left: 0.1rem;
  display: block;
  width: 2.3rem;
  height: 2.3rem;
  background: url(./images/dia.svg) no-repeat;
  background-size: 100% auto;
  content: "";
}
@media screen and (min-width: 768px) {
  .offer-lead::before {
    top: 1.1rem;
    left: 1.1rem;
  }
}
.offer-lead-lg {
  order: 1;
  font-size: 2.2rem;
  letter-spacing: 0.12em;
  line-height: 1.2;
}
@media screen and (min-width: 768px) {
  .offer-lead-lg {
    font-size: 2.4rem;
    line-height: 1.9;
  }
}
.offer-lead-md {
  order: 2;
  font-size: 1.8rem;
  letter-spacing: 0.16em;
}
@media screen and (min-width: 1024px) {
  .offer-lead-md {
    order: 3;
  }
}
.offer-lead-sm {
  order: 3;
  width: 100%;
  margin-top: -0.4rem;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
}
@media screen and (min-width: 1024px) {
  .offer-lead-sm {
    order: 2;
    margin-top: 0;
    width: auto;
  }
}
.offer-note {
  margin-bottom: 1.5rem;
  color: #753945;
  font-size: 1.6rem;
  letter-spacing: 0.16em;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .offer-note {
    margin-bottom: 0;
    text-align: left;
    line-height: 2;
  }
}
.offer-note-pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .offer-note-pc {
    display: block;
  }
}
@media screen and (min-width: 768px) {
  .offer-note-sp {
    display: none;
  }
}
.offer-subList {
  margin-top: 1rem;
}
.offer-subItem {
  display: flex;
  align-items: flex-start;
  color: #fff;
  font-size: 1.4rem;
  letter-spacing: 0.16em;
}
.offer-subItem::before {
  content: attr(data-text);
}
@media screen and (min-width: 768px) {
  .offer-area {
    display: flex;
    flex-direction: column;
    width: 38rem;
    width: 34.546%;
  }
}
.offer-thumb {
  position: relative;
  width: 50%;
  margin: 0 auto 2rem;
}
@media screen and (min-width: 768px) {
  .offer-thumb {
    width: 100%;
  }
}
.offer-thumb img {
  width: 100%;
}
.offer-thumb::before {
  position: absolute;
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: 0 0;
  content: "";
  z-index: 1;
}
.offer-thumb-detox::before {
  top: -1.6rem;
  left: -3.8rem;
  width: 17.6rem;
  height: 6.5rem;
  background-image: url(./images/detox.svg);
}
.offer-thumb-relax::before {
  top: -2rem;
  right: -1rem;
  width: 15.1rem;
  height: 8.2rem;
  background-image: url(./images/relax.svg);
}
.offer-label {
  margin-top: auto;
  color: #753945;
  font-size: 1.6rem;
  letter-spacing: 0.16em;
  text-align: center;
}
.offer-price {
  color: #753945;
  margin-top: -0.7rem;
  margin-bottom: -1.5rem;
  font-size: 1.6rem;
  text-align: center;
  letter-spacing: 0.1em;
}
.offer-price-lg {
  margin-right: 0.1rem;
  font-size: 3rem;
  font-weight: 300;
  letter-spacing: 0.11em;
}
.offer-price-red {
  color: #aa2633;
}
.offer-butterfly {
  position: absolute;
  z-index: 1;
}
.offer-butterfly-01 {
  top: -3.3rem;
  left: 50%;
  width: 8.5rem;
  translate: -43% 0;
}
.offer-butterfly-02 {
  top: -0.6rem;
  left: 50%;
  width: 7.6rem;
  translate: 162% 0;
}
@media screen and (min-width: 768px) {
  .offer-butterfly-02 {
    top: 2.4rem;
    width: 9.6rem;
    translate: 311% 0;
  }
}

/* ------------------------------
* policy
------------------------------ */
.policy {
  position: relative;
  padding: 8rem 0 6rem;
  background-color: #fffffa;
}
@media screen and (min-width: 768px) {
  .policy {
    padding-bottom: 10rem;
  }
}
.policy-catch {
  margin: 0px auto 4rem;
}
@media screen and (min-width: 768px) {
  .policy-catch {
    width: 33.6rem;
    margin-bottom: 6.1rem;
  }
}
.policy-catch img {
  width: auto;
  height: 2.2rem;
  margin: 0 auto;
  max-width: none;
}
@media screen and (min-width: 768px) {
  .policy-catch img {
    width: 100%;
    height: auto;
  }
}
.policy-block {
  display: flex;
  flex-direction: column;
  gap: 5rem 0;
}
@media screen and (min-width: 1024px) {
  .policy-block {
    flex-direction: row;
    align-items: flex-start;
    gap: 0 6%;
    max-width: 120rem;
    margin: 0 auto;
  }
}
.policy-table {
  flex: 1;
}
.policy-table-row {
  display: flex;
  padding: 1.7rem 2.7%;
  flex-direction: column;
  gap: 1rem;
  border-top: 1px solid rgba(150, 110, 119, 0.5);
}
@media screen and (min-width: 768px) {
  .policy-table-row {
    flex-direction: row;
    gap: 2rem;
  }
}
.policy-table-row:last-child {
  border-bottom: 1px solid rgba(150, 110, 119, 0.5);
}
.policy-table-name {
  width: 14rem;
  color: #753945;
  font-size: 1.4rem;
  letter-spacing: 0.15em;
}
.policy-table-data {
  flex: 1;
  color: #753945;
  font-size: 1.4rem;
  letter-spacing: 0.17em;
}
.policy-list {
  margin-top: -0.7rem;
}
@media screen and (min-width: 1024px) {
  .policy-list {
    width: 45.9%;
  }
}
.policy-item {
  position: relative;
  padding-left: 1.8rem;
  color: #753945;
}
.policy-item + .policy-item {
  margin-top: 3rem;
}
.policy-item::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "■";
  font-size: 1.6rem;
}
.policy-lead {
  margin-bottom: 1.2rem;
  font-size: 1.6rem;
  letter-spacing: 0.15em;
  line-height: 1.75;
}
@media screen and (min-width: 768px) {
  .policy-lead {
    margin-bottom: 1.7rem;
    line-height: 1.9;
  }
}
.policy-text {
  font-size: 1.4rem;
  letter-spacing: 0.15em;
  line-height: 1.81;
}
.policy-text-sm {
  display: block;
  font-size: 1.3rem;
  letter-spacing: 0.15em;
}
.policy-text-note {
  display: flex;
  align-items: flex-start;
}
.policy-text-note:before {
  flex: none;
  content: attr(data-text);
}
.policy-text-note > * {
  flex: 1;
}
.policy-text + .policy-text {
  margin-top: 1.9rem;
}

/* ------------------------------
* product
------------------------------ */
.product {
  position: relative;
  padding: 8rem 0;
}
@media screen and (min-width: 768px) {
  .product {
    padding: 8.7rem 0 10rem;
  }
}
.product-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -10;
}
.product-bg img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
}
.product-sub {
  position: relative;
  padding-top: 6rem;
  color: #fff;
  font-size: 1.8rem;
  letter-spacing: 0.17em;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .product-sub {
    padding-top: 6.8rem;
    margin-bottom: -2.2rem;
    font-size: 2rem;
  }
}
.product-sub::before {
  position: absolute;
  top: 0;
  left: 50%;
  width: 7.9rem;
  height: 4.5rem;
  background: url(./images/crown.svg) no-repeat;
  background-size: 100% auto;
  translate: -50% 0;
  content: "";
}
@media screen and (min-width: 768px) {
  .product-sub::before {
    width: 7.9rem;
    height: 4.5rem;
  }
}
.product-title {
  width: 40rem;
  margin: 0 auto 2rem;
}
@media screen and (min-width: 768px) {
  .product-title {
    width: 78.3rem;
    margin-bottom: 2rem;
  }
}
.product-title img {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .product-description {
    text-align: center;
  }
}
.product-list {
  display: flex;
  flex-direction: column;
  gap: 6rem 0;
  margin-top: 4rem;
}
@media screen and (min-width: 768px) {
  .product-list {
    max-width: 89.2rem;
    flex-direction: row;
    gap: 0 7.3%;
    margin: 5.8rem auto 0;
  }
}
@media screen and (min-width: 768px) {
  .product-item {
    flex: 1;
  }
}
.product-thumb {
  padding: 0.5rem;
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 0 3rem 0 3rem;
  margin-bottom: 2rem;
}
@media screen and (min-width: 768px) {
  .product-thumb {
    margin-bottom: 2.6rem;
  }
}
.product-thumb img {
  width: 100%;
  border-radius: 0 3rem 0 3rem;
}
.product-text {
  letter-spacing: 0.2em;
  margin-bottom: 1.4rem;
}
.product-name {
  margin-bottom: 0.5rem;
}
.product-name img {
  width: auto;
  height: 2.55rem;
  margin: 0 auto;
}
.product-price {
  font-size: 2.8rem;
  font-weight: 600;
  color: #ff7687;
}
@media screen and (min-width: 768px) {
  .product-price {
    margin-left: 0.5rem;
    font-size: 2.4rem;
  }
}

/* ------------------------------
* voice
------------------------------ */
.voice {
  position: relative;
  padding: 8rem 0 10rem;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .voice {
    padding: 11.9rem 0 19.3rem;
  }
}
.voice::before, .voice::after {
  position: absolute;
  z-index: 0;
  background: url(./images/voice_bg.svg) no-repeat;
  width: 55vw;
  height: 55vw;
  content: "";
}
@media screen and (min-width: 768px) {
  .voice::before, .voice::after {
    width: 40.8vw;
    height: 40.8vw;
  }
}
.voice::before {
  top: 8.4rem;
  left: -9%;
}
@media screen and (min-width: 768px) {
  .voice::before {
    top: 6.8%;
    left: 2%;
  }
}
.voice::after {
  bottom: 2.4rem;
  right: -9%;
}
@media screen and (min-width: 768px) {
  .voice::after {
    bottom: 2.6%;
    right: -1.4%;
  }
}
.voice-bg {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -10;
  overflow: hidden;
}
.voice-bg img {
  position: absolute;
  width: 100%;
  bottom: 0;
}
.voice-bg::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom, #853657 90%, transparent 90%);
  content: "";
  z-index: -20;
}
@media screen and (min-width: 768px) {
  .voice-bg::before {
    background: linear-gradient(to bottom, #853657 80%, transparent 80%);
  }
}
@media screen and (min-width: 1024px) {
  .voice-bg::before {
    background: linear-gradient(to bottom, #853657 50%, transparent 50%);
  }
}
.voice-title {
  position: relative;
  width: 80%;
  padding-top: 6rem;
  margin: 0px auto 4rem;
}
@media screen and (min-width: 768px) {
  .voice-title {
    width: 16.7rem;
    margin: 0px auto 7.6rem;
  }
}
.voice-title::before {
  position: absolute;
  top: 0;
  left: 50%;
  width: 7.9rem;
  height: 4.5rem;
  background: url(./images/crown_white.svg) no-repeat;
  background-size: 100% auto;
  translate: -50% 0;
  content: "";
}
@media screen and (min-width: 768px) {
  .voice-title::before {
    width: 7.9rem;
    height: 4.5rem;
  }
}
.voice-title img {
  width: auto;
  height: 2.2rem;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .voice-title img {
    height: auto;
  }
}
.voice-list {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 3rem 4%;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .voice-list {
    gap: 7.4rem 4%;
    max-width: 111.8rem;
    margin: 0 auto;
  }
}
.voice-item {
  position: relative;
  width: 100%;
  border: 1px solid #fffffa;
  border-radius: 0 5rem 0 5rem;
  padding: 0.5rem;
}
@media screen and (min-width: 768px) {
  .voice-item {
    width: 47.8%;
  }
}
@media screen and (min-width: 768px) {
  .voice-item:nth-child(2n) {
    top: 4rem;
  }
}
.voice-inner {
  position: relative;
  height: 100%;
  background-color: #fffffa;
  border-radius: 0 5rem 0 5rem;
  padding: 3rem 6% 5rem;
}
@media screen and (min-width: 768px) {
  .voice-inner {
    padding: 4.4rem 10% 5.9rem;
  }
}
.voice-name {
  margin-bottom: 2rem;
  color: #966e77;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 768px) {
  .voice-name {
    margin-bottom: 4.3rem;
  }
}
.voice-lead {
  margin-bottom: 1.4rem;
  color: #753945;
  font-size: 1.8rem;
  letter-spacing: 0.14em;
}
.voice-text {
  color: #966e77;
  font-size: 1.4rem;
  letter-spacing: 0.15em;
  line-height: 2;
}
.voice-butterfly {
  position: absolute;
  z-index: 1;
}
.voice-butterfly-01 {
  top: -3.5rem;
  right: -2.9%;
  width: 9rem;
}
@media screen and (min-width: 1024px) {
  .voice-butterfly-01 {
    top: -3.5rem;
    right: -2.9%;
    width: 15rem;
  }
}
.voice-butterfly-02 {
  top: 3.5rem;
  right: 11.5%;
  width: 3.4rem;
}
@media screen and (min-width: 1024px) {
  .voice-butterfly-02 {
    top: 5.5rem;
    right: 19.5%;
    width: 6.4rem;
  }
}
.voice-butterfly-03 {
  top: 0.8rem;
  right: 14.9%;
  width: 5.5rem;
}
@media screen and (min-width: 1024px) {
  .voice-butterfly-03 {
    top: -4.2rem;
    right: 18.9%;
    width: 8.5rem;
  }
}
.voice-butterfly-04 {
  top: 4.4rem;
  right: -5.4%;
  width: 10.2rem;
}
@media screen and (min-width: 1024px) {
  .voice-butterfly-04 {
    top: -2.6rem;
    right: -8.4%;
    width: 18.2rem;
  }
}
.voice-butterfly-05 {
  top: -1.4rem;
  right: 4.2%;
  width: 6.4rem;
}
@media screen and (min-width: 1024px) {
  .voice-butterfly-05 {
    top: -3.4rem;
    right: -1.8%;
    width: 12.4rem;
  }
}
.voice-butterfly-06 {
  top: 3.9rem;
  right: 13.9%;
  width: 6.5rem;
}
@media screen and (min-width: 1024px) {
  .voice-butterfly-06 {
    top: 3.9rem;
    right: 13.9%;
    width: 9.5rem;
  }
}
.voice-butterfly-07 {
  top: -3.5rem;
  right: -2.9%;
  width: 9rem;
}
@media screen and (min-width: 1024px) {
  .voice-butterfly-07 {
    top: -6.2rem;
    right: -3.2%;
    width: 14.8rem;
  }
}
.voice-butterfly-08 {
  top: 3.5rem;
  right: 11.5%;
  width: 3.4rem;
}
@media screen and (min-width: 1024px) {
  .voice-butterfly-08 {
    top: 2.8rem;
    right: 19%;
    width: 6rem;
  }
}

/* ------------------------------
* utility
------------------------------ */
/* ------------------------------
* guide
------------------------------ */
.guide-outer, .guide-container, .guide-wrapper, .guide-inner {
  width: 90%;
  margin-right: auto;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .guide-outer, .guide-container, .guide-wrapper, .guide-inner {
    width: 94%;
  }
}
.guide-outer {
  max-width: 140rem;
}
.guide-container {
  max-width: 120rem;
}
.guide-wrapper {
  max-width: 110rem;
}
.guide-inner {
  max-width: 100rem;
}

/* ------------------------------
* sp
------------------------------ */
.sp-none {
  display: none !important;
}
@media screen and (min-width: 768px) {
  .sp-none {
    display: block !important;
  }
}
.sp-block {
  display: block;
}
@media screen and (min-width: 768px) {
  .sp-block {
    display: none !important;
  }
}
