.top {

}
:where(.top) {
  .mv {
    margin-bottom: 40px;
    @media screen and (min-width: 769px) {
      margin-bottom: 61px;
    }
  }
  .recommend {
    @media screen and (min-width: 769px) {
      margin-bottom: 50px;
    }
    &.bottom {
      margin-bottom: 30px;
      @media screen and (min-width: 769px) {
        margin-bottom: 100px;
      }
    }
  }
  .about {
    background-image: url("../../images/top/bg_about.webp");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
    padding: 64px 0 42px;
    margin-bottom: 74px;
    @media screen and (max-width: 768px) {
      margin-bottom: 54px;
      padding: 51px 0 36px;
      background-image: url("../../images/top/bg_about-sp.webp");
    }
  }
  .about__lead {
    text-align: center;
    font-size: calc(var(--rem) * 16);
    letter-spacing: 1.28px;
    line-height: 29px;
    margin-bottom: 8px;
    @media screen and (min-width: 769px) {
      font-size: calc(var(--rem) * 20);
      letter-spacing: 1.6px;
      line-height: 34px;
      margin-bottom: 22px;
    }
    .strong {
      color: #DF8F9B;
    }
  }
  .about__icon {
    width: 26px;
    @media screen and (min-width: 769px) {
      width: 44px;
    }
  }
  .about__list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    @media screen and (max-width: 768px) {
      column-gap: 10px;
    }
    @media screen and (min-width: 769px) {
      gap: 33px;
    }
  }
  .about__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 181px;
    height: 181px;
    border-radius: 50%;
    background: linear-gradient(to bottom, transparent 0%, rgba(255, 255, 255, 0.3) 17%, #fff 100%);
    gap: 8px;
    @media screen and (min-width: 769px) {
      gap: 9px;
      width: 298px;
      height: 298px;
    }
    &:not(:nth-child(2)) {
      @media screen and (min-width: 769px) {
        margin-top: 44px;
      }
    }
    &:last-child {
      @media screen and (max-width: 768px) {
        margin-top: -16px;
      }
    }
  }
  .about__text {
    text-align: center;
    font-size: calc(var(--rem) * 20);
    letter-spacing: 1.6px;
    line-height: 26px;
    @media screen and (min-width: 769px) {
      font-size: calc(var(--rem) * 28);
      letter-spacing: 2.24px;
      line-height: 33px;
    }
    span {
      font-size: calc(var(--rem) * 15);
      letter-spacing: 1.2px;
      @media screen and (max-width: 768px) {
        line-height: 23px !important;
      }
      @media screen and (min-width: 769px) {
        font-size: calc(var(--rem) * 22);
        letter-spacing: 1.76px;
      }
    }
    .small {
      font-size: calc(var(--rem) * 14);
      letter-spacing: 1.12px;
    }
  }

  .problem {
    @media screen and (min-width: 769px) {
      margin-bottom: 65px !important;
    }
  }
  .case {
    margin-bottom: 65px;
    @media screen and (min-width: 769px) {
      margin-bottom: 100px;
    }
  }
  .c-banners {
    margin-bottom: 45px;
    @media screen and (min-width: 769px) {
      margin-bottom: 140px;
    }
  }
  .woman {
    margin-bottom: 60px;
    @media screen and (min-width: 769px) {
      margin-bottom: 140px;
    }
    .splide {
      margin-bottom: 20px;
      @media screen and (min-width: 769px) {
        margin-bottom: 44px;
      }
    }
  }
  .woman__lead {
    width: 330px;
    margin: 0 auto 9px auto;
    @media screen and (min-width: 769px) {
      width: 316px;
      margin: 0 auto 11px auto;
    }
  }
  .woman__text {
    text-align: center;
    color: #DF8F9B;
    @media screen and (max-width: 768px) {
      font-size: calc(var(--rem) * 20);
      letter-spacing: 1.6px;
      line-height: 34px;
      margin-bottom: 25px;
    }
    @media screen and (min-width: 769px) {
      font-size: calc(var(--rem) * 22);
      letter-spacing: 1.76px;
      margin-bottom: 40px;
    }
  }
  .woman__button {
    display: block;
    margin: 0 auto;
    width: 300px;
    @media screen and (min-width: 769px) {
      width: 357px;
    }
  }
  .info {
    color: #8A626F;
    margin-bottom: 80px;
    @media screen and (min-width: 769px) {
      margin-bottom: 100px;
    }
  }
  .info__title-en {
    color: #DF8F9B;
    position: relative;
    display: block;
    font-size: calc(var(--rem) * 13);
    letter-spacing: 1.04px;
    padding-left: 29px;
    margin-bottom: 3px;
    @media screen and (min-width: 769px) {
      padding-left: 16px;
      margin-bottom: 6px;
    }
    &::after {
      content: "";
      display: inline-block;
      position: absolute;
      width: 14px;
      height: 44px;
      background: #DF8F9B;
      left: 0%;
      top: 129%;
      transform: translateY(-50%);
      @media screen and (min-width: 769px) {
        width: 5px;
        height: 19px;
        top: 50%;
      }
    }
  }
  .info__title {
    font-size: calc(var(--rem) * 17);
    letter-spacing: 1.36px;
    padding-left: 29px;
    @media screen and (min-width: 769px) {
      font-size: calc(var(--rem) * 18);
      letter-spacing: 1.44px;
      padding-left: 16px;
    }
  }
  .info__button {
    @media screen and (min-width: 769px) {
      width: min(245px, calc(var(--vw) * 245));
    }
  }
  .info__head {
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px;
    @media screen and (min-width: 769px) {
      margin-bottom: 40px;
    }
  }
  .info__list {
    display: flex;
    @media screen and (max-width: 768px) {
      flex-direction: column;
      gap: 60px;
    }
    @media screen and (min-width: 769px) {
      gap: 50px;
      justify-content: space-between;
    }
  }
  .info__item {
    @media screen and (min-width: 769px) {
      max-width: 500px;
      width: 100%;
    }
  }
  .news-list {
    @media screen and (min-width: 769px) {
      padding-left: 16px;
    }
    li + li {
      margin-top: 15px;
      @media screen and (min-width: 769px) {
        margin-top: 30px;
      }
    }
  }
  .news-item, .column-item {
    display: flex;
    align-items: center;
    font-size: calc(var(--rem) * 13);
    letter-spacing: 1.04px;
    line-height: 22px;
    @media screen and (min-width: 769px) {
      font-size: calc(var(--rem) * 15);
      letter-spacing: 1.2px;
      line-height: 24px;
    }
    time {
      width: 85px;
      margin-right: 20px;
      @media screen and (min-width: 769px) {
        width: 95px;
        margin-right: min(30px, calc(var(--vw) * 30));
      }
    }
  }
  .column-list {
    li + li {
      margin-top: 30px;
      @media screen and (min-width: 769px) {
        margin-top: 24px;
      }
    }
  }
  .column-item__thumb {
    flex-shrink: 0;
    overflow: hidden;
    width: 100%;
    height: calc(var(--vw) * 200);
    background: #8D8D8D;
    border-radius: 20px;
    @media screen and (max-width: 768px) {
      margin-bottom: 12px;
    }
    @media screen and (min-width: 769px) {
      border-radius: 13.5px;
      width: 159px;
      height: 98px;
      margin-right: min(30px, calc(var(--vw) * 30));
    }
    figure {
      height: 100%;
      object-fit: contain;
    }
    img {
      height: 100%;
      object-fit: cover;
    }
  }
  .column-item {
    display: flex;
    @media screen and (max-width: 768px) {
      flex-wrap: wrap;
    }
  }
  .ranking {
    margin-bottom: 65px;
    @media screen and (min-width: 769px) {
      margin-bottom: 78px;
    }
  }
  .ranking__lead {
    margin: 0 auto 30px auto;
    @media screen and (min-width: 769px) {
      width: 488px;
      margin: 0 auto 37px auto;
    }
  }
  .ranking__list {
    display: grid;
    gap: 20px;
    @media screen and (min-width: 769px) {
      gap: min(50px, calc(var(--vw) * 50));
      grid-template-columns: 1fr 1fr 1fr;
    }
  }
  .ranking__inner + .ranking__inner {
    margin-top: 30px;
    @media screen and (min-width: 769px) {
      margin-top: 48px;
    }
  }
  .doctors {
    margin-bottom: 70px;
    @media screen and (min-width: 769px) {
      margin-bottom: 61px;
    }
  }
  .doctor-list {
    @media screen and (max-width: 768px) {
      display: grid;
      grid-template-columns: 1fr 1fr;
      column-gap: 25px;
      row-gap: 19px;
      margin-bottom: 24px;
    }
    @media screen and (min-width: 769px) {
      display: flex;
      justify-content: center;
      gap: 20px;
      margin-bottom: 35px;
    }
  }
  .doctor-list__thumb {
    margin-bottom: 12px;
    @media screen and (min-width: 769px) {
      margin-bottom: 30px;
    }
  }
  .doctor-list__item {
    @media screen and (min-width: 769px) {
      width: 180px;
    }
  }
  .doctor-list__name {
    text-align: center;
    font-size: calc(var(--rem) * 13);
    letter-spacing: 1.04px;
    @media screen and (min-width: 769px) {
      font-size: calc(var(--rem) * 14);
      letter-spacing: 1.12px;
    }
  }
  .doctor__button {
    margin: 0 auto;
    display: block;
    width: 300px;
    @media screen and (min-width: 769px) {
      width: 357px;
    }
  }
  .sns {
    margin-bottom: 55px;
    @media screen and (min-width: 769px) {
      margin-bottom: 69px;
    }
  }
  .reason {
    background: #FDFBFA;
    padding: 35px 25px 30px;
    margin-bottom: 35px;
    @media screen and (min-width: 769px) {
      padding: 63px 0 40px 149px;
      margin-bottom: 100px;
    }
  }
  .reason__title {
    font-size: calc(var(--rem) * 20);
    letter-spacing: 1.6px;
    line-height: 30px;
    white-space: nowrap;
    @media screen and (min-width: 769px) {
      font-size: calc(var(--rem) * 26);
      letter-spacing: 2.08px;
      line-height: 49px;
    }
    span {
      color: #DF8F9B;
    }
  }
  .reason__head {
    margin-bottom: 30px;
    @media screen and (min-width: 769px) {
      display: flex;
      align-items: center;
      margin-right: min(143px, calc(var(--vw) * 143));
      gap: min(50px, calc(var(--vw) * 50));
      justify-content: space-between;
      margin-bottom: 20px;
    }
  }
  .reason__button {
    display: block;
    @media screen and (max-width: 768px) {
      width: 300px;
      margin: 0 auto;
    }
    @media screen and (min-width: 769px) {
      width: 370px;
      flex-shrink: 0;
    }
  }
  .reason__list {
    background-color: #FFF;
    @media screen and (max-width: 768px) {
      margin-bottom: 30px;
    }
    @media screen and (min-width: 769px) {
      display: flex;
      gap: 80px;
      overflow-x: scroll;
      padding: 56px 0 80px 86px;
      margin-left: min(80px, calc(var(--vw) * 80));
    }
    li {
      flex-shrink: 0;
      @media screen and (min-width: 769px) {
        width: 487px;
      }
      &:last-child {
        @media screen and (min-width: 769px) {
          margin-right: 40px;
        }
      }
    }
    li + li {
      @media screen and (max-width: 768px) {
        margin-top: 40px;
      }
    }
  }
  .reason__image {
    margin-bottom: 20px;
    @media screen and (min-width: 769px) {
      margin-bottom: 43px;
    }
  }
  .reason__lead {
    color: #DF8F9B;
    font-size: calc(var(--rem) * 17);
    letter-spacing: 1.36px;
    line-height: 28px;
    margin-bottom: 20px;
    @media screen and (min-width: 769px) {
      font-size: calc(var(--rem) * 20);
      letter-spacing: 1.6px;
      line-height: 30px;
      margin-bottom: 39px;
    }
  }
  .reason__text {
    font-size: calc(var(--rem) * 13);
    letter-spacing: 1.04px;
    line-height: 23px;
    @media screen and (min-width: 769px) {
      font-size: calc(var(--rem) * 14);
      letter-spacing: 1.12px;
      line-height: 28px;
    }
  }
  .gallery {
    margin-bottom: 116px;
    @media screen and (max-width: 768px) {
      margin-bottom: 20px;
    }
  }
  .gallery__inner {
    display: flex;
    @media screen and (max-width: 768px) {
      flex-direction: column-reverse;
      gap: 10px;
      margin-bottom: 21px;
    }
    @media screen and (min-width: 769px) {
      align-items: end;
      gap: 33px;
    }
    .swiper-container {
      position: relative;
    }
    .thumbnail {
      width: 100%;
      overflow: hidden;
      @media screen and (min-width: 769px) {
        width: 45%;
      }
    }
    .slider {
      width: 100%;
      overflow: hidden;
      @media screen and (min-width: 769px) {
        width: 55%;
      }
    }
    .c-title-en, .c-title {
      text-align: start;
      white-space: nowrap;
      margin-right: min(61px, calc(var(--vw) * 61));
    }
  }
  .gallery-arrow {
    width: 30px;
    height: 30px;
    background-image: url("../../images/top/icon_slider-next.svg");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    cursor: pointer;
    @media screen and (min-width: 769px) {
      width: 50px;
      height: 50px;
    }
    &.gallery-prev {
      background-image: url("../../images/top/icon_slider-prev.svg");
    }
  }
  .gallery__head {
    display: flex;
    align-items: center;
    @media screen and (min-width: 769px) {
      margin-bottom: min(40px, calc(var(--vw) * 40));
    }
  }
  .gallery-prev {
    left: 10px;
  }
  .gallery-next {
    right: 10px;
  }
  .gallery-button {
    display: block;
    width: 300px;
    margin: 0 auto;
  }

  .support {
    margin-bottom: 70px;
    @media screen and (min-width: 769px) {
      margin-bottom: 100px;
    }
  }
  .support__inner {
    position: relative;
    border: 2px solid #DF8F9B;
    position: relative;
    padding: 19px;
    @media screen and (min-width: 769px) {
      padding: 107px 47px 53px;
    }
  }
  .support__lead {
    text-align: center;
    color: #DF8F9B;
    font-weight: normal;
    font-size: calc(var(--rem) * 17);
    letter-spacing: 1.36px;
    margin: 0 0 20px 0;
    @media screen and (min-width: 769px) {
      width: 564px;
      height: 73px;
      background: #FFF;
      font-size: calc(var(--rem) * 20);
      letter-spacing: 1.6px;
      top: -23px;
      position: absolute;
      right: 0;
      left: 0;
      margin: 0 auto;
    }
  }
  .support__head {
    display: flex;
    @media screen and (max-width: 768px) {
      flex-direction: column;
      gap: 20px;
      margin-bottom: 20px;
    }
    @media screen and (min-width: 769px) {
      gap: 50px;
      align-items: center;
      margin-bottom: 46px;
    }
  }
  .support__head-text {
    font-size: calc(var(--rem) * 13);
    letter-spacing: 1.04px;
    line-height: 23px;
    @media screen and (min-width: 769px) {
      font-size: calc(var(--rem) * 14);
      letter-spacing: 1.12px;
      line-height: 28px;
    }
  }
  .support__item {
    color: #DF8F9B;
    text-align: center;
    font-size: calc(var(--rem) * 15);
    letter-spacing: 1.2px;
    margin-bottom: 20px;
    @media screen and (min-width: 769px) {
      font-size: calc(var(--rem) * 20);
      letter-spacing: 1.6px;
      margin-bottom: 20px;
    }
  }
}