/* =======================================　実績表示＆ニュースティッカー =======================================　*/
#index_achievements_and_news {
  background-color: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(10px);
  border-radius: 20px;
  margin: 0 auto;
  max-width: 1000px;
  padding: 40px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
  margin-top: -40px;
  position: relative;
  z-index: 10;
}

#index_achievements {
  text-align: center;
  margin-bottom: 32px;
}

#index_achievements .headline {
  font-size: 18px;
  font-weight: 600;
  color: #333333;
  margin-bottom: 16px;
  font-family: "Zen Kaku Gothic New", sans-serif;
}

#index_achievements .num_area {
  display: flex;
  align-items: baseline;
  justify-content: center;
  margin-bottom: 12px;
}

#index_achievements .num {
  font-size: 48px;
  font-weight: 700;
  color: #ff6b9d;
  font-family: "Zen Kaku Gothic New", sans-serif;
  line-height: 1;
}

#index_achievements .unit {
  font-size: 24px;
  font-weight: 600;
  color: #ff6b9d;
  margin-left: 8px;
  font-family: "Zen Kaku Gothic New", sans-serif;
}

#index_achievements .desc {
  font-size: 16px;
  color: #666666;
  line-height: 1.6;
  margin: 0;
  font-family: "Zen Kaku Gothic New", sans-serif;
}

#news_ticker {
  border-top: 1px solid #e0e0e0;
  padding-top: 0;
}

#news_ticker .news_item {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 20px;
  background-color: #ffffff;
  border-radius: 12px;
  border-left: 4px solid #ff6b9d;
  transition: all 0.3s ease;
}

#news_ticker .news_item:hover {
  background-color: #fafafa;
  transform: translateX(4px);
}

#news_ticker .date {
  font-size: 14px;
  color: #888888;
  font-weight: 500;
  min-width: 80px;
  font-family: "Zen Kaku Gothic New", sans-serif;
}

#news_ticker .title {
  color: #333333;
  text-decoration: none;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
  flex: 1;
  font-family: "Zen Kaku Gothic New", sans-serif;
  transition: color 0.3s ease;
}

#news_ticker .title:hover {
  color: #ff6b9d;
  text-decoration: none;
}

/* スマートフォン対応 */
@media screen and (max-width: 768px) {
  #index_achievements_and_news {
    margin: 0 16px;
    margin-top: -20px;
    padding: 24px 20px;
    border-radius: 16px;
  }

  #index_achievements {
    margin-bottom: 24px;
  }

  #index_achievements .headline {
    font-size: 16px;
    margin-bottom: 12px;
  }

  #index_achievements .num {
    font-size: 36px;
  }

  #index_achievements .unit {
    font-size: 18px;
    margin-left: 6px;
  }

  #index_achievements .desc {
    font-size: 14px;
  }

  #news_ticker {
    padding-top: 0;
  }

  #news_ticker .news_item {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding: 16px;
  }

  #news_ticker .date {
    font-size: 12px;
    min-width: auto;
  }

  #news_ticker .title {
    font-size: 14px;
  }
}

/* タブレット対応 */
@media screen and (min-width: 769px) and (max-width: 1024px) {
  #index_achievements_and_news {
    margin: 0 24px;
    margin-top: -30px;
    padding: 32px;
  }

  #index_achievements .num {
    font-size: 42px;
  }

  #index_achievements .unit {
    font-size: 20px;
  }
}

/* =======================================　サービス紹介 =======================================　*/
.service-introduction,
.service-introduction * {
  font-family: "Zen Kaku Gothic New";
}

.service-introduction {
  position: relative;
  background-color: #ffffff;
  padding-top: 129px;
  z-index: 1;
}

.service-introduction::before {
  content: "";
  position: absolute;
  bottom: calc(100vw / 1440 * 100 * -1 + 1px);
  left: 0;
  width: 100%;
  height: auto;
  background-image: url("../img/renewal/aboutus-service-introduction-background-bottom-pc-large.png");
  background-size: cover;
  background-repeat: no-repeat;
  aspect-ratio: 1440/100;
  z-index: 2;
}

.service-introduction-inner {
  position: relative;
  max-width: 1176px;
  width: 100%;
  height: 476px;
  margin: 0 auto;
  padding-left: 18px;
}

.service-introduction-content {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.service-introduction-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  color: #333333;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .service-introduction-heading {
  animation: fadeInUp 1s ease forwards;
}

.service-introduction-text {
  font-size: 18px;
  font-weight: 500;
  line-height: 200%;
  color: #333333;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .service-introduction-text {
  animation: fadeInUp 1s ease forwards 0.5s;
}

.service-introduction-doctor-image-pc {
  position: absolute;
  top: -17px;
  right: 18px;
  width: 541.13px;
  height: 458px;
}

.service-introduction-doctor-image-pc img {
  width: 100%;
}

.service-introduction-emblem-image-mobile {
  display: none;
}

.service-introduction-doctor-image-mobile {
  display: none;
}

@media (max-width: 1440px) {
  .service-introduction::before {
    bottom: -11%;
  }
}

@media (max-width: 1279px) {
  .service-introduction {
    padding-top: 72px;
    padding-bottom: 32px;
  }

  .service-introduction::before {
    content: "";
    position: absolute;
    bottom: -5.2%;
    left: 0;
    width: 100%;
    height: auto;
    background-image: url("../img/renewal/aboutus-service-introduction-background-bottom-pc.png");
    background-size: cover;
    background-repeat: no-repeat;
    aspect-ratio: 750/52.08;
    z-index: 2;
  }

  .service-introduction-inner {
    display: block;
    max-width: 541.13px;
    height: 879px;
    padding-left: 0;
  }

  .service-introduction-content {
    display: flex;
    flex-direction: column;
    gap: 32px;
  }

  .service-introduction-text {
    font-weight: 400;
    margin-bottom: 46px;
  }

  .service-introduction-doctor-image-pc {
    top: 420px;
    right: 0;
  }
}

@media (max-width: 749px) {
  .service-introduction {
    padding-top: 64px;
    padding-bottom: 0;
  }

  .service-introduction::before {
    display: none;
  }

  .service-introduction-inner {
    max-width: 375px;
    height: 601px;
    padding-left: 0;
  }

  .service-introduction-content {
    display: flex;
    flex-direction: column;
    max-width: 327px;
    margin: 0 24px;
    gap: 32px;
  }

  .service-introduction-heading {
    font-size: 24px;
  }

  .service-introduction-text {
    font-size: 15px;
    font-weight: 500;
    line-height: 173%;
    color: #555555;
  }

  .service-introduction-doctor-image-pc {
    display: none;
  }

  .service-introduction-emblem-image-mobile {
    position: absolute;
    display: block;
    top: -128px;
    right: 16px;
    max-width: 208.52px;
    height: 100px;
    z-index: auto;
  }

  .service-introduction-emblem-image-mobile img {
    width: 100%;
  }

  .service-introduction-doctor-image-mobile {
    position: absolute;
    display: block;
    bottom: 48px;
    right: 24px;
    max-width: 327px;
    height: 100px;
  }

  .service-introduction-doctor-image-mobile img {
    width: 100%;
  }
}

/* ======================================= 更年期症状のお悩み ======================================= */
.about-worries,
.about-worries * {
  font-family: "Zen Kaku Gothic New";
}

.about-worries {
  position: relative;
  padding: 101px 2px 0 0;
  margin-top: calc(100vw / 1440 * 100 - 110px);
  display: flex;
  justify-content: center;
  opacity: 0;
}

.about-worries.is-ScrollActive {
  animation: fadeInUp 1.2s ease forwards;
}

/* 黒いオーバーレイを追加 */
.about-worries::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.2);
  z-index: 1;
}

.about-worries-background-image-pc {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("../img/renewal/aboutus-worries-background-pc.jpg");
  background-size: cover;
  background-repeat: no-repeat;
  filter: blur(2px);
  z-index: 0;
}

.about-worries-background-image-mobile {
  display: none;
}

.about-worries-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  max-width: 840.43px;
  width: 100%;
  margin-left: 2.75px;
  padding-bottom: 40px;
  gap: 24px;
  z-index: 2;
}

.about-worries-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  text-align: center;
  display: inline-block;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-image: linear-gradient(90deg, #ffffff 50%, transparent 50%);
  background-size: 200%;
  background-position: 100% 0;
  opacity: 0;
}

.title-animation03__wrapper.is-ScrollActive .about-worries-heading {
  animation: textAnimation 0.65s cubic-bezier(0.45, 0.05, 0.55, 0.95) forwards 0.8s;
}

.about-worries-image {
  position: relative;
  display: block;
  width: 682px;
  height: 261px;
}

.about-worries-bubble1,
.about-worries-bubble2,
.about-worries-bubble3 {
  position: relative;
  background-color: #ffffff;
  border-radius: 8px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
}

.about-worries-bubble1 {
  width: 320px;
  height: 98.29px;
  top: 7px;
  left: 0;
}

.about-worries-bubble2 {
  width: 318.73px;
  height: 97.9px;
  top: -68px;
  left: 362px;
}

.about-worries-bubble3 {
  width: 318.73px;
  height: 97.9px;
  top: -42px;
  left: 182px;
}

.about-worries-bubble1::before,
.about-worries-bubble2::before,
.about-worries-bubble3::before {
  content: "";
  position: absolute;
  border-width: 19px 9px 0;
  border-style: solid;
  border-color: #ffffff transparent transparent transparent;
  display: block;
  width: 0;
}

.about-worries-bubble1::before {
  bottom: -11px;
  right: 28px;
  transform: rotate(-38deg);
}

.about-worries-bubble2::before {
  bottom: -11px;
  left: 30px;
  transform: rotate(37deg);
}

.about-worries-bubble3::before {
  bottom: -11px;
  right: 30px;
  transform: rotate(-37deg);
}

.about-worries-bubble-decoration {
  position: absolute;
  width: 31.37px;
  height: 22px;
  background-image: url("../img/renewal/aboutus-worries-decoration.png");
  background-repeat: no-repeat;
  background-size: contain;
}

.about-worries-bubble1 .about-worries-bubble-decoration {
  top: -6px;
  left: 12px;
}

.about-worries-bubble2 .about-worries-bubble-decoration {
  top: -6px;
  right: 12px;
  transform: rotate(-180deg);
}

.about-worries-bubble3 .about-worries-bubble-decoration {
  top: -6px;
  left: 12px;
}

.about-worries-bubble1-text,
.about-worries-bubble2-text,
.about-worries-bubble3-text {
  width: 100%;
  font-size: 18px;
  font-weight: 700;
  line-height: 160%;
  color: #333333;
  text-align: left;
}

.about-worries-bubble1-text {
  padding-left: 25px;
}

.about-worries-bubble2-text {
  padding-left: 25px;
}

.about-worries-bubble3-text {
  padding-left: 69px;
}

.about-worries-text {
  position: relative;
  max-width: 600px;
  width: 100%;
  height: auto;
  margin-left: 0;
}

.about-worries-symptoms-heading {
  position: absolute;
  top: -3px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 18px;
  font-weight: 500;
  line-height: 200%;
  text-align: center;
  color: #ffffff;
  padding: 0 10px;
  z-index: 2;
  width: auto;
}

.symptoms-list {
  position: relative;
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #ffffff;
  padding: 17px 28px 16px 47px;
  margin-top: 16px;
}

/* 左側の線 */
.symptoms-list::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: calc(50% - 140px);
  height: 1px;
  background-color: #ffffff;
}

/* 右側の線 */
.symptoms-list::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: calc(50% - 140px);
  height: 1px;
  background-color: #ffffff;
}

.symptoms-items-left {
  max-width: 407.24px;
  width: 100%;
  height: auto;
}

.symptoms-items-right {
  max-width: 232px;
  width: 100%;
  height: auto;
}

.symptoms-item {
  display: flex;
  align-items: center;
  gap: 5px;
  height: auto;
}

.symptoms-item-pc-only {
  display: flex;
  align-items: center;
  gap: 5px;
  height: auto;
}

.symptom-item-text {
  font-size: 13px;
  font-weight: 500;
  line-height: 160%;
  color: #ffffff;
}

.symptom-item-check {
  display: inline-block;
  min-width: 12px;
  height: 6.5px;
  border-left: 2px solid #ffffff;
  border-bottom: 2px solid #ffffff;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  margin-top: -2px;
}
@media (max-width: 1440px) {
  .about-worries {
    position: relative;
    padding: 101px 2px 0 0;
    margin: 0;
    display: flex;
    justify-content: center;
    opacity: 0;
  }
}

@media (max-width: 1279px) {
  .about-worries {
    padding: 103px 2px 0 0;
  }

  .about-worries-background-image-pc {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url("../img/renewal/aboutus-worries-background-pc.jpg");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: 53% center;
    filter: blur(2px);
    z-index: 0;
  }
}

@media (max-width: 749px) {
  .about-worries {
    padding: 40px 24px 0 24px;
    opacity: 1;
    animation: none;
  }

  .about-worries.is-ScrollActive {
    animation: none;
  }

  /* 黒いオーバーレイを追加 */
  .about-worries::before {
    background-color: rgba(0, 0, 0, 0.15);
  }

  .about-worries-background-image-pc {
    display: none;
  }

  .about-worries-background-image-mobile {
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url("../img/renewal/aboutus-worries-background-mobile.jpg");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    z-index: 0;
  }

  .about-worries-content {
    max-width: 540px;
    margin-left: 0;
    padding-bottom: 51px;
    gap: 31px;
  }

  .about-worries-heading {
    font-size: 24px;
    opacity: 1;
    animation: none;
  }

  .about-worries-image {
    width: 400px;
    height: 330px;
    opacity: 0;
  }

  .title-animation02__wrapper.is-ScrollActive .about-worries-image {
    animation: fadeInUp 1s ease forwards;
  }

  .about-worries-bubble1,
  .about-worries-bubble2,
  .about-worries-bubble3 {
    width: 280px;
    height: 86px;
  }

  .about-worries-bubble1 {
    top: 0;
    left: 0;
  }

  .about-worries-bubble2 {
    top: 32px;
    left: 120px;
  }

  .about-worries-bubble3 {
    top: 64px;
    left: 0;
  }

  .about-worries-bubble1::before {
    right: 25px;
  }

  .about-worries-bubble2::before {
    left: 25px;
  }

  .about-worries-bubble3::before {
    right: 24px;
  }

  .about-worries-bubble-decoration {
    width: 28.52px;
    height: 20px;
  }

  .about-worries-bubble1-text,
  .about-worries-bubble2-text,
  .about-worries-bubble3-text {
    font-size: 15px;
    color: #555555;
    text-align: center;
    padding-left: 0;
  }

  .about-worries-bubble1-text {
    padding-top: 4px;
  }

  .about-worries-text {
    max-width: 400px;
    margin-left: 0;
  }

  .about-worries-symptoms-heading {
    top: -11px;
    width: 208px;
    font-size: 15px;
    line-height: 170%;
    padding: 0;
  }

  .symptoms-list {
    padding: 16px 36.3px 15px 24px;
    margin: 2px auto;
  }

  .symptoms-list::before,
  .symptoms-list::after {
    width: calc(50% - 130px);
  }

  .symptoms-items-left {
    max-width: 136px;
  }

  .symptoms-items-right {
    max-width: 196px;
  }

  .symptoms-item {
    gap: 4px;
  }

  .symptoms-item-pc-only {
    display: none;
  }

  .symptom-item-text {
    font-size: 12px;
    line-height: 170%;
  }
}

@media (max-width: 539px) {
  .about-worries-background-image-mobile {
    background-position: 45% center;
  }

  .about-worries-content {
    max-width: 375px;
    padding-bottom: 51px;
  }

  .about-worries-image {
    width: 327px;
  }

  .about-worries-bubble2 {
    left: 47px;
  }

  .about-worries-text {
    max-width: 339.7px;
    margin-left: 0;
  }

  .symptoms-list {
    padding: 16px 0 15px 0;
    margin: 2px auto;
  }

  .symptoms-list::before,
  .symptoms-list::after {
    width: calc(50% - 110px);
  }
}

/* ======================================= 診療の流れ ======================================= */
.treatment-flow,
.treatment-flow * {
  font-family: "Zen Kaku Gothic New";
}

.treatment-flow {
  padding: 64px 26px 64px 0;
  background-color: #ffffff;
}

.treatment-flow-content {
  width: 1240px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 26px;
}

.treatment-flow-heading {
  display: flex;
  flex-direction: column;
  width: 691px;
  height: fit-content;
  margin-bottom: 23px;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .treatment-flow-heading {
  animation: fadeInUp 1s ease forwards;
}

.treatment-flow-title {
  position: relative;
  font-size: 32px;
  font-weight: 700;
  line-height: 160%;
  letter-spacing: 0.03em;
  text-align: center;
  align-items: end;
  color: #333333;
  margin: 0 auto;
  padding: 8px 0 0 3px;
}

.treatment-flow-title::after {
  content: "";
  position: absolute;
  background-image: url("../img/renewal/aboutus-text-emphasis.png");
  background-repeat: no-repeat;
  background-size: contain;
  top: 0;
  left: 203px;
  width: 33px;
  height: 15px;
}

.treatment-flow-subtitle {
  font-size: 18px;
  font-weight: 500;
  line-height: 100%;
  text-align: center;
  color: #333333;
}

.treatment-flow-text.text95 {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  color: #e66d54;
}

.treatment-flow-text.percent {
  font-size: 24px;
  font-weight: 700;
  line-height: 180%;
  color: #e66d54;
}

.treatment-flow-card {
  display: flex;
  justify-content: flex-start;
  gap: 55px;
  width: 1240px;
  height: 231px;
  margin-bottom: 9px;
}

.sp-treatment-flow {
  display: none;
}

.treatment-flow-step {
  position: relative;
  width: 272px;
  height: fit-content;
}

.treatment-flow-step::before {
  content: "";
  position: absolute;
  top: 78px;
  right: -38px;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-top: 14px solid transparent;
  border-bottom: 14px solid transparent;
  border-left: 20px solid #555555;
  z-index: 1;
}

/* 最後のカードには三角形を表示しない */
.treatment-flow-step:last-child::before {
  display: none;
}

.treatment-flow-step1-image,
.treatment-flow-step2-image,
.treatment-flow-step3-image,
.treatment-flow-step4-image {
  position: absolute;
  display: block;
  background-size: contain;
  width: 272px;
  height: 181.33px;
}

.treatment-flow-step1-image {
  background-image: url("../img/renewal/aboutus-treatment-flow-step1.jpg");
}

.treatment-flow-step2-image {
  background-image: url("../img/renewal/aboutus-treatment-flow-step2.jpg");
}

.treatment-flow-step3-image {
  background-image: url("../img/renewal/aboutus-treatment-flow-step3.jpg");
}

.treatment-flow-step4-image {
  background-image: url("../img/renewal/aboutus-treatment-flow-step4.jpg");
}

.treatment-flow-step-content {
  position: absolute;
  top: 156px;
  left: 0;
  display: flex;
  justify-content: flex-start;
  max-width: 272px;
  width: fit-content;
  height: fit-content;
  background-color: #ffffff;
  padding: 10px 0;
  gap: 8px;
}

.treatment-flow-step-number {
  font-family: "Roboto" !important;
  white-space: nowrap;
  font-size: 36px;
  font-weight: 500;
  line-height: 140%;
  letter-spacing: -0.02em;
  color: #555555;
}

.treatment-flow-step-text {
  white-space: nowrap;
  font-size: 18px;
  font-weight: 500;
  line-height: 140%;
  color: #333333;
  padding-right: 16px;
}

.treatment-flow-medical-time {
  display: flex;
  width: 600px;
  height: fit-content;
  background-color: #f7eeea;
  border-radius: 8px;
  padding: 16px 32px;
}

.treatment-flow-medical-time-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 536px;
  width: 100%;
  gap: 8px;
}

.treatment-flow-medical-time-title {
  width: 100%;
  font-size: 22px;
  font-weight: 700;
  line-height: 170%;
  color: #333333;
  text-align: center;
  border-bottom: 1px solid #888888;
}

.treatment-flow-medical-time-subtitle {
  font-size: 15px;
  font-weight: 500;
  line-height: 180%;
  padding-left: 2px;
}

.treatment-flow-medical-time-schedule {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 374px;
  background-color: #ffffff;
  border-radius: 4px;
  padding: 5px 31px 6px 33px;
  gap: 20px;
}

.treatment-flow-medical-time-schedule::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  max-width: 310px;
  width: 100%;
  height: 1px;
  background-color: #888888;
  transform: translateX(-50%);
}

.treatment-flow-medical-time-schedule-header,
.treatment-flow-medical-time-schedule-detail {
  display: flex;
  justify-content: flex-start;
  gap: 24px;
}

