@charset "UTF-8";
/* 共通スタイル */
/* ベーススタイル */
html {
  scroll-behavior: smooth;
  font-size: 62.5%;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
  color: #454343;
  font-feature-settings: "palt";
}
@media only screen and (max-width: 500px) {
  html {
    font-size: 2.6666666667vw;
  }
}

/* コンテンツ */
.wrap {
  position: relative;
  margin-inline: auto;
  padding-block: 2.7rem;
}
@media only screen and (max-width: 500px) {
  .wrap {
    padding-block: 0;
  }
}

.background {
  position: fixed;
  width: 100%;
  height: 100%;
  background-image: url("../img/background.webp");
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  z-index: -2;
}
@media only screen and (max-width: 500px) {
  .background {
    display: none;
  }
}

.main {
  max-width: 37.5rem;
  min-width: 37.5rem;
  box-shadow: 0.5rem 0.5rem 1rem rgba(0, 0, 0, 0.15);
  border-radius: 4rem;
  border: solid 0.4rem #fff;
  margin-inline: auto;
  overflow: hidden;
  z-index: 1;
  position: relative;
  background-color: #fff;
}
@media only screen and (max-width: 500px) {
  .main {
    max-width: 100%;
    border: 0;
    border-radius: 0;
    box-shadow: none;
  }
}

.keyVisual {
  width: 100%;
  aspect-ratio: 375/820;
  background: url("../img/keyVisual_background.webp") #F4E6E7;
  background-size: contain;
  background-repeat: no-repeat;
}

.keyVisual__title > img {
  max-width: 100%;
  margin-top: 4.1rem;
}

.keyVisual__image {
  margin-top: 1.2rem;
  max-width: 100%;
}

.keyVisual__text {
  margin-top: -6.8rem;
  max-width: 100%;
}

.keyVisual__button {
  position: relative;
  padding: 0 0.5rem 0.2rem 1rem;
  width: 100%;
  min-height: 4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10rem;
  box-shadow: 0.5rem 0.5rem 1rem rgba(139, 106, 109, 0.6);
  text-decoration: none;
  max-width: calc(100% - 3.2rem);
  margin-inline: auto;
  margin-top: 3.4rem;
}
.keyVisual__button::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: linear-gradient(to bottom right, #da4d4a, #f8b0af);
  border-radius: 10rem;
  z-index: 0;
}
.keyVisual__button::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: #ed6461;
  border-radius: 10rem;
  z-index: 1;
  margin: 0.4rem;
}
.keyVisual__button span {
  z-index: 2;
}
.keyVisual__button > span {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
  color: #fff;
  font-size: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  -moz-column-gap: 1.6rem;
       column-gap: 1.6rem;
  min-height: 6.4rem;
}
.keyVisual__button > span::after {
  content: "";
  display: inline-block;
  max-width: 1.8rem;
  min-width: 1.8rem;
  aspect-ratio: 18/5;
  background-image: url("../img/icon_arrow_white.svg");
  background-size: contain;
}

.about {
  padding: 4.8rem 2.2rem 7.2rem;
  background-image: url("../img/about_background.webp");
  background-position: top center;
  background-size: 64.9rem 116.4rem;
}

.about__title {
  max-width: 33.2rem;
  margin-inline: auto;
}
.about__title > img {
  display: block;
  width: 100%;
  height: auto;
}

.about__logo {
  margin-top: 4.4rem;
  max-width: 17.1rem;
  margin-inline: auto;
  display: block;
}

.about__text {
  text-align: center;
  font-size: 1.5rem;
  line-height: 1.8;
  margin-top: 4rem;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
}
.about__text + .about__text {
  margin-top: 2rem;
}

.about__mission {
  margin-top: 4rem;
}

.about__missionTitle {
  text-align: center;
  color: #aa6670;
  font-family: "Satoshi", sans-serif;
  font-size: 2.4rem;
  letter-spacing: 0.1em;
}

.about__missionContents {
  margin-top: 1.6rem;
  background-color: #fff;
  border-radius: 1rem;
  padding: 1rem 1rem 4rem;
}

.about__missionContentsPoint {
  font-family: "Satoshi", sans-serif;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: #8C8C8C;
}

.about__missionContentsText {
  margin-top: 1.4rem;
  text-align: center;
  color: #aa6670;
  font-size: 1.8rem;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
}

.treatmentAreas {
  background-image: url("../img/treatmentAreas_background.webp");
  background-position: top center;
  background-size: cover;
  padding: 4.8rem 2.2rem 5.7rem 2.2rem;
}

.treatmentAreas__title {
  max-width: 33.2rem;
  margin-inline: auto;
}
.treatmentAreas__title > img {
  display: block;
  width: 100%;
  height: auto;
}

