@charset "UTF-8";
html {
  font-size: 0.1333333333vw;
}

@media screen and (min-width: 750px) {
  html {
    font-size: 1px;
  }
}
body {
  font-family: リュウミン R-KL, Ryumin Regular KL, ヒラギノ明朝 ProN W3, Hiragino Mincho ProN, ヒラギノ明朝 Pro W3, Hiragino Mincho Pro, 游明朝体, YuMincho, 游明朝, Yu Mincho, ＭＳ Ｐ明朝, MS PMincho, serif !important;
  color: #333;
  font-weight: 500;
  letter-spacing: 0.03em;
}

img {
  display: block;
  width: 100%;
  object-fit: cover;
}

p {
  letter-spacing: 0.03em;
}

a {
  transition: opacity 0.3s ease;
}
a:hover {
  opacity: 0.8;
}

.l-container {
  max-width: 750rem;
  margin: 0 auto;
  overflow: hidden;
}

header {
  background-color: #fff;
  padding: 34rem 0;
}
header .header-logo {
  max-width: 425rem;
  margin: 0 auto;
}

.cta {
  background-color: #011388;
  padding: 0 14rem 30rem;
}
.cta h2 {
  margin: 0 -14rem;
}
.cta .inner {
  background-color: #fff;
  border-radius: 5rem;
  padding-bottom: 15rem;
}
.cta p:nth-child(1) {
  margin-bottom: 39rem;
}

.contact {
  display: flex;
  margin: 32rem 14rem 0 22rem;
}
.contact > li {
  width: 33.3333333333%;
}

.s_01 {
  background-color: #fff;
  padding: 110rem 40rem 45rem;
}
.s_01 h2 {
  margin-bottom: 52rem;
}
.s_01 .s_01-text {
  font-size: 30rem;
  line-height: 2.3;
  letter-spacing: 0.03em;
  text-align: center;
  margin-top: 50rem;
  margin-bottom: 20rem;
}
.s_01 .s_01-note {
  text-align: right;
  font-size: 18rem;
  letter-spacing: 0.03em;
  font-family: "Noto Sans JP", sans-serif;
}

.pore {
  background-color: #ececec;
  padding: 66rem 0;
}
.pore h2 {
  font-size: 56rem;
  line-height: 1.3;
  text-align: center;
  position: relative;
  padding-bottom: 40rem;
  margin-bottom: 50rem;
  letter-spacing: 0.03em;
}
.pore h2::after {
  content: "";
  position: absolute;
  background: url("../img/decor_ttl.png") no-repeat center/contain;
  width: 593rem;
  height: 63rem;
  left: 50%;
  transform: translateX(-50%);
  bottom: -60rem;
}
.pore p {
  max-width: 588rem;
  margin: 0 auto 42rem;
}
.pore .pore-problem {
  font-size: 34rem;
  line-height: 1.6;
  padding: 0 35rem 0 43rem;
}
.pore .pore-problem > li {
  position: relative;
  padding-bottom: 20rem;
  margin-bottom: 20rem;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  padding-left: 80rem;
  letter-spacing: 0.03em;
}
.pore .pore-problem > li::before {
  content: "";
  position: absolute;
  left: 10rem;
  top: 0;
  background: url("../img/icon_tick.png") no-repeat center/contain;
  width: 50rem;
  height: 50rem;
}
.pore .pore-problem > li::after {
  content: "";
  position: absolute;
  background: url("../img/line_bg.png") no-repeat center/contain;
  width: 100%;
  height: 2rem;
  left: 0;
  bottom: 0;
}
.pore .pore-problem .highlight {
  background-color: #707070;
  color: #fff;
  padding: 0 10rem;
  margin-right: 8rem;
}