.treatment-flow-medical-time-schedule-header-title,
.treatment-flow-medical-time-schedule-title {
  width: 80px;
  font-size: 13px;
  font-weight: 500;
  line-height: 180%;
  text-align: center;
}

.treatment-flow-medical-time-schedule-header-day-of-week,
.treatment-flow-medical-time-schedule-day-of-week {
  display: flex;
  font-size: 13px;
  font-weight: 500;
  line-height: 180%;
  gap: 16px;
}

.treatment-flow-medical-time-schedule-day-of-week-item {
  width: 13px;
  height: 13px;
  background-color: #e66d54;
  border-radius: 50%;
  margin-top: 5px;
}

@media (max-width: 1279px) {
  .treatment-flow {
    padding: 64px 0;
  }

  .treatment-flow-content {
    width: 100%;
  }

  .pc-treatment-flow {
    display: none;
  }

  .sp-treatment-flow {
    display: block;
    width: 100%;
    margin-left: 40px;
  }

  /* Swiperのスライド幅調整 */
  .sp-treatment-flow .swiper-slide {
    width: 308px !important;
    flex-shrink: 0;
  }

  .sp-treatment-flow .swiper-slide.swiper-slide-active {
    opacity: 1;
  }

  .treatment-flow-step {
    width: 272px;
  }

  .treatment-flow-step::before {
    right: -3px;
  }
}

@media (max-width: 749px) {
  .treatment-flow {
    padding: 48px 0;
    background-color: #ffffff;
  }

  .treatment-flow-content {
    /* max-width: 327px; */
    gap: 24px;
  }

  .treatment-flow-heading {
    max-width: 327px;
    width: 100%;
    gap: 24px;
    margin-bottom: 0;
  }

  .treatment-flow-title {
    font-size: 24px;
    padding: 5px 0 0 0;
  }

  .treatment-flow-title::after {
    top: 41px;
    left: 20px;
    width: 18px;
    height: 10px;
  }

  .treatment-flow-subtitle-top {
    width: 100%;
    font-size: 15px;
    font-weight: 500;
    line-height: 120%;
    text-align: center;
    color: #555555;
    margin-bottom: 5px;
  }

  .treatment-flow-subtitle-bottom {
    width: 100%;
    font-size: 15px;
    font-weight: 500;
    line-height: 180%;
    text-align: center;
    color: #555555;
  }

  .treatment-flow-text.support-text {
    font-size: 15px;
    font-weight: 500;
    line-height: 170%;
    color: #333333;
  }

  .treatment-flow-text.text95 {
    font-size: 24px;
    font-weight: 700;
    line-height: 180%;
    color: #e66d54;
  }

  .treatment-flow-text.percent {
    font-size: 15px;
    font-weight: 700;
    line-height: 180%;
    color: #e66d54;
  }

  .treatment-flow-card {
    margin-bottom: 0;
  }

  .sp-treatment-flow {
    margin-left: 24px;
    height: 210px;
  }

  .treatment-flow-step {
    width: 240px;
  }

  .treatment-flow-step::before {
    top: 76px;
    right: 5px;
    border-top: 12px solid transparent;
    border-bottom: 12px solid transparent;
    border-left: 18px solid #555555;
  }

  .sp-treatment-flow .swiper-slide {
    width: 283px !important;
  }

  .treatment-flow-step1-image,
  .treatment-flow-step2-image,
  .treatment-flow-step3-image,
  .treatment-flow-step4-image {
    width: 240px;
    height: 160px;
  }

  .treatment-flow-step-content {
    top: 153px;
    max-width: 240px;
    padding: 4px 0;
    gap: 10px;
  }

  .treatment-flow-step-text {
    font-size: 15px;
    padding-top: 3px;
  }

  .treatment-flow-medical-time {
    max-width: 327px;
    width: 100%;
  }

  .treatment-flow-medical-time-content {
    max-width: 263px;
  }

  .treatment-flow-medical-time-title {
    font-size: 18px;
    color: #555555;
  }

  .treatment-flow-medical-time-subtitle {
    font-size: 13px;
    line-height: 170%;
    text-align: center;
    padding-left: 0;
  }

  .treatment-flow-medical-time-schedule {
    max-width: 263px;
    width: 100%;
    padding: 6px 0 6px 9px;
  }

  .treatment-flow-medical-time-schedule::before {
    top: 48%;
    max-width: 231px;
  }

  .treatment-flow-medical-time-schedule-header,
  .treatment-flow-medical-time-schedule-detail {
    gap: 0;
  }

  .treatment-flow-medical-time-schedule-header-title {
    width: 70px;
    font-size: 12px;
    line-height: 170%;
    padding-left: 4px;
  }

  .treatment-flow-medical-time-schedule-title {
    width: 70px;
    font-size: 12px;
    line-height: 170%;
  }

  .treatment-flow-medical-time-schedule-header-day-of-week {
    font-size: 12px;
    line-height: 170%;
    gap: 14px;
  }

  .treatment-flow-medical-time-schedule-day-of-week {
    font-size: 12px;
    line-height: 170%;
    gap: 14px;
  }

  .treatment-flow-medical-time-schedule-day-of-week-item {
    width: 12px;
    height: 12px;
    margin-top: 3px;
  }
}

/* ======================================= 医師紹介 ======================================= */
.doctor-introduction,
.doctor-introduction * {
  font-family: "Zen Kaku Gothic New";
}

.doctor-introduction {
  position: relative;
  display: flex;
  justify-content: center;
  width: 100%;
  height: calc(100vw / 1440 * 100 + 550px);
  padding: 64px 0 166px 0;
  opacity: 0;
}

.doctor-introduction.is-ScrollActive {
  animation: fadeInUp 1.2s ease forwards;
}

.doctor-introduction::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 640px;
  height: 600px;
  background: linear-gradient(270deg, rgba(255, 255, 255, 0) 0%, #ffffff 200%);
  z-index: 1;
}

.doctor-introduction-background-image {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: calc(100vw / 1440 * 100 + 550px);
  background-image: url("../img/renewal/aboutus-doctor-introduction-background.jpg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50% 0%;
  z-index: 0;
}

.doctor-introduction-inner {
  display: flex;
  justify-content: flex-start;
  max-width: 1200px;
  width: 100%;
  height: 370px;
  z-index: 2;
}

.doctor-introduction-content {
  display: flex;
  flex-direction: column;
  width: 542px;
  height: 370px;
  gap: 8px;
  padding: 0;
}

.doctor-introduction-content-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  display: inline-block;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-image: linear-gradient(90deg, #333333 50%, transparent 50%);
  background-size: 200%;
  background-position: 100% 0;
  opacity: 0;
}

.title-animation03__wrapper.is-ScrollActive .doctor-introduction-content-heading {
  animation: textAnimation 0.65s cubic-bezier(0.45, 0.05, 0.55, 0.95) forwards 1s;
}

.doctor-introduction-text {
  font-size: 18px;
  font-weight: 500;
  line-height: 180%;
  margin-bottom: 32px;
  color: #333333;
}

.doctor-introduction-content-card {
  background-color: #ffffff;
  width: 542px;
  height: fit-content;
  padding: 16px;
  border-radius: 8px;
  gap: 16px;
}

.doctor-introduction-content-card-container {
  display: flex;
  gap: 16px;
}

.doctor-image {
  display: block;
  width: 140px;
  height: 140px;
  background-image: url("../img/renewal/aboutus-doctor-introduction-profile.jpg");
  background-repeat: no-repeat;
  background-size: contain;
  border-radius: 50%;
}

.doctor-introduction-content-profile {
  display: flex;
  flex-direction: column;
  width: 354px;
  height: fit-content;
  gap: 10px;
}

.doctor-profile {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
}

.doctor-name {
  width: fit-content;
  height: fit-content;
  font-size: 18px;
  font-weight: 500;
  line-height: 200%;
  color: #333333;
}

.doctor-introduction-content-profile-message-pc {
  width: fit-content;
  height: fit-content;
  font-size: 15px;
  font-weight: 400;
  line-height: 160%;
  color: #333333;
}

.doctor-introduction-content-profile-message-mobile {
  display: none;
}

@media (max-width: 1440px) {
  .doctor-introduction {
    position: relative;
    display: flex;
    justify-content: center;
    width: 100%;
    height: auto;
    padding: 64px 0 166px 0;
    opacity: 0;
  }

  .doctor-introduction-background-image {
    height: 600px;
    background-position: 50% center;
  }
}

@media (max-width: 1279px) {
  .doctor-introduction {
    padding: 64px 0 130px 0;
  }

  .doctor-introduction-inner {
    justify-content: center;
    max-width: 750px;
  }

  .doctor-introduction-content {
    gap: 9px;
  }
}

@media (max-width: 749px) {
  .doctor-introduction {
    padding: 63px 0 112px 0;
  }

  .doctor-introduction::before {
    width: 540px;
  }

  .doctor-introduction-background-image {
    background-position: 58.5% center;
  }

  .doctor-introduction-inner {
    max-width: 400px;
    height: 425px;
  }

  .doctor-introduction-content {
    width: 100%;
    height: 100%;
    gap: 48px;
  }

  .doctor-introduction-content-heading {
    font-size: 24px;
  }

  .doctor-introduction-text {
    display: none;
  }

  .doctor-introduction-content-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 400px;
  }

  .doctor-introduction-content-card-container {
    justify-content: flex-start;
    align-items: center;
  }

  .doctor-image {
    width: 112px;
    height: 112px;
  }

  .doctor-introduction-content-profile {
    display: block;
    width: fit-content;
    height: fit-content;
    padding-top: 2px;
    gap: 0;
  }

  .doctor-profile {
    align-items: center;
    gap: 8px;
  }

  .doctor-name {
    font-size: 15px;
    line-height: 170%;
  }

  .doctor-introduction-content-profile-message-pc {
    display: none;
  }

  .doctor-introduction-content-profile-message-mobile {
    display: block;
    width: fit-content;
    height: fit-content;
    font-size: 13px;
    font-weight: 400;
    line-height: 170%;
    color: #333333;
  }
}

@media (max-width: 539px) {
  .doctor-introduction {
    padding: 63px 0 85px 0;
  }

  .doctor-introduction::before {
    width: 375px;
  }

  .doctor-introduction-background-image {
    background-position: 60.3% center;
  }

  .doctor-introduction-inner {
    max-width: 343px;
  }

  .doctor-introduction-content-card {
    width: 343px;
  }

  .doctor-introduction-content-profile {
    padding-top: 0;
  }
}

/* ======================================= MyLilyの特徴 ======================================= */
.mylily-features,
.mylily-features * {
  font-family: "Zen Kaku Gothic New";
}

.mylily-features {
  position: relative;
  background-color: #fdf4ee;
}

.mylily-features::before {
  content: "";
  position: absolute;
  top: calc(100vw / 1440 * 100 * -1 - 46px);
  left: 0;
  width: 100%;
  height: auto;
  background-image: url("../img/renewal/aboutus-feature-background-top-pc.png");
  background-size: cover;
  background-repeat: no-repeat;
  aspect-ratio: 1440/160;
  z-index: 0;
}

.mylily-features::after {
  content: "";
  position: absolute;
  bottom: calc(100vw / 1440 * 100 * -1 - 46px);
  left: 0;
  width: 100%;
  height: auto;
  background-image: url("../img/renewal/aboutus-feature-background-bottom-pc.png");
  background-size: cover;
  background-repeat: no-repeat;
  background-color: #ffffff;
  aspect-ratio: 1440/160;
  z-index: 0;
}

.mylily-features-content {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 78px;
  padding-bottom: 50px;
  gap: 37px;
  z-index: 1;
}

.mylily-features-heading {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 32px;
  font-weight: 700;
  line-height: 160%;
  letter-spacing: 0.03em;
  text-align: center;
  color: #333333;
  opacity: 0;
}

.mylily-features-heading-nomal-text {
  padding-top: 6px;
}

.title-animation02__wrapper.is-ScrollActive .mylily-features-heading {
  animation: fadeInUp 1s ease forwards;
}

.mylily-features-list-pc {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto auto;
  justify-content: center;
  width: 1000px;
  height: fit-content;
  gap: 32px;
}

.mylily-features-list-mobile {
  display: none;
}

.mylily-features-list-pc > article:nth-child(-n + 3) {
  opacity: 0;
}

.mylily-features-list-pc > article:nth-child(n + 4):nth-child(-n + 6) {
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .mylily-features-list-pc > article:nth-child(-n + 3) {
  animation: fadeInUp 1s ease forwards 0.5s;
}

.title-animation02__wrapper.is-ScrollActive
  .mylily-features-list-pc
  > article:nth-child(n + 4):nth-child(-n + 6) {
  animation: fadeInUp 1s ease forwards 1s;
}

.mylily-features-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 312px;
  height: fit-content;
  background-color: #ffffff;
  border-radius: 8px;
  padding-top: 8px;
  padding-bottom: 16px;
  gap: 8px;
}

.mylily-features-card-number {
  font-size: 18px;
  font-weight: 500;
  line-height: 160%;
  font-family: "Roboto" !important;
  color: #888888;
  border-bottom: 1px solid #888888;
  padding: 0 5px;
}

.mylily-features-card-title {
  font-size: 22px;
  font-weight: 700;
  line-height: 150%;
  text-align: center;
  color: #333333;
  margin-bottom: 8px;
}

.mylily-features-card-image1,
.mylily-features-card-image2,
.mylily-features-card-image3,
.mylily-features-card-image4,
.mylily-features-card-image5,
.mylily-features-card-image6 {
  width: 84px;
  height: 76px;
  background-repeat: no-repeat;
  background-size: contain;
  margin-bottom: 8px;
}

.mylily-features-card-image1 {
  background-image: url("../img/renewal/aboutus-feature-image1.png");
}

.mylily-features-card-image2 {
  background-image: url("../img/renewal/aboutus-feature-image2.png");
}

.mylily-features-card-image3 {
  background-image: url("../img/renewal/aboutus-feature-image3.png");
}

.mylily-features-card-image4 {
  background-image: url("../img/renewal/aboutus-feature-image4.png");
}

.mylily-features-card-image5 {
  background-image: url("../img/renewal/aboutus-feature-image5.png");
}

.mylily-features-card-image6 {
  background-image: url("../img/renewal/aboutus-feature-image6.png");
}

.mylily-features-card-text {
  font-size: 15px;
  font-weight: 400;
  line-height: 170%;
  width: fit-content;
  height: fit-content;
  color: #333333;
  text-align: center;
}

@media (max-width: 1440px) {
  .mylily-features::before {
    top: -14.5%;
  }

  .mylily-features::after {
    bottom: -17%;
  }
}

@media (max-width: 1279px) {
  .mylily-features::before {
    top: -8.8%;
    aspect-ratio: 750/83.33;
  }

  .mylily-features::after {
    bottom: -8.7%;
    aspect-ratio: 750/83.33;
  }

  .mylily-features-content {
    padding-top: 37px;
    padding-bottom: 32px;
  }

  .mylily-features-list-pc {
    grid-template-columns: repeat(2, 1fr);
    width: 655px;
    gap: 31px;
  }

  .mylily-features-list-pc > article:nth-child(-n + 2) {
    opacity: 0;
  }

  .mylily-features-list-pc > article:nth-child(n + 3):nth-child(-n + 4) {
    opacity: 0;
  }

  .mylily-features-list-pc > article:nth-child(n + 5):nth-child(-n + 6) {
    opacity: 0;
  }

  .title-animation02__wrapper.is-ScrollActive .mylily-features-list-pc > article:nth-child(-n + 2) {
    animation: fadeInUp 1s ease forwards 0.5s;
  }

  .title-animation02__wrapper.is-ScrollActive
    .mylily-features-list-pc
    > article:nth-child(n + 3):nth-child(-n + 4) {
    animation: fadeInUp 1s ease forwards 1s;
  }

  .title-animation02__wrapper.is-ScrollActive
    .mylily-features-list-pc
    > article:nth-child(n + 5):nth-child(-n + 6) {
    animation: fadeInUp 1s ease forwards 1.5s;
  }

  .mylily-features-card-number {
    display: none;
  }

  .mylily-features-card-image1,
  .mylily-features-card-image2,
  .mylily-features-card-image3,
  .mylily-features-card-image4,
  .mylily-features-card-image5,
  .mylily-features-card-image6 {
    min-width: 64px;
    width: 64px;
    height: 58px;
    margin-bottom: 10px;
  }
}

@media (max-width: 749px) {
  .mylily-features::before {
    top: -11%;
    background-image: url("../img/renewal/aboutus-feature-background-top-mobile.png");
    aspect-ratio: 540/115;
  }

  .mylily-features::after {
    bottom: -8%;
    background-image: url("../img/renewal/aboutus-feature-background-bottom-mobile.png");
    aspect-ratio: 540/115;
  }

  .mylily-features-content {
    padding-top: 4px;
    padding-left: 24px;
    padding-right: 24px;
    gap: 12px;
  }

  .mylily-features-heading {
    font-size: 24px;
  }

  .mylily-features-heading-nomal-text {
    padding-top: 11px;
  }

  .mylily-features-list-pc {
    display: none;
  }

  .mylily-features-list-mobile {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    grid-template-rows: auto auto;
    justify-content: center;
    max-width: 400px;
    width: 100%;
    height: fit-content;
    gap: 16px;
  }

  .mylily-features-card {
    flex-direction: row;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding-top: 16px;
    padding-left: 12px;
    padding-right: 12px;
    gap: 4px;
  }

  .mylily-features-card-content {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    max-width: 308px;
    width: 100%;
    gap: 4px;
  }

  .mylily-features-card-title {
    font-size: 18px;
    text-align: left;
    height: 54px;
    margin-bottom: 0;
    align-items: center;
  }

  .mylily-features-card-title-one-line {
    font-size: 18px;
    text-align: left;
    height: 54px;
    padding-top: 17px;
    align-items: center;
  }

  .mylily-features-card-image1,
  .mylily-features-card-image2,
  .mylily-features-card-image3,
  .mylily-features-card-image4,
  .mylily-features-card-image5,
  .mylily-features-card-image6 {
    display: block;
    margin-bottom: 0;
  }

  .mylily-features-card-text {
    font-size: 13px;
    text-align: left;
  }
}

@media (max-width: 539px) {
  .mylily-features::before {
    top: -7.3%;
    aspect-ratio: 375/80;
  }

  .mylily-features::after {
    bottom: -4.5%;
    aspect-ratio: 375/80;
  }
}

@media (max-width: 374px) {
  .mylily-features::before {
    top: -5%;
    aspect-ratio: 320/60;
  }
}

/* ======================================= 治療プラン ======================================= */
.treatment-plan,
.treatment-plan * {
  font-family: "Zen Kaku Gothic New";
}

.treatment-plan {
  display: flex;
  justify-content: center;
  background-color: #ffffff;
  padding-left: 13px;
}

.treatment-plan-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 1000px;
  width: 100%;
  height: fit-content;
  padding-top: calc(100vw / 1440 * 100 + 40px);
  padding-bottom: calc(100vw / 1440 * 100 + 40px);
}

.treatment-plan-heading-pc {
  display: flex;
  align-items: center;
  margin-bottom: 53px;
  opacity: 0;
  padding-left: 2px;
}

.title-animation02__wrapper.is-ScrollActive .treatment-plan-heading-pc {
  animation: fadeInUp 1s ease forwards;
}

.treatment-plan-heading-mobile {
  display: none;
}

.treatment-plan-heading-normal {
  font-size: 32px;
  font-weight: 700;
  line-height: 160%;
  letter-spacing: 0.03em;
  color: #333333;
  padding-top: 5px;
}

.treatment-plan-image-container {
  position: relative;
  display: flex;
  max-width: 1000px;
  width: 100%;
  height: fit-content;
  gap: 0;
}

.treatment-plan-card-left,
.treatment-plan-card-right {
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 500px;
  width: 100%;
  height: fit-content;
}

.treatment-plan-card-image-left,
.treatment-plan-card-image-right {
  position: relative;
  background-size: cover;
  background-position: center 146px;
  max-width: 500px;
  width: 100%;
  height: 140px;
}

.treatment-plan-card-image-left {
  background-image: url("../img/renewal/aboutus-treatment-plan-image-pc-left.png");
  background-color: rgba(230, 109, 84, 0.2);
}

.treatment-plan-card-image-right {
  background-image: url("../img/renewal/aboutus-treatment-plan-image-pc-right.png");
  background-color: rgba(81, 118, 125, 0.2);
}

.treatment-plan-card-overlay-left,
.treatment-plan-card-overlay-right {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 32px 2px 0 0;
  color: #ffffff;
  text-align: center;
  gap: 1px;
}

.treatment-plan-card-subtitle {
  font-size: 18px;
  font-weight: 500;
  line-height: 170%;
}

.treatment-plan-card-title {
  font-size: 32px;
  font-weight: 700;
  line-height: 140%;
  letter-spacing: 0.03em;
  padding-left: 3px;
}