.treatmentAreasWrap {
  margin-top: 4.1rem;
  position: relative;
  aspect-ratio: 322/467;
}

.treatmentAreas__list {
  width: 100%;
}
.treatmentAreas__list > li {
  position: absolute;
  width: 50.9%;
  max-width: 16.5rem;
}
.treatmentAreas__list > li:nth-child(1) {
  left: 0;
  top: 0;
}
.treatmentAreas__list > li:nth-child(2) {
  right: 0;
  top: min(4rem, 8.56%);
}
.treatmentAreas__list > li:nth-child(3) {
  left: 0;
  top: min(15.6rem, 33.4%);
}
.treatmentAreas__list > li:nth-child(4) {
  right: 0;
  top: min(19.6rem, 41.9%);
}
.treatmentAreas__list > li:nth-child(5) {
  left: 0;
  bottom: 0;
}

.treatmentAreas_note {
  position: absolute;
  right: 1.2rem;
  bottom: 2.8rem;
  text-align: center;
  font-size: 1.2rem;
  line-height: 1.7;
  font-feature-settings: normal;
}

.treatmentAreas__button {
  position: relative;
  padding: 0 0.5rem 0.2rem 1rem;
  width: 100%;
  min-height: 4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10rem;
  box-shadow: 0.5rem 0.5rem 1rem rgba(139, 106, 109, 0.6);
  margin-top: 1.6rem;
  text-decoration: none;
}
.treatmentAreas__button::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: linear-gradient(to bottom right, #da4d4a, #f8b0af);
  border-radius: 10rem;
  z-index: 0;
}
.treatmentAreas__button::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: #ed6461;
  border-radius: 10rem;
  z-index: 1;
  margin: 0.4rem;
}
.treatmentAreas__button span {
  z-index: 2;
}
.treatmentAreas__button > span {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
  color: #fff;
  font-size: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  -moz-column-gap: 1.6rem;
       column-gap: 1.6rem;
  min-height: 6.4rem;
}
.treatmentAreas__button > span::after {
  content: "";
  display: inline-block;
  max-width: 1.8rem;
  min-width: 1.8rem;
  aspect-ratio: 18/5;
  background-image: url("../img/icon_arrow_white.svg");
  background-size: contain;
}

.online {
  padding: 4.8rem 2.2rem 6.7rem;
  background-image: url("../img/online_background.webp");
  background-position: left top;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
}

.online__title {
  max-width: 33.2rem;
  margin-inline: auto;
}
.online__title > img {
  display: block;
  width: 100%;
  height: auto;
}

.onlineWrap {
  margin-top: 4.2rem;
  border-radius: 2rem;
  background: linear-gradient(to bottom, #dae8f9 0%, #ffffff 25%, #ffffff 68%, #f7dbcd 100%);
  padding: 1.4rem;
}

.online__partner {
  padding: 3.2rem 2.4rem;
  background-color: #fff;
  border-radius: 2rem;
  border: solid 0.4rem #e8eff6;
}

.online__partnerTitle,
.online__flowTitle,
.online__pointTitle {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
  font-size: 2.2rem;
  color: #aa6670;
  text-align: center;
}

.online__partnerImage {
  margin-top: 2.4rem;
}
.online__partnerImage > figcaption {
  display: flex;
  align-items: center;
  -moz-column-gap: 0.4rem;
       column-gap: 0.4rem;
  color: #aa6670;
  font-family: "Satoshi", sans-serif;
  letter-spacing: 0.1em;
  justify-content: center;
  margin-top: 1rem;
}
.online__partnerImage > figcaption::before, .online__partnerImage > figcaption::after {
  content: "";
  width: 0.8rem;
  aspect-ratio: 1/1;
  background-image: url("../img/icon_star_pink.svg");
  background-size: contain;
  background-repeat: no-repeat;
}

.online__partnerText {
  margin-top: 1rem;
  text-align: center;
  font-size: 1.3rem;
  line-height: 1.7;
}

.online__flow {
  margin-top: 4.6rem;
}

.online__flowList {
  margin-top: 2.4rem;
  counter-reset: flow-counter;
  position: relative;
}
.online__flowList::before {
  content: "";
  display: inline-block;
  left: 1.5rem;
  position: absolute;
  width: 0.3rem;
  height: 100%;
  background: linear-gradient(to bottom, rgba(215, 215, 215, 0) 0%, #d7d7d7 15%, #d7d7d7 84%, rgba(215, 215, 215, 0) 100%);
}

.onlineFlowListItem {
  z-index: 1;
  position: relative;
  display: grid;
  grid-template-columns: 4.4rem 1fr 13.6rem;
  align-items: center;
  counter-increment: flow-counter;
}
.onlineFlowListItem::before {
  content: counter(flow-counter, decimal-leading-zero);
  border-radius: 20rem;
  aspect-ratio: 1/1;
  width: 3.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Satoshi", sans-serif;
  letter-spacing: 0.1em;
  font-size: 1.3rem;
  margin-right: 1.2rem;
}
.onlineFlowListItem + .onlineFlowListItem {
  margin-top: 1.6rem;
}
.onlineFlowListItem:nth-child(3n+1)::before {
  background-color: #dbe9f9;
  color: #5d6671;
}
.onlineFlowListItem:nth-child(3n+2)::before {
  background-color: #e1f4ec;
  color: #65736d;
}
.onlineFlowListItem:nth-child(3n)::before {
  background-color: #f7dbcd;
  color: #915757;
}

.onlineFlowListItem__text {
  font-size: 1.6rem;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
}

.onlineFlowListItem__image {
  margin-left: 0.8rem;
}

.online__point {
  margin-top: 4.8rem;
}

.online__pointList {
  margin-top: 2.4rem;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.9rem 0.6rem;
}

.onlinePointListItem {
  background: linear-gradient(to bottom right, #f2eaea 0%, #fff 22%, #fff 45%, #f2eaea 81%, #fff 100%);
  border-radius: 1rem;
  overflow: hidden;
}

.onlinePointListItem__title {
  padding-inline: 1.2rem;
  height: 2.4rem;
  background-color: #aa6670;
  color: #fff;
  font-family: "Satoshi", sans-serif;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  display: flex;
  align-items: center;
}

.onlinePointListItem__text {
  padding: 2.4rem 1.2rem;
  font-size: 1.4rem;
  font-feature-settings: normal;
  line-height: 1.7;
}
.onlinePointListItem__text > strong {
  font-weight: normal;
  color: #aa6670;
}
.onlinePointListItem__text > span {
  font-feature-settings: "palt";
}

.online__image {
  position: absolute;
  bottom: 0;
  right: 0;
  max-width: 20.3rem;
}

.price {
  padding: 4.8rem 2.15rem 8rem;
  background-color: #f8ecec;
}

.price__title {
  max-width: 33.2rem;
  margin-inline: auto;
}
.price__title > img {
  display: block;
  width: 100%;
  height: auto;
}

.price__text {
  margin-top: 4.8rem;
  text-align: center;
  font-size: 1.2rem;
  line-height: 1.7;
}

.priceListItem--eyebrow {
  background: #fff url("../img/price_shadow.webp") no-repeat top center/cover;
  border-radius: 2rem;
  padding: 2.4rem 2.4rem 3.2rem 2.4rem;
  position: relative;
  margin-top: 2.4rem;
}
.priceListItem--eyebrow::before {
  content: "";
  display: inline-block;
  position: absolute;
  width: 8rem;
  aspect-ratio: 1/1;
  top: 2rem;
  right: 2rem;
  background-image: url("../img/price_eyebrow.webp");
  background-size: contain;
  background-repeat: no-repeat;
}
.priceListItem--eyebrow:nth-child(3n+1) .priceListItem__category {
  background-color: #dbe9f9;
  color: #5d6671;
}
.priceListItem--eyebrow:nth-child(3n+2) .priceListItem__category {
  background-color: #e1f4ec;
  color: #65736d;
}
.priceListItem--eyebrow:nth-child(3n) .priceListItem__category {
  background-color: #f7dbcd;
  color: #915757;
}
.priceListItem--lip {
  background: #fff url("../img/price_shadow.webp") no-repeat top center/cover;
  border-radius: 2rem;
  padding: 2.4rem 2.4rem 3.2rem 2.4rem;
  position: relative;
  margin-top: 2.4rem;
}
.priceListItem--lip::before {
  content: "";
  display: inline-block;
  position: absolute;
  width: 8rem;
  aspect-ratio: 1/1;
  top: 2rem;
  right: 2rem;
  background-image: url("../img/price_lip.webp");
  background-size: contain;
  background-repeat: no-repeat;
}
.priceListItem--lip:nth-child(3n+1) .priceListItem__category {
  background-color: #dbe9f9;
  color: #5d6671;
}
.priceListItem--lip:nth-child(3n+2) .priceListItem__category {
  background-color: #e1f4ec;
  color: #65736d;
}
.priceListItem--lip:nth-child(3n) .priceListItem__category {
  background-color: #f7dbcd;
  color: #915757;
}
.priceListItem--eyelinerSimple {
  background: #fff url("../img/price_shadow.webp") no-repeat top center/cover;
  border-radius: 2rem;
  padding: 2.4rem 2.4rem 3.2rem 2.4rem;
  position: relative;
  margin-top: 2.4rem;
}
.priceListItem--eyelinerSimple::before {
  content: "";
  display: inline-block;
  position: absolute;
  width: 8rem;
  aspect-ratio: 1/1;
  top: 2rem;
  right: 2rem;
  background-image: url("../img/price_eyelinerSimple.webp");
  background-size: contain;
  background-repeat: no-repeat;
}
.priceListItem--eyelinerSimple:nth-child(3n+1) .priceListItem__category {
  background-color: #dbe9f9;
  color: #5d6671;
}
.priceListItem--eyelinerSimple:nth-child(3n+2) .priceListItem__category {
  background-color: #e1f4ec;
  color: #65736d;
}
.priceListItem--eyelinerSimple:nth-child(3n) .priceListItem__category {
  background-color: #f7dbcd;
  color: #915757;
}
.priceListItem--eyelinerDesign {
  background: #fff url("../img/price_shadow.webp") no-repeat top center/cover;
  border-radius: 2rem;
  padding: 2.4rem 2.4rem 3.2rem 2.4rem;
  position: relative;
  margin-top: 2.4rem;
}
.priceListItem--eyelinerDesign::before {
  content: "";
  display: inline-block;
  position: absolute;
  width: 8rem;
  aspect-ratio: 1/1;
  top: 2rem;
  right: 2rem;
  background-image: url("../img/price_eyelinerDesign.webp");
  background-size: contain;
  background-repeat: no-repeat;
}
.priceListItem--eyelinerDesign:nth-child(3n+1) .priceListItem__category {
  background-color: #dbe9f9;
  color: #5d6671;
}
.priceListItem--eyelinerDesign:nth-child(3n+2) .priceListItem__category {
  background-color: #e1f4ec;
  color: #65736d;
}
.priceListItem--eyelinerDesign:nth-child(3n) .priceListItem__category {
  background-color: #f7dbcd;
  color: #915757;
}
.priceListItem--eyeliner {
  background: #fff url("../img/price_shadow.webp") no-repeat top center/cover;
  border-radius: 2rem;
  padding: 2.4rem 2.4rem 3.2rem 2.4rem;
  position: relative;
  margin-top: 2.4rem;
}
.priceListItem--eyeliner::before {
  content: "";
  display: inline-block;
  position: absolute;
  width: 8rem;
  aspect-ratio: 1/1;
  top: 2rem;
  right: 2rem;
  background-image: url("../img/price_eyeliner.webp");
  background-size: contain;
  background-repeat: no-repeat;
}
.priceListItem--eyeliner:nth-child(3n+1) .priceListItem__category {
  background-color: #dbe9f9;
  color: #5d6671;
}
.priceListItem--eyeliner:nth-child(3n+2) .priceListItem__category {
  background-color: #e1f4ec;
  color: #65736d;
}
.priceListItem--eyeliner:nth-child(3n) .priceListItem__category {
  background-color: #f7dbcd;
  color: #915757;
}
.priceListItem--mark {
  background: #fff url("../img/price_shadow.webp") no-repeat top center/cover;
  border-radius: 2rem;
  padding: 2.4rem 2.4rem 3.2rem 2.4rem;
  position: relative;
  margin-top: 2.4rem;
}
.priceListItem--mark::before {
  content: "";
  display: inline-block;
  position: absolute;
  width: 8rem;
  aspect-ratio: 1/1;
  top: 2rem;
  right: 2rem;
  background-image: url("../img/price_mark.webp");
  background-size: contain;
  background-repeat: no-repeat;
}
.priceListItem--mark:nth-child(3n+1) .priceListItem__category {
  background-color: #dbe9f9;
  color: #5d6671;
}
.priceListItem--mark:nth-child(3n+2) .priceListItem__category {
  background-color: #e1f4ec;
  color: #65736d;
}
.priceListItem--mark:nth-child(3n) .priceListItem__category {
  background-color: #f7dbcd;
  color: #915757;
}

.priceListItem__category {
  font-family: "Satoshi", sans-serif;
  font-size: 1rem;
  letter-spacing: 0.1em;
  border-radius: 4rem;
  min-height: 1.8rem;
  padding: 0.4rem 1rem;
  display: inline-block;
  line-height: 1;
}

.priceListItem__title {
  font-size: 2.8rem;
  color: #aa6670;
  margin-top: 3.2rem;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
  line-height: 1;
}
.priceListItem__title > span {
  font-size: 2rem;
}

.priceListItem__menu {
  margin-top: 3.2rem;
}

.priceListItem__menuWrap {
  border-bottom: solid 0.1rem rgba(188, 147, 153, 0.2);
  padding-block: 1.75rem;
  display: flex;
  justify-content: space-between;
  color: #aa6670;
  flex-wrap: wrap;
}
.priceListItem__menuWrap dt {
  display: flex;
  align-items: center;
  -moz-column-gap: 0.4rem;
       column-gap: 0.4rem;
  font-size: 1.6rem;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
}
.priceListItem__menuWrap dt::before {
  content: "";
  width: 1.3rem;
  aspect-ratio: 1/1;
  background-image: url("../img/icon_star_pink.svg");
  background-size: contain;
  background-repeat: no-repeat;
  display: inline-block;
}
.priceListItem__menuWrap dd {
  font-family: "Satoshi", sans-serif;
  display: flex;
  align-items: center;
  -moz-column-gap: 0.2rem;
       column-gap: 0.2rem;
  font-size: 2.2rem;
}
.priceListItem__menuWrap dd > span {
  font-size: 1.4rem;
}

.note {
  padding-block: 4rem;
}

.noteList {
  border-bottom: solid 0.1rem rgba(188, 147, 153, 0.2);
  padding: 0 1.6rem;
}
.noteList[open] .noteList__title::after {
  background-image: url("../img/icon_minus_pink.svg");
}
.noteList[open] .noteList__title::before {
  content: "とじる";
}

.noteList__title {
  cursor: pointer;
  padding-block: 2rem;
  color: #aa6670;
  display: grid;
  grid-template-columns: 1fr auto 2.8rem;
  grid-row: auto;
  align-items: center;
}
.noteList__title::-webkit-details-marker {
  display: none;
}
.noteList__title > span {
  font-size: 2.4rem;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
  grid-column: 1/2;
  grid-row: 1/2;
  margin-right: 1.6rem;
}
.noteList__title::before {
  content: "開く";
  font-size: 1.2rem;
  text-decoration: underline;
  grid-column: 2/3;
  grid-row: 1/2;
  margin-right: 0.8rem;
}
.noteList__title::after {
  content: "";
  aspect-ratio: 1/1;
  width: 100%;
  background-image: url("../img/icon_plus_pink.svg");
  background-size: contain;
  background-repeat: no-repeat;
  grid-column: 3/4;
  grid-row: 1/2;
}

.noteList__detail {
  margin-top: 0.4rem;
  padding-bottom: 2rem;
}

.noteList__detailNg {
  padding-inline: 0.8rem;
}
.noteList__detailNg > li {
  font-size: 1.4rem;
  font-feature-settings: normal;
  line-height: 1.7;
  display: grid;
  -moz-column-gap: 0.8rem;
       column-gap: 0.8rem;
  align-items: flex-start;
}
.noteList__detailNg > li + li {
  margin-top: 0.8rem;
}
.noteList__detailNg > li {
  grid-template-columns: 2.4rem 1fr;
}
.noteList__detailNg > li::before {
  content: "";
  display: block;
  aspect-ratio: 1/1;
  width: 100%;
  background-image: url("../img/icon_ng_pink.svg");
  background-size: contain;
  background-repeat: no-repeat;
  grid-column: 1/2;
  grid-row: 1/10;
}
.noteList__detailNg > li small {
  margin-top: 0.8rem;
  font-size: 1.2rem;
}

.noteList__detailDefault {
  padding-inline: 0.8rem;
}
.noteList__detailDefault > li {
  font-size: 1.4rem;
  font-feature-settings: normal;
  line-height: 1.7;
  display: grid;
  -moz-column-gap: 0.8rem;
       column-gap: 0.8rem;
  align-items: flex-start;
}
.noteList__detailDefault > li + li {
  margin-top: 0.8rem;
}
.noteList__detailDefault > li {
  grid-template-columns: 0.5rem 1fr;
}
.noteList__detailDefault > li::before {
  content: "";
  display: block;
  aspect-ratio: 1/1;
  width: 100%;
  background-color: #b9c8d9;
  border-radius: 30rem;
  grid-column: 1/2;
  grid-row: 1/10;
  margin-top: 1rem;
}

.faq {
  padding-top: 4.8rem;
}

.faq__title {
  max-width: 27.9rem;
  margin-inline: auto;
}
.faq__title > img {
  display: block;
  width: 100%;
  height: auto;
}

.faq__list {
  background: linear-gradient(to bottom, rgb(255, 255, 255) 0%, rgb(248, 234, 234) 4.9rem);
  padding: 2.4rem 2.2rem 8rem;
  margin-top: 4.8rem;
}

.faqListItem {
  background-color: #fff;
  border-radius: 1.6rem;
}
.faqListItem[open] .faqListItem__question::after {
  background-image: url("../img/icon_minus_pink.svg");
}
.faqListItem + .faqListItem {
  margin-top: 0.8rem;
}

.faqListItem__question {
  padding: 1.6rem;
  cursor: pointer;
  display: grid;
  grid-template-columns: 1fr 2.8rem;
  -moz-column-gap: 0.8rem;
       column-gap: 0.8rem;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
  font-size: 1.8rem;
  color: #aa6670;
  align-items: flex-start;
  line-height: 1.4;
}
.faqListItem__question::-webkit-details-marker {
  display: none;
}
.faqListItem__question::after {
  content: "";
  aspect-ratio: 1/1;
  width: 100%;
  background-image: url("../img/icon_plus_pink.svg");
  background-size: contain;
  background-repeat: no-repeat;
}
.faqListItem__question > span {
  display: grid;
  grid-template-columns: 4.5rem 1fr;
  align-items: center;
  -moz-column-gap: 0.8rem;
       column-gap: 0.8rem;
}
.faqListItem__question > span::before {
  content: "Q";
  font-family: "Satoshi", sans-serif;
  font-size: 1.6rem;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-inline: 1.6rem;
  background-color: #aa6670;
  border-radius: 4rem;
  height: 2.2rem;
}

.faqListItem__answer {
  padding-bottom: 1.6rem;
  padding-inline: 1.6rem;
  display: grid;
  grid-template-columns: 4.5rem 1fr;
  -moz-column-gap: 0.8rem;
       column-gap: 0.8rem;
  font-size: 1.4rem;
  font-feature-settings: normal;
  line-height: 1.7;
  align-items: flex-start;
}
.faqListItem__answer::before {
  content: "A";
  font-family: "Satoshi", sans-serif;
  font-size: 1.6rem;
  color: #65736d;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-inline: 1.6rem;
  background-color: #e1f4ec;
  border-radius: 4rem;
  height: 2.2rem;
}

.area {
  background: radial-gradient(circle, #fff 85%, #fff4e1 100%);
  padding-block: 5.3rem 4.8rem;
  padding-inline: 2.2rem;
}

.area__title {
  max-width: 19.2rem;
  margin-inline: auto;
}
.area__title > img {
  display: block;
  width: 100%;
  height: auto;
}

.area__image {
  margin-top: 4.2rem;
}

.area__list,
.area__artist {
  background-color: #fbf2f3;
  border-radius: 1.6rem;
  padding: 2.4rem;
}
.area__list + .area__list,
.area__list + .area__artist,
.area__artist + .area__list,
.area__artist + .area__artist {
  margin-top: 1rem;
}

.area__listTitle,
.area__artistTitle {
  text-align: center;
  font-size: 2rem;
  color: #aa6670;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
}

.area__listText {
  margin-top: 0.8rem;
  text-align: center;
  font-size: 1.4rem;
  font-feature-settings: normal;
  line-height: 1.7;
}

.area__artistText {
  border: solid 0.1rem #aa6670;
  border-radius: 0.5rem;
  padding-block: 1.6rem;
  background-color: #fff;
  position: relative;
  margin-top: 2.4rem;
  font-size: 1.5rem;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
  text-align: center;
}
.area__artistText::after {
  position: absolute;
  bottom: -0.7rem;
  left: 50%;
  transform: translateX(-50%);
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0.7rem 0.6rem 0 0.6rem;
  border-color: #aa6670 transparent transparent transparent;
}

.area__artistList {
  margin-top: 2.4rem;
}

.areaArtistListItem + .areaArtistListItem {
  margin-top: 3.2rem;
}

.areaArtistListItem__human {
  display: grid;
  grid-template-columns: 13.2rem 1fr;
  align-items: center;
  -moz-column-gap: 1.6rem;
       column-gap: 1.6rem;
}

.areaArtistListItem__humanNameTitle {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
  font-size: 1.8rem;
}

.areaArtistListItem__humanNameDetail {
  margin-top: 0.4rem;
  font-size: 1.2rem;
  font-family: "Satoshi", sans-serif;
  color: #aa6670;
  letter-spacing: 0.1em;
}

.areaArtistListItem__area {
  margin-top: 1.6rem;
  border-left: 0.1rem rgba(188, 147, 153, 0.2) solid;
  padding-left: 1.2rem;
}
.areaArtistListItem__area dt {
  font-size: 1.4rem;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
}
.areaArtistListItem__area dd {
  margin-top: 0.3rem;
  font-size: 1.4rem;
  font-feature-settings: normal;
  line-height: 1.7;
}

.areaArtistListItem__menu {
  margin-top: 1.6rem;
  border-left: 0.1rem rgba(188, 147, 153, 0.2) solid;
  padding-left: 1.2rem;
}

.areaArtistListItem__menuTitle {
  font-size: 1.4rem;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
}

.areaArtistListItem__menuList {
  margin-top: 0.6rem;
  display: grid;
  row-gap: 0.6rem;
}

.areaArtistListItem__menuRow {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  -moz-column-gap: 1.2rem;
       column-gap: 1.2rem;
  color: #aa6670;
}

.areaArtistListItem__menuLabel {
  font-size: 1.4rem;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
}

.areaArtistListItem__menuPrice {
  font-family: "Satoshi", sans-serif;
  font-size: 1.6rem;
  display: inline-flex;
  align-items: baseline;
  -moz-column-gap: 0.2rem;
       column-gap: 0.2rem;
}
.areaArtistListItem__menuPrice > span {
  font-size: 1.2rem;
}

.areaArtistListItem__button {
  display: inline-block;
  margin-top: 1.6rem;
  position: relative;
  padding: 0 0.5rem 0.2rem 1rem;
  width: 100%;
  min-height: 4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10rem;
  box-shadow: 0.5rem 0.5rem 1rem rgba(139, 106, 109, 0.6);
  text-decoration: none;
}
.areaArtistListItem__button::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: linear-gradient(to bottom right, #da4d4a, #f8b0af);
  border-radius: 10rem;
  z-index: 0;
}
.areaArtistListItem__button::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: #ed6461;
  border-radius: 10rem;
  z-index: 1;
  margin: 0.4rem;
}
.areaArtistListItem__button span {
  z-index: 2;
}
.areaArtistListItem__button > span {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
  color: #fff;
  font-size: 1.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  -moz-column-gap: 1.6rem;
       column-gap: 1.6rem;
  min-height: 5.6rem;
}
.areaArtistListItem__button > span::before {
  content: "";
  display: inline-block;
  max-width: 2.2rem;
  min-width: 2.2rem;
  aspect-ratio: 1/1;
  background-image: url("../img/icon_Instagram.svg");
  background-size: contain;
}
.areaArtistListItem__button > span::after {
  content: "";
  display: inline-block;
  max-width: 1.8rem;
  min-width: 1.8rem;
  aspect-ratio: 18/5;
  background-image: url("../img/icon_arrow_white.svg");
  background-size: contain;
}

.recruit {
  background-color: #fff4e1;
  padding: 3.3rem 2.2rem 8rem;
}

.recruitWrap {
  border-radius: 2rem;
  background-color: #fff;
  padding-block: 3.5rem 4rem;
  background-image: url("../img/recruit_background.webp");
  background-position: top center;
  background-size: 100%;
  background-repeat: no-repeat;
}

.recruit__title {
  display: flex;
  -moz-column-gap: 0.4rem;
       column-gap: 0.4rem;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
  width: calc(100% + 4.4rem);
  margin-left: -2.2rem;
  padding-left: 4.7rem;
  align-items: center;
}

.recruit__titleWrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #aa6670;
  font-size: 2.22rem;
}

.recruit__titleSub {
  font-size: 1.78rem;
}

.recruit__titlePoint {
  color: #fff;
  border-radius: 30rem 0 0 30rem;
  font-size: 3.8rem;
  padding: 0 5.7rem 0.3rem 2.4rem;
  line-height: 1.5;
  background: linear-gradient(to right, rgb(170, 102, 112) 19%, rgba(170, 102, 112, 0) 100%);
}

.recruit__image {
  margin-top: 1rem;
  min-width: calc(100% + 4.4rem);
  margin-left: -2.2rem;
}

.recruit__text {
  text-align: center;
  margin-top: 1.6rem;
  font-size: 1.6rem;
  line-height: 1.8;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
}

.recruit__button {
  position: relative;
  padding: 0 0.5rem 0.2rem 1rem;
  width: 100%;
  min-height: 4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10rem;
  box-shadow: 0.5rem 0.5rem 1rem rgba(139, 106, 109, 0.6);
  text-decoration: none;
  max-width: calc(100% - 3.2rem);
  margin-inline: auto;
  margin-top: 2.4rem;
}
.recruit__button::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: linear-gradient(to bottom right, #da4d4a, #f8b0af);
  border-radius: 10rem;
  z-index: 0;
}
.recruit__button::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: #ed6461;
  border-radius: 10rem;
  z-index: 1;
  margin: 0.4rem;
}
.recruit__button span {
  z-index: 2;
}
.recruit__button > span {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
  color: #fff;
  font-size: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  -moz-column-gap: 1.6rem;
       column-gap: 1.6rem;
  min-height: 6.4rem;
}
.recruit__button > span::after {
  content: "";
  display: inline-block;
  max-width: 1.8rem;
  min-width: 1.8rem;
  aspect-ratio: 18/5;
  background-image: url("../img/icon_arrow_white.svg");
  background-size: contain;
}

.footer {
  background-color: #aa6670;
  padding: 2.8rem 1.6rem;
  color: #fff;
  font-family: "Satoshi", sans-serif;
  font-size: 1.3rem;
  text-align: center;
}

/* サイドメニュー */
.aside {
  max-width: 131.3rem;
  width: 100%;
  padding-inline: 1.6rem;
  margin-inline: auto;
  margin-right: 0;
  display: flex;
  justify-content: space-between;
  position: fixed;
  align-items: center;
  left: 50%;
  transform: translateX(-50%);
  top: 0;
  height: 100vh;
}
@media only screen and (max-width: 1110px) {
  .aside {
    display: none;
  }
}
@media only screen and (max-height: 730px) {
  .aside {
    align-items: flex-start;
    overflow-y: scroll;
    -ms-overflow-style: none;
    scrollbar-width: none;
    padding-block: 2.7rem;
  }
  .aside::-webkit-scrollbar {
    display: none;
  }
}
.aside::before {
  content: "";
  max-width: 29.2rem;
  width: 22.8%;
  aspect-ratio: 292/330;
  background-image: url("../img/logo_square.webp");
  background-size: contain;
  background-repeat: no-repeat;
  display: inline-block;
}

.aside__contents {
  width: 32.8rem;
  margin-left: 3.6rem;
  z-index: 0;
}

.aside__contentsMenu {
  background-color: #fff;
  border-radius: 4rem;
  padding: 4rem;
}

.asideContentsMenuList > a {
  display: grid;
  grid-template-columns: 1fr 1.8rem;
  align-items: center;
  text-decoration: none;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
}
.asideContentsMenuList > a::after {
  content: "";
  display: inline-block;
  max-width: 1.8rem;
  min-width: 1.8rem;
  aspect-ratio: 18/5;
  background-image: url("../img/icon_arrow_pink.svg");
  background-size: contain;
}
.asideContentsMenuList:first-child .asideContentsMenuList__title {
  letter-spacing: -0.15em;
}
.asideContentsMenuList + .asideContentsMenuList {
  margin-top: 3rem;
}

.asideContentsMenuList__title {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
  font-size: 2rem;
}

.asideContentsMenuList__sub {
  font-family: "Satoshi", sans-serif;
  color: #aa6670;
  font-size: 1rem;
  letter-spacing: 0.1em;
  margin-top: 0.8rem;
}

.aside__button {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.05em;
  margin-top: 4.2rem;
  border: rgba(188, 147, 153, 0.2) solid 0.2rem;
  border-radius: 4rem;
  display: flex;
  align-items: center;
  text-decoration: none;
  background-color: #fff1f0;
  justify-content: space-between;
}
.aside__button::before {
  content: "";
  display: inline-block;
  max-width: 134px;
  width: 40%;
  aspect-ratio: 134/145;
  background-image: url("../img/cta_hospital.webp");
  background-size: contain;
}

.aside__buttonWrap {
  padding: 2.8rem 2.6rem 2.8rem 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  row-gap: 0.6rem;
  width: max(16.5rem, 60%);
}

.aside__buttonText {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  row-gap: 0.3rem;
  color: #aa6670;
}

.aside__buttonTextSub {
  font-size: 1.7rem;
  line-height: 1.3;
}

.aside__buttonTextMark,
.recruit__titleMark,
.recruit__titlePointMark {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
}

.aside__buttonTextDetails {
  font-size: 1.1rem;
}

.aside__buttonTextMain {
  font-size: 2rem;
  line-height: 1.3;
}

.aside__buttonPoint {
  position: relative;
  padding: 0 0.5rem 0.2rem 1rem;
  width: 100%;
  min-height: 4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10rem;
}
.aside__buttonPoint::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: linear-gradient(to bottom right, #da4d4a, #f8b0af);
  border-radius: 10rem;
  z-index: 0;
}
.aside__buttonPoint::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: #ed6461;
  border-radius: 10rem;
  z-index: 1;
  margin: 0.2rem;
}
.aside__buttonPoint span {
  z-index: 2;
}
.aside__buttonPoint > span {
  color: #fff;
  font-size: 1.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  -moz-column-gap: 0.4rem;
       column-gap: 0.4rem;
}
.aside__buttonPoint > span::after {
  content: "";
  display: inline-block;
  max-width: 1.8rem;
  min-width: 1.8rem;
  aspect-ratio: 18/5;
  background-image: url("../img/icon_arrow_white.svg");
  background-size: contain;
}/*# sourceMappingURL=top.css.map */