.clinic {
  background: url("../img/clinic_bg.png") no-repeat top center/contain;
  color: #011388;
  text-align: center;
  padding: 49rem 25rem 0 26rem;
  letter-spacing: 0.03em;
  position: relative;
}
.clinic::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -146rem;
  height: 139rem;
  background: url("../img/08.png") no-repeat center/contain;
}
.clinic h2 {
  font-size: 36rem;
  font-weight: 500;
  line-height: 1.5111111111;
  letter-spacing: 0.03em;
  margin-top: 26rem;
  margin-bottom: 20rem;
}
.clinic .clinic-highlight {
  font-size: 32rem;
  background-color: #011388;
  color: #fff;
  margin: 0 45rem 18rem;
  padding: 9rem 4rem;
  letter-spacing: 0.03em;
}
.clinic .clinic-text {
  font-size: 50rem;
  line-height: 1.648;
  letter-spacing: 0.03em;
}
.clinic .clinic-text span {
  display: block;
  text-decoration: underline;
  text-decoration-color: #011388;
  text-underline-offset: 21rem;
  text-decoration-thickness: 1rem;
}

.treatment {
  padding-top: 222rem;
  letter-spacing: 0.03em;
  background-color: #fff;
}
.treatment h2 {
  color: #011388;
  font-weight: 700;
  font-size: 34rem;
  line-height: 1.6;
  letter-spacing: -0.03em;
  text-align: center;
  margin-bottom: 22rem;
}
.treatment .treatment-process {
  max-width: 677rem;
  margin: 0 auto 168rem;
  position: relative;
}
.treatment .treatment-process::before {
  content: "";
  position: absolute;
  z-index: 2;
  left: -35rem;
  bottom: -110rem;
  width: 748rem;
  height: 85rem;
  background: url("../img/ellipse.png") no-repeat center center/cover;
}
.treatment h3 {
  text-align: center;
  color: #011388;
  font-weight: 400;
  font-size: 66rem;
  letter-spacing: 0.03em;
  margin-bottom: 50rem;
}
.treatment .number {
  display: block;
  font-weight: 600;
  font-size: 38rem;
}
.treatment .treatment-content {
  background-color: #fff;
  max-width: 660rem;
  font-weight: 400;
  margin-left: auto;
  margin-top: -50rem;
  position: relative;
  padding: 55rem 50rem 60rem;
}
.treatment .treatment-title {
  font-size: 36rem;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.03em;
  margin-bottom: 18rem;
}
.treatment .treatment-text {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 28rem;
  line-height: 1.8;
  margin-bottom: 20rem;
}
.treatment .treatment-note_02 {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18rem;
  line-height: 1.6;
  margin-top: 24rem;
}
.treatment .treatment-note {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18rem;
}
.treatment figure {
  max-width: 680rem;
}
.treatment .treatment-list {
  background-color: #f3f8ff;
  position: relative;
}
.treatment .treatment-list::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -80rem;
  height: 504rem;
  background: url("../img/treatment_bg_04.png") no-repeat center/cover;
}
.treatment .treatment-item {
  position: relative;
  z-index: 1;
  margin-bottom: 84rem;
}
.treatment .treatment-item::before {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  z-index: -1;
  height: 766rem;
}
.treatment .treatment-item:nth-child(1)::before {
  background: url("../img/treatment_bg_01.png") no-repeat center/cover;
  top: -142rem;
}
.treatment .treatment-item:nth-child(2)::before {
  background: url("../img/treatment_bg_02.png") no-repeat center/cover;
  top: -85rem;
}
.treatment .treatment-item:nth-child(3)::before {
  background: url("../img/treatment_bg_03.png") no-repeat center/cover;
  top: -85rem;
}
.treatment .treatment-item:nth-child(2n) figure {
  margin-left: auto;
}
.treatment .treatment-item:nth-child(2n) .treatment-content {
  margin-right: auto;
  margin-left: 0;
}