.treatment-plan-card-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  height: auto;
  border: 1px solid #e0e0e0;
  padding: 15px 1px 22px 0;
  gap: 15px;
}

.treatment-plan-card-pros-left,
.treatment-plan-card-pros-right {
  font-size: 18px;
  font-weight: 500;
  line-height: 180%;
}

.treatment-plan-card-pros-point {
  position: absolute;
  top: 159px;
  left: 460px;
  display: flex;
  flex-direction: column;
  gap: 21px;
  padding: 0 8px;
}

.treatment-plan-card-pros-features,
.treatment-plan-card-pros-benefits {
  font-size: 15px;
  font-weight: 500;
  line-height: 170%;
  color: #e66d54;
  text-align: center;
  height: 27px;
  background-color: #ffffff;
  border: 1px solid #e66d54;
  border-radius: 4px;
  padding: 0px 16px;
}

.treatment-plan-other {
  position: relative;
  display: flex;
  align-items: center;
  width: fit-content;
  height: fit-content;
}

.treatment-plan-other-message {
  display: flex;
  text-align: center;
  align-items: center;
  justify-content: center;
  width: 468px;
  height: 86px;
  margin: 42.5px 172px 41.5px 0;
  padding: 16px 7px 16px 30px;
  background-color: #f7eeea;
  border-radius: 8px;
}

.treatment-plan-other-message::before {
  content: "";
  position: absolute;
  top: 68px;
  right: 158px;
  width: 17px;
  height: 25px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  background-color: #f7eeea;
  transform: rotate(87deg);
}

.treatment-plan-other-icon {
  position: absolute;
  display: block;
  background-image: url("../img/renewal/aboutus-treatment-plan-mascot-image.png");
  background-size: contain;
  background-repeat: no-repeat;
  width: 173px;
  height: 173px;
  top: 0;
  right: 1px;
  opacity: 1;
  animation: laggy 2000ms steps(1, end) infinite;
  animation-delay: 2s;
}

.treatment-plan-other-message p {
  font-size: 15px;
  font-weight: 700;
  line-height: 180%;
  color: #333333;
}

@media (max-width: 1440px) {
  .treatment-plan-content {
    padding-top: 149px;
    padding-bottom: 135px;
  }
}

@media (max-width: 1279px) {
  .treatment-plan {
    padding-left: 0;
    margin: 0 40px;
  }

  .treatment-plan-content {
    max-width: 670px;
    width: 100%;
    padding-top: 140px;
  }

  .treatment-plan-heading-pc {
    margin-bottom: 55px;
    padding-left: 4px;
  }

  .treatment-plan-heading-normal {
    padding-top: 9px;
  }

  .treatment-plan-image-container {
    max-width: 670px;
    gap: 0;
  }

  .treatment-plan-card-left,
  .treatment-plan-card-right {
    max-width: 335px;
  }

  .treatment-plan-card-image-left,
  .treatment-plan-card-image-right {
    max-width: 335px;
    background-position: center 140px;
  }

  .treatment-plan-card-image-left {
    background-image: url("../img/renewal/aboutus-treatment-plan-image-pc-small-left.png");
  }

  .treatment-plan-card-image-right {
    background-image: url("../img/renewal/aboutus-treatment-plan-image-pc-small-right.png");
  }

  .treatment-plan-card-overlay-left,
  .treatment-plan-card-overlay-right {
    padding: 32px 0px 0 0;
    gap: 0px;
  }

  .treatment-plan-card-title {
    padding-left: 0;
  }

  .treatment-plan-card-content {
    padding: 15px 0px 24px 0;
    gap: 16px;
  }

  .treatment-plan-card-pros-left,
  .treatment-plan-card-pros-right {
    line-height: 160%;
    text-align: center;
  }

  .treatment-plan-card-pros-point {
    top: 171px;
    left: 295px;
    gap: 47px;
  }

  .treatment-plan-other img {
    right: 0;
  }
}

@media (max-width: 749px) {
  .treatment-plan {
    margin: 0 16px;
  }

  .treatment-plan-content {
    max-width: 400px;
    padding-top: 95px;
    padding-bottom: 166px;
  }
  .treatment-plan-heading-pc {
    display: none;
  }

  .treatment-plan-heading-mobile {
    display: flex;
    flex-direction: column;
    font-size: 24px;
    font-weight: 700;
    line-height: 160%;
    letter-spacing: 0.03em;
    text-align: center;
    margin-bottom: 23px;
    padding-left: 0;
    opacity: 0;
  }

  .title-animation02__wrapper.is-ScrollActive .treatment-plan-heading-mobile {
    animation: fadeInUp 1s ease forwards;
  }

  .treatment-plan-heading-mobile-bottom {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-right: 1px;
    gap: 2px;
  }

  .treatment-plan-heading-normal {
    font-size: 24px;
    padding-top: 0;
  }

  .treatment-plan-image-container {
    max-width: 400px;
    margin-bottom: 24px;
  }

  .treatment-plan-card-left,
  .treatment-plan-card-right {
    max-width: 200px;
  }

  .treatment-plan-card-image-left,
  .treatment-plan-card-image-right {
    max-width: 200px;
    height: 192px;
    background-size: cover;
    background-position: center 0px;
  }

  .treatment-plan-card-image-left {
    background-image: url("../img/renewal/aboutus-treatment-plan-image-sp-left.png");
  }

  .treatment-plan-card-image-right {
    background-image: url("../img/renewal/aboutus-treatment-plan-image-sp-right.png");
  }

  .treatment-plan-card-overlay-left {
    padding: 56px 0 0 0;
  }

  .treatment-plan-card-overlay-right {
    padding: 56px 0 0 1px;
    gap: 12px;
  }

  .treatment-plan-card-subtitle {
    font-size: 15px;
  }

  .treatment-plan-card-title {
    font-size: 24px;
    line-height: 140%;
    padding-left: 3px;
  }

  .treatment-plan-card-content {
    padding: 8px 0;
  }

  .treatment-plan-card-pros-left {
    font-size: 13px;
    padding: 0 16px 0 4px;
  }

  .treatment-plan-card-pros-right {
    font-size: 13px;
    padding: 0 4px 0 16px;
  }

  .treatment-plan-card-pros-point {
    top: 67.8%;
    left: 42.3%;
    gap: 33px;
    padding: 0 8px;
  }

  .treatment-plan-card-pros-features,
  .treatment-plan-card-pros-benefits {
    font-size: 13px;
    line-height: 160%;
    width: 38px;
    height: 25px;
    padding: 0 5px;
  }

  .treatment-plan-other {
    position: relative;
    display: flex;
    justify-content: flex-start;
    max-width: 343px;
    width: 100%;
    height: fit-content;
  }

  .treatment-plan-other-message {
    width: 311px;
    height: 68px;
    margin: 0 30px 0 0;
    padding: 14px 6px 16px 7px;
  }

  .treatment-plan-other-message::before {
    display: none;
  }

  .treatment-plan-other-icon {
    position: absolute;
    display: block;
    background-image: url("../img/renewal/aboutus-treatment-plan-mascot-image.png");
    background-size: contain;
    width: 133px;
    height: 134.46px;
    top: 0;
    right: -19px;
  }

  .treatment-plan-other-message p {
    font-size: 13px;
    line-height: 160%;
    letter-spacing: 0.03em;
  }
}

@media (max-width: 374px) {
  .treatment-plan-card-image-left,
  .treatment-plan-card-image-right {
    background-size: cover;
  }

  .treatment-plan-card-right .treatment-plan-card-content {
    gap: 37px;
  }

  .treatment-plan-card-pros-left {
    padding: 0 20px 0 4px;
  }

  .treatment-plan-card-pros-right {
    width: 100%;
    padding: 0 4px 0 20px;
  }

  .treatment-plan-card-pros-point {
    top: 61.8%;
    left: 43%;
    gap: 50px;
    padding: 0 0;
  }

  .treatment-plan-card-pros-features,
  .treatment-plan-card-pros-benefits {
    width: 40px;
    padding: 1px 5px 0 5px;
  }

  .treatment-plan-other-message {
    margin: 0;
    padding: 15px 6px 15px 6px;
  }

  .treatment-plan-other-icon {
    top: 1px;
  }
}

/* ======================================= 料金プラン ======================================= */
.price-plan,
.price-plan * {
  font-family: "Zen Kaku Gothic New";
}

.price-plan {
  position: relative;
  background-color: #f7eeea;
  z-index: 1;
}

.price-plan::before {
  content: "";
  position: absolute;
  top: calc(100vw / 1440 * 100 * -1 - 40px);
  left: 0;
  width: 100%;
  height: auto;
  background-image: url("../img/renewal/aboutus-price-plan-background-top-pc.png");
  background-size: cover;
  background-repeat: no-repeat;
  aspect-ratio: 1440/160;
  z-index: -1;
}

.price-plan::after {
  content: "";
  position: absolute;
  bottom: calc(100vw / 1440 * 100 * -1 - 40px);
  left: 0;
  width: 100%;
  height: auto;
  background-image: url("../img/renewal/aboutus-price-plan-background-bottom-pc.png");
  background-size: cover;
  background-repeat: no-repeat;
  background-color: #ffffff;
  aspect-ratio: 1440/160;
  z-index: -1;
}

.price-plan-content {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  padding: 28px 0;
  gap: 6px;
}

.price-plan-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  text-align: center;
  color: #333333;
  z-index: 1;
}

.price-plan-text {
  font-size: 18px;
  font-weight: 500;
  line-height: 180%;
  text-align: center;
  color: #333333;
  margin-bottom: 16px;
}


.price-plan-list {
  padding-left: 15.278vw;
  margin-bottom: 24px;
}

.pc-price-plan {
  display: block;
  /* width: 100%; */
  width: 1688px;
}

.pc-price-plan .swiper-slide {
  margin-right: 32px;
}

.pc-price-plan .swiper-slide.swiper-slide-active {
  opacity: 1;
}

.price-plan-card-type2.swiper-slide:last-child {
  margin-right: 314px;
}

.price-plan-card-type1,
.price-plan-card-type2 {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 312px;
  height: 481px;
  background-color: #ffffff;
  border-radius: 4px;
  gap: 16px;
}

.price-plan-card-type1 {
  padding: 28px 13px 0 13px;
}

.price-plan-card-type2 {
  padding: 28px 16px 0 16px;
}

.price-plan-card-heading {
  position: relative;
  width: 100%;
}

.title-number {
  position: absolute;
  top: -11px;
  left: 42%;
  font-size: 12px;
  font-weight: 400;
  line-height: 170%;
  text-align: center;
  color: #e66d54;
}

.price-plan-card-title {
  font-size: 22px;
  font-weight: 700;
  line-height: 170%;
  text-align: center;
  color: #e66d54;
}

.price-plan-card-price {
  display: flex;
  align-items: center;
  margin-bottom: 3px;
  gap: 2px;
}

.price-value {
  font-family: "Roboto" !important;
  font-size: 40px;
  font-weight: 500;
  line-height: 100%;
  text-align: center;
  margin: auto 0;
  padding-top: 3px;
  color: #333333;
}

.price-unit-1 {
  font-size: 24px;
  font-weight: 700;
  line-height: 160%;
  letter-spacing: 0.03em;
  color: #333333;
  padding-top: 6px;
}

.price-unit-2 {
  display: flex;
  flex-direction: column;
  font-size: 12px;
  font-weight: 500;
  line-height: 151%;
  color: #888888;
}

.price-plan-list-card-image-container-type1,
.price-plan-list-card-image-container-type2 {
  position: relative;
  display: block;
  min-height: 90px;
  height: 90px;
}

.price-plan-list-card-image-container-type1 {
  width: 272px;
}

.price-plan-list-card-image-container-type2 {
  width: 280px;
}

.price-plan-list-card-image1,
.price-plan-list-card-image2,
.price-plan-list-card-image3,
.price-plan-list-card-image4,
.price-plan-list-card-image5 {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  height: 90px;
  background-repeat: no-repeat;
}

.price-plan-list-card-image1 {
  width: 272px;
  background-image: url("../img/renewal/aboutus-price-plan-imege1-pc.png");
  background-size: 100% 100%;
}

.price-plan-list-card-image2 {
  width: 280px;
  background-image: url("../img/renewal/aboutus-price-plan-imege2.png");
  background-size: 100% 100%;
}

.price-plan-list-card-image3 {
  width: 280px;
  background-image: url("../img/renewal/aboutus-price-plan-imege3.png");
  background-size: 100% 100%;
}

.price-plan-list-card-image4 {
  width: 280px;
  background-image: url("../img/renewal/aboutus-price-plan-imege4.png");
  background-size: 97% 100%;
}

.price-plan-list-card-image5 {
  width: 280px;
  background-image: url("../img/renewal/aboutus-price-plan-imege5.png");
  background-size: 97% 100%;
}

.prescription-heading-type1,
.prescription-heading-type2 {
  position: relative;
  width: 100%;
  font-size: 15px;
  font-weight: 700;
  line-height: 180%;
  text-align: left;
  color: #888888;
}

.prescription-heading-type1::before,
.prescription-heading-type2::before {
  content: "";
  position: absolute;
  top: 50%;
  width: 223px;
  height: 0;
  border: 0.5px solid #c4c4c4;
}

.prescription-heading-type1::before {
  right: 6px;
}

.prescription-heading-type2::before {
  right: 0;
}

.price-plan-list-card-prescription {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 31.5px;
}

.prescription-list {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}

.prescription-list::before {
  content: "";
  position: absolute;
  bottom: -16px;
  left: 3px;
  width: 280px;
  height: 0;
  border: 0.5px dashed #c4c4c4;
}

.prescription-list-end {
  display: flex;
  justify-content: space-between;
  width: 100%;
  align-items: center;
}

.prescription-list-item {
  font-size: 12px;
  font-weight: 400;
  line-height: 160%;
  color: #333333;
  max-width: 205px;
}

.prescription-list-price {
  display: flex;
  flex-direction: column;
  justify-content: center;
  font-size: 12px;
  font-weight: 400;
  line-height: 160%;
  color: #333333;
  text-align: center;
}

.price-plan-regular-delivery {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.price-plan-regular-delivery-title {
  position: absolute;
  top: -35px;
  left: 67px;
  padding: 0 11px 5px 12px;
  font-size: 24px;
  font-weight: 700;
  line-height: 160%;
  letter-spacing: 0.03em;
  text-align: center;
  color: #333333;
  background-color: #f7eeea;
}

.price-plan-regular-delivery-title::before,
.price-plan-regular-delivery-title::after {
  content: "";
  position: absolute;
  top: 31px;
  width: 26.4px; /* 斜線の長さ */
  height: 1px; /* 斜線の太さ */
  background-color: #c4c4c4;
}

.price-plan-regular-delivery-title::before {
  left: -5px;
  transform: rotate(52.7deg); /* 左側の斜線の角度 */
}

.price-plan-regular-delivery-title::after {
  right: -5px;
  transform: rotate(-52.7deg); /* 右側の斜線の角度 */
}

.price-plan-regular-delivery-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 700px;
  height: 160px;
  border-width: 1px 0px 1px 0px;
  border-style: solid;
  border-color: #c4c4c4;
  padding: 10.74px 54px 0.26px 54px;
  gap: 36.5px;
}

.price-plan-regular-delivery-content-image {
  position: relative;
  width: 200px;
  height: 147px;
}

.price-plan-regular-delivery-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 200px;
  height: 147px;
  background-image: url("../img/renewal/aboutus-price-plan-delivery-image-pc.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  overflow: hidden;
}

.price-plan-regular-delivery-content-list {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 352px;
  height: fit-content;
}

.regular-delivery-item {
  display: flex;
  align-items: flex-start;
  font-size: 18px;
  font-weight: 500;
  line-height: 200%;
  color: #333333;
  gap: 0;
}

.regular-delivery-item-check {
  position: relative;
  padding-left: 24px;
}

.regular-delivery-item-check:after {
  content: "";
  display: block;
  position: absolute;
  border-left: 2px solid #888888;
  border-bottom: 2px solid #888888;
  width: 12.5px;
  height: 7.5px;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  top: 12.5px;
  left: 0;
}

@media (max-width: 1909px) {
  .pc-price-plan {
    width: 100%;
  }
}

@media (max-width: 1440px) {
  .price-plan::before {
    top: -13.2%;
  }

  .price-plan::after {
    bottom: -13.2%;
  }
}

@media (max-width: 1279px) {
  .price-plan::before {
    top: -11%;
    aspect-ratio: 750/83.33;
  }

  .price-plan::after {
    bottom: -11%;
    aspect-ratio: 750/83.33;
  }

  .price-plan-list {
    padding-left: 80px;
    /* margin: 0 0 94px 80px; */
  }

  .price-plan-card-type2.swiper-slide:last-child {
    margin-right: 44px;
  }
}

@media (max-width: 1024px) {
  .price-plan::before {
    top: -7.4%;
    aspect-ratio: 750/83.33;
  }

  .price-plan::after {
    bottom: -8%;
    aspect-ratio: 750/83.33;
  }
}

@media (max-width: 749px) {
  .price-plan::before {
    top: -10.6%;
    background-image: url("../img/renewal/aboutus-price-plan-background-top-mobile.png");
    aspect-ratio: 375/80;
  }

  .price-plan::after {
    bottom: -10.5%;
    background-image: url("../img/renewal/aboutus-price-plan-background-bottom-mobile.png");
    aspect-ratio: 375/80;
  }

  .price-plan-content {
    padding: 24px 0;
    gap: 32px;
  }

  .price-plan-heading {
    font-size: 24px;
    margin-bottom: 1px;
  }

  .price-plan-text {
    font-size: 15px;
    line-height: 170%;
    color: #555555;
    text-align: center;
    width: 327px;
    margin-bottom: 0;
  }

  .price-plan-list {
    padding-left: 24px;
    padding-top: 83px;
    margin-bottom: 34px;
  }

  .pc-price-plan .swiper-slide {
    margin-right: 16px;
  }

  .price-plan-card-type1,
  .price-plan-card-type2 {
    width: 280px;
    height: 401px;
    padding: 32px 16px 0 16px;
    gap: 6px;
  }

  .price-plan-card-type2.swiper-slide:last-child {
    /* margin-right: 24px; */
  }

  .price-plan .swiper-pagination {
    position: absolute;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 340px;
    height: fit-content;
    gap: 8px;
    z-index: 10;
  }

  .price-plan .swiper-pagination-bullet {
    height: 30px;
    padding: 4px 11px;
    background: #ffffff;
    border: 1px solid #888888;
    border-radius: 28px;
    font-family: Zen Kaku Gothic New;
    font-size: 13px;
    font-weight: 500;
    line-height: 170%;
    color: #888888;
    text-align: center;
    margin: 0;
    opacity: 1;
  }

  .price-plan .swiper-pagination-bullet:nth-child(1) {
    width: 141px;
    margin: 0;
  }

  .price-plan .swiper-pagination-bullet:nth-child(2),
  .price-plan .swiper-pagination-bullet:nth-child(4) {
    width: 89px;
    margin: 0;
  }

  .price-plan .swiper-pagination-bullet:nth-child(3) {
    width: 102px;
    margin: 0;
  }

  .price-plan .swiper-pagination-bullet:nth-child(5) {
    width: 130px;
    margin: 0;
  }

  .price-plan .swiper-pagination-bullet:nth-child(1)::after {
    content: "ホルモン療法プラン";
  }

  .price-plan .swiper-pagination-bullet:nth-child(2)::after {
    content: "漢方プラン";
  }

  .price-plan .swiper-pagination-bullet:nth-child(3)::after {
    content: "腟ケアプラン";
  }

  .price-plan .swiper-pagination-bullet:nth-child(4)::after {
    content: "美容プラン";
  }

  .price-plan .swiper-pagination-bullet:nth-child(5)::after {
    content: "ダイエットプラン";
  }

  .price-plan .swiper-pagination-bullet-active {
    background: #e66d54;
    border: none;
    color: #ffffff;
  }

  .title-number {
    position: absolute;
    top: -15px;
    left: 44%;
    font-size: 10px;
  }

  .price-plan-card-title {
    font-size: 18px;
    line-height: 160%;
  }

  .price-plan-card-price {
    display: flex;
    align-items: center;
    margin-bottom: 3px;
    gap: 2px;
  }

  .price-value {
    font-size: 32px;
    margin: auto 0;
    padding-top: 6px;
    padding-right: 2px;
    color: #333333;
  }

  .price-unit-1 {
    font-size: 18px;
    padding-top: 9px;
  }

  .price-unit-2 {
    font-size: 10px;
    line-height: 170%;
    padding: 1px 0 0 1px;
  }

  .price-plan-list-card-image-container-type1,
  .price-plan-list-card-image-container-type2 {
    min-height: 75px;
    height: 75px;
    margin-bottom: 8px;
  }

  .price-plan-list-card-image-container-type1 {
    width: 248px;
  }

  .price-plan-list-card-image-container-type2 {
    width: 218px;
  }

  .price-plan-list-card-image1,
  .price-plan-list-card-image2,
  .price-plan-list-card-image3,
  .price-plan-list-card-image4,
  .price-plan-list-card-image5 {
    height: 75px;
  }

  .price-plan-list-card-image1 {
    width: 248px;
    background-image: url("../img/renewal/aboutus-price-plan-imege1-mobile.png");
    background-size: 100% 100%;
  }

  .price-plan-list-card-image2 {
    width: 218px;
    background-image: url("../img/renewal/aboutus-price-plan-imege2.png");
    background-size: 100% 100%;
  }

  .price-plan-list-card-image3 {
    width: 218px;
    background-image: url("../img/renewal/aboutus-price-plan-imege3.png");
    background-size: 100% 100%;
  }

  .price-plan-list-card-image4 {
    width: 218px;
    background-image: url("../img/renewal/aboutus-price-plan-imege4.png");
    background-size: 97% 100%;
  }

  .price-plan-list-card-image5 {
    width: 218px;
    background-image: url("../img/renewal/aboutus-price-plan-imege5.png");
    background-size: 97% 100%;
  }

  .prescription-heading-type1,
  .prescription-heading-type2 {
    font-size: 13px;
    line-height: 170%;
    padding-top: 1px;
    margin-bottom: 7px;
  }

  .prescription-heading-type1::before,
  .prescription-heading-type2::before {
    width: 197px;
    right: 0;
  }

  .price-plan-list-card-prescription {
    gap: 23.5px;
  }

  .prescription-list::before {
    bottom: -12px;
    left: 0;
    width: 248px;
    height: 0;
    border: 0.5px dashed #c4c4c4;
  }

  .prescription-list-item {
    font-size: 10px;
    line-height: 170%;
    max-width: 180px;
  }

  .prescription-list-price {
    font-size: 10px;
    font-weight: 500;
    line-height: 170%;
  }

  .price-plan-regular-delivery-title {
    top: -33px;
    left: 17px;
    font-size: 18px;
    padding: 0 18px 5px 18px;
  }

  .price-plan-regular-delivery-title::before,
  .price-plan-regular-delivery-title::after {
    top: 24px;
  }

  .price-plan-regular-delivery-title::before {
    left: -4px;
  }

  .price-plan-regular-delivery-title::after {
    right: -4px;
  }

  .price-plan-regular-delivery-content {
    justify-content: center;
    width: 327px;
    height: 148px;
    padding: 16px 0 0.26px 3px;
    margin: 0 auto;
    gap: 10px;
  }

  .price-plan-regular-delivery-content-image {
    display: block;
    width: 100px;
    height: 100px;
  }

  .price-plan-regular-delivery-image {
    top: 0;
    left: 0;
    width: 100px;
    height: 100px;
    background-image: url("../img/renewal/aboutus-price-plan-delivery-image-mobile.png");
  }

  .price-plan-regular-delivery-content-list {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 180px;
    height: fit-content;
    padding-top: 2px;
    gap: 8px;
  }

  .regular-delivery-item {
    font-size: 13px;
    line-height: 170%;
    gap: 0;
  }

  .regular-delivery-item-check {
    position: relative;
    padding-left: 20px;
  }

  .regular-delivery-item-check:after {
    content: "";
    display: block;
    position: absolute;
    border-left: 2px solid #888888;
    border-bottom: 2px solid #888888;
    width: 10.5px;
    height: 6.5px;
    transform: rotate(-45deg);
    top: 30%;
    left: 0;
  }
}

@media (max-width: 500px) {
  .price-plan::before {
    top: -7.9%;
    background-image: url("../img/renewal/aboutus-price-plan-background-top-mobile.png");
    aspect-ratio: 375/80;
  }

  .price-plan::after {
    bottom: -7.9%;
    background-image: url("../img/renewal/aboutus-price-plan-background-bottom-mobile.png");
    aspect-ratio: 375/80;
  }
}

@media (max-width: 374px) {
  .price-plan::before {
    top: -6.9%;
    background-image: url("../img/renewal/aboutus-price-plan-background-top-mobile.png");
    aspect-ratio: 320/72;
  }

  .price-plan::after {
    bottom: -6.9%;
    background-image: url("../img/renewal/aboutus-price-plan-background-bottom-mobile.png");
    aspect-ratio: 320/72;
  }
}

/* ======================================= サポート ======================================= */
.support,
.support * {
  font-family: "Zen Kaku Gothic New";
}

.support {
  background-color: #ffffff;
}

.support-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  padding: 166px 0 64px 0;
  /* padding: calc(100vw / 1440 * 100 + 50px) 0 64px 0; */
}

.support-content-heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 396px;
  height: 106px;
  margin-bottom: 15px;
}

.support-title__wrapper {
  padding: 0 24px;
}

.support-content-title {
  position: relative;
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  color: #333333;
  padding-left: 16px;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-image: linear-gradient(90deg, #333333 50%, transparent 50%);
  background-size: 200%;
  background-position: 100% 0;
  opacity: 0;
}

.highlight-support {
  position: relative;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-image: linear-gradient(90deg, #e66d54 50%, transparent 50%);
  background-size: 200%;
  background-position: 100% 0;
  opacity: 0;
}

.title-animation03__wrapper.is-ScrollActive .support-content-title {
  animation: textAnimation 0.65s cubic-bezier(0.45, 0.05, 0.55, 0.95) forwards;
}

.title-animation03__wrapper.is-ScrollActive .highlight-support {
  animation: textAnimation 0.65s cubic-bezier(0.45, 0.05, 0.55, 0.95) forwards 0.2s;
}

.support-content-title::after {
  content: "";
  position: absolute;
  background-image: url("../img/renewal/aboutus-text-emphasis.png");
  background-repeat: no-repeat;
  background-size: contain;
  top: -8px;
  right: 24px;
  width: 33px;
  height: 15px;
  opacity: 0;
}

.title-animation03__wrapper.is-ScrollActive .support-content-title::after {
  animation: fadeIn 0.8s ease forwards 0.3s;
}

.support-content-subtitle {
  font-size: 18px;
  font-weight: 500;
  line-height: 180%;
  color: #333333;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-image: linear-gradient(90deg, #333333 50%, transparent 50%);
  background-size: 200%;
  background-position: 100% 0;
  opacity: 0;
}

.title-animation03__wrapper.is-ScrollActive .support-content-subtitle {
  animation: textAnimation 0.65s cubic-bezier(0.45, 0.05, 0.55, 0.95) forwards;
}

.support-content-list {
  display: flex;
  gap: 32px;
}

.support-content-list-card1-pc,
.support-content-list-card2-pc,
.support-content-list-card3-pc {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 312px;
  height: 312px;
  background-color: #f7eeea;
  border-radius: 8px;
  padding-top: 20px;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .support-content-list-card1-pc {
  animation: fadeInUp 1s ease forwards 0.8s;
}

.title-animation02__wrapper.is-ScrollActive .support-content-list-card2-pc {
  animation: fadeInUp 1s ease forwards 1.2s;
}

.title-animation02__wrapper.is-ScrollActive .support-content-list-card3-pc {
  animation: fadeInUp 1s ease forwards 1.6s;
}

.support-content-list-card1-pc {
  gap: 5px;
}

.support-content-list-card2-pc,
.support-content-list-card3-pc {
  gap: 9px;
}

.support-content-list-card1-mobile,
.support-content-list-card2-mobile,
.support-content-list-card3-mobile {
  display: none;
}

.support-content-list-card-title {
  font-size: 24px;
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.03em;
  text-align: center;
  color: #333333;
}

.support-content-list-card-text-type1,
.support-content-list-card-text-type2 {
  font-size: 13px;
  font-weight: 400;
  text-align: center;
  color: #333333;
}

.support-content-list-card-text-type1 {
  line-height: 180%;
}

.support-content-list-card-text-type2 {
  line-height: 150%;
}

.support-content-list-card-image1-container,
.support-content-list-card-image2-container,
.support-content-list-card-image3-container {
  background-size: contain;
  background-repeat: no-repeat;
  width: 312px;
  height: 200px;
  overflow: hidden;
}

.support-content-list-card-image1-container {
  background-image: url("../img/renewal/aboutus-support-image1-pc-large.png");
}

.support-content-list-card-image2-container {
  background-image: url("../img/renewal/aboutus-support-image2-pc-large.png");
}

.support-content-list-card-image3-container {
  background-image: url("../img/renewal/aboutus-support-image3-pc-large.png");
}

@media (max-width: 1279px) {
  .support-content-title {
    padding-left: 0;
    margin-bottom: -1px;
  }

  .support-content-title::after {
    top: -9px;
    right: 16px;
  }

  .support-content-heading {
    height: 98px;
    margin-bottom: 14px;
  }

  .support-content-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 670px;
    width: 100%;
    gap: 32px;
  }

  .support-content-list-card1-pc,
  .support-content-list-card2-pc,
  .support-content-list-card3-pc {
    height: 232px;
  }

  .support-content-list-card3-pc {
    flex: 0 0 100%;
    max-width: 312px;
  }

  .support-content-list-card-title {
    font-weight: 500;
  }

  .support-content-list-card-image1-container,
  .support-content-list-card-image2-container,
  .support-content-list-card-image3-container {
    background-size: contain;
    background-repeat: no-repeat;
    width: 187px;
    height: 120px;
    overflow: hidden;
  }

  .support-content-list-card-image1-container {
    margin-left: 3px;
  }

  .support-content-list-card-image3-container {
    background-image: url("../img/renewal/aboutus-support-image3-pc-medium.png");
  }
}

@media (max-width: 749px) {
  .support-content {
    padding: 109px 0 48px 0;
  }

  .support-content-heading {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: fit-content;
    height: fit-content;
    margin-bottom: 24px;
  }

  .support-content-title {
    font-size: 24px;
    margin-bottom: 0px;
  }

  .support-content-title::after {
    top: -3px;
    right: 18px;
    width: 18px;
    height: 10px;
  }

  .support-content-subtitle {
    font-size: 15px;
    line-height: 170%;
    color: #555555;
  }

  .support-content-list {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    justify-content: center;
    max-width: 400px;
    width: calc(100% - 48px);
    height: fit-content;
    gap: 24px;
  }

  .support-content-list-card1-pc,
  .support-content-list-card2-pc,
  .support-content-list-card3-pc {
    display: none;
    animation: none !important;
    opacity: 0 !important;
  }

  .title-animation02__wrapper.is-ScrollActive .support-content-list-card1-pc,
  .title-animation02__wrapper.is-ScrollActive .support-content-list-card2-pc,
  .title-animation02__wrapper.is-ScrollActive .support-content-list-card3-pc {
    animation: none !important;
  }

  .support-content-list-card1-mobile,
  .support-content-list-card2-mobile,
  .support-content-list-card3-mobile {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: fit-content;
    background-color: #f7eeea;
    border-radius: 8px;
    margin: 0 auto;
    gap: 8px;
    opacity: 0;
  }

  .title-animation02__wrapper.is-ScrollActive .support-content-list-card1-mobile {
    animation: fadeInUp 1s ease forwards 0.8s;
  }

  .title-animation02__wrapper.is-ScrollActive .support-content-list-card2-mobile {
    animation: fadeInUp 1s ease forwards 1.3s;
  }

  .title-animation02__wrapper.is-ScrollActive .support-content-list-card3-mobile {
    animation: fadeInUp 1s ease forwards 1.8s;
  }

  .support-content-list-card-image1-container,
  .support-content-list-card-image2-container,
  .support-content-list-card-image3-container {
    width: 90px;
    height: 112px;
    margin-left: 0;
  }

  .support-content-list-card-image1-container {
    background-image: url("../img/renewal/aboutus-support-image1-mobile.png");
  }

  .support-content-list-card-image2-container {
    background-image: url("../img/renewal/aboutus-support-image2-mobile.png");
  }

  .support-content-list-card-image3-container {
    background-size: cover;
    background-image: url("../img/renewal/aboutus-support-image3-mobile.png");
  }

  .support-content-list-card-content {
    display: flex;
    flex-direction: column;
    max-width: 213px;
    height: fit-content;
    gap: 6px;
  }

  .support-content-list-card-title {
    font-size: 18px;
    font-weight: 500;
    padding-bottom: 2px;
    text-align: left;
  }

  .support-content-list-card-text-type1,
  .support-content-list-card-text-type2 {
    font-size: 12px;
    line-height: 150%;
    text-align: left;
  }
}

/* ======================================= お客様の声 ======================================= */
.user-voice,
.user-voice * {
  font-family: "Zen Kaku Gothic New";
}

.user-voice {
  background-color: #fdf4ee;
}

.user-voice-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 1048px;
  margin: 0 auto;
  padding: 56px 0 56px 0;
  gap: 16px;
}

.user-voice-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  color: #333333;
  opacity: 0;
}

.user-voice-list .swiper-slide:last-child {
  margin-right: 0px;
}

.title-animation02__wrapper.is-ScrollActive .user-voice-heading {
  animation: fadeInUp 1s ease forwards;
}

.user-voice-content {
  position: relative;
  display: flex;
  justify-content: flex-start;
  width: 1048px;
  /* height: 347px; */
  padding: 22px 24px 0 24px;
}

.user-voice-list {
  display: flex;
  justify-content: center;
  max-width: 1000px;
  width: 100%;
  /* height: 280px; */
  padding: 46px 55px 38px 55px;
  gap: 64px;
  background-color: #ffffff;
  border-radius: 8px;
  filter: drop-shadow(6px 6px 0px rgba(173, 173, 173, 0.2));
  z-index: 3;
}

.sp-user-voice {
  display: none;
}

.user-voice-bubble-left {
  position: absolute;
  background-image: url("../img/renewal/aboutus-user-voice-bubble-left.png");
  background-size: cover;
  background-repeat: no-repeat;
  top: 0;
  left: 0;
  width: 176px;
  height: 101.01px;
  z-index: 2;
}

.user-voice-bubble-right {
  position: absolute;
  background-image: url("../img/renewal/aboutus-user-voice-bubble-right.png");
  background-size: cover;
  background-repeat: no-repeat;
  top: 232px;
  right: 0;
  width: 252px;
  height: 116px;
  z-index: 2;
}

.voice-card {
  position: relative;
  text-decoration: none;
  color: inherit;
  display: block;
  transition: transform 0.3s ease;
}

.voice-card::before {
  content: "";
  position: absolute;
  top: -13px;
  right: -32px;
  width: 0;
  height: 217px;
  border: 0.8px solid #e0e0e0;
}

.voice-card:last-child::before {
  display: none;
}

.voice-card:hover {
  color: #e66d54; /* ホバー時の文字色を変更 */
}

.voice-card:hover .voice-content h3 {
  color: #e66d54; /* ホバー時に見出しの色だけ変更 */
}

.voice-item {
  display: flex;
  flex-direction: column;
  width: 254px;
  /* height: 196px; */
  gap: 10px;
}

.voice-header {
  display: flex;
  width: 100%;
  height: 100px;
  gap: 11px;
}

.voice-image {
  position: relative;
  width: 100px;
  height: 100px;
}

.voice-image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 96px;
  height: 96px;
}

.voice-image::before {
  content: "";
  position: absolute;
  top: 4px;
  left: 4px;
  background-color: #e66d54;
  width: 96px;
  height: 96px;
}

.voice-info {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding-top: 25px;
}

.voice-number {
  font-family: Roboto !important;
  font-size: 15px;
  font-weight: 500;
  line-height: 180%;
  color: #e66d54;
}

.voice-profile {
  display: flex;
  font-size: 15px;
  font-weight: 400;
  line-height: 180%;
  color: #888888;
  gap: 6px;
}

.voice-content {
  width: 100%;
  height: fit-content;
}

.voice-content h3 {
  font-size: 18px;
  font-weight: 500;
  line-height: 170%;
  color: #555555;
}

.user-voice .swiper-pagination {
  display: none;
}

.user-voice-button {
  display: flex;
  justify-content: center;
  width: 311px;
  height: fit-content;
  background-color: #ffffff;
  border: 1px solid #888888;
  border-radius: 28px;
  padding: 9px 16px;
  margin-top: 40px;
}

.user-voice-button-text {
  font-size: 15px;
  font-weight: 700;
  line-height: 180%;
  color: #888888;
}

.user-voice-button:hover .user-voice-button-text {
  color: #e66d54;
}

@media (max-width: 1279px) {
  .user-voice-inner {
    width: 100%;
  }

  .user-voice-content {
    max-width: 1066px;
    width: 100%;
    /* height: 347px; */
    margin: 0 40px 0 40px;
  }

  .user-voice-list {
    justify-content: flex-start;
    max-width: 1066px;
    padding: 46px 55px 38px 55px;
    gap: 0;
  }

  .pc-user-voice {
    display: none;
  }

  .sp-user-voice {
    display: block;
    width: 100%;
  }

  .sp-user-voice .swiper-slide {
    width: 286px !important;
    flex-shrink: 0;
  }

  .voice-card::before {
    top: -14px;
    right: 0;
  }
}

@media (max-width: 1066px) {
  .user-voice-content {
    width: 100%;
    /* height: 347px; */
    margin: 0 0 0 80px;
  }

  .user-voice-bubble-right {
    right: 80px;
  }
}

@media (max-width: 749px) {
  .user-voice-inner {
    padding: 56px 0 47px 0;
    gap: 24px;
  }

  .user-voice-heading {
    font-size: 24px;
  }

  .user-voice-list .swiper-slide:last-child {
    margin-right: 24px;
  }

  .user-voice-content {
    height: 300px;
    padding: 16px 16px 0 16px;
    margin: 0 0 0 32px;
  }

  .user-voice-list {
    height: 100%;
    padding: 0;
    background-color: inherit;
    border-radius: 0;
    filter: none;
  }

  .user-voice-bubble-right {
    top: 170px;
    right: 32px;
  }

  .voice-card {
    height: 235px;
    background-color: #ffffff;
    border-radius: 8px;
    filter: drop-shadow(6px 6px 0px rgba(173, 173, 173, 0.2));
    padding: 24px 16px;
  }

  .voice-card::before {
    display: none;
  }

  .voice-item {
    /* height: 187px; */
  }

  .voice-header {
    gap: 16px;
  }

  .voice-info {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    padding-top: 25px;
  }

  .voice-number {
    font-family: Zen Kaku Gothic New !important;
    font-size: 13px;
    font-weight: 700;
    line-height: 170%;
  }

  .voice-profile {
    font-size: 13px;
    line-height: 170%;
    padding-top: 4px;
    gap: 9px;
  }

  .voice-content h3 {
    font-size: 15px;
  }

  .user-voice .swiper-pagination {
    position: absolute;
    width: 100%;
    display: flex;
    justify-content: center;
    bottom: 0.5px;
    left: -4.5%;
    z-index: 10;
  }

  .user-voice .swiper-pagination-bullet {
    width: 6px;
    height: 6px;
    background-color: inherit;
    opacity: 1;
    margin: 0 4px !important;
    border: 0.5px solid #888888;
  }

  .user-voice .swiper-pagination-bullet-active {
    background-color: #888888;
  }

  .user-voice-button {
    padding: 8px 16px 6px 16px;
    margin-top: 0;
  }

  .user-voice-button-text {
    font-size: 13px;
    line-height: 170%;
  }
}

/* ======================================= よくある質問 ======================================= */
.faq,
.faq * {
  font-family: "Zen Kaku Gothic New";
}

.faq {
  background-color: #ffffff;
  padding: 57px 0;
}

.faq-content {
  display: flex;
  flex-direction: column;
  width: 800px;
  margin: 0 auto;
  gap: 24px;
}

.faq-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  text-align: center;
  color: #333333;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .faq-heading {
  animation: fadeInUp 1s ease forwards;
}

.faq-list {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 24px;
}

.faq-item {
  width: 100%;
  height: fit-content;
  padding: 8px 24px;
  background: #ffffff;
  border-radius: 5px;
  overflow: hidden;
  transition: box-shadow 0.2s ease;
  cursor: pointer;
}

.faq-item:hover {
  box-shadow: 6px 6px 0 rgba(173, 173, 173, 0.2);
}

.faq-question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 2px;
}

.faq-question-content {
  position: relative;
  display: flex;
  align-items: center;
  width: calc(100% - 30px);
}

.faq-answer {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  padding: 0 22px 0 0;
  transition: max-height 0.2s ease, opacity 0.2s ease, padding 0.2s ease;
}

.faq-answer.active {
  max-height: 150px;
  opacity: 1;
  padding: 21px 22px 10px 0;
}

.q-mark,
.a-mark {
  font-size: 24px;
  font-weight: 500;
  line-height: 100%;
  min-width: 20px;
}

.q-mark {
  margin-right: 6px;
  color: #e66d54;
}