.point {
  border: 2rem solid #011388;
  background-color: #fff;
  position: relative;
  z-index: 1;
  margin: 58rem 40rem 0;
  padding: 0 49rem 67rem;
}
.point::after {
  content: "";
  position: absolute;
  left: 5rem;
  top: 5rem;
  right: 5rem;
  bottom: 5rem;
  border: 2rem solid rgba(1, 19, 136, 0.4);
  pointer-events: none;
}
.point .point-label {
  background-color: #011388;
  color: #fff;
  font-size: 24rem;
  letter-spacing: 0.08em;
  padding: 10rem 20rem;
  width: 200rem;
  margin: -26rem auto 48rem;
  text-align: center;
}
.point .point-title {
  color: #011388;
  font-size: 40rem;
  line-height: 1.36;
  text-align: center;
  margin-bottom: 45rem;
  letter-spacing: 0.03em;
}
.point .point-heading {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 600;
  font-size: 28rem;
  line-height: 1.4;
  margin: -4rem 0 15rem;
}
.point .point-text {
  font-size: 26rem;
  line-height: 1.6;
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0.1em;
  margin-right: -10rem;
  font-feature-settings: "palt";
}
.point .point-image {
  width: 591rem;
  margin: -11rem 0 21rem;
}
.point .point-desc {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 26rem;
  line-height: 1.6;
  letter-spacing: 0.03em;
  margin-bottom: 25rem;
  margin-right: -20rem;
}
.point .point-list figure {
  width: 250rem;
  flex-shrink: 0;
  margin-right: 35rem;
}
.point .point-list > li {
  display: flex;
  margin-bottom: 53rem;
}
.point .point-list > li:nth-child(2n) {
  flex-direction: row-reverse;
}
.point .point-list > li:nth-child(2n) .point-text {
  margin-right: 0;
}
.point .point-list > li:nth-child(2n) figure {
  margin-right: 0;
  margin-left: 22rem;
}
.point .point-list > li:last-child {
  margin-bottom: 0;
}

.reason {
  padding: 110rem 0;
}
.reason h2 {
  color: #011388;
  font-weight: 500;
  font-size: 56rem;
  letter-spacing: 0.03em;
  line-height: 1.3;
  text-align: center;
  margin-bottom: 52rem;
}
.reason .reason-item {
  position: relative;
  background-color: #fff;
  font-family: "Noto Sans JP", sans-serif;
}
.reason .reason-item > div {
  padding-top: 86rem;
  border-radius: 0 120rem 120rem 0;
  margin-right: 40rem;
  background-color: #f3f8ff;
}
.reason .reason-item:nth-child(2n) {
  background-color: #f3f8ff;
}
.reason .reason-item:nth-child(2n) > div {
  background-color: #fff;
  margin-right: 0;
  margin-left: 40rem;
  border-radius: 120rem 0 0 120rem;
}
.reason .reason-item:nth-child(2n) figure {
  margin-left: auto;
}
.reason .reason-item:nth-child(2n) .reason-content {
  padding-right: 40rem;
  padding-left: 210rem;
}
.reason .reason-item:last-child {
  padding-bottom: 100rem;
}
.reason figure {
  width: 658rem;
}
.reason .reason-text {
  font-size: 30rem;
  line-height: 1.6;
  margin-bottom: 15rem;
}
.reason .reason-note {
  font-size: 18rem;
  line-height: 1.6;
}
.reason .reason-content {
  padding: 30rem 188rem 83rem 38rem;
}

.flow {
  padding: 0 40rem 84rem;
}
.flow h2 {
  color: #011388;
  font-size: 56rem;
  line-height: 1.3;
  text-align: center;
  margin: 0 -40rem 50rem;
}
.flow .flow-heading {
  color: #011388;
  font-size: 38rem;
  letter-spacing: 0.06rem;
  border: 2rem solid #011388;
  padding: 22rem 50rem;
  text-align: center;
  margin-bottom: 22rem;
}
.flow .flow-text {
  font-size: 30rem;
  line-height: 1.6;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  margin-top: 37rem;
  margin-right: -10rem;
}
.flow .flow-list {
  margin-bottom: 22rem;
}
.flow .flow-item {
  padding-bottom: 120rem;
  position: relative;
  margin-bottom: 22rem;
}
.flow .flow-item::after {
  content: "";
  position: absolute;
  left: 50%;
  width: 2rem;
  height: 68rem;
  background-color: #011388;
  bottom: 0;
}
.flow .flow-item.is-modify {
  padding-bottom: 0;
}
.flow .flow-item.is-modify::after {
  display: none;
}