.a-mark {
  margin-right: 8px;
  color: #888888;
}

.question-text {
  font-size: 18px;
  font-weight: 500;
  line-height: 180%;
  color: #333333;
}

.answer-text {
  font-size: 15px;
  font-weight: 400;
  line-height: 180%;
  color: #333333;
}

.toggle-btn {
  position: relative;
  display: block;
  width: 30px;
  height: 20px;
  cursor: pointer;
}

.toggle-btn:before {
  content: "";
  position: absolute;
  top: 9px;
  left: 8px;
  width: 20px;
  height: 2px;
  background-color: #e66d54;
  transition: all 0.3s ease;
}

.toggle-btn:after {
  content: "";
  position: absolute;
  top: 0;
  left: 17px;
  height: 20px;
  width: 2px;
  background-color: #e66d54;
  transition: all 0.2s ease;
  transform-origin: center;
}

.toggle-btn.active:after {
  transform: rotate(90deg);
  opacity: 0;
}

.faq-answer.active + .faq-question .toggle-btn:after,
.faq-question:has(+ .faq-answer.active) .toggle-btn:after {
  transform: rotate(90deg);
  opacity: 0;
}

@media (max-width: 879px) {
  .faq-content {
    width: calc(100% - 80px);
    margin: 0 40px;
  }
}

@media (max-width: 749px) {
  .faq-content {
    max-width: 400px;
    width: calc(100% - 48px);
    margin: 0 24px;
  }

  .faq-heading {
    font-size: 24px;
  }

  .faq-list {
    gap: 25px;
  }

  .faq-item {
    padding: 8px 16px;
  }

  .faq-question-content {
    width: calc(100% - 20px);
  }

  .faq-answer {
    padding: 19px 22px 7px 0;
  }

  .q-mark,
  .a-mark {
    font-size: 20px;
    min-width: 15px;
  }

  .q-mark {
    margin-right: 8px;
  }

  .a-mark {
    margin-right: 11px;
  }

  .question-text {
    font-size: 15px;
    line-height: 170%;
  }

  .answer-text {
    font-size: 13px;
    line-height: 170%;
  }

  .toggle-btn {
    width: 28px;
  }

  .toggle-btn:before {
    transition: all 0.2s ease;
  }

  .toggle-btn:after {
    transition: all 0.2s ease;
    transform-origin: center;
  }

  .toggle-btn.active:after {
    transform: rotate(90deg);
    opacity: 0;
  }
}

/* ======================================= 医師監修コラム ======================================= */
.medically-reviewed-article,
.medically-reviewed-article * {
  font-family: "Zen Kaku Gothic New";
}

.medically-reviewed-article {
  background-color: #f7eeea;
}

.medically-reviewed-article-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 66px 0;
  gap: 20px;
}

.medically-reviewed-article-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  color: #333333;
  margin-bottom: 22px;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .medically-reviewed-article-heading {
  animation: fadeInUp 1s ease forwards;
}

.medically-reviewed-article-list {
  max-width: 1000px;
  width: 100%;
  height: auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: 27px;
  row-gap: 20px;
  margin-bottom: 7px;
}

.article-card {
  display: flex;
  flex-direction: column;
  width: 312px;
  text-decoration: none;
  color: inherit;
  transition: transform 0.3s ease;
  background-color: #ffffff;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  margin: 6px 0 6px 6px;
  padding-bottom: 12px;
  gap: 12px;
  transition: box-shadow 0.2s ease;
}

.article-card:hover {
  box-shadow: 6px 6px 0 rgba(173, 173, 173, 0.2);
}

.article-card:hover .article-title h3 {
  color: #e66d54;
}

.article-image {
  position: relative;
  display: block;
  width: 100%;
  height: 175px;
  overflow: hidden;
}

.article-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
}

.article-content {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: auto;
  padding: 0 12px 0 10px;
  gap: 8px;
}

.article-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: fit-content;
}

.article-date {
  font-size: 13px;
  font-weight: 500;
  line-height: 180%;
  color: #888888;
}

.article-category {
  padding: 0 7px;
  border: 1px solid #51767d;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 500;
  line-height: 160%;
  color: #51767d;
}

.article-title {
  width: 100%;
}

.article-title h3 {
  font-size: 15px;
  font-weight: 500;
  line-height: 160%;
  color: #333333;
}

.medically-reviewed-article-button {
  display: flex;
  justify-content: center;
  width: 311px;
  height: 47px;
  background-color: #ffffff;
  border: 1px solid #888888;
  border-radius: 28px;
  padding: 10px 16px;
}

.medically-reviewed-article-button-text {
  font-size: 15px;
  font-weight: 700;
  line-height: 180%;
  color: #888888;
}

.medically-reviewed-article-button:hover .medically-reviewed-article-button-text {
  color: #e66d54;
}

@media (max-width: 1279px) {
  .medically-reviewed-article-list {
    max-width: 680px;
    grid-template-columns: repeat(2, 1fr);
  }

  .tablet-hide {
    display: none !important;
  }
}

@media (max-width: 749px) {
  .medically-reviewed-article-inner {
    padding: 48px 0;
    gap: 24px;
  }

  .medically-reviewed-article-heading {
    font-size: 24px;
    margin-bottom: 0;
  }

  .medically-reviewed-article-list {
    max-width: 320px;
    grid-template-columns: 1fr;
    margin-bottom: 0;
  }

  .article-card {
    margin: 0 auto;
    gap: 10px;
  }

  .article-content {
    padding: 0 11px;
    gap: 8px;
  }

  .article-info {
    margin-bottom: 3px;
  }

  .article-date {
    font-size: 12px;
    line-height: 170%;
  }

  .article-category {
    padding: 0 7px;
    font-size: 12px;
    line-height: 170%;
    height: 20px;
  }

  .article-title h3 {
    font-size: 13px;
  }

  .medically-reviewed-article-button {
    height: 38px;
    padding: 0;
    align-items: center;
  }

  .medically-reviewed-article-button-text {
    font-size: 13px;
    line-height: 170%;
  }

  .mobile-hide {
    display: none !important;
  }
}

/* ======================================= 利用ガイド ======================================= */
.usage-guide,
.usage-guide * {
  font-family: "Zen Kaku Gothic New";
}

.usage-guide {
  background-color: #ffffff;
}

.usage-guide-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 55px 0;
  gap: 24px;
}

.usage-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  color: #333333;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .usage-heading {
  animation: fadeInUp 1s ease forwards;
}

.usage-video {
  max-width: 580px;
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}

.usage-guide-annotation {
  margin-top: 12px;
  text-align: center;
}

.usage-guide-annotation p {
  font-size: 12px;
  color: #888888;
  line-height: 1.5;
  margin: 4px 0;
}

@media (max-width: 749px) {
  .usage-guide-content {
    padding: 47px 0;
    gap: 24px;
  }

  .usage-heading {
    font-size: 24px;
    line-height: 150%;
    text-align: center;
  }

  .usage-video {
    max-width: 327px;
    width: 100%;
    height: auto;
    aspect-ratio: 16/9;
  }
}

/* 余白用のダミースライド */
.price-plan-dummy-slide {
  width: 32px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

/* Safari専用のスタイル - -webkit-backdrop-filterはSafariが対応している特有のプロパティ */
@supports (-webkit-backdrop-filter: none) and (not (backdrop-filter: none)) {
  .price-plan-dummy-slide {
    width: 32px !important;
    height: 481px !important;
    opacity: 0 !important;
    pointer-events: none !important;
    margin-right: 0 !important;
    flex-shrink: 0 !important;
  }
}

.price-plan-list-card-image-container-type1,
.price-plan-list-card-image-container-type2 {
  position: relative;
  display: block;
  min-height: 90px;
  height: 90px;
}

.price-plan-list-card-image-container-type1 {
  width: 272px;
}

.price-plan-list-card-image-container-type2 {
  width: 280px;
}

.price-plan-list-card-image1,
.price-plan-list-card-image2,
.price-plan-list-card-image3,
.price-plan-list-card-image4,
.price-plan-list-card-image5 {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  height: 90px;
  background-repeat: no-repeat;
}

.price-plan-list-card-image1 {
  width: 272px;
  background-image: url("../img/renewal/aboutus-price-plan-imege1-pc.png");
  background-size: 100% 100%;
}

.price-plan-list-card-image2 {
  width: 280px;
  background-image: url("../img/renewal/aboutus-price-plan-imege2.png");
  background-size: 100% 100%;
}

.price-plan-list-card-image3 {
  width: 280px;
  background-image: url("../img/renewal/aboutus-price-plan-imege3.png");
  background-size: 100% 100%;
}

.price-plan-list-card-image4 {
  width: 280px;
  background-image: url("../img/renewal/aboutus-price-plan-imege4.png");
  background-size: 97% 100%;
}

.price-plan-list-card-image5 {
  width: 280px;
  background-image: url("../img/renewal/aboutus-price-plan-imege5.png");
  background-size: 97% 100%;
}

.prescription-heading-type1,
.prescription-heading-type2 {
  position: relative;
  width: 100%;
  font-size: 15px;
  font-weight: 700;
  line-height: 180%;
  text-align: left;
  color: #888888;
}

.prescription-heading-type1::before,
.prescription-heading-type2::before {
  content: "";
  position: absolute;
  top: 50%;
  width: 223px;
  height: 0;
  border: 0.5px solid #c4c4c4;
}

.prescription-heading-type1::before {
  right: 6px;
}

.prescription-heading-type2::before {
  right: 0;
}

.price-plan-list-card-prescription {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 31.5px;
}

.prescription-list {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}

.prescription-list::before {
  content: "";
  position: absolute;
  bottom: -16px;
  left: 3px;
  width: 280px;
  height: 0;
  border: 0.5px dashed #c4c4c4;
}

.prescription-list-end {
  display: flex;
  justify-content: space-between;
  width: 100%;
  align-items: center;
}

.prescription-list-item {
  font-size: 12px;
  font-weight: 400;
  line-height: 160%;
  color: #333333;
  max-width: 205px;
}

.prescription-list-price {
  display: flex;
  flex-direction: column;
  justify-content: center;
  font-size: 12px;
  font-weight: 400;
  line-height: 160%;
  color: #333333;
  text-align: center;
}

.price-plan-regular-delivery {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.price-plan-regular-delivery-title {
  position: absolute;
  top: -35px;
  left: 67px;
  padding: 0 11px 5px 12px;
  font-size: 24px;
  font-weight: 700;
  line-height: 160%;
  letter-spacing: 0.03em;
  text-align: center;
  color: #333333;
  background-color: #f7eeea;
}

.price-plan-regular-delivery-title::before,
.price-plan-regular-delivery-title::after {
  content: "";
  position: absolute;
  top: 31px;
  width: 26.4px; /* 斜線の長さ */
  height: 1px; /* 斜線の太さ */
  background-color: #c4c4c4;
}

.price-plan-regular-delivery-title::before {
  left: -5px;
  transform: rotate(52.7deg); /* 左側の斜線の角度 */
}

.price-plan-regular-delivery-title::after {
  right: -5px;
  transform: rotate(-52.7deg); /* 右側の斜線の角度 */
}

.price-plan-regular-delivery-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 700px;
  height: 160px;
  border-width: 1px 0px 1px 0px;
  border-style: solid;
  border-color: #c4c4c4;
  padding: 10.74px 54px 0.26px 54px;
  gap: 36.5px;
}

.price-plan-regular-delivery-content-image {
  position: relative;
  width: 200px;
  height: 147px;
}

.price-plan-regular-delivery-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 200px;
  height: 147px;
  background-image: url("../img/renewal/aboutus-price-plan-delivery-image-pc.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  overflow: hidden;
}

.price-plan-regular-delivery-content-list {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 352px;
  height: fit-content;
}

.regular-delivery-item {
  display: flex;
  align-items: flex-start;
  font-size: 18px;
  font-weight: 500;
  line-height: 200%;
  color: #333333;
  gap: 0;
}

.regular-delivery-item-check {
  position: relative;
  padding-left: 24px;
}

.regular-delivery-item-check:after {
  content: "";
  display: block;
  position: absolute;
  border-left: 2px solid #888888;
  border-bottom: 2px solid #888888;
  width: 12.5px;
  height: 7.5px;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  top: 12.5px;
  left: 0;
}

@media (max-width: 1909px) {
  .pc-price-plan {
    width: 100%;
  }
}

@media (max-width: 1440px) {
  .price-plan::before {
    top: -13.2%;
  }

  .price-plan::after {
    bottom: -13.2%;
  }
}

@media (max-width: 1279px) {
  .price-plan::before {
    top: -11%;
    aspect-ratio: 750/83.33;
  }

  .price-plan::after {
    bottom: -11%;
    aspect-ratio: 750/83.33;
  }

  .price-plan-list {
    padding-left: 80px;
    /* margin: 0 0 94px 80px; */
  }

  .price-plan-card-type2.swiper-slide:last-child {
    margin-right: 44px;
  }
}

@media (max-width: 1024px) {
  .price-plan::before {
    top: -7.4%;
    aspect-ratio: 750/83.33;
  }

  .price-plan::after {
    bottom: -8%;
    aspect-ratio: 750/83.33;
  }
}

@media (max-width: 749px) {
  .price-plan::before {
    top: -10.6%;
    background-image: url("../img/renewal/aboutus-price-plan-background-top-mobile.png");
    aspect-ratio: 375/80;
  }

  .price-plan::after {
    bottom: -10.5%;
    background-image: url("../img/renewal/aboutus-price-plan-background-bottom-mobile.png");
    aspect-ratio: 375/80;
  }

  .price-plan-content {
    padding: 24px 0;
    gap: 32px;
  }

  .price-plan-heading {
    font-size: 24px;
    margin-bottom: 1px;
  }

  .price-plan-text {
    font-size: 15px;
    line-height: 170%;
    color: #555555;
    text-align: center;
    width: 327px;
    margin-bottom: 0;
  }

  .price-plan-list {
    padding-left: 24px;
    padding-top: 83px;
    margin-bottom: 34px;
  }

  .pc-price-plan .swiper-slide {
    margin-right: 16px;
  }

  .price-plan-card-type1,
  .price-plan-card-type2 {
    width: 280px;
    height: 401px;
    padding: 32px 16px 0 16px;
    gap: 6px;
  }

  .price-plan-card-type2.swiper-slide:last-child {
    /* margin-right: 24px; */
  }

  .price-plan .swiper-pagination {
    position: absolute;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 340px;
    height: fit-content;
    gap: 8px;
    z-index: 10;
  }

  .price-plan .swiper-pagination-bullet {
    height: 30px;
    padding: 4px 11px;
    background: #ffffff;
    border: 1px solid #888888;
    border-radius: 28px;
    font-family: Zen Kaku Gothic New;
    font-size: 13px;
    font-weight: 500;
    line-height: 170%;
    color: #888888;
    text-align: center;
    margin: 0;
    opacity: 1;
  }

  .price-plan .swiper-pagination-bullet:nth-child(1) {
    width: 141px;
    margin: 0;
  }

  .price-plan .swiper-pagination-bullet:nth-child(2),
  .price-plan .swiper-pagination-bullet:nth-child(4) {
    width: 89px;
    margin: 0;
  }

  .price-plan .swiper-pagination-bullet:nth-child(3) {
    width: 102px;
    margin: 0;
  }

  .price-plan .swiper-pagination-bullet:nth-child(5) {
    width: 130px;
    margin: 0;
  }

  .price-plan .swiper-pagination-bullet:nth-child(1)::after {
    content: "ホルモン療法プラン";
  }

  .price-plan .swiper-pagination-bullet:nth-child(2)::after {
    content: "漢方プラン";
  }

  .price-plan .swiper-pagination-bullet:nth-child(3)::after {
    content: "腟ケアプラン";
  }

  .price-plan .swiper-pagination-bullet:nth-child(4)::after {
    content: "美容プラン";
  }

  .price-plan .swiper-pagination-bullet:nth-child(5)::after {
    content: "ダイエットプラン";
  }

  .price-plan .swiper-pagination-bullet-active {
    background: #e66d54;
    border: none;
    color: #ffffff;
  }

  .title-number {
    position: absolute;
    top: -15px;
    left: 44%;
    font-size: 10px;
  }

  .price-plan-card-title {
    font-size: 18px;
    line-height: 160%;
  }

  .price-plan-card-price {
    display: flex;
    align-items: center;
    margin-bottom: 3px;
    gap: 2px;
  }

  .price-value {
    font-size: 32px;
    margin: auto 0;
    padding-top: 6px;
    padding-right: 2px;
    color: #333333;
  }

  .price-unit-1 {
    font-size: 18px;
    padding-top: 9px;
  }

  .price-unit-2 {
    font-size: 10px;
    line-height: 170%;
    padding: 1px 0 0 1px;
  }

  .price-plan-list-card-image-container-type1,
  .price-plan-list-card-image-container-type2 {
    min-height: 75px;
    height: 75px;
    margin-bottom: 8px;
  }

  .price-plan-list-card-image-container-type1 {
    width: 248px;
  }

  .price-plan-list-card-image-container-type2 {
    width: 218px;
  }

  .price-plan-list-card-image1,
  .price-plan-list-card-image2,
  .price-plan-list-card-image3,
  .price-plan-list-card-image4,
  .price-plan-list-card-image5 {
    height: 75px;
  }

  .price-plan-list-card-image1 {
    width: 248px;
    background-image: url("../img/renewal/aboutus-price-plan-imege1-mobile.png");
    background-size: 100% 100%;
  }

  .price-plan-list-card-image2 {
    width: 218px;
    background-image: url("../img/renewal/aboutus-price-plan-imege2.png");
    background-size: 100% 100%;
  }

  .price-plan-list-card-image3 {
    width: 218px;
    background-image: url("../img/renewal/aboutus-price-plan-imege3.png");
    background-size: 100% 100%;
  }

  .price-plan-list-card-image4 {
    width: 218px;
    background-image: url("../img/renewal/aboutus-price-plan-imege4.png");
    background-size: 97% 100%;
  }

  .price-plan-list-card-image5 {
    width: 218px;
    background-image: url("../img/renewal/aboutus-price-plan-imege5.png");
    background-size: 97% 100%;
  }

  .prescription-heading-type1,
  .prescription-heading-type2 {
    font-size: 13px;
    line-height: 170%;
    padding-top: 1px;
    margin-bottom: 7px;
  }

  .prescription-heading-type1::before,
  .prescription-heading-type2::before {
    width: 197px;
    right: 0;
  }

  .price-plan-list-card-prescription {
    gap: 23.5px;
  }

  .prescription-list::before {
    bottom: -12px;
    left: 0;
    width: 248px;
    height: 0;
    border: 0.5px dashed #c4c4c4;
  }

  .prescription-list-item {
    font-size: 10px;
    line-height: 170%;
    max-width: 180px;
  }

  .prescription-list-price {
    font-size: 10px;
    font-weight: 500;
    line-height: 170%;
  }

  .price-plan-regular-delivery-title {
    top: -33px;
    left: 17px;
    font-size: 18px;
    padding: 0 18px 5px 18px;
  }

  .price-plan-regular-delivery-title::before,
  .price-plan-regular-delivery-title::after {
    top: 24px;
  }

  .price-plan-regular-delivery-title::before {
    left: -4px;
  }

  .price-plan-regular-delivery-title::after {
    right: -4px;
  }

  .price-plan-regular-delivery-content {
    justify-content: center;
    width: 327px;
    height: 148px;
    padding: 16px 0 0.26px 3px;
    margin: 0 auto;
    gap: 10px;
  }

  .price-plan-regular-delivery-content-image {
    display: block;
    width: 100px;
    height: 100px;
  }

  .price-plan-regular-delivery-image {
    top: 0;
    left: 0;
    width: 100px;
    height: 100px;
    background-image: url("../img/renewal/aboutus-price-plan-delivery-image-mobile.png");
  }

  .price-plan-regular-delivery-content-list {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 180px;
    height: fit-content;
    padding-top: 2px;
    gap: 8px;
  }

  .regular-delivery-item {
    font-size: 13px;
    line-height: 170%;
    gap: 0;
  }

  .regular-delivery-item-check {
    position: relative;
    padding-left: 20px;
  }

  .regular-delivery-item-check:after {
    content: "";
    display: block;
    position: absolute;
    border-left: 2px solid #888888;
    border-bottom: 2px solid #888888;
    width: 10.5px;
    height: 6.5px;
    transform: rotate(-45deg);
    top: 30%;
    left: 0;
  }
}

@media (max-width: 500px) {
  .price-plan::before {
    top: -7.9%;
    background-image: url("../img/renewal/aboutus-price-plan-background-top-mobile.png");
    aspect-ratio: 375/80;
  }

  .price-plan::after {
    bottom: -7.9%;
    background-image: url("../img/renewal/aboutus-price-plan-background-bottom-mobile.png");
    aspect-ratio: 375/80;
  }
}

@media (max-width: 374px) {
  .price-plan::before {
    top: -6.9%;
    background-image: url("../img/renewal/aboutus-price-plan-background-top-mobile.png");
    aspect-ratio: 320/72;
  }

  .price-plan::after {
    bottom: -6.9%;
    background-image: url("../img/renewal/aboutus-price-plan-background-bottom-mobile.png");
    aspect-ratio: 320/72;
  }
}

/* ======================================= サポート ======================================= */
.support,
.support * {
  font-family: "Zen Kaku Gothic New";
}

.support {
  background-color: #ffffff;
}

.support-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  padding: 166px 0 64px 0;
  /* padding: calc(100vw / 1440 * 100 + 50px) 0 64px 0; */
}

.support-content-heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 396px;
  height: 106px;
  margin-bottom: 15px;
}

.support-title__wrapper {
  padding: 0 24px;
}

.support-content-title {
  position: relative;
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  color: #333333;
  padding-left: 16px;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-image: linear-gradient(90deg, #333333 50%, transparent 50%);
  background-size: 200%;
  background-position: 100% 0;
  opacity: 0;
}

.highlight-support {
  position: relative;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-image: linear-gradient(90deg, #e66d54 50%, transparent 50%);
  background-size: 200%;
  background-position: 100% 0;
  opacity: 0;
}

.title-animation03__wrapper.is-ScrollActive .support-content-title {
  animation: textAnimation 0.65s cubic-bezier(0.45, 0.05, 0.55, 0.95) forwards;
}

.title-animation03__wrapper.is-ScrollActive .highlight-support {
  animation: textAnimation 0.65s cubic-bezier(0.45, 0.05, 0.55, 0.95) forwards 0.2s;
}

.support-content-title::after {
  content: "";
  position: absolute;
  background-image: url("../img/renewal/aboutus-text-emphasis.png");
  background-repeat: no-repeat;
  background-size: contain;
  top: -8px;
  right: 24px;
  width: 33px;
  height: 15px;
  opacity: 0;
}

.title-animation03__wrapper.is-ScrollActive .support-content-title::after {
  animation: fadeIn 0.8s ease forwards 0.3s;
}

.support-content-subtitle {
  font-size: 18px;
  font-weight: 500;
  line-height: 180%;
  color: #333333;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-image: linear-gradient(90deg, #333333 50%, transparent 50%);
  background-size: 200%;
  background-position: 100% 0;
  opacity: 0;
}

.title-animation03__wrapper.is-ScrollActive .support-content-subtitle {
  animation: textAnimation 0.65s cubic-bezier(0.45, 0.05, 0.55, 0.95) forwards;
}

.support-content-list {
  display: flex;
  gap: 32px;
}

.support-content-list-card1-pc,
.support-content-list-card2-pc,
.support-content-list-card3-pc {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 312px;
  height: 312px;
  background-color: #f7eeea;
  border-radius: 8px;
  padding-top: 20px;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .support-content-list-card1-pc {
  animation: fadeInUp 1s ease forwards 0.8s;
}

.title-animation02__wrapper.is-ScrollActive .support-content-list-card2-pc {
  animation: fadeInUp 1s ease forwards 1.2s;
}

.title-animation02__wrapper.is-ScrollActive .support-content-list-card3-pc {
  animation: fadeInUp 1s ease forwards 1.6s;
}

.support-content-list-card1-pc {
  gap: 5px;
}

.support-content-list-card2-pc,
.support-content-list-card3-pc {
  gap: 9px;
}

.support-content-list-card1-mobile,
.support-content-list-card2-mobile,
.support-content-list-card3-mobile {
  display: none;
}

.support-content-list-card-title {
  font-size: 24px;
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.03em;
  text-align: center;
  color: #333333;
}

.support-content-list-card-text-type1,
.support-content-list-card-text-type2 {
  font-size: 13px;
  font-weight: 400;
  text-align: center;
  color: #333333;
}

.support-content-list-card-text-type1 {
  line-height: 180%;
}

.support-content-list-card-text-type2 {
  line-height: 150%;
}

.support-content-list-card-image1-container,
.support-content-list-card-image2-container,
.support-content-list-card-image3-container {
  background-size: contain;
  background-repeat: no-repeat;
  width: 312px;
  height: 200px;
  overflow: hidden;
}

.support-content-list-card-image1-container {
  background-image: url("../img/renewal/aboutus-support-image1-pc-large.png");
}

.support-content-list-card-image2-container {
  background-image: url("../img/renewal/aboutus-support-image2-pc-large.png");
}

.support-content-list-card-image3-container {
  background-image: url("../img/renewal/aboutus-support-image3-pc-large.png");
}

@media (max-width: 1279px) {
  .support-content-title {
    padding-left: 0;
    margin-bottom: -1px;
  }

  .support-content-title::after {
    top: -9px;
    right: 16px;
  }

  .support-content-heading {
    height: 98px;
    margin-bottom: 14px;
  }

  .support-content-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 670px;
    width: 100%;
    gap: 32px;
  }

  .support-content-list-card1-pc,
  .support-content-list-card2-pc,
  .support-content-list-card3-pc {
    height: 232px;
  }

  .support-content-list-card3-pc {
    flex: 0 0 100%;
    max-width: 312px;
  }

  .support-content-list-card-title {
    font-weight: 500;
  }

  .support-content-list-card-image1-container,
  .support-content-list-card-image2-container,
  .support-content-list-card-image3-container {
    background-size: contain;
    background-repeat: no-repeat;
    width: 187px;
    height: 120px;
    overflow: hidden;
  }

  .support-content-list-card-image1-container {
    margin-left: 3px;
  }

  .support-content-list-card-image3-container {
    background-image: url("../img/renewal/aboutus-support-image3-pc-medium.png");
  }
}

@media (max-width: 749px) {
  .support-content {
    padding: 109px 0 48px 0;
  }

  .support-content-heading {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: fit-content;
    height: fit-content;
    margin-bottom: 24px;
  }

  .support-content-title {
    font-size: 24px;
    margin-bottom: 0px;
  }

  .support-content-title::after {
    top: -3px;
    right: 18px;
    width: 18px;
    height: 10px;
  }

  .support-content-subtitle {
    font-size: 15px;
    line-height: 170%;
    color: #555555;
  }

  .support-content-list {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    justify-content: center;
    max-width: 400px;
    width: calc(100% - 48px);
    height: fit-content;
    gap: 24px;
  }

  .support-content-list-card1-pc,
  .support-content-list-card2-pc,
  .support-content-list-card3-pc {
    display: none;
    animation: none !important;
    opacity: 0 !important;
  }

  .title-animation02__wrapper.is-ScrollActive .support-content-list-card1-pc,
  .title-animation02__wrapper.is-ScrollActive .support-content-list-card2-pc,
  .title-animation02__wrapper.is-ScrollActive .support-content-list-card3-pc {
    animation: none !important;
  }

  .support-content-list-card1-mobile,
  .support-content-list-card2-mobile,
  .support-content-list-card3-mobile {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: fit-content;
    background-color: #f7eeea;
    border-radius: 8px;
    margin: 0 auto;
    gap: 8px;
    opacity: 0;
  }

  .title-animation02__wrapper.is-ScrollActive .support-content-list-card1-mobile {
    animation: fadeInUp 1s ease forwards 0.8s;
  }

  .title-animation02__wrapper.is-ScrollActive .support-content-list-card2-mobile {
    animation: fadeInUp 1s ease forwards 1.3s;
  }

  .title-animation02__wrapper.is-ScrollActive .support-content-list-card3-mobile {
    animation: fadeInUp 1s ease forwards 1.8s;
  }

  .support-content-list-card-image1-container,
  .support-content-list-card-image2-container,
  .support-content-list-card-image3-container {
    width: 90px;
    height: 112px;
    margin-left: 0;
  }

  .support-content-list-card-image1-container {
    background-image: url("../img/renewal/aboutus-support-image1-mobile.png");
  }

  .support-content-list-card-image2-container {
    background-image: url("../img/renewal/aboutus-support-image2-mobile.png");
  }

  .support-content-list-card-image3-container {
    background-size: cover;
    background-image: url("../img/renewal/aboutus-support-image3-mobile.png");
  }

  .support-content-list-card-content {
    display: flex;
    flex-direction: column;
    max-width: 213px;
    height: fit-content;
    gap: 6px;
  }

  .support-content-list-card-title {
    font-size: 18px;
    font-weight: 500;
    padding-bottom: 2px;
    text-align: left;
  }

  .support-content-list-card-text-type1,
  .support-content-list-card-text-type2 {
    font-size: 12px;
    line-height: 150%;
    text-align: left;
  }
}

/* ======================================= お客様の声 ======================================= */
.user-voice,
.user-voice * {
  font-family: "Zen Kaku Gothic New";
}

.user-voice {
  background-color: #fdf4ee;
}

.user-voice-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 1048px;
  margin: 0 auto;
  padding: 56px 0 56px 0;
  gap: 16px;
}

.user-voice-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  color: #333333;
  opacity: 0;
}

.user-voice-list .swiper-slide:last-child {
  margin-right: 0px;
}

.title-animation02__wrapper.is-ScrollActive .user-voice-heading {
  animation: fadeInUp 1s ease forwards;
}

.user-voice-content {
  position: relative;
  display: flex;
  justify-content: flex-start;
  width: 1048px;
  /* height: 347px; */
  padding: 22px 24px 0 24px;
}

.user-voice-list {
  display: flex;
  justify-content: center;
  max-width: 1000px;
  width: 100%;
  /* height: 280px; */
  padding: 46px 55px 38px 55px;
  gap: 64px;
  background-color: #ffffff;
  border-radius: 8px;
  filter: drop-shadow(6px 6px 0px rgba(173, 173, 173, 0.2));
  z-index: 3;
}

.sp-user-voice {
  display: none;
}

.user-voice-bubble-left {
  position: absolute;
  background-image: url("../img/renewal/aboutus-user-voice-bubble-left.png");
  background-size: cover;
  background-repeat: no-repeat;
  top: 0;
  left: 0;
  width: 176px;
  height: 101.01px;
  z-index: 2;
}

.user-voice-bubble-right {
  position: absolute;
  background-image: url("../img/renewal/aboutus-user-voice-bubble-right.png");
  background-size: cover;
  background-repeat: no-repeat;
  top: 232px;
  right: 0;
  width: 252px;
  height: 116px;
  z-index: 2;
}

.voice-card {
  position: relative;
  text-decoration: none;
  color: inherit;
  display: block;
  transition: transform 0.3s ease;
}

.voice-card::before {
  content: "";
  position: absolute;
  top: -13px;
  right: -32px;
  width: 0;
  height: 217px;
  border: 0.8px solid #e0e0e0;
}

.voice-card:last-child::before {
  display: none;
}

.voice-card:hover {
  color: #e66d54; /* ホバー時の文字色を変更 */
}

.voice-card:hover .voice-content h3 {
  color: #e66d54; /* ホバー時に見出しの色だけ変更 */
}

.voice-item {
  display: flex;
  flex-direction: column;
  width: 254px;
  /* height: 196px; */
  gap: 10px;
}

.voice-header {
  display: flex;
  width: 100%;
  height: 100px;
  gap: 11px;
}

.voice-image {
  position: relative;
  width: 100px;
  height: 100px;
}

.voice-image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 96px;
  height: 96px;
}

.voice-image::before {
  content: "";
  position: absolute;
  top: 4px;
  left: 4px;
  background-color: #e66d54;
  width: 96px;
  height: 96px;
}

.voice-info {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding-top: 25px;
}

.voice-number {
  font-family: Roboto !important;
  font-size: 15px;
  font-weight: 500;
  line-height: 180%;
  color: #e66d54;
}

.voice-profile {
  display: flex;
  font-size: 15px;
  font-weight: 400;
  line-height: 180%;
  color: #888888;
  gap: 6px;
}

.voice-content {
  width: 100%;
  height: fit-content;
}

.voice-content h3 {
  font-size: 18px;
  font-weight: 500;
  line-height: 170%;
  color: #555555;
}

.user-voice .swiper-pagination {
  display: none;
}

.user-voice-button {
  display: flex;
  justify-content: center;
  width: 311px;
  height: fit-content;
  background-color: #ffffff;
  border: 1px solid #888888;
  border-radius: 28px;
  padding: 9px 16px;
  margin-top: 40px;
}

.user-voice-button-text {
  font-size: 15px;
  font-weight: 700;
  line-height: 180%;
  color: #888888;
}

.user-voice-button:hover .user-voice-button-text {
  color: #e66d54;
}

@media (max-width: 1279px) {
  .user-voice-inner {
    width: 100%;
  }

  .user-voice-content {
    max-width: 1066px;
    width: 100%;
    /* height: 347px; */
    margin: 0 40px 0 40px;
  }

  .user-voice-list {
    justify-content: flex-start;
    max-width: 1066px;
    padding: 46px 55px 38px 55px;
    gap: 0;
  }

  .pc-user-voice {
    display: none;
  }

  .sp-user-voice {
    display: block;
    width: 100%;
  }

  .sp-user-voice .swiper-slide {
    width: 286px !important;
    flex-shrink: 0;
  }

  .voice-card::before {
    top: -14px;
    right: 0;
  }
}

@media (max-width: 1066px) {
  .user-voice-content {
    width: 100%;
    /* height: 347px; */
    margin: 0 0 0 80px;
  }

  .user-voice-bubble-right {
    right: 80px;
  }
}

@media (max-width: 749px) {
  .user-voice-inner {
    padding: 56px 0 47px 0;
    gap: 24px;
  }

  .user-voice-heading {
    font-size: 24px;
  }

  .user-voice-list .swiper-slide:last-child {
    margin-right: 24px;
  }

  .user-voice-content {
    height: 300px;
    padding: 16px 16px 0 16px;
    margin: 0 0 0 32px;
  }

  .user-voice-list {
    height: 100%;
    padding: 0;
    background-color: inherit;
    border-radius: 0;
    filter: none;
  }

  .user-voice-bubble-right {
    top: 170px;
    right: 32px;
  }

  .voice-card {
    height: 235px;
    background-color: #ffffff;
    border-radius: 8px;
    filter: drop-shadow(6px 6px 0px rgba(173, 173, 173, 0.2));
    padding: 24px 16px;
  }

  .voice-card::before {
    display: none;
  }

  .voice-item {
    /* height: 187px; */
  }

  .voice-header {
    gap: 16px;
  }

  .voice-info {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    padding-top: 25px;
  }

  .voice-number {
    font-family: Zen Kaku Gothic New !important;
    font-size: 13px;
    font-weight: 700;
    line-height: 170%;
  }

  .voice-profile {
    font-size: 13px;
    line-height: 170%;
    padding-top: 4px;
    gap: 9px;
  }

  .voice-content h3 {
    font-size: 15px;
  }

  .user-voice .swiper-pagination {
    position: absolute;
    width: 100%;
    display: flex;
    justify-content: center;
    bottom: 0.5px;
    left: -4.5%;
    z-index: 10;
  }

  .user-voice .swiper-pagination-bullet {
    width: 6px;
    height: 6px;
    background-color: inherit;
    opacity: 1;
    margin: 0 4px !important;
    border: 0.5px solid #888888;
  }

  .user-voice .swiper-pagination-bullet-active {
    background-color: #888888;
  }

  .user-voice-button {
    padding: 8px 16px 6px 16px;
    margin-top: 0;
  }

  .user-voice-button-text {
    font-size: 13px;
    line-height: 170%;
  }
}

/* ======================================= よくある質問 ======================================= */
.faq,
.faq * {
  font-family: "Zen Kaku Gothic New";
}

.faq {
  background-color: #ffffff;
  padding: 57px 0;
}

.faq-content {
  display: flex;
  flex-direction: column;
  width: 800px;
  margin: 0 auto;
  gap: 24px;
}

.faq-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  text-align: center;
  color: #333333;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .faq-heading {
  animation: fadeInUp 1s ease forwards;
}

.faq-list {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 24px;
}

.faq-item {
  width: 100%;
  height: fit-content;
  padding: 8px 24px;
  background: #ffffff;
  border-radius: 5px;
  overflow: hidden;
  transition: box-shadow 0.2s ease;
  cursor: pointer;
}

.faq-item:hover {
  box-shadow: 6px 6px 0 rgba(173, 173, 173, 0.2);
}

.faq-question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 2px;
}

.faq-question-content {
  position: relative;
  display: flex;
  align-items: center;
  width: calc(100% - 30px);
}

.faq-answer {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  padding: 0 22px 0 0;
  transition: max-height 0.2s ease, opacity 0.2s ease, padding 0.2s ease;
}

.faq-answer.active {
  max-height: 150px;
  opacity: 1;
  padding: 21px 22px 10px 0;
}

.q-mark,
.a-mark {
  font-size: 24px;
  font-weight: 500;
  line-height: 100%;
  min-width: 20px;
}

.q-mark {
  margin-right: 6px;
  color: #e66d54;
}

.a-mark {
  margin-right: 8px;
  color: #888888;
}

.question-text {
  font-size: 18px;
  font-weight: 500;
  line-height: 180%;
  color: #333333;
}

.answer-text {
  font-size: 15px;
  font-weight: 400;
  line-height: 180%;
  color: #333333;
}

.toggle-btn {
  position: relative;
  display: block;
  width: 30px;
  height: 20px;
  cursor: pointer;
}

.toggle-btn:before {
  content: "";
  position: absolute;
  top: 9px;
  left: 8px;
  width: 20px;
  height: 2px;
  background-color: #e66d54;
  transition: all 0.3s ease;
}

.toggle-btn:after {
  content: "";
  position: absolute;
  top: 0;
  left: 17px;
  height: 20px;
  width: 2px;
  background-color: #e66d54;
  transition: all 0.2s ease;
  transform-origin: center;
}

.toggle-btn.active:after {
  transform: rotate(90deg);
  opacity: 0;
}

.faq-answer.active + .faq-question .toggle-btn:after,
.faq-question:has(+ .faq-answer.active) .toggle-btn:after {
  transform: rotate(90deg);
  opacity: 0;
}

@media (max-width: 879px) {
  .faq-content {
    width: calc(100% - 80px);
    margin: 0 40px;
  }
}

@media (max-width: 749px) {
  .faq-content {
    max-width: 400px;
    width: calc(100% - 48px);
    margin: 0 24px;
  }

  .faq-heading {
    font-size: 24px;
  }

  .faq-list {
    gap: 25px;
  }

  .faq-item {
    padding: 8px 16px;
  }

  .faq-question-content {
    width: calc(100% - 20px);
  }

  .faq-answer {
    padding: 19px 22px 7px 0;
  }

  .q-mark,
  .a-mark {
    font-size: 20px;
    min-width: 15px;
  }

  .q-mark {
    margin-right: 8px;
  }

  .a-mark {
    margin-right: 11px;
  }

  .question-text {
    font-size: 15px;
    line-height: 170%;
  }

  .answer-text {
    font-size: 13px;
    line-height: 170%;
  }

  .toggle-btn {
    width: 28px;
  }

  .toggle-btn:before {
    transition: all 0.2s ease;
  }

  .toggle-btn:after {
    transition: all 0.2s ease;
    transform-origin: center;
  }

  .toggle-btn.active:after {
    transform: rotate(90deg);
    opacity: 0;
  }
}

/* ======================================= 医師監修コラム ======================================= */
.medically-reviewed-article,
.medically-reviewed-article * {
  font-family: "Zen Kaku Gothic New";
}

.medically-reviewed-article {
  background-color: #f7eeea;
}

.medically-reviewed-article-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 66px 0;
  gap: 20px;
}

.medically-reviewed-article-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  color: #333333;
  margin-bottom: 22px;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .medically-reviewed-article-heading {
  animation: fadeInUp 1s ease forwards;
}

.medically-reviewed-article-list {
  max-width: 1000px;
  width: 100%;
  height: auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: 27px;
  row-gap: 20px;
  margin-bottom: 7px;
}

.article-card {
  display: flex;
  flex-direction: column;
  width: 312px;
  text-decoration: none;
  color: inherit;
  transition: transform 0.3s ease;
  background-color: #ffffff;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  margin: 6px 0 6px 6px;
  padding-bottom: 12px;
  gap: 12px;
  transition: box-shadow 0.2s ease;
}

.article-card:hover {
  box-shadow: 6px 6px 0 rgba(173, 173, 173, 0.2);
}

.article-card:hover .article-title h3 {
  color: #e66d54;
}

.article-image {
  position: relative;
  display: block;
  width: 100%;
  height: 175px;
  overflow: hidden;
}

.article-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
}

.article-content {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: auto;
  padding: 0 12px 0 10px;
  gap: 8px;
}

.article-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: fit-content;
}

.article-date {
  font-size: 13px;
  font-weight: 500;
  line-height: 180%;
  color: #888888;
}