.flow-clinic {
  color: #011388;
  background-color: #fff;
}
.flow-clinic h3 {
  background-color: #011388;
  color: #fff;
  font-size: 38rem;
  letter-spacing: 0.06em;
  line-height: 1.4315789474;
  text-align: center;
  padding: 63rem 30rem;
}
.flow-clinic li {
  font-family: "Noto Sans JP", sans-serif;
  background-color: #f3f8ff;
  position: relative;
  z-index: 1;
  padding-bottom: 30rem;
}
.flow-clinic li::after {
  content: "";
  position: absolute;
  z-index: 1;
  left: 50%;
  transform: translateX(-50%);
  bottom: -57rem;
  width: 8rem;
  height: 52rem;
  background: url("../img/icon_dots.png") no-repeat center/cover;
}
.flow-clinic li:first-child {
  padding-top: 40rem;
}
.flow-clinic li:last-child {
  padding-bottom: 126rem;
}
.flow-clinic li:last-child::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0;
  left: 0;
  right: 0;
  height: 504rem;
  background: url("../img/flow_bg.png") no-repeat center/cover;
}
.flow-clinic li:last-child::after {
  bottom: 53rem;
}
.flow-clinic .clinic-content {
  background-color: #fff;
  padding: 82rem 25rem 50rem 70rem;
  margin: -40rem 0 0 80rem;
}
.flow-clinic .clinic-text {
  font-size: 30rem;
  line-height: 1.6;
}
.flow-clinic .clinic-note {
  font-size: 18rem;
  line-height: 1.6;
  margin-top: 26rem;
  text-indent: -20rem;
  margin-left: 13rem;
  margin-right: -20rem;
}
.flow-clinic figure {
  width: 691rem;
  margin-left: -22rem;
  position: relative;
}

.faq {
  padding: 104rem 0 110rem;
}
.faq h2 {
  width: 391rem;
  margin: 0 auto 74rem;
}
.faq h2 span {
  display: block;
  font-size: 40rem;
  line-height: 1.36;
}
.faq .faq-list {
  padding: 0 40rem;
  margin-bottom: 90rem;
}
.faq .faq-list > li:not(:last-child) {
  margin-bottom: 110rem;
}
.faq .faq-title {
  font-size: 34rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1.6;
  color: #011388;
  border-bottom: 2rem dashed #011388;
  position: relative;
  padding-left: 76rem;
  padding-bottom: 30rem;
  margin-bottom: 23rem;
}
.faq .faq-title::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  background: url("../img/Q.png") no-repeat center center/cover;
  width: 60rem;
  height: 52rem;
}
.faq .faq-content {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 28rem;
  line-height: 2;
}
.faq .qa-note {
  font-family: "Noto Sans JP", sans-serif;
  border: 2rem solid #011388;
  margin: 0 40rem;
  padding: 26rem 32rem 26rem 26rem;
}
.faq .qa-note h4 {
  font-weight: 700;
  font-size: 26rem;
  letter-spacing: 0.03em;
  line-height: 2.1538461538;
  margin-bottom: 7rem;
}
.faq .qa-note li {
  font-size: 24rem;
  line-height: 1.6;
  position: relative;
  padding-left: 20rem;
  margin-bottom: 22rem;
  letter-spacing: 0.03em;
}
.faq .qa-note li::before {
  content: "";
  position: absolute;
  left: 2rem;
  top: 15rem;
  width: 6rem;
  height: 6rem;
  border-radius: 100%;
  background-color: #333;
}

.address {
  font-size: 24rem;
  line-height: 1.5;
  padding: 72rem 40rem;
  background-color: #f3f8ff;
}
.address h2 {
  font-weight: 700;
  font-size: 34rem;
  letter-spacing: 0.03em;
  line-height: 1.6470588235;
  border-top: 2rem solid #011388;
  border-bottom: 2rem solid #011388;
  padding: 50rem 0;
  text-align: center;
  margin-bottom: 40rem;
}
.address .address-image {
  width: 300rem;
  margin: 0 auto 33rem;
}
.address p,
.address address,
.address a {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
}
.address address {
  margin-bottom: 9rem;
}
.address p {
  margin-bottom: 12rem;
}
.address a {
  color: #011388;
  text-decoration: underline;
}