.article-category {
  padding: 0 7px;
  border: 1px solid #51767d;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 500;
  line-height: 160%;
  color: #51767d;
}

.article-title {
  width: 100%;
}

.article-title h3 {
  font-size: 15px;
  font-weight: 500;
  line-height: 160%;
  color: #333333;
}

.medically-reviewed-article-button {
  display: flex;
  justify-content: center;
  width: 311px;
  height: 47px;
  background-color: #ffffff;
  border: 1px solid #888888;
  border-radius: 28px;
  padding: 10px 16px;
}

.medically-reviewed-article-button-text {
  font-size: 15px;
  font-weight: 700;
  line-height: 180%;
  color: #888888;
}

.medically-reviewed-article-button:hover .medically-reviewed-article-button-text {
  color: #e66d54;
}

@media (max-width: 1279px) {
  .medically-reviewed-article-list {
    max-width: 680px;
    grid-template-columns: repeat(2, 1fr);
  }

  .tablet-hide {
    display: none !important;
  }
}

@media (max-width: 749px) {
  .medically-reviewed-article-inner {
    padding: 48px 0;
    gap: 24px;
  }

  .medically-reviewed-article-heading {
    font-size: 24px;
    margin-bottom: 0;
  }

  .medically-reviewed-article-list {
    max-width: 320px;
    grid-template-columns: 1fr;
    margin-bottom: 0;
  }

  .article-card {
    margin: 0 auto;
    gap: 10px;
  }

  .article-content {
    padding: 0 11px;
    gap: 8px;
  }

  .article-info {
    margin-bottom: 3px;
  }

  .article-date {
    font-size: 12px;
    line-height: 170%;
  }

  .article-category {
    padding: 0 7px;
    font-size: 12px;
    line-height: 170%;
    height: 20px;
  }

  .article-title h3 {
    font-size: 13px;
  }

  .medically-reviewed-article-button {
    height: 38px;
    padding: 0;
    align-items: center;
  }

  .medically-reviewed-article-button-text {
    font-size: 13px;
    line-height: 170%;
  }

  .mobile-hide {
    display: none !important;
  }
}

/* ======================================= 利用ガイド ======================================= */
.usage-guide,
.usage-guide * {
  font-family: "Zen Kaku Gothic New";
}

.usage-guide {
  background-color: #ffffff;
}

.usage-guide-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 55px 0;
  gap: 24px;
}

.usage-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  color: #333333;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .usage-heading {
  animation: fadeInUp 1s ease forwards;
}

.usage-video {
  max-width: 580px;
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}

@media (max-width: 749px) {
  .usage-guide-content {
    padding: 47px 0;
    gap: 24px;
  }

  .usage-heading {
    font-size: 24px;
    line-height: 150%;
    text-align: center;
  }

  .usage-video {
    max-width: 327px;
    width: 100%;
    height: auto;
    aspect-ratio: 16/9;
  }
}

/* 余白用のダミースライド */
.price-plan-dummy-slide {
  width: 32px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

/* Safari専用のスタイル - -webkit-backdrop-filterはSafariが対応している特有のプロパティ */
@supports (-webkit-backdrop-filter: none) and (not (backdrop-filter: none)) {
  .price-plan-dummy-slide {
    width: 32px !important;
    height: 481px !important;
    opacity: 0 !important;
    pointer-events: none !important;
    margin-right: 0 !important;
    flex-shrink: 0 !important;
  }
}

.price-plan-list-card-image-container-type1,
.price-plan-list-card-image-container-type2 {
  position: relative;
  display: block;
  min-height: 90px;
  height: 90px;
}

.price-plan-list-card-image-container-type1 {
  width: 272px;
}

.price-plan-list-card-image-container-type2 {
  width: 280px;
}

.price-plan-list-card-image1,
.price-plan-list-card-image2,
.price-plan-list-card-image3,
.price-plan-list-card-image4,
.price-plan-list-card-image5 {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  height: 90px;
  background-repeat: no-repeat;
}

.price-plan-list-card-image1 {
  width: 272px;
  background-image: url("../img/renewal/aboutus-price-plan-imege1-pc.png");
  background-size: 100% 100%;
}

.price-plan-list-card-image2 {
  width: 280px;
  background-image: url("../img/renewal/aboutus-price-plan-imege2.png");
  background-size: 100% 100%;
}

.price-plan-list-card-image3 {
  width: 280px;
  background-image: url("../img/renewal/aboutus-price-plan-imege3.png");
  background-size: 100% 100%;
}

.price-plan-list-card-image4 {
  width: 280px;
  background-image: url("../img/renewal/aboutus-price-plan-imege4.png");
  background-size: 97% 100%;
}

.price-plan-list-card-image5 {
  width: 280px;
  background-image: url("../img/renewal/aboutus-price-plan-imege5.png");
  background-size: 97% 100%;
}

.prescription-heading-type1,
.prescription-heading-type2 {
  position: relative;
  width: 100%;
  font-size: 15px;
  font-weight: 700;
  line-height: 180%;
  text-align: left;
  color: #888888;
}

.prescription-heading-type1::before,
.prescription-heading-type2::before {
  content: "";
  position: absolute;
  top: 50%;
  width: 223px;
  height: 0;
  border: 0.5px solid #c4c4c4;
}

.prescription-heading-type1::before {
  right: 6px;
}

.prescription-heading-type2::before {
  right: 0;
}

.price-plan-list-card-prescription {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 31.5px;
}

.prescription-list {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}

.prescription-list::before {
  content: "";
  position: absolute;
  bottom: -16px;
  left: 3px;
  width: 280px;
  height: 0;
  border: 0.5px dashed #c4c4c4;
}

.prescription-list-end {
  display: flex;
  justify-content: space-between;
  width: 100%;
  align-items: center;
}

.prescription-list-item {
  font-size: 12px;
  font-weight: 400;
  line-height: 160%;
  color: #333333;
  max-width: 205px;
}

.prescription-list-price {
  display: flex;
  flex-direction: column;
  justify-content: center;
  font-size: 12px;
  font-weight: 400;
  line-height: 160%;
  color: #333333;
  text-align: center;
}

.price-plan-regular-delivery {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.price-plan-regular-delivery-title {
  position: absolute;
  top: -35px;
  left: 67px;
  padding: 0 11px 5px 12px;
  font-size: 24px;
  font-weight: 700;
  line-height: 160%;
  letter-spacing: 0.03em;
  text-align: center;
  color: #333333;
  background-color: #f7eeea;
}

.price-plan-regular-delivery-title::before,
.price-plan-regular-delivery-title::after {
  content: "";
  position: absolute;
  top: 31px;
  width: 26.4px; /* 斜線の長さ */
  height: 1px; /* 斜線の太さ */
  background-color: #c4c4c4;
}

.price-plan-regular-delivery-title::before {
  left: -5px;
  transform: rotate(52.7deg); /* 左側の斜線の角度 */
}

.price-plan-regular-delivery-title::after {
  right: -5px;
  transform: rotate(-52.7deg); /* 右側の斜線の角度 */
}

.price-plan-regular-delivery-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 700px;
  height: 160px;
  border-width: 1px 0px 1px 0px;
  border-style: solid;
  border-color: #c4c4c4;
  padding: 10.74px 54px 0.26px 54px;
  gap: 36.5px;
}

.price-plan-regular-delivery-content-image {
  position: relative;
  width: 200px;
  height: 147px;
}

.price-plan-regular-delivery-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 200px;
  height: 147px;
  background-image: url("../img/renewal/aboutus-price-plan-delivery-image-pc.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  overflow: hidden;
}

.price-plan-regular-delivery-content-list {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 352px;
  height: fit-content;
}

.regular-delivery-item {
  display: flex;
  align-items: flex-start;
  font-size: 18px;
  font-weight: 500;
  line-height: 200%;
  color: #333333;
  gap: 0;
}

.regular-delivery-item-check {
  position: relative;
  padding-left: 24px;
}

.regular-delivery-item-check:after {
  content: "";
  display: block;
  position: absolute;
  border-left: 2px solid #888888;
  border-bottom: 2px solid #888888;
  width: 12.5px;
  height: 7.5px;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  top: 12.5px;
  left: 0;
}

@media (max-width: 1909px) {
  .pc-price-plan {
    width: 100%;
  }
}

@media (max-width: 1440px) {
  .price-plan::before {
    top: -13.2%;
  }

  .price-plan::after {
    bottom: -13.2%;
  }
}

@media (max-width: 1279px) {
  .price-plan::before {
    top: -11%;
    aspect-ratio: 750/83.33;
  }

  .price-plan::after {
    bottom: -11%;
    aspect-ratio: 750/83.33;
  }

  .price-plan-list {
    padding-left: 80px;
    /* margin: 0 0 94px 80px; */
  }

  .price-plan-card-type2.swiper-slide:last-child {
    margin-right: 44px;
  }
}

@media (max-width: 1024px) {
  .price-plan::before {
    top: -7.4%;
    aspect-ratio: 750/83.33;
  }

  .price-plan::after {
    bottom: -8%;
    aspect-ratio: 750/83.33;
  }
}

@media (max-width: 749px) {
  .price-plan::before {
    top: -10.6%;
    background-image: url("../img/renewal/aboutus-price-plan-background-top-mobile.png");
    aspect-ratio: 375/80;
  }

  .price-plan::after {
    bottom: -10.5%;
    background-image: url("../img/renewal/aboutus-price-plan-background-bottom-mobile.png");
    aspect-ratio: 375/80;
  }

  .price-plan-content {
    padding: 24px 0;
    gap: 32px;
  }

  .price-plan-heading {
    font-size: 24px;
    margin-bottom: 1px;
  }

  .price-plan-text {
    font-size: 15px;
    line-height: 170%;
    color: #555555;
    text-align: center;
    width: 327px;
    margin-bottom: 0;
  }

  .price-plan-list {
    padding-left: 24px;
    padding-top: 83px;
    margin-bottom: 34px;
  }

  .pc-price-plan .swiper-slide {
    margin-right: 16px;
  }

  .price-plan-card-type1,
  .price-plan-card-type2 {
    width: 280px;
    height: 401px;
    padding: 32px 16px 0 16px;
    gap: 6px;
  }

  .price-plan-card-type2.swiper-slide:last-child {
    /* margin-right: 24px; */
  }

  .price-plan .swiper-pagination {
    position: absolute;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 340px;
    height: fit-content;
    gap: 8px;
    z-index: 10;
  }

  .price-plan .swiper-pagination-bullet {
    height: 30px;
    padding: 4px 11px;
    background: #ffffff;
    border: 1px solid #888888;
    border-radius: 28px;
    font-family: Zen Kaku Gothic New;
    font-size: 13px;
    font-weight: 500;
    line-height: 170%;
    color: #888888;
    text-align: center;
    margin: 0;
    opacity: 1;
  }

  .price-plan .swiper-pagination-bullet:nth-child(1) {
    width: 141px;
    margin: 0;
  }

  .price-plan .swiper-pagination-bullet:nth-child(2),
  .price-plan .swiper-pagination-bullet:nth-child(4) {
    width: 89px;
    margin: 0;
  }

  .price-plan .swiper-pagination-bullet:nth-child(3) {
    width: 102px;
    margin: 0;
  }

  .price-plan .swiper-pagination-bullet:nth-child(5) {
    width: 130px;
    margin: 0;
  }

  .price-plan .swiper-pagination-bullet:nth-child(1)::after {
    content: "ホルモン療法プラン";
  }

  .price-plan .swiper-pagination-bullet:nth-child(2)::after {
    content: "漢方プラン";
  }

  .price-plan .swiper-pagination-bullet:nth-child(3)::after {
    content: "腟ケアプラン";
  }

  .price-plan .swiper-pagination-bullet:nth-child(4)::after {
    content: "美容プラン";
  }

  .price-plan .swiper-pagination-bullet:nth-child(5)::after {
    content: "ダイエットプラン";
  }

  .price-plan .swiper-pagination-bullet-active {
    background: #e66d54;
    border: none;
    color: #ffffff;
  }

  .title-number {
    position: absolute;
    top: -15px;
    left: 44%;
    font-size: 10px;
  }

  .price-plan-card-title {
    font-size: 18px;
    line-height: 160%;
  }

  .price-plan-card-price {
    display: flex;
    align-items: center;
    margin-bottom: 3px;
    gap: 2px;
  }

  .price-value {
    font-size: 32px;
    margin: auto 0;
    padding-top: 6px;
    padding-right: 2px;
    color: #333333;
  }

  .price-unit-1 {
    font-size: 18px;
    padding-top: 9px;
  }

  .price-unit-2 {
    font-size: 10px;
    line-height: 170%;
    padding: 1px 0 0 1px;
  }

  .price-plan-list-card-image-container-type1,
  .price-plan-list-card-image-container-type2 {
    min-height: 75px;
    height: 75px;
    margin-bottom: 8px;
  }

  .price-plan-list-card-image-container-type1 {
    width: 248px;
  }

  .price-plan-list-card-image-container-type2 {
    width: 218px;
  }

  .price-plan-list-card-image1,
  .price-plan-list-card-image2,
  .price-plan-list-card-image3,
  .price-plan-list-card-image4,
  .price-plan-list-card-image5 {
    height: 75px;
  }

  .price-plan-list-card-image1 {
    width: 248px;
    background-image: url("../img/renewal/aboutus-price-plan-imege1-mobile.png");
    background-size: 100% 100%;
  }

  .price-plan-list-card-image2 {
    width: 218px;
    background-image: url("../img/renewal/aboutus-price-plan-imege2.png");
    background-size: 100% 100%;
  }

  .price-plan-list-card-image3 {
    width: 218px;
    background-image: url("../img/renewal/aboutus-price-plan-imege3.png");
    background-size: 100% 100%;
  }

  .price-plan-list-card-image4 {
    width: 218px;
    background-image: url("../img/renewal/aboutus-price-plan-imege4.png");
    background-size: 97% 100%;
  }

  .price-plan-list-card-image5 {
    width: 218px;
    background-image: url("../img/renewal/aboutus-price-plan-imege5.png");
    background-size: 97% 100%;
  }

  .prescription-heading-type1,
  .prescription-heading-type2 {
    font-size: 13px;
    line-height: 170%;
    padding-top: 1px;
    margin-bottom: 7px;
  }

  .prescription-heading-type1::before,
  .prescription-heading-type2::before {
    width: 197px;
    right: 0;
  }

  .price-plan-list-card-prescription {
    gap: 23.5px;
  }

  .prescription-list::before {
    bottom: -12px;
    left: 0;
    width: 248px;
    height: 0;
    border: 0.5px dashed #c4c4c4;
  }

  .prescription-list-item {
    font-size: 10px;
    line-height: 170%;
    max-width: 180px;
  }

  .prescription-list-price {
    font-size: 10px;
    font-weight: 500;
    line-height: 170%;
  }

  .price-plan-regular-delivery-title {
    top: -33px;
    left: 17px;
    font-size: 18px;
    padding: 0 18px 5px 18px;
  }

  .price-plan-regular-delivery-title::before,
  .price-plan-regular-delivery-title::after {
    top: 24px;
  }

  .price-plan-regular-delivery-title::before {
    left: -4px;
  }

  .price-plan-regular-delivery-title::after {
    right: -4px;
  }

  .price-plan-regular-delivery-content {
    justify-content: center;
    width: 327px;
    height: 148px;
    padding: 16px 0 0.26px 3px;
    margin: 0 auto;
    gap: 10px;
  }

  .price-plan-regular-delivery-content-image {
    display: block;
    width: 100px;
    height: 100px;
  }

  .price-plan-regular-delivery-image {
    top: 0;
    left: 0;
    width: 100px;
    height: 100px;
    background-image: url("../img/renewal/aboutus-price-plan-delivery-image-mobile.png");
  }

  .price-plan-regular-delivery-content-list {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 180px;
    height: fit-content;
    padding-top: 2px;
    gap: 8px;
  }

  .regular-delivery-item {
    font-size: 13px;
    line-height: 170%;
    gap: 0;
  }

  .regular-delivery-item-check {
    position: relative;
    padding-left: 20px;
  }

  .regular-delivery-item-check:after {
    content: "";
    display: block;
    position: absolute;
    border-left: 2px solid #888888;
    border-bottom: 2px solid #888888;
    width: 10.5px;
    height: 6.5px;
    transform: rotate(-45deg);
    top: 30%;
    left: 0;
  }
}

@media (max-width: 500px) {
  .price-plan::before {
    top: -7.9%;
    background-image: url("../img/renewal/aboutus-price-plan-background-top-mobile.png");
    aspect-ratio: 375/80;
  }

  .price-plan::after {
    bottom: -7.9%;
    background-image: url("../img/renewal/aboutus-price-plan-background-bottom-mobile.png");
    aspect-ratio: 375/80;
  }
}

@media (max-width: 374px) {
  .price-plan::before {
    top: -6.9%;
    background-image: url("../img/renewal/aboutus-price-plan-background-top-mobile.png");
    aspect-ratio: 320/72;
  }

  .price-plan::after {
    bottom: -6.9%;
    background-image: url("../img/renewal/aboutus-price-plan-background-bottom-mobile.png");
    aspect-ratio: 320/72;
  }
}

/* ======================================= サポート ======================================= */
.support,
.support * {
  font-family: "Zen Kaku Gothic New";
}

.support {
  background-color: #ffffff;
}

.support-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  padding: 166px 0 64px 0;
  /* padding: calc(100vw / 1440 * 100 + 50px) 0 64px 0; */
}

.support-content-heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 396px;
  height: 106px;
  margin-bottom: 15px;
}

.support-title__wrapper {
  padding: 0 24px;
}

.support-content-title {
  position: relative;
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  color: #333333;
  padding-left: 16px;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-image: linear-gradient(90deg, #333333 50%, transparent 50%);
  background-size: 200%;
  background-position: 100% 0;
  opacity: 0;
}

.highlight-support {
  position: relative;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-image: linear-gradient(90deg, #e66d54 50%, transparent 50%);
  background-size: 200%;
  background-position: 100% 0;
  opacity: 0;
}

.title-animation03__wrapper.is-ScrollActive .support-content-title {
  animation: textAnimation 0.65s cubic-bezier(0.45, 0.05, 0.55, 0.95) forwards;
}

.title-animation03__wrapper.is-ScrollActive .highlight-support {
  animation: textAnimation 0.65s cubic-bezier(0.45, 0.05, 0.55, 0.95) forwards 0.2s;
}

.support-content-title::after {
  content: "";
  position: absolute;
  background-image: url("../img/renewal/aboutus-text-emphasis.png");
  background-repeat: no-repeat;
  background-size: contain;
  top: -8px;
  right: 24px;
  width: 33px;
  height: 15px;
  opacity: 0;
}

.title-animation03__wrapper.is-ScrollActive .support-content-title::after {
  animation: fadeIn 0.8s ease forwards 0.3s;
}

.support-content-subtitle {
  font-size: 18px;
  font-weight: 500;
  line-height: 180%;
  color: #333333;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-image: linear-gradient(90deg, #333333 50%, transparent 50%);
  background-size: 200%;
  background-position: 100% 0;
  opacity: 0;
}

.title-animation03__wrapper.is-ScrollActive .support-content-subtitle {
  animation: textAnimation 0.65s cubic-bezier(0.45, 0.05, 0.55, 0.95) forwards;
}

.support-content-list {
  display: flex;
  gap: 32px;
}

.support-content-list-card1-pc,
.support-content-list-card2-pc,
.support-content-list-card3-pc {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 312px;
  height: 312px;
  background-color: #f7eeea;
  border-radius: 8px;
  padding-top: 20px;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .support-content-list-card1-pc {
  animation: fadeInUp 1s ease forwards 0.8s;
}

.title-animation02__wrapper.is-ScrollActive .support-content-list-card2-pc {
  animation: fadeInUp 1s ease forwards 1.2s;
}

.title-animation02__wrapper.is-ScrollActive .support-content-list-card3-pc {
  animation: fadeInUp 1s ease forwards 1.6s;
}

.support-content-list-card1-pc {
  gap: 5px;
}

.support-content-list-card2-pc,
.support-content-list-card3-pc {
  gap: 9px;
}

.support-content-list-card1-mobile,
.support-content-list-card2-mobile,
.support-content-list-card3-mobile {
  display: none;
}

.support-content-list-card-title {
  font-size: 24px;
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.03em;
  text-align: center;
  color: #333333;
}

.support-content-list-card-text-type1,
.support-content-list-card-text-type2 {
  font-size: 13px;
  font-weight: 400;
  text-align: center;
  color: #333333;
}

.support-content-list-card-text-type1 {
  line-height: 180%;
}

.support-content-list-card-text-type2 {
  line-height: 150%;
}

.support-content-list-card-image1-container,
.support-content-list-card-image2-container,
.support-content-list-card-image3-container {
  background-size: contain;
  background-repeat: no-repeat;
  width: 312px;
  height: 200px;
  overflow: hidden;
}

.support-content-list-card-image1-container {
  background-image: url("../img/renewal/aboutus-support-image1-pc-large.png");
}

.support-content-list-card-image2-container {
  background-image: url("../img/renewal/aboutus-support-image2-pc-large.png");
}

.support-content-list-card-image3-container {
  background-image: url("../img/renewal/aboutus-support-image3-pc-large.png");
}

@media (max-width: 1279px) {
  .support-content-title {
    padding-left: 0;
    margin-bottom: -1px;
  }

  .support-content-title::after {
    top: -9px;
    right: 16px;
  }

  .support-content-heading {
    height: 98px;
    margin-bottom: 14px;
  }

  .support-content-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 670px;
    width: 100%;
    gap: 32px;
  }

  .support-content-list-card1-pc,
  .support-content-list-card2-pc,
  .support-content-list-card3-pc {
    height: 232px;
  }

  .support-content-list-card3-pc {
    flex: 0 0 100%;
    max-width: 312px;
  }

  .support-content-list-card-title {
    font-weight: 500;
  }

  .support-content-list-card-image1-container,
  .support-content-list-card-image2-container,
  .support-content-list-card-image3-container {
    background-size: contain;
    background-repeat: no-repeat;
    width: 187px;
    height: 120px;
    overflow: hidden;
  }

  .support-content-list-card-image1-container {
    margin-left: 3px;
  }

  .support-content-list-card-image3-container {
    background-image: url("../img/renewal/aboutus-support-image3-pc-medium.png");
  }
}

@media (max-width: 749px) {
  .support-content {
    padding: 109px 0 48px 0;
  }

  .support-content-heading {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: fit-content;
    height: fit-content;
    margin-bottom: 24px;
  }

  .support-content-title {
    font-size: 24px;
    margin-bottom: 0px;
  }

  .support-content-title::after {
    top: -3px;
    right: 18px;
    width: 18px;
    height: 10px;
  }

  .support-content-subtitle {
    font-size: 15px;
    line-height: 170%;
    color: #555555;
  }

  .support-content-list {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    justify-content: center;
    max-width: 400px;
    width: calc(100% - 48px);
    height: fit-content;
    gap: 24px;
  }

  .support-content-list-card1-pc,
  .support-content-list-card2-pc,
  .support-content-list-card3-pc {
    display: none;
    animation: none !important;
    opacity: 0 !important;
  }

  .title-animation02__wrapper.is-ScrollActive .support-content-list-card1-pc,
  .title-animation02__wrapper.is-ScrollActive .support-content-list-card2-pc,
  .title-animation02__wrapper.is-ScrollActive .support-content-list-card3-pc {
    animation: none !important;
  }

  .support-content-list-card1-mobile,
  .support-content-list-card2-mobile,
  .support-content-list-card3-mobile {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: fit-content;
    background-color: #f7eeea;
    border-radius: 8px;
    margin: 0 auto;
    gap: 8px;
    opacity: 0;
  }

  .title-animation02__wrapper.is-ScrollActive .support-content-list-card1-mobile {
    animation: fadeInUp 1s ease forwards 0.8s;
  }

  .title-animation02__wrapper.is-ScrollActive .support-content-list-card2-mobile {
    animation: fadeInUp 1s ease forwards 1.3s;
  }

  .title-animation02__wrapper.is-ScrollActive .support-content-list-card3-mobile {
    animation: fadeInUp 1s ease forwards 1.8s;
  }

  .support-content-list-card-image1-container,
  .support-content-list-card-image2-container,
  .support-content-list-card-image3-container {
    width: 90px;
    height: 112px;
    margin-left: 0;
  }

  .support-content-list-card-image1-container {
    background-image: url("../img/renewal/aboutus-support-image1-mobile.png");
  }

  .support-content-list-card-image2-container {
    background-image: url("../img/renewal/aboutus-support-image2-mobile.png");
  }

  .support-content-list-card-image3-container {
    background-size: cover;
    background-image: url("../img/renewal/aboutus-support-image3-mobile.png");
  }

  .support-content-list-card-content {
    display: flex;
    flex-direction: column;
    max-width: 213px;
    height: fit-content;
    gap: 6px;
  }

  .support-content-list-card-title {
    font-size: 18px;
    font-weight: 500;
    padding-bottom: 2px;
    text-align: left;
  }

  .support-content-list-card-text-type1,
  .support-content-list-card-text-type2 {
    font-size: 12px;
    line-height: 150%;
    text-align: left;
  }
}

/* ======================================= お客様の声 ======================================= */
.user-voice,
.user-voice * {
  font-family: "Zen Kaku Gothic New";
}

.user-voice {
  background-color: #fdf4ee;
}

.user-voice-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 1048px;
  margin: 0 auto;
  padding: 56px 0 56px 0;
  gap: 16px;
}

.user-voice-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  color: #333333;
  opacity: 0;
}

.user-voice-list .swiper-slide:last-child {
  margin-right: 0px;
}

.title-animation02__wrapper.is-ScrollActive .user-voice-heading {
  animation: fadeInUp 1s ease forwards;
}

.user-voice-content {
  position: relative;
  display: flex;
  justify-content: flex-start;
  width: 1048px;
  /* height: 347px; */
  padding: 22px 24px 0 24px;
}

.user-voice-list {
  display: flex;
  justify-content: center;
  max-width: 1000px;
  width: 100%;
  /* height: 280px; */
  padding: 46px 55px 38px 55px;
  gap: 64px;
  background-color: #ffffff;
  border-radius: 8px;
  filter: drop-shadow(6px 6px 0px rgba(173, 173, 173, 0.2));
  z-index: 3;
}

.sp-user-voice {
  display: none;
}

.user-voice-bubble-left {
  position: absolute;
  background-image: url("../img/renewal/aboutus-user-voice-bubble-left.png");
  background-size: cover;
  background-repeat: no-repeat;
  top: 0;
  left: 0;
  width: 176px;
  height: 101.01px;
  z-index: 2;
}

.user-voice-bubble-right {
  position: absolute;
  background-image: url("../img/renewal/aboutus-user-voice-bubble-right.png");
  background-size: cover;
  background-repeat: no-repeat;
  top: 232px;
  right: 0;
  width: 252px;
  height: 116px;
  z-index: 2;
}

.voice-card {
  position: relative;
  text-decoration: none;
  color: inherit;
  display: block;
  transition: transform 0.3s ease;
}

.voice-card::before {
  content: "";
  position: absolute;
  top: -13px;
  right: -32px;
  width: 0;
  height: 217px;
  border: 0.8px solid #e0e0e0;
}

.voice-card:last-child::before {
  display: none;
}

.voice-card:hover {
  color: #e66d54; /* ホバー時の文字色を変更 */
}

.voice-card:hover .voice-content h3 {
  color: #e66d54; /* ホバー時に見出しの色だけ変更 */
}

.voice-item {
  display: flex;
  flex-direction: column;
  width: 254px;
  /* height: 196px; */
  gap: 10px;
}

.voice-header {
  display: flex;
  width: 100%;
  height: 100px;
  gap: 11px;
}

.voice-image {
  position: relative;
  width: 100px;
  height: 100px;
}

.voice-image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 96px;
  height: 96px;
}

.voice-image::before {
  content: "";
  position: absolute;
  top: 4px;
  left: 4px;
  background-color: #e66d54;
  width: 96px;
  height: 96px;
}

.voice-info {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding-top: 25px;
}

.voice-number {
  font-family: Roboto !important;
  font-size: 15px;
  font-weight: 500;
  line-height: 180%;
  color: #e66d54;
}

.voice-profile {
  display: flex;
  font-size: 15px;
  font-weight: 400;
  line-height: 180%;
  color: #888888;
  gap: 6px;
}

.voice-content {
  width: 100%;
  height: fit-content;
}

.voice-content h3 {
  font-size: 18px;
  font-weight: 500;
  line-height: 170%;
  color: #555555;
}

.user-voice .swiper-pagination {
  display: none;
}

.user-voice-button {
  display: flex;
  justify-content: center;
  width: 311px;
  height: fit-content;
  background-color: #ffffff;
  border: 1px solid #888888;
  border-radius: 28px;
  padding: 9px 16px;
  margin-top: 40px;
}

.user-voice-button-text {
  font-size: 15px;
  font-weight: 700;
  line-height: 180%;
  color: #888888;
}

.user-voice-button:hover .user-voice-button-text {
  color: #e66d54;
}

@media (max-width: 1279px) {
  .user-voice-inner {
    width: 100%;
  }

  .user-voice-content {
    max-width: 1066px;
    width: 100%;
    /* height: 347px; */
    margin: 0 40px 0 40px;
  }

  .user-voice-list {
    justify-content: flex-start;
    max-width: 1066px;
    padding: 46px 55px 38px 55px;
    gap: 0;
  }

  .pc-user-voice {
    display: none;
  }

  .sp-user-voice {
    display: block;
    width: 100%;
  }

  .sp-user-voice .swiper-slide {
    width: 286px !important;
    flex-shrink: 0;
  }

  .voice-card::before {
    top: -14px;
    right: 0;
  }
}

@media (max-width: 1066px) {
  .user-voice-content {
    width: 100%;
    /* height: 347px; */
    margin: 0 0 0 80px;
  }

  .user-voice-bubble-right {
    right: 80px;
  }
}

@media (max-width: 749px) {
  .user-voice-inner {
    padding: 56px 0 47px 0;
    gap: 24px;
  }

  .user-voice-heading {
    font-size: 24px;
  }

  .user-voice-list .swiper-slide:last-child {
    margin-right: 24px;
  }

  .user-voice-content {
    height: 300px;
    padding: 16px 16px 0 16px;
    margin: 0 0 0 32px;
  }

  .user-voice-list {
    height: 100%;
    padding: 0;
    background-color: inherit;
    border-radius: 0;
    filter: none;
  }

  .user-voice-bubble-right {
    top: 170px;
    right: 32px;
  }

  .voice-card {
    height: 235px;
    background-color: #ffffff;
    border-radius: 8px;
    filter: drop-shadow(6px 6px 0px rgba(173, 173, 173, 0.2));
    padding: 24px 16px;
  }

  .voice-card::before {
    display: none;
  }

  .voice-item {
    /* height: 187px; */
  }

  .voice-header {
    gap: 16px;
  }

  .voice-info {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    padding-top: 25px;
  }

  .voice-number {
    font-family: Zen Kaku Gothic New !important;
    font-size: 13px;
    font-weight: 700;
    line-height: 170%;
  }

  .voice-profile {
    font-size: 13px;
    line-height: 170%;
    padding-top: 4px;
    gap: 9px;
  }

  .voice-content h3 {
    font-size: 15px;
  }

  .user-voice .swiper-pagination {
    position: absolute;
    width: 100%;
    display: flex;
    justify-content: center;
    bottom: 0.5px;
    left: -4.5%;
    z-index: 10;
  }

  .user-voice .swiper-pagination-bullet {
    width: 6px;
    height: 6px;
    background-color: inherit;
    opacity: 1;
    margin: 0 4px !important;
    border: 0.5px solid #888888;
  }

  .user-voice .swiper-pagination-bullet-active {
    background-color: #888888;
  }

  .user-voice-button {
    padding: 8px 16px 6px 16px;
    margin-top: 0;
  }

  .user-voice-button-text {
    font-size: 13px;
    line-height: 170%;
  }
}

/* ======================================= よくある質問 ======================================= */
.faq,
.faq * {
  font-family: "Zen Kaku Gothic New";
}

.faq {
  background-color: #ffffff;
  padding: 57px 0;
}

.faq-content {
  display: flex;
  flex-direction: column;
  width: 800px;
  margin: 0 auto;
  gap: 24px;
}

.faq-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  text-align: center;
  color: #333333;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .faq-heading {
  animation: fadeInUp 1s ease forwards;
}

.faq-list {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 24px;
}

.faq-item {
  width: 100%;
  height: fit-content;
  padding: 8px 24px;
  background: #ffffff;
  border-radius: 5px;
  overflow: hidden;
  transition: box-shadow 0.2s ease;
  cursor: pointer;
}

.faq-item:hover {
  box-shadow: 6px 6px 0 rgba(173, 173, 173, 0.2);
}

.faq-question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 2px;
}

.faq-question-content {
  position: relative;
  display: flex;
  align-items: center;
  width: calc(100% - 30px);
}

.faq-answer {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  padding: 0 22px 0 0;
  transition: max-height 0.2s ease, opacity 0.2s ease, padding 0.2s ease;
}

.faq-answer.active {
  max-height: 150px;
  opacity: 1;
  padding: 21px 22px 10px 0;
}

.q-mark,
.a-mark {
  font-size: 24px;
  font-weight: 500;
  line-height: 100%;
  min-width: 20px;
}

.q-mark {
  margin-right: 6px;
  color: #e66d54;
}

.a-mark {
  margin-right: 8px;
  color: #888888;
}

.question-text {
  font-size: 18px;
  font-weight: 500;
  line-height: 180%;
  color: #333333;
}

.answer-text {
  font-size: 15px;
  font-weight: 400;
  line-height: 180%;
  color: #333333;
}

.toggle-btn {
  position: relative;
  display: block;
  width: 30px;
  height: 20px;
  cursor: pointer;
}

.toggle-btn:before {
  content: "";
  position: absolute;
  top: 9px;
  left: 8px;
  width: 20px;
  height: 2px;
  background-color: #e66d54;
  transition: all 0.3s ease;
}

.toggle-btn:after {
  content: "";
  position: absolute;
  top: 0;
  left: 17px;
  height: 20px;
  width: 2px;
  background-color: #e66d54;
  transition: all 0.2s ease;
  transform-origin: center;
}

.toggle-btn.active:after {
  transform: rotate(90deg);
  opacity: 0;
}

.faq-answer.active + .faq-question .toggle-btn:after,
.faq-question:has(+ .faq-answer.active) .toggle-btn:after {
  transform: rotate(90deg);
  opacity: 0;
}

@media (max-width: 879px) {
  .faq-content {
    width: calc(100% - 80px);
    margin: 0 40px;
  }
}

@media (max-width: 749px) {
  .faq-content {
    max-width: 400px;
    width: calc(100% - 48px);
    margin: 0 24px;
  }

  .faq-heading {
    font-size: 24px;
  }

  .faq-list {
    gap: 25px;
  }

  .faq-item {
    padding: 8px 16px;
  }

  .faq-question-content {
    width: calc(100% - 20px);
  }

  .faq-answer {
    padding: 19px 22px 7px 0;
  }

  .q-mark,
  .a-mark {
    font-size: 20px;
    min-width: 15px;
  }

  .q-mark {
    margin-right: 8px;
  }

  .a-mark {
    margin-right: 11px;
  }

  .question-text {
    font-size: 15px;
    line-height: 170%;
  }

  .answer-text {
    font-size: 13px;
    line-height: 170%;
  }

  .toggle-btn {
    width: 28px;
  }

  .toggle-btn:before {
    transition: all 0.2s ease;
  }

  .toggle-btn:after {
    transition: all 0.2s ease;
    transform-origin: center;
  }

  .toggle-btn.active:after {
    transform: rotate(90deg);
    opacity: 0;
  }
}

/* ======================================= 医師監修コラム ======================================= */
.medically-reviewed-article,
.medically-reviewed-article * {
  font-family: "Zen Kaku Gothic New";
}

.medically-reviewed-article {
  background-color: #f7eeea;
}

.medically-reviewed-article-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 66px 0;
  gap: 20px;
}

.medically-reviewed-article-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  color: #333333;
  margin-bottom: 22px;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .medically-reviewed-article-heading {
  animation: fadeInUp 1s ease forwards;
}

.medically-reviewed-article-list {
  max-width: 1000px;
  width: 100%;
  height: auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: 27px;
  row-gap: 20px;
  margin-bottom: 7px;
}

.article-card {
  display: flex;
  flex-direction: column;
  width: 312px;
  text-decoration: none;
  color: inherit;
  transition: transform 0.3s ease;
  background-color: #ffffff;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  margin: 6px 0 6px 6px;
  gap: 12px;
  transition: box-shadow 0.2s ease;
}

.article-card:hover {
  box-shadow: 6px 6px 0 rgba(173, 173, 173, 0.2);
}

.article-card:hover .article-title h3 {
  color: #e66d54;
}

.article-image {
  position: relative;
  display: block;
  width: 100%;
  height: 175px;
  overflow: hidden;
}

.article-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
}

.article-content {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: auto;
  padding: 0 12px 0 10px;
  gap: 8px;
}

.article-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: fit-content;
}

.article-date {
  font-size: 13px;
  font-weight: 500;
  line-height: 180%;
  color: #888888;
}

.article-category {
  padding: 0 7px;
  border: 1px solid #51767d;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 500;
  line-height: 160%;
  color: #51767d;
}

.article-title h3 {
  font-size: 15px;
  font-weight: 500;
  line-height: 160%;
  color: #333333;
}

.medically-reviewed-article-button {
  display: flex;
  justify-content: center;
  width: 311px;
  height: 47px;
  background-color: #ffffff;
  border: 1px solid #888888;
  border-radius: 28px;
  padding: 10px 16px;
}

.medically-reviewed-article-button-text {
  font-size: 15px;
  font-weight: 700;
  line-height: 180%;
  color: #888888;
}

.medically-reviewed-article-button:hover .medically-reviewed-article-button-text {
  color: #e66d54;
}

@media (max-width: 1279px) {
  .medically-reviewed-article-list {
    max-width: 680px;
    grid-template-columns: repeat(2, 1fr);
  }

  .tablet-hide {
    display: none !important;
  }
}

@media (max-width: 749px) {
  .medically-reviewed-article-inner {
    padding: 48px 0;
    gap: 24px;
  }

  .medically-reviewed-article-heading {
    font-size: 24px;
    margin-bottom: 0;
  }

  .medically-reviewed-article-list {
    max-width: 320px;
    grid-template-columns: 1fr;
    margin-bottom: 0;
  }

  .article-card {
    margin: 0 auto;
    gap: 10px;
  }

  .article-content {
    padding: 0 11px;
    gap: 8px;
  }

  .article-info {
    margin-bottom: 3px;
  }

  .article-date {
    font-size: 12px;
    line-height: 170%;
  }

  .article-category {
    padding: 0 7px;
    font-size: 12px;
    line-height: 170%;
    height: 20px;
  }

  .article-title h3 {
    font-size: 13px;
  }

  .medically-reviewed-article-button {
    height: 38px;
    padding: 0;
    align-items: center;
  }

  .medically-reviewed-article-button-text {
    font-size: 13px;
    line-height: 170%;
  }

  .mobile-hide {
    display: none !important;
  }
}

/* ======================================= 利用ガイド ======================================= */
.usage-guide,
.usage-guide * {
  font-family: "Zen Kaku Gothic New";
}

.usage-guide {
  background-color: #ffffff;
}

.usage-guide-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 55px 0;
  gap: 24px;
}

.usage-heading {
  font-size: 32px;
  font-weight: 700;
  line-height: 180%;
  color: #333333;
  opacity: 0;
}

.title-animation02__wrapper.is-ScrollActive .usage-heading {
  animation: fadeInUp 1s ease forwards;
}

.usage-video {
  max-width: 580px;
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}

@media (max-width: 749px) {
  .usage-guide-content {
    padding: 47px 0;
    gap: 24px;
  }

  .usage-heading {
    font-size: 24px;
    line-height: 150%;
    text-align: center;
  }

  .usage-video {
    max-width: 327px;
    width: 100%;
    height: auto;
    aspect-ratio: 16/9;
  }
}

/* 余白用のダミースライド */
.price-plan-dummy-slide {
  width: 32px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.price-plan-annotation {
  font-size: 14px;
  text-align:center;
  color: #888 !important;
  line-height: 1.2;
  margin-bottom: 2px;
  margin-bottom: 41px;
}

@media (max-width: 749px) {
  .price-plan-annotation {
    font-size: 12px;
  }
}

.price-plan-footer-annotation {
  font-size: 14px;
  text-align: center;
  color: #888 !important;
  line-height: 1.4;
  margin-top: 0;
  margin-bottom: 70px;
}

@media (max-width: 749px) {
  .price-plan-footer-annotation {
    font-size: 12px;
    margin-top: 20px;
  }
}

.mylily-features-annotation {
  font-size: 14px;
  color: #888 !important;
  line-height: 1.2;
  text-align: center;
  margin-bottom: 0;
  min-height: 17px;
}

@media (max-width: 749px) {
  .mylily-features-annotation {
    font-size: 12px;
  }
}

.treatment-flow-medical-time-annotation {
  font-size: 14px;
  color: #888 !important;
  line-height: 1.2;
  text-align: center;
  margin-bottom: 0;
  margin-top: 16px;
}

@media (max-width: 749px) {
  .treatment-flow-medical-time-annotation {
    font-size: 12px;
  }
}
