/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#main .mainVisual {
  padding: 6.51vw 0;
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
  align-items: flex-start;
  position: relative;
  background: url(../img/index/fv_bg01.webp) no-repeat center top/cover;
  z-index: 5;
}
#main .mainVisual::before {
  margin-left: -0.521vw;
  width: 65.104vw;
  height: 44.922vw;
  position: absolute;
  left: 50%;
  top: 10.417vw;
  transform: translateX(-50%);
  background: url(../img/index/fv_bg02.webp) no-repeat center center/cover;
  border-radius: 1.302vw;
  content: "";
}
#main .mainVisual .img01 {
  width: 8.529vw;
  position: absolute;
  left: 0;
  top: 6.706vw;
}
#main .mainVisual .img02 {
  width: 19.141vw;
  position: absolute;
  right: -12.76vw;
  top: 19.466vw;
}
#main .mainVisual .img03 {
  width: 27.344vw;
  position: absolute;
  left: 0;
  bottom: -5.208vw;
  border-radius: 0 1.302vw 1.302vw 0;
  box-shadow: 0 0.4rem 2rem rgba(0, 0, 0, 0.3);
}
#main .mainVisual .img03 img {
  width: 100%;
  border-radius: inherit;
}
#main .mainVisual .guidebook {
  width: 7vw;
  position: absolute;
  left: 15.2vw;
  bottom: 13vw;
  z-index: 1;
}
#main .mainVisual .hero {
  width: 50.78125%;
  position: relative;
}
#main .mainVisual .hero img {
  width: 100%;
  border-radius: 1.302vw 0 0 1.302vw;
}
#main .mainVisual .hero .txt01 {
  padding: 0 0 3.711vw 0.651vw;
  position: absolute;
  right: 1%;
  top: 6.9%;
  text-indent: 0.25em;
  color: var(--blue);
  font-weight: 600;
  font-size: 4.8vw;
  font-style: italic;
  line-height: 1.1;
  white-space: nowrap;
  letter-spacing: -0.06em;
  background: url(../img/index/line01.webp) no-repeat left bottom;
  background-size: 25.977vw;
}
#main .mainVisual .hero .txt01 .sm {
  font-size: 3.906vw;
}
#main .mainVisual .hero .txt02 {
  position: absolute;
  left: 10.3%;
  top: 36.2%;
  color: var(--blue);
  font-family: var(--zenKakuGothic);
  font-size: 1.042vw;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.36;
}
#main .mainVisual .hero .txt02 .sm {
  display: block;
  font-size: 0.911vw;
}
#main .mainVisual .hero .txt03 {
  position: absolute;
  right: 1.237vw;
  bottom: 1.302vw;
  color: var(--blue);
  font-weight: 700;
  font-size: 1.302vw;
  font-family: var(--zenKakuGothic);
  line-height: 1.3;
  letter-spacing: 0.06em;
}
#main .mainVisual .hero .banner {
  width: 29.948vw;
  position: absolute;
  right: 0;
  bottom: 3.32vw;
  box-shadow: 0 0.4rem 2rem rgba(0, 0, 0, 0.3);
}
#main .mainVisual .hero .banner img {
  width: 100%;
  border-radius: 0;
}
#main .mainVisual .leadBox {
  padding: 7.943vw 1.302vw 6.51vw 2.865vw;
  flex: 1;
  position: relative;
}
#main .mainVisual .copy {
  margin-bottom: 2.865vw;
  text-align: center;
  color: var(--white);
  font-size: 5.078vw;
  font-style: italic;
  font-weight: 700;
  letter-spacing: -0.12em;
  line-height: 1;
}
#main .mainVisual .copy .txt {
  margin-bottom: 0.456vw;
  display: block;
  color: var(--yellow);
  font-family: var(--zenKakuGothic);
  font-size: 1.302vw;
  letter-spacing: 0.72em;
  line-height: 1.8;
}
#main .mainVisual .copy .mincho {
  display: block;
  letter-spacing: -0.06em;
}
#main .mainVisual .copy .lg {
  font-size: 7.031vw;
  letter-spacing: -0.1em;
  line-height: 1;
}
#main .mainVisual .copy .mid {
  font-size: 6.901vw;
  line-height: 1;
}
#main .mainVisual .copy .sm01 {
  font-size: 2.865vw;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
}
#main .mainVisual .copy .sm02 {
  font-size: 4.167vw;
  line-height: 1;
}
#main .mainVisual .pointList {
  margin: 0 auto;
  width: 40.365vw;
  display: flex;
  border-radius: 1.302vw;
  background: rgba(255, 255, 255, 0.1);
  box-shadow: 0 0.4rem 2rem rgba(0, 0, 0, 0.3);
  position: relative;
  z-index: 1;
}
#main .mainVisual .pointList li {
  padding: 3.385vw 0.651vw 1.497vw;
  width: 22%;
  position: relative;
}
#main .mainVisual .pointList li:nth-child(2) {
  width: 23.3%;
}
#main .mainVisual .pointList li:nth-child(3) {
  width: 28.2%;
}
#main .mainVisual .pointList li:nth-child(4) {
  flex: 1;
}
#main .mainVisual .pointList li:not(:last-child)::after {
  width: 0.065vw;
  position: absolute;
  right: 0;
  top: 1.302vw;
  bottom: 1.302vw;
  background: var(--yellow);
  content: "";
}
#main .mainVisual .pointList li .num {
  position: absolute;
  left: 50%;
  top: -1.302vw;
  color: var(--white);
  font-family: var(--mincho);
  font-style: italic;
  font-weight: 600;
  font-size: 1.823vw;
  transform: translateX(-50%);
}
#main .mainVisual .pointList li .text {
  width: 100%;
  text-align: center;
  color: var(--yellow);
  font-family: var(--zenKakuGothic);
  font-size: 1.042vw;
  font-weight: 700;
  line-height: 1.36;
  position: relative;
  z-index: 1;
}
#main .mainVisual .pointList li .icon {
  width: 100%;
  position: absolute;
  left: 0;
  top: 1.042vw;
  text-align: center;
}
#main .mainVisual .pointList li .icon img {
  width: 8.464vw;
}
@media all and (max-width: 896px) {
  #main .mainVisual {
    padding: 6.3rem 0;
    display: block;
  }
  #main .mainVisual::before {
    margin-left: 0;
    width: calc(100% - 2rem);
    height: auto;
    left: auto;
    right: 0;
    top: 7.9rem;
    transform: none;
    aspect-ratio: 355/260;
    border-radius: 1rem 0 0 1rem;
  }
  #main .mainVisual .img01 {
    width: 18.667vw;
    top: 14.4vw;
    left: -0.8vw;
    z-index: 1;
  }
  #main .mainVisual .img02 {
    width: 13rem;
    right: -5.2rem;
    top: -1.5rem;
  }
  #main .mainVisual .img03 {
    width: 18rem;
    bottom: -8.7rem;
    border-radius: 0 1rem 1rem 0;
  }
  #main .mainVisual .guidebook {
    width: 21vw;
    position: absolute;
    right: 3.2vw;
    bottom: 38vw;
    z-index: 1;
    transform: rotate(11deg);
    left: auto;
  }
  #main .mainVisual .hero {
    margin: -4vw 0 10.2vw 10.667vw;
    width: auto;
  }
  #main .mainVisual .hero img {
    border-radius: 2.667vw 0 0 2.667vw;
  }
  #main .mainVisual .hero .txt01 {
    padding: 0 1.6vw 6.933vw 1.6vw;
    right: 3%;
    top: 8%;
    font-size: 8vw;
    background-size: 100% auto;
  }
  #main .mainVisual .hero .txt01 .sm {
    font-size: 7.2vw;
  }
  #main .mainVisual .hero .txt02 {
    left: 3.6%;
    top: 57%;
    font-size: 3.733vw;
    line-height: 1.4;
  }
  #main .mainVisual .hero .txt02 .sm {
    font-size: 3.2vw;
  }
  #main .mainVisual .hero .txt03 {
    right: auto;
    left: 0;
    bottom: -5.333vw;
    font-size: 2.933vw;
    color: var(--white);
  }
  #main .mainVisual .hero .banner {
    width: 53.333vw;
    bottom: -4.267vw;
  }
  #main .mainVisual .leadBox {
    padding: 0 2rem;
  }
  #main .mainVisual .copy {
    margin-bottom: 2rem;
    font-size: 3rem;
    letter-spacing: -0.06em;
  }
  #main .mainVisual .copy .txt {
    margin-bottom: 0.7rem;
    font-size: 1.6rem;
    line-height: 1.6;
    letter-spacing: 0.3em;
  }
  #main .mainVisual .copy .mincho {
    letter-spacing: -0.06em;
  }
  #main .mainVisual .copy .lg {
    font-size: 4.8rem;
    letter-spacing: -0.06em;
  }
  #main .mainVisual .copy .mid {
    font-size: 4.6rem;
  }
  #main .mainVisual .copy .sm01 {
    font-size: 2.4rem;
  }
  #main .mainVisual .copy .sm02 {
    font-size: 3.2rem;
    letter-spacing: -0.04em;
  }
  #main .mainVisual .pointList {
    padding: 0.6rem 2rem 0;
    width: auto;
    flex-wrap: wrap;
    border-radius: 1rem;
  }
  #main .mainVisual .pointList li {
    padding: 2.5rem 0.5rem 1.2rem;
    width: 50%;
    min-height: 9.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  #main .mainVisual .pointList li:nth-child(2) {
    width: 50%;
  }
  #main .mainVisual .pointList li:nth-child(3) {
    width: 50%;
  }
  #main .mainVisual .pointList li:nth-child(4) {
    width: 50%;
    flex: initial;
  }
  #main .mainVisual .pointList li:not(:last-child)::after {
    top: 0.8rem;
    bottom: 1.6rem;
  }
  #main .mainVisual .pointList li:not(:nth-child(2n-1))::after {
    display: none;
  }
  #main .mainVisual .pointList li::before {
    width: 100%;
    height: 0.1rem;
    position: absolute;
    left: 0;
    top: -0.5rem;
    background: var(--yellow);
    content: "";
  }
  #main .mainVisual .pointList li:nth-child(1)::before, #main .mainVisual .pointList li:nth-child(2)::before {
    display: none;
  }
  #main .mainVisual .pointList li .num {
    left: 0.4rem;
    top: 0.3rem;
    font-size: 1.8rem;
    transform: none;
  }
  #main .mainVisual .pointList li .text {
    font-size: 1.3rem;
    line-height: 1.3;
  }
  #main .mainVisual .pointList li .icon {
    top: 1.2rem;
  }
  #main .mainVisual .pointList li .icon img {
    width: 10.8rem;
  }
}
#main .first {
  padding: 8.3rem 0 13.9rem;
  position: relative;
  text-align: center;
  z-index: 2;
}
#main .first::before {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background: url(../img/index/first_bg.webp) no-repeat center top/cover;
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 10.8rem), 50% 100%, 0 calc(100% - 10.8rem));
  content: "";
}
#main .first .content {
  max-width: 153.6rem;
  position: relative;
  z-index: 1;
}
#main .first h2 {
  margin-bottom: 1.4rem;
  color: var(--pink);
  font-weight: 700;
  font-size: 7rem;
  font-style: italic;
  letter-spacing: -0.06em;
  line-height: 1;
}
#main .first h2 .sm {
  font-size: 71.4%;
}
#main .first .lead {
  margin: 0 auto 3.3rem;
  width: fit-content;
  color: var(--pink);
  font-family: var(--zenKakuGothic);
  font-weight: 700;
  font-style: italic;
  font-size: 3rem;
  letter-spacing: 0.6em;
  line-height: 1.8;
}
#main .first .lead span {
  padding-bottom: 0.5rem;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  background: linear-gradient(var(--white), var(--white)) no-repeat left bottom 15%/100% 2rem;
}
#main .first .text {
  font-weight: 500;
  font-size: 1.8rem;
  letter-spacing: 0.06em;
  line-height: 2.33;
}
#main .first .text .pink {
  color: var(--pink);
  font-weight: 700;
  letter-spacing: 0.1em;
}
#main .first .photoBox img {
  width: 100%;
  object-fit: cover;
  aspect-ratio: 1;
  border-radius: 100%;
  background: rgba(0, 0, 0, 0.3);
  box-shadow: 0 0.4rem 2rem rgba(0, 0, 0, 0.3);
}
#main .first .photoBox .photo01 {
  width: 20rem;
  position: absolute;
  right: 3rem;
  top: 3.7rem;
}
#main .first .photoBox .photo02 {
  width: 28rem;
  position: absolute;
  right: 8rem;
  bottom: -17.9rem;
}
@media all and (max-width: 896px) {
  #main .first {
    padding: 11.4rem 0 5.3rem;
  }
  #main .first::before {
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 5.2rem), 50% 100%, 0 calc(100% - 5.2rem));
  }
  #main .first h2 {
    margin-bottom: 1.8rem;
    font-size: 5rem;
  }
  #main .first h2 .sm {
    font-size: 71.4%;
  }
  #main .first .lead {
    margin-bottom: 2.7rem;
    font-size: 1.8rem;
    line-height: 1.75;
    letter-spacing: 0.5em;
  }
  #main .first .lead span {
    padding-bottom: 0.5rem;
    background-position: left bottom;
  }
  #main .first .text {
    text-align: justify;
    font-size: 1.4rem;
    line-height: 1.79;
  }
  #main .first .photoBox {
    display: flex;
    justify-content: center;
    gap: 1rem;
    flex-direction: row-reverse;
  }
  #main .first .photoBox .photo01 {
    width: 10rem;
    position: relative;
    right: auto;
    top: auto;
  }
  #main .first .photoBox .photo01 img {
    box-shadow: 0 0.4rem 1rem rgba(0, 0, 0, 0.2);
  }
  #main .first .photoBox .photo02 {
    margin-top: 3rem;
    width: 15rem;
    position: relative;
    right: auto;
    bottom: auto;
  }
  #main .first .photoBox .photo02 img {
    box-shadow: 0 0.4rem 1rem rgba(0, 0, 0, 0.2);
  }
}
#main .plan {
  padding: 7rem 0 18rem;
  position: relative;
  z-index: 1;
}
#main .plan::before {
  width: 100%;
  height: 46rem;
  position: absolute;
  left: 0;
  top: -10.8rem;
  background: url(../img/index/plan_bg01.webp) no-repeat center top/100% 100%;
  content: "";
}
#main .plan::after {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background: url(../img/index/plan_bg02.webp) no-repeat center bottom -0.1rem/100% auto;
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 11.2rem), 50% 100%, 0 calc(100% - 11.2rem));
  content: "";
}
#main .plan .content {
  max-width: 124rem;
  position: relative;
  z-index: 2;
}
#main .plan .img01 {
  width: 22rem;
  max-width: 14.5%;
  position: absolute;
  right: 0;
  top: 23.5rem;
}
#main .plan .img01 img {
  width: 100%;
  border-radius: 2rem 0 0 2rem;
  box-shadow: 0 0.4rem 2rem rgba(0, 0, 0, 0.3);
}
#main .plan .img02 {
  width: 22rem;
  max-width: 14.5%;
  position: absolute;
  left: 0;
  top: 69.1rem;
  z-index: 1;
}
#main .plan .img02 img {
  width: 100%;
  border-radius: 0 2rem 2rem 0;
  box-shadow: 0 0.4rem 2rem rgba(0, 0, 0, 0.3);
}
#main .plan .comLinkUl {
  margin-bottom: 15.9rem;
}
#main .plan h2 {
  margin: 0 auto 4.8rem;
  padding-left: 2.9rem;
  width: fit-content;
  position: relative;
  text-align: center;
  color: var(--green);
  font-weight: 700;
  font-size: 8.8rem;
  font-style: italic;
  line-height: 1;
  letter-spacing: -0.06em;
}
#main .plan h2 .fz01 {
  font-size: 9.4rem;
  line-height: 1;
  letter-spacing: -0.1em;
}
#main .plan h2 .fz02 {
  font-weight: 900;
  font-size: 6rem;
  letter-spacing: -0.06em;
}
#main .plan h2 .txt01 {
  padding: 0 0 5rem;
  width: fit-content;
  min-width: 30.9rem;
  display: block;
  position: absolute;
  left: -16.8rem;
  top: -4.5rem;
  font-weight: 700;
  font-family: var(--zenKakuGothic);
  font-size: 2.8rem;
  font-style: normal;
  letter-spacing: 0;
  background: url(../img/index/line03.webp) no-repeat center bottom/100% auto;
}
#main .plan h2 .txt01 span {
  padding-right: 0.5rem;
  display: block;
  transform: rotate(-8deg);
}
#main .plan .tblBox {
  margin: 0 auto 12.8rem;
  max-width: 100rem;
  border-radius: 2rem;
  box-shadow: 0 0.4rem 2rem rgba(0, 0, 0, 0.3);
  border: 0.2rem solid var(--green);
  background: var(--white);
  overflow: hidden;
}
#main .plan .tblBox table {
  width: 100%;
  border-collapse: collapse;
}
#main .plan .tblBox th,
#main .plan .tblBox td {
  padding: 1.5rem 2.8rem 1.5rem;
  height: 8rem;
  vertical-align: middle;
  text-align: left;
  color: var(--green);
  font-weight: 700;
  font-size: 2.4rem;
  letter-spacing: 0.04em;
  line-height: 1.2;
  font-feature-settings: "palt";
  background: url(../img/index/plan_bg03.webp) no-repeat center center/cover, var(--white);
  background-blend-mode: multiply, normal;
  border-top: 0.2rem solid var(--green);
}
#main .plan .tblBox th {
  width: 68%;
  border-right: 0.2rem solid var(--green);
}
#main .plan .tblBox th .txt01 {
  font-size: 2.8rem;
}
@media all and (min-width: 897px) {
  #main .plan .tblBox th .sm {
    font-size: 2.2rem;
  }
}
#main .plan .tblBox td {
  text-align: right;
  font-size: 3.2rem;
}
#main .plan .tblBox td .txt02 {
  font-size: 3.6rem;
}
#main .plan .tblBox td .sm {
  font-size: 2.4rem;
}
#main .plan .tblBox tr:nth-child(2n-1) th,
#main .plan .tblBox tr:nth-child(2n-1) td {
  background: url(../img/index/plan_bg03.webp) no-repeat center center/cover, var(--grey2);
  background-blend-mode: multiply, normal;
}
#main .plan .tblBox tr:first-child th,
#main .plan .tblBox tr:first-child td {
  height: 7.8rem;
  background: url(../img/index/plan_bg03.webp) no-repeat center center/cover, var(--yellow);
  background-blend-mode: multiply, normal;
  border-top: none;
}
#main .plan .text {
  margin: 0 auto;
  max-width: 105rem;
  text-indent: 0.3em;
  font-style: italic;
  font-size: 4.6rem;
  font-weight: 700;
  line-height: 1.48;
}
#main .plan .text .lg {
  color: var(--blue3);
  font-size: 7rem;
}
@media all and (max-width: 896px) {
  #main .plan {
    padding: 4.1rem 0 7.8rem;
  }
  #main .plan::before {
    top: -5.4rem;
  }
  #main .plan::after {
    min-width: 58rem;
    left: 50%;
    transform: translateX(-50%);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 5.8rem), 50% 100%, 0 calc(100% - 5.8rem));
  }
  #main .plan .img01,
  #main .plan .img02 {
    display: none;
  }
  #main .plan .comLinkUl {
    margin-bottom: 12.8rem;
  }
  #main .plan h2 {
    margin-bottom: 2.9rem;
    padding-left: 0;
    font-size: 4.2rem;
  }
  #main .plan h2 .mincho {
    line-height: 1.2;
  }
  #main .plan h2 .fz01 {
    font-size: 4.8rem;
  }
  #main .plan h2 .fz02 {
    font-size: 3.6rem;
  }
  #main .plan h2 .txt01 {
    padding: 0 0 3.2rem;
    width: fit-content;
    min-width: 21rem;
    font-size: 1.8rem;
    left: -5rem;
    top: -5.3rem;
  }
  #main .plan h2 .txt01 span {
    padding-right: 0.5rem;
  }
  #main .plan .tblBox {
    margin-bottom: 2.9rem;
    border-radius: 1rem;
    box-shadow: none;
  }
  #main .plan .tblBox th,
  #main .plan .tblBox td {
    padding: 0.5rem;
    width: 100% !important;
    height: auto;
    display: block;
    font-size: 1.6rem;
    line-height: 1.5;
    text-align: center;
    border-right: none;
  }
  #main .plan .tblBox th {
    border-right: none;
    background: url(../img/index/plan_bg03.webp) no-repeat center center/cover, var(--grey3);
    background-blend-mode: multiply, normal;
  }
  #main .plan .tblBox th .txt01 {
    font-size: 1.6rem;
  }
  #main .plan .tblBox td {
    text-align: center;
    font-size: 3.2rem;
    background: url(../img/index/plan_bg03.webp) no-repeat center center/cover, var(--white);
    background-blend-mode: multiply, normal;
  }
  #main .plan .tblBox td .txt02 {
    font-size: 2.8rem;
  }
  #main .plan .tblBox tr:nth-child(2n-1) th {
    background: url(../img/index/plan_bg03.webp) no-repeat center center/cover, var(--grey3);
    background-blend-mode: multiply, normal;
  }
  #main .plan .tblBox tr:nth-child(2n-1) td {
    background: url(../img/index/plan_bg03.webp) no-repeat center center/cover, var(--white);
    background-blend-mode: multiply, normal;
  }
  #main .plan .tblBox tr:first-child th,
  #main .plan .tblBox tr:first-child td {
    height: auto;
  }
  #main .plan .tblBox tr:first-child th {
    padding: 0.8rem 0.5rem 0.5rem;
    border-bottom: 0.2rem solid var(--green);
    background: url(../img/index/plan_bg03.webp) no-repeat center center/cover, var(--yellow2);
    background-blend-mode: multiply, normal;
  }
  #main .plan .tblBox tr:first-child td {
    padding: 0.3rem 0.5rem 0.7rem;
    background: url(../img/index/plan_bg03.webp) no-repeat center center/cover, var(--yellow);
    background-blend-mode: multiply, normal;
  }
  #main .plan .text {
    font-size: 2.2rem;
  }
  #main .plan .text .lg {
    font-size: 3.2rem;
  }
}
#main .dental {
  margin-top: -11.5rem;
  padding: 22.6rem 0 21.8rem;
  position: relative;
  background: url(../img/index/dental_bg03.webp) no-repeat center bottom/100% 24rem, url(../img/index/dental_bg01.webp) repeat center center/3rem;
}
#main .dental .bubble01 {
  width: 22rem;
  position: absolute;
  left: 0;
  top: -42.4rem;
  z-index: 3;
}
#main .dental .bubble02 {
  width: 20rem;
  position: absolute;
  right: 0;
  top: 7.5rem;
}
#main .dental .bubble03 {
  width: 14rem;
  position: absolute;
  left: 0;
  top: 86.9rem;
}
#main .dental .bubble04 {
  width: 13rem;
  position: absolute;
  right: 0;
  bottom: 4rem;
}
#main .dental .content {
  position: relative;
  max-width: 104rem;
}
#main .dental h2 {
  margin: 0 auto 3.9rem;
  padding: 0 2rem;
  width: fit-content;
  position: relative;
  font-size: 8.8rem;
  font-weight: 700;
  font-style: italic;
  letter-spacing: -0.07em;
  line-height: 1;
  color: var(--blue2);
}
#main .dental h2::before, #main .dental h2::after {
  margin-top: 0.8rem;
  width: 0.4rem;
  height: 91%;
  position: absolute;
  top: 50%;
  background: var(--blue2);
  content: "";
}
#main .dental h2::before {
  left: 0;
  transform: translateY(-50%) rotate(-20deg);
}
#main .dental h2::after {
  right: 0;
  transform: translateY(-50%) rotate(20deg);
}
#main .dental .lead {
  margin-bottom: 4.8rem;
  text-align: center;
  font-style: italic;
  font-weight: 500;
  font-size: 2.8rem;
  font-family: var(--zenKakuGothic);
  letter-spacing: 0.4em;
  line-height: 2;
}
#main .dental .lead .lg {
  font-size: 3.4rem;
  font-weight: 700;
  color: var(--blue2);
  letter-spacing: 0.4em;
}
#main .dental .priceBox {
  margin-bottom: 11.6rem;
  padding: 4rem;
  border-radius: 2rem;
  background: url(../img/index/dental_bg02.webp) no-repeat center center/cover;
}
#main .dental .priceBox .text01 {
  margin-bottom: 1.9rem;
  padding: 0.3rem 1rem 0.6rem;
  text-align: center;
  color: var(--blue2);
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  border-radius: 5rem;
  background: var(--white);
}
#main .dental .priceBox .text01 .lg {
  font-size: 3.4rem;
}
#main .dental .priceBox .text02 {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2.5rem;
}
#main .dental .priceBox .text02 .subTxt01 {
  margin: 2rem 0 0 1.2rem;
  padding: 0.9rem 0.5rem 1.7rem;
  min-width: 24rem;
  color: var(--white);
  text-align: center;
  font-size: 3.4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1;
  border-radius: 1rem;
  background: var(--blue2);
}
#main .dental .priceBox .text02 .subTxt01 .lg {
  font-size: 5.4rem;
  line-height: 1;
}
#main .dental .priceBox .text02 .subTxt02 {
  font-weight: 700;
  font-size: 5.4rem;
  letter-spacing: 0.04em;
  line-height: 1;
  color: var(--blue2);
}
#main .dental .priceBox .text02 .subTxt02 .lg {
  font-size: 10rem;
  line-height: 1;
}
#main .dental .text03 {
  margin: 0 auto 2.1rem;
  width: fit-content;
  position: relative;
  text-align: center;
  font-weight: 500;
  font-family: var(--zenKakuGothic);
  font-size: 2.8rem;
  font-style: italic;
  line-height: 1.79;
  letter-spacing: 0.4em;
}
#main .dental .text03 .mincho {
  padding-bottom: 3.1rem;
  min-width: 14.1rem;
  position: absolute;
  left: 2.1rem;
  top: -3.2rem;
  color: var(--pink);
  text-align: center;
  font-weight: 700;
  font-size: 3.8rem;
  font-style: normal;
  letter-spacing: -0.2em;
  line-height: 1;
  background: url(../img/index/line04.webp) no-repeat center bottom/100%;
}
#main .dental .text03 .mincho span {
  width: fit-content;
  display: block;
  margin: 0 auto;
  transform: rotate(-8deg);
}
#main .dental .text03 .highlight01 {
  color: var(--pink);
  font-weight: 700;
  font-size: 5rem;
  letter-spacing: 0.4em;
  background: linear-gradient(var(--yellow), var(--yellow)) no-repeat left bottom/100% 3rem;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
#main .dental .text03 .highlight02 {
  color: var(--pink);
  font-weight: 700;
  font-size: 3.4rem;
  letter-spacing: 0.4em;
}
#main .dental .text04 {
  margin-bottom: 9rem;
  text-align: center;
  font-weight: 500;
  font-size: 1.8rem;
  line-height: 2;
  letter-spacing: 0.01em;
}
#main .dental .tabelBox h3 {
  margin-bottom: 2.9rem;
  text-align: center;
  overflow-x: clip;
}
#main .dental .tabelBox h3 span {
  position: relative;
  display: inline-block;
  color: var(--blue);
  font-weight: 700;
  font-size: 2.8rem;
  letter-spacing: 0.01em;
}
#main .dental .tabelBox h3 span::before {
  margin-top: 0.1rem;
  margin-right: 2rem;
  width: 100rem;
  height: 0.2rem;
  position: absolute;
  right: 100%;
  top: 50%;
  background: var(--blue);
  content: "";
}
#main .dental .tabelBox h3 span::after {
  margin-top: 0.1rem;
  margin-left: 2rem;
  width: 100rem;
  height: 0.2rem;
  position: absolute;
  left: 100%;
  top: 50%;
  background: var(--blue);
  content: "";
}
#main .dental .tabelBox .scrollBox {
  margin-bottom: 2.2rem;
}
#main .dental .tabelBox .scrollBox .tblWrap {
  border-radius: 2rem;
  border: 0.2rem solid var(--blue);
  overflow: hidden;
}
#main .dental .tabelBox .scrollBox .tblWrap table {
  width: 100%;
  border-collapse: collapse;
}
#main .dental .tabelBox .scrollBox .tblWrap th,
#main .dental .tabelBox .scrollBox .tblWrap td {
  height: 6rem;
  padding: 1rem;
  vertical-align: middle;
  text-align: center;
  color: var(--blue);
  font-weight: 700;
  font-size: 1.6rem;
  letter-spacing: 0.04em;
  background: var(--white);
  border-top: 0.2rem solid var(--blue);
  border-left: 0.2rem solid var(--blue);
}
#main .dental .tabelBox .scrollBox .tblWrap th:first-child {
  width: 13.9%;
  border-left: none;
}
#main .dental .tabelBox .scrollBox .tblWrap thead th,
#main .dental .tabelBox .scrollBox .tblWrap thead td {
  height: 5.8rem;
  border-top: none;
  color: var(--white);
  background: var(--blue5);
}
#main .dental .tabelBox .scrollBox .tblWrap tbody th {
  background: var(--blue4);
}
#main .dental .tabelBox .scrollBox .tblWrap tbody td {
  width: 16.225%;
}
#main .dental .tabelBox .scrollBox .tblWrap tbody td:first-of-type {
  width: 21.2%;
}
#main .dental .tabelBox .scrollBox .tblWrap tbody tr:nth-child(2n) th {
  background: var(--green2);
}
#main .dental .tabelBox .scrollBox .tblWrap tbody tr:nth-child(2n) td {
  background: var(--grey);
}
#main .dental .tabelBox .note {
  padding-left: 1em;
  text-indent: -1em;
  text-align: right;
  font-size: 1.4rem;
  font-weight: 400;
  letter-spacing: 0.01em;
}
@media all and (max-width: 896px) {
  #main .dental {
    margin-top: -5.8rem;
    padding: 12.1rem 0 10rem;
    background: url(../img/index/dental_bg03.webp) no-repeat center bottom/100% 5.9rem, url(../img/index/dental_bg01.webp) repeat center center/3rem;
  }
  #main .dental .bubble01 {
    width: 3.4rem;
    top: -2.3rem;
  }
  #main .dental .bubble02 {
    width: 4.4rem;
    top: 3.5rem;
  }
  #main .dental .bubble03 {
    width: 5.4rem;
    top: 49rem;
    z-index: 2;
    user-select: none;
  }
  #main .dental .bubble04 {
    width: 3.8rem;
    bottom: auto;
    top: 53.3rem;
  }
  #main .dental h2 {
    margin-bottom: 2.4rem;
    padding: 0 1.8rem 0.1rem;
    font-size: 3.2rem;
  }
  #main .dental h2::before, #main .dental h2::after {
    margin-top: 0;
    height: 122%;
  }
  #main .dental .lead {
    margin-bottom: 2.5rem;
    font-size: 1.8rem;
    letter-spacing: 0.3em;
  }
  #main .dental .lead .lg {
    padding-top: 0.4rem;
    display: inline-block;
    font-size: 2.4rem;
    letter-spacing: 0.2em;
    line-height: 1.78;
  }
  #main .dental .priceBox {
    margin-bottom: 11.2rem;
    padding: 2.1rem 2rem;
    border-radius: 1rem;
  }
  #main .dental .priceBox .text01 {
    margin-bottom: 0.8rem;
    padding: 1.7rem 1rem 1.4rem;
    font-size: 2rem;
    line-height: 1.18;
    border-radius: 1rem;
  }
  #main .dental .priceBox .text01 .lg {
    font-size: 3rem;
  }
  #main .dental .priceBox .text02 {
    margin: 0 -1.5rem;
    gap: 1rem;
  }
  #main .dental .priceBox .text02 .subTxt01 {
    margin: 1.6rem 0 0 0;
    padding: 0.7rem 0.5rem 0.9rem;
    min-width: 8rem;
    font-size: 1.2rem;
    border-radius: 1rem;
  }
  #main .dental .priceBox .text02 .subTxt01 .lg {
    font-size: 1.8rem;
  }
  #main .dental .priceBox .text02 .subTxt02 {
    font-size: 2rem;
  }
  #main .dental .priceBox .text02 .subTxt02 .lg {
    font-size: 5rem;
  }
  #main .dental .text03 {
    margin-bottom: 1.9rem;
    font-size: 1.8rem;
    letter-spacing: 0.3em;
  }
  #main .dental .text03 .txtWrap {
    margin: 0 -0.5em;
    display: block;
    width: fit-content;
  }
  #main .dental .text03 .mincho {
    padding-bottom: 2.5rem;
    min-width: 10.2rem;
    left: -0.2rem;
    top: -5.4rem;
    font-size: 2.4rem;
  }
  #main .dental .text03 .mincho span {
    padding-right: 0.5rem;
  }
  #main .dental .text03 .highlight01 {
    font-size: 2.4rem;
    letter-spacing: 0.3em;
    background-size: 100% 2rem;
  }
  #main .dental .text03 .highlight02 {
    font-size: 2.4rem;
    letter-spacing: 0.3em;
    background: linear-gradient(var(--yellow), var(--yellow)) no-repeat left bottom/100% 2rem;
  }
  #main .dental .text04 {
    margin-bottom: 5.2rem;
    text-align: justify;
    font-size: 1.6rem;
    letter-spacing: 0;
  }
  #main .dental .tabelBox h3 {
    margin-bottom: 2rem;
  }
  #main .dental .tabelBox h3 span {
    font-size: 1.8rem;
    line-height: 1.4;
  }
  #main .dental .tabelBox h3 span::before {
    margin: 0;
    top: 0.7em;
    right: calc(100% - 1rem);
  }
  #main .dental .tabelBox h3 span::after {
    margin: 0;
    top: 0.7em;
    left: calc(100% - 1rem);
  }
  #main .dental .tabelBox .scrollBox {
    margin-bottom: 1.7rem;
    margin-right: -2rem;
    padding-top: 4.6rem;
  }
  #main .dental .tabelBox .scrollBox::-webkit-scrollbar {
    display: none;
  }
  #main .dental .tabelBox .scrollBox ::-webkit-scrollbar {
    display: none;
  }
  #main .dental .tabelBox .scrollBox .tblWrap {
    min-width: 88rem;
    border-radius: 1rem;
  }
  #main .dental .tabelBox .scrollBox .tblWrap th,
  #main .dental .tabelBox .scrollBox .tblWrap td {
    height: 5rem;
    padding: 0.5rem 0;
  }
  #main .dental .tabelBox .scrollBox .tblWrap thead th,
  #main .dental .tabelBox .scrollBox .tblWrap thead td {
    height: 4.8rem;
  }
  #main .dental .tabelBox .scrollBox .simplebar-track.simplebar-horizontal {
    bottom: auto;
    top: 0.5rem;
    left: -0.7rem;
    right: 2rem;
    height: 1.4rem;
    background: var(--grey);
    border-radius: 1rem;
  }
  #main .dental .tabelBox .scrollBox .simplebar-scrollbar::before {
    background: var(--grey4);
    opacity: 1;
  }
  #main .dental .tabelBox .note {
    text-align: justify;
    font-size: 1.2rem;
    line-height: 1.6;
  }
}
#main .doctor {
  padding: 0.1rem 0 18.4rem;
  position: relative;
  color: var(--white);
  background: url(../img/index/doctor_bg01.webp) no-repeat center center/cover;
}
#main .doctor h2 {
  margin: -10.3rem auto 4.8rem;
  padding: 0 2rem;
  max-width: 146rem;
  color: rgba(255, 255, 255, 0.5);
  font-weight: 400;
  font-size: 20rem;
  font-style: italic;
  font-family: var(--bacasime);
  line-height: 0.78;
  letter-spacing: 0;
  position: relative;
  z-index: 1;
}
#main .doctor h2 .mask {
  width: fit-content;
  display: inline-block;
  position: relative;
}
#main .doctor h2 .mask::before {
  width: 105%;
  height: 65.5%;
  position: absolute;
  left: 0;
  top: 0;
  color: transparent;
  overflow: hidden;
  background: url(../img/index/txt_bg.webp) no-repeat center center/cover;
  -webkit-background-clip: text;
  background-clip: text;
  content: "Doctor";
}
#main .doctor .itemBox {
  margin-bottom: 6rem;
  position: relative;
}
#main .doctor .itemBox::before {
  width: calc(50% + 23rem);
  position: absolute;
  right: 0;
  top: -5.9rem;
  bottom: -5.9rem;
  border-radius: 2rem 0 0 2rem;
  background: url(../img/index/doctor_bg02.webp) no-repeat center center/cover;
  content: "";
}
#main .doctor .itemBox:first-of-type {
  margin-bottom: 12.1rem;
}
#main .doctor .itemBox:first-of-type::before {
  top: -11.8rem;
  bottom: -12.2rem;
}
#main .doctor .itemBox:last-of-type {
  margin-bottom: 0;
}
#main .doctor .itemBox .subBox {
  margin: 0 auto;
  width: 120rem;
  max-width: calc(100% - 4rem);
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
  position: relative;
  z-index: 1;
}
#main .doctor .itemBox .subBox .photoBox {
  width: 28.37%;
}
#main .doctor .itemBox .subBox .photoBox img {
  width: 100%;
  border-radius: 2rem;
  box-shadow: 0 0.4rem 2rem rgba(0, 0, 0, 0.3);
}
#main .doctor .itemBox .subBox .textBox {
  padding-top: 4rem;
  width: 68%;
  max-width: 80rem;
}
#main .doctor .itemBox .subBox .textBox .ttlBox {
  margin-bottom: 3rem;
}
#main .doctor .itemBox .subBox .textBox .ttlBox h3 {
  padding-bottom: 3rem;
  display: flex;
  align-items: center;
  gap: 1.7rem;
  font-weight: 500;
  border-bottom: 0.1rem solid var(--white);
}
#main .doctor .itemBox .subBox .textBox .ttlBox h3 .txt01 {
  padding: 0.9rem 1.5rem;
  font-size: 2rem;
  letter-spacing: 0.06em;
  line-height: 1;
  border-radius: 5rem;
  border: 0.1rem solid var(--white);
}
#main .doctor .itemBox .subBox .textBox .ttlBox h3 .txt02 {
  margin-top: -0.5rem;
  font-size: 4rem;
  letter-spacing: 0.06em;
  line-height: 1;
}
#main .doctor .itemBox .subBox .textBox p {
  margin-bottom: 1.6rem;
}
#main .doctor .itemBox .subBox .textBox p:last-child {
  margin-bottom: 0;
}
#main .doctor .itemBox .subBox .textBox p {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.06em;
  text-align: justify;
}
#main .doctor .itemBox:nth-of-type(2n)::before {
  right: auto;
  left: 0;
  border-radius: 0 2rem 2rem 0;
}
#main .doctor .itemBox:nth-of-type(2n) .subBox {
  flex-direction: row;
}
@media all and (max-width: 896px) {
  #main .doctor {
    padding: 0 0 6.6rem;
  }
  #main .doctor h2 {
    margin: 0 0 0.6rem;
    padding: 0 1.8rem;
    font-size: 6rem;
    transform: translateY(-3rem);
  }
  #main .doctor .itemBox {
    margin: 0 0 2.3rem;
    padding: 0 2rem;
  }
  #main .doctor .itemBox::before {
    width: calc(100% - 4rem);
    top: 2rem;
    bottom: -8rem;
  }
  #main .doctor .itemBox:first-of-type {
    margin-bottom: 4.2rem;
  }
  #main .doctor .itemBox:first-of-type::before {
    top: -2rem;
    bottom: -10.6rem;
  }
  #main .doctor .itemBox:last-of-type {
    margin-bottom: 0;
  }
  #main .doctor .itemBox .subBox {
    width: auto;
    max-width: initial;
    display: block;
  }
  #main .doctor .itemBox .subBox .photoBox {
    width: 20rem;
    position: absolute;
    right: -5rem;
    top: 0;
  }
  #main .doctor .itemBox .subBox .photoBox img {
    border-radius: 1rem;
  }
  #main .doctor .itemBox .subBox .textBox {
    padding-top: 0;
    width: auto;
    max-width: initial;
  }
  #main .doctor .itemBox .subBox .textBox .ttlBox {
    margin-bottom: 2rem;
    padding-top: 5.5rem;
    min-height: 23.5rem;
    display: flex;
    align-items: center;
  }
  #main .doctor .itemBox .subBox .textBox .ttlBox h3 {
    padding-bottom: 2rem;
    width: 100%;
    align-items: flex-start;
    flex-direction: column;
    gap: 1rem;
  }
  #main .doctor .itemBox .subBox .textBox .ttlBox h3 .txt01 {
    padding: 0.9rem 1.5rem 1rem;
    width: fit-content;
    font-size: 1.6rem;
  }
  #main .doctor .itemBox .subBox .textBox .ttlBox h3 .txt02 {
    margin-top: 0.2rem;
    font-size: 3rem;
  }
  #main .doctor .itemBox .subBox .textBox p {
    margin-bottom: 1.6rem;
  }
  #main .doctor .itemBox .subBox .textBox p:last-child {
    margin-bottom: 0;
  }
  #main .doctor .itemBox .subBox .textBox p {
    font-size: 1.4rem;
    line-height: 1.78;
    letter-spacing: 0.04em;
  }
  #main .doctor .itemBox:nth-of-type(2n)::before {
    right: auto;
    left: 0;
  }
  #main .doctor .itemBox:nth-of-type(2n) .subBox .photoBox {
    right: auto;
    left: -5rem;
  }
  #main .doctor .itemBox:nth-of-type(2n) .subBox .textBox .ttlBox h3 {
    align-items: flex-end;
  }
  #main .doctor .item02 .subBox .textBox .ttlBox,
  #main .doctor .item03 .subBox .textBox .ttlBox {
    margin-bottom: 2.3rem;
    padding-top: 6.5rem;
  }
  #main .doctor .item03::before {
    bottom: -3.5rem;
  }
}
#main .clinic {
  padding: 8rem 0;
  position: relative;
  color: var(--white);
  background: url(../img/index/clinic_bg.webp) no-repeat center center/cover;
}
#main .clinic .content {
  max-width: 124rem;
}
#main .clinic .textBox {
  margin-left: auto;
  width: 90rem;
  padding: 5.5rem 6rem 4.8rem 10rem;
  border-radius: 2rem;
  border: 0.1rem solid var(--white);
}
#main .clinic .textBox h2 {
  margin-bottom: 1.9rem;
  text-align: center;
  font-weight: 600;
  font-size: 3rem;
  letter-spacing: 0.06em;
  line-height: 2.1;
}
#main .clinic .textBox h2 span {
  padding: 0.5rem 1rem;
  background: var(--pink);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
#main .clinic .textBox p {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.06em;
  text-align: justify;
}
#main .clinic .photo {
  width: 54.4rem;
  max-width: 35.42%;
  position: absolute;
  left: 0;
  bottom: -6.3rem;
}
#main .clinic .photo img {
  width: 100%;
}
@media all and (max-width: 896px) {
  #main .clinic {
    padding: 2rem 0;
  }
  #main .clinic .textBox {
    margin-left: 0;
    width: auto;
    padding: 3.4rem 1.9rem 7.6rem;
    border-radius: 1rem;
  }
  #main .clinic .textBox h2 {
    margin: 0 -4rem 1.8rem;
    font-size: 2rem;
    line-height: 2.46;
    letter-spacing: 0.04em;
  }
  #main .clinic .textBox h2 span {
    padding: 0.6rem 0.1rem 0.5rem;
  }
  #main .clinic .textBox p {
    font-size: 1.6rem;
    line-height: 1.81;
  }
  #main .clinic .photo {
    width: 18.2rem;
    max-width: initial;
    left: -0.7rem;
    bottom: -5.8rem;
  }
}
#main .ctaBox {
  padding: 10rem 0;
  background: url(../img/index/cta_bg.webp) no-repeat right top/70rem;
}
#main .ctaBox .content {
  max-width: 124rem;
}
#main .ctaBox p {
  margin-bottom: 5.3rem;
  text-align: center;
  font-weight: 500;
  font-size: 1.8rem;
  letter-spacing: 0.06em;
  line-height: 2;
}
@media all and (max-width: 896px) {
  #main .ctaBox {
    padding: 14.3rem 0 6.3rem;
    background-size: 39.5rem;
  }
  #main .ctaBox p {
    margin-bottom: 4.1rem;
    text-align: justify;
    letter-spacing: 0.03em;
  }
}
#main .promise {
  position: relative;
  z-index: 2;
}
#main .promise .sub01 {
  padding-top: 11.2rem;
  position: relative;
  z-index: 1;
}
#main .promise .sub01::before {
  width: 100%;
  height: calc(100% - 11.5rem);
  position: absolute;
  left: 0;
  top: 0;
  background: url(../img/index/promise_bg01.webp) no-repeat center top/cover;
  content: "";
  user-select: none;
  pointer-events: none;
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 13.9rem), 50% 100%, 0 calc(100% - 13.9rem));
}
#main .promise .sub01 h2 {
  margin-bottom: 6.9rem;
  text-align: center;
  color: var(--white);
  font-style: italic;
  font-family: var(--zenKakuGothic);
  font-weight: 700;
  font-size: 2.8rem;
  line-height: 1;
  letter-spacing: 0.4em;
  position: relative;
  z-index: 1;
}
#main .promise .sub01 h2 .lg {
  font-size: 8rem;
  font-weight: 600;
  letter-spacing: -0.08em;
  line-height: 1;
}
#main .promise .sub01 h2 .lg span {
  font-weight: 400;
}
#main .promise .sub01 .thinkBox {
  margin: 0 auto;
  max-width: 108.4rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}
#main .promise .sub01 .thinkBox .item {
  width: fit-content;
  min-width: 24rem;
  min-height: 14rem;
  padding: 3rem 2rem;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 4rem;
  background: var(--white);
}
#main .promise .sub01 .thinkBox .item::after {
  width: 6.1rem;
  position: absolute;
  left: calc(100% + 1.4rem);
  bottom: -3.2rem;
  aspect-ratio: 61/82;
  background: url(../img/index/bg01.webp) no-repeat center center/100%;
  content: "";
}
#main .promise .sub01 .thinkBox .item p {
  width: fit-content;
  color: var(--3rd);
  font-size: 2.6rem;
  font-weight: 600;
  font-family: var(--mincho);
  line-height: 1.54;
}
#main .promise .sub01 .thinkBox .item p.center {
  text-align: center;
}
#main .promise .sub01 .thinkBox .item01 {
  margin-left: auto;
}
#main .promise .sub01 .thinkBox .item02 {
  margin-top: -1rem;
  min-width: 26rem;
}
#main .promise .sub01 .thinkBox .item02::after {
  width: 7.1rem;
  bottom: -2.6rem;
  left: calc(100% + 1.2rem);
  aspect-ratio: 71/76;
  background-image: url(../img/index/bg02.webp);
}
#main .promise .sub01 .thinkBox .item03 {
  min-width: 26rem;
}
#main .promise .sub01 .thinkBox .item03::after {
  width: 5.5rem;
  aspect-ratio: 55/86;
  left: -0.2rem;
  bottom: -10.6rem;
  background-image: url(../img/index/bg03.webp);
}
#main .promise .sub01 .thinkBox .item04 {
  margin: -2rem 0 0 auto;
}
#main .promise .sub01 .thinkBox .item04::after {
  width: 8.5rem;
  left: -7.3rem;
  bottom: -7.6rem;
  aspect-ratio: 85/86;
  background-image: url(../img/index/bg04.webp);
}
#main .promise .sub01 .thinkBox .col01 {
  margin-left: 3.4rem;
  width: 33.8rem;
}
#main .promise .sub01 .thinkBox .col02 {
  width: 43.4rem;
}
#main .promise .sub01 .thinkBox .photo {
  margin: -20.2rem auto 0;
  width: 29.4rem;
  transform: translateX(-0.2rem);
}
#main .promise .sbu02 {
  padding: 6.5rem 0 16.6rem;
  position: relative;
  background: url(../img/index/promise_bg02.webp) no-repeat center top/cover;
}
#main .promise .sbu02 .bg01 {
  width: 70.2rem;
  position: absolute;
  left: 0;
  top: -25.5rem;
}
#main .promise .sbu02 .bg02 {
  width: 24.1rem;
  position: absolute;
  right: 12.8rem;
  top: -26rem;
  z-index: 2;
}
#main .promise .sbu02 .bg03 {
  width: 26.9rem;
  position: absolute;
  top: -8.4rem;
  right: 0;
  z-index: 3;
}
#main .promise .sbu02 .bg04 {
  width: 44rem;
  position: absolute;
  left: 0;
  bottom: 0;
}
#main .promise .sbu02 .bg05 {
  width: 44rem;
  position: absolute;
  right: 0;
  bottom: 0;
}
#main .promise .sbu02 .content {
  position: relative;
  z-index: 1;
}
#main .promise .sbu02 h3 {
  margin-bottom: 5.6rem;
  text-align: center;
  font-style: italic;
  font-family: var(--zenKakuGothic);
  font-weight: 700;
  font-size: 2.8rem;
  line-height: 1.8;
  letter-spacing: 0.4em;
}
#main .promise .sbu02 h3 .mincho {
  margin: 3.6rem auto 0;
  width: fit-content;
  display: block;
  position: relative;
  font-size: 6rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--blue2);
}
#main .promise .sbu02 h3 .mincho .sm {
  padding: 0 1.9rem;
  width: fit-content;
  white-space: nowrap;
  position: absolute;
  left: -6.2rem;
  top: -2.8rem;
  font-size: 2rem;
  font-weight: 700;
  font-family: var(--zenKakuGothic);
  font-style: normal;
  line-height: 1;
  letter-spacing: 0.06em;
  transform: rotate(-10deg);
}
#main .promise .sbu02 h3 .mincho .sm::before {
  width: 0.2rem;
  height: 150%;
  position: absolute;
  left: 0.6rem;
  top: -0.6rem;
  background: currentColor;
  transform: rotate(-20deg);
  content: "";
}
#main .promise .sbu02 h3 .mincho .sm::after {
  width: 0.2rem;
  height: 150%;
  position: absolute;
  right: 0;
  top: -0.6rem;
  background: currentColor;
  transform: rotate(20deg);
  content: "";
}
#main .promise .sbu02 .textBox {
  margin: 0 auto 5.8rem;
  max-width: 90rem;
  padding: 5.6rem 4rem 4.3rem;
  position: relative;
  color: var(--white);
  background: url(../img/index/promise_bg03.webp) no-repeat center center/cover;
  border-radius: 1.6rem;
  box-shadow: 0 0.4rem 2rem 0 rgba(0, 0, 0, 0.3);
}
#main .promise .sbu02 .textBox h4 {
  margin-bottom: 4.7rem;
  text-align: center;
  font-size: 3.8rem;
  font-weight: 700;
  line-height: 1;
  overflow-x: clip;
}
#main .promise .sbu02 .textBox h4 span {
  padding: 0 2rem;
  display: inline-block;
  position: relative;
}
#main .promise .sbu02 .textBox h4 span::before {
  margin-top: 0.2rem;
  width: 90rem;
  height: 0.7rem;
  position: absolute;
  right: 100%;
  top: 50%;
  transform: translateY(-50%);
  border-top: 0.1rem solid var(--white);
  border-bottom: 0.1rem solid var(--white);
  box-sizing: border-box;
  content: "";
}
#main .promise .sbu02 .textBox h4 span::after {
  margin-top: 0.2rem;
  width: 90rem;
  height: 0.7rem;
  position: absolute;
  left: 100%;
  top: 50%;
  transform: translateY(-50%);
  border-top: 0.1rem solid var(--white);
  border-bottom: 0.1rem solid var(--white);
  box-sizing: border-box;
  content: "";
}
#main .promise .sbu02 .textBox .textList li {
  padding: 1.8rem 21rem 1.8rem 9rem;
  font-size: 2.8rem;
  font-weight: 300;
  background: url(../img/index/check.webp) no-repeat left 2.9rem top 2rem/4.5rem;
  border-bottom: 0.2rem dotted var(--white);
}
#main .promise .sbu02 .textBox .textList li .highlight {
  color: var(--yellow);
  font-weight: 700;
}
#main .promise .sbu02 .textBox .textList li:last-child {
  border-bottom: none;
}
#main .promise .sbu02 .textBox .photo {
  width: 26rem;
  position: absolute;
  right: 2.8rem;
  bottom: 0;
}
#main .promise .sbu02 .text {
  text-align: center;
  color: var(--white);
  font-weight: 700;
  font-size: 6rem;
  font-style: italic;
  line-height: 1.4;
}
#main .promise .sbu02 .text .lg {
  font-size: 9rem;
  line-height: 1.13;
}
@media all and (max-width: 896px) {
  #main .promise .sub01 {
    padding-top: 4.5rem;
  }
  #main .promise .sub01::before {
    height: calc(100% - 3.6rem);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 6.4rem), 50% 100%, 0 calc(100% - 6.4rem));
  }
  #main .promise .sub01 .content {
    padding: 0 1rem;
  }
  #main .promise .sub01 h2 {
    margin-bottom: 2rem;
    font-size: 1.8rem;
    letter-spacing: 0.3em;
    line-height: 1.85;
  }
  #main .promise .sub01 h2 .lg {
    font-size: 3.6rem;
  }
  #main .promise .sub01 .thinkBox {
    margin: 0 auto;
    max-width: 35.5rem;
  }
  #main .promise .sub01 .thinkBox .item {
    width: 11.4rem;
    min-width: initial !important;
    min-height: 6.6rem;
    padding: 1.1rem 0.5rem 1rem;
    border-radius: 2rem;
  }
  #main .promise .sub01 .thinkBox .item::after {
    width: 3.4rem;
    left: 49.5%;
    bottom: -5.1rem;
  }
  #main .promise .sub01 .thinkBox .item p {
    font-size: 1.25rem;
  }
  #main .promise .sub01 .thinkBox .item01 p {
    font-size: 1.2rem;
  }
  #main .promise .sub01 .thinkBox .item02 {
    margin-top: 3.8rem;
    width: 12.4rem;
  }
  #main .promise .sub01 .thinkBox .item02::after {
    width: 4rem;
    bottom: -5rem;
    left: 49%;
  }
  #main .promise .sub01 .thinkBox .item03 {
    width: 12.4rem;
  }
  #main .promise .sub01 .thinkBox .item03::after {
    width: 3rem;
    left: -0.3rem;
    bottom: -5.2rem;
  }
  #main .promise .sub01 .thinkBox .item04 {
    margin: 6.1rem 0 0 auto;
    width: 14.4rem;
  }
  #main .promise .sub01 .thinkBox .item04::after {
    width: 4.8rem;
    left: 31.5%;
    bottom: -5rem;
  }
  #main .promise .sub01 .thinkBox .col01 {
    margin-left: 0;
    width: calc(50% + 0.4rem);
  }
  #main .promise .sub01 .thinkBox .col02 {
    margin-top: 1.8rem;
    width: calc(50% - 2.3rem);
  }
  #main .promise .sub01 .thinkBox .photo {
    margin-top: -8.1rem;
    width: 14.7rem;
    transform: translateX(-1rem);
  }
  #main .promise .sbu02 {
    padding: 3rem 0 12.4rem;
  }
  #main .promise .sbu02 .bg01 {
    width: 12.8rem;
    top: -10.5rem;
  }
  #main .promise .sbu02 .bg02 {
    width: 11.2rem;
    right: -0.9rem;
    top: -10.4rem;
  }
  #main .promise .sbu02 .bg03 {
    width: 12.4rem;
    top: -2.1rem;
    right: -6.7rem;
  }
  #main .promise .sbu02 .bg04 {
    width: 15.4rem;
  }
  #main .promise .sbu02 .bg05 {
    width: 15.4rem;
  }
  #main .promise .sbu02 h3 {
    margin-bottom: 2.2rem;
    font-size: 1.8rem;
    letter-spacing: 0.1em;
    line-height: 1.6;
  }
  #main .promise .sbu02 h3 .mincho {
    margin: 1.8rem auto 0;
    font-size: 3rem;
    line-height: 1.38;
  }
  #main .promise .sbu02 h3 .mincho .sm {
    margin: 0 auto 1rem;
    padding: 0 1rem;
    width: fit-content;
    position: relative;
    left: auto;
    top: auto;
    display: block;
    font-size: 1.6rem;
    line-height: 1;
    transform: none;
  }
  #main .promise .sbu02 h3 .mincho .sm::before {
    left: 0.1rem;
    top: -0.5rem;
  }
  #main .promise .sbu02 h3 .mincho .sm::after {
    top: -0.5rem;
  }
  #main .promise .sbu02 .textBox {
    margin-bottom: 4.1rem;
    max-width: initial;
    padding: 3.7rem 2rem 0;
  }
  #main .promise .sbu02 .textBox h4 {
    margin-bottom: 0.6rem;
    font-size: 2.6rem;
    line-height: 1.18;
  }
  #main .promise .sbu02 .textBox h4 span {
    padding: 0;
  }
  #main .promise .sbu02 .textBox h4 span::before {
    display: none;
  }
  #main .promise .sbu02 .textBox h4 span::after {
    display: none;
  }
  #main .promise .sbu02 .textBox .textList li {
    padding: 1.5rem 0 0.9rem 3.8rem;
    font-size: 2rem;
    background-size: 3rem;
    background-position: left top 1.7rem;
  }
  #main .promise .sbu02 .textBox .photo {
    margin: -0.6rem auto 0;
    width: 17rem;
    height: 16rem;
    overflow: hidden;
    position: relative;
    right: auto;
    bottom: auto;
    transform: translateX(1rem);
  }
  #main .promise .sbu02 .text {
    margin: 0 -1.5rem;
    font-size: 2rem;
  }
  #main .promise .sbu02 .text .lg {
    font-size: 4rem;
  }
  #main .promise .sbu02 .text .mid {
    font-size: 3rem;
  }
}
#main .anchorBox {
  display: flex;
  box-shadow: 0 -1rem 6rem rgba(0, 0, 0, 0.4);
  position: relative;
  z-index: 1;
}
#main .anchorBox .item {
  position: relative;
  flex: 1;
  color: var(--white);
}
#main .anchorBox .item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#main .anchorBox .item::before {
  position: absolute;
  top: 2rem;
  right: 2rem;
  bottom: 2rem;
  left: 2rem;
  border: 0.1rem solid var(--white);
  border-radius: 1rem;
  box-sizing: border-box;
  user-select: none;
  pointer-events: none;
  content: "";
}
#main .anchorBox .item .inner {
  padding-bottom: 1.4rem;
  width: 100%;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
#main .anchorBox .item .inner p {
  text-align: center;
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1.62;
  letter-spacing: 0.06em;
  margin-bottom: 1.7rem;
}
#main .anchorBox .item .inner a {
  margin: 0 auto;
  padding: 1rem 7.5rem 1.5rem 3.5rem;
  width: 44rem;
  max-width: 90%;
  height: 8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  text-align: center;
  color: var(--green);
  font-size: 3rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1;
  border-radius: 5rem;
  background: var(--white);
}
#main .anchorBox .item .inner a::after {
  margin-top: -0.5rem;
  width: 1.6rem;
  position: absolute;
  right: 4.3rem;
  top: 50%;
  transform: translateY(-50%) rotate(-45deg);
  border-left: 0.2rem solid currentColor;
  border-bottom: 0.2rem solid currentColor;
  box-sizing: border-box;
  aspect-ratio: 1;
  content: "";
}
@media all and (min-width: 1025px) {
  #main .anchorBox .item .inner a:hover {
    opacity: 0.65;
  }
}
#main .anchorBox .item01 .inner a {
  color: var(--brown);
}
@media all and (max-width: 896px) {
  #main .anchorBox {
    display: block;
  }
  #main .anchorBox .item::before {
    bottom: 3rem;
  }
  #main .anchorBox .item img {
    width: 100%;
    height: auto;
    aspect-ratio: 375/260;
    object-fit: cover;
  }
  #main .anchorBox .item .inner {
    padding-bottom: 0.8rem;
  }
  #main .anchorBox .item .inner p {
    font-size: 1.6rem;
    line-height: 1.85;
    margin-bottom: 1.1rem;
  }
  #main .anchorBox .item .inner a {
    padding: 1rem 5.5rem 1.3rem 2.5rem;
    width: 29.5rem;
    max-width: 85%;
    font-size: 2.2rem;
    text-align: left;
    justify-content: flex-start;
  }
  #main .anchorBox .item .inner a::after {
    margin-top: -0.3rem;
    width: 1.4rem;
    right: 3rem;
  }
  #main .anchorBox .item01 .inner a {
    color: var(--brown);
  }
}
#main .orthodontics {
  padding: 10rem 0 0;
}
@media all and (max-width: 896px) {
  #main .orthodontics {
    padding: 5rem 0 0;
  }
}
#main .orthodontics .h2Ttl {
  margin-bottom: -2.8rem;
  color: var(--blue);
  text-align: center;
  font-family: var(--mincho);
  font-size: 8rem;
  font-weight: 700;
  line-height: 140%;
  font-style: italic;
}
@media all and (max-width: 896px) {
  #main .orthodontics .h2Ttl {
    margin-bottom: 2.5rem;
    font-size: 4rem;
    font-weight: 700;
    line-height: 1.2;
  }
}
#main .orthodontics .h2Ttl small {
  font-size: 62.5%;
}
#main .orthodontics .enTxt {
  margin: 0 -5rem -3.3rem -11rem;
  white-space: nowrap;
  text-align: center;
  color: var(--blue);
  text-align: center;
  font-family: var(--bacasime);
  font-size: 30rem;
  font-weight: 400;
  line-height: 80%;
  opacity: 0.06;
  font-style: italic;
}
@media all and (min-width: 1441px) {
  #main .orthodontics .enTxt {
    font-size: min(19.53vw, 30rem);
  }
}
@media all and (min-width: 897px) and (max-width: 1440px) {
  #main .orthodontics .enTxt {
    font-size: 28.1rem;
  }
}
@media all and (max-width: 896px) {
  #main .orthodontics .enTxt {
    margin: 0 -5rem -0.7rem -6.5rem;
    font-size: 7.5rem;
  }
}
#main .orthodontics .orthodonticsList {
  display: flex;
}
@media all and (max-width: 896px) {
  #main .orthodontics .orthodonticsList {
    flex-direction: column;
    gap: 2rem 0;
  }
}
#main .orthodontics .orthodonticsList li {
  aspect-ratio: 512/518;
  position: relative;
  width: 33.33%;
}
@media all and (max-width: 896px) {
  #main .orthodontics .orthodonticsList li {
    aspect-ratio: inherit;
    width: 100%;
  }
}
#main .orthodontics .orthodonticsList li .bigPhoto {
  inset: 0;
  position: absolute;
}
#main .orthodontics .orthodonticsList li .bigPhoto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#main .orthodontics .orthodonticsList li .sub {
  padding: 0 6rem 5rem;
  position: relative;
  z-index: 1;
}
@media all and (max-width: 896px) {
  #main .orthodontics .orthodonticsList li .sub {
    padding: 0 2rem 8.1rem;
  }
}
#main .orthodontics .orthodonticsList li .photo {
  margin: -6.2rem auto 2.8rem;
  width: 20rem;
  aspect-ratio: 1;
  position: relative;
  border-radius: 100%;
  box-shadow: 0 0.4rem 2rem 0 rgba(0, 0, 0, 0.3);
}
@media all and (max-width: 896px) {
  #main .orthodontics .orthodonticsList li .photo {
    margin: -6rem auto 1.4rem;
    width: 18rem;
  }
}
#main .orthodontics .orthodonticsList li .photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 100%;
}
#main .orthodontics .orthodonticsList li h3 {
  margin-bottom: 2rem;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  display: flex;
  min-height: 9rem;
  color: var(--yellow);
  font-feature-settings: "pwid" on;
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.5;
  font-family: var(--mincho);
}
@media all and (max-width: 896px) {
  #main .orthodontics .orthodonticsList li h3 {
    text-align: center;
    display: block;
    min-height: inherit;
    font-size: 2.6rem;
  }
}
#main .orthodontics .orthodonticsList li h3 small {
  display: block;
  margin-top: -0.2rem;
  font-size: 2.2rem;
  font-family: var(--base-font);
}
@media all and (max-width: 896px) {
  #main .orthodontics .orthodonticsList li h3 small {
    font-size: 1.8rem;
  }
}
#main .orthodontics .orthodonticsList li p {
  color: var(--white);
  text-align: justify;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.01em;
}
@media all and (max-width: 896px) {
  #main .orthodontics .orthodonticsList li p {
    font-size: 1.6rem;
  }
}
#main .simulation {
  background: url(../img/index/orthodontics_bg04.webp) no-repeat center bottom;
  position: relative;
  z-index: 1;
  background-size: cover;
}
@media all and (max-width: 896px) {
  #main .simulation {
    padding: 3.7rem 0 0;
    margin-top: -5rem;
    background-image: url(../img/index/orthodontics_bg04_sp.webp);
  }
}
#main .simulation .content {
  max-width: 124rem;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
}
@media all and (max-width: 896px) {
  #main .simulation .content {
    display: block;
  }
}
#main .simulation .photoBox {
  margin: -6rem -16.8rem 0 -3rem;
  order: 2;
  width: 66.8rem;
}
@media all and (max-width: 896px) {
  #main .simulation .photoBox {
    width: auto;
    margin: 0 1.1rem;
  }
  #main .simulation .photoBox img {
    width: 100%;
  }
}
#main .simulation .textBox {
  padding-top: 10rem;
  flex: 1;
  margin-left: -1.5rem;
}
@media all and (max-width: 896px) {
  #main .simulation .textBox {
    margin: 0;
    padding: 0 0 3.2rem;
  }
}
#main .simulation .textBox p {
  margin-left: 1.4rem;
  color: var(--blue);
  text-align: justify;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 180%;
  letter-spacing: 0.18rem;
}
@media all and (max-width: 896px) {
  #main .simulation .textBox p {
    margin: 0;
    font-size: 1.6rem;
    letter-spacing: 0.064rem;
  }
}
#main .simulation h3 {
  margin-bottom: 1.8rem;
  padding-bottom: 2.7rem;
  color: var(--blue);
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.2;
  position: relative;
}
@media all and (max-width: 896px) {
  #main .simulation h3 {
    font-size: 2.6rem;
    font-weight: 700;
    margin-bottom: 2rem;
    padding-bottom: 2rem;
  }
  #main .simulation h3 small {
    font-size: 2rem;
    letter-spacing: 0;
  }
}
#main .simulation h3::after {
  width: 8888.8rem;
  height: 0.1rem;
  background-color: var(--blue);
  position: absolute;
  bottom: 0;
  right: 0;
  content: "";
}
#main .simulation h3 .txtSpan {
  margin-right: 2rem;
  color: var(--pink2);
  font-family: var(--mincho);
  font-size: 8rem;
  font-weight: 700;
  line-height: 140%;
  letter-spacing: -0.22em;
  font-style: italic;
}
@media all and (max-width: 896px) {
  #main .simulation h3 .txtSpan {
    font-size: 3.6rem;
    margin-right: 1rem;
    letter-spacing: -0.72rem;
  }
}
#main .simulation h3 .txtSpan span {
  font-size: 14rem;
  letter-spacing: -0.28rem;
}
@media all and (max-width: 896px) {
  #main .simulation h3 .txtSpan span {
    font-size: 5.4rem;
    letter-spacing: -0.108rem;
  }
}
#main .case {
  padding: 14rem 0 12rem;
  background: url(../img/index/orthodontics_bg05.webp) no-repeat center bottom;
  background-size: cover;
  position: relative;
}
@media all and (max-width: 896px) {
  #main .case {
    padding: 5rem 0 6.5rem;
    background-image: url(../img/index/orthodontics_bg05_sp.webp);
  }
}
#main .case .arrow {
  position: absolute;
  top: -4rem;
  left: 50%;
  z-index: 1;
  transform: translateX(-50%);
  width: 40rem;
}
@media all and (max-width: 896px) {
  #main .case .arrow {
    width: 16rem;
    top: -2rem;
  }
}
#main .case h2 {
  margin-bottom: 1.5rem;
  text-align: center;
  color: var(--blue);
  font-family: var(--mincho);
  font-size: 5rem;
  font-weight: 900;
  line-height: 1.4;
  font-style: italic;
}
@media all and (max-width: 896px) {
  #main .case h2 {
    line-height: 1.3;
    margin-bottom: 1rem;
    color: var(--blue);
    font-size: 3rem;
    font-weight: 900;
  }
}
#main .case h2 .txtSpan {
  color: var(--green);
  font-size: 8rem;
  font-weight: 700;
}
@media all and (max-width: 896px) {
  #main .case h2 .txtSpan {
    color: var(--green);
    font-size: 4rem;
    font-weight: 700;
  }
}
#main .case .centerTxt {
  margin-bottom: 4rem;
  color: var(--blue);
  text-align: center;
  font-family: var(--zenKakuGothic);
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 1.12rem;
  font-style: italic;
}
@media all and (max-width: 896px) {
  #main .case .centerTxt {
    margin-bottom: 3.5rem;
    color: var(--blue);
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.8;
    letter-spacing: 0.54rem;
  }
}
#main .kidsCase {
  padding-top: 15.9rem;
  padding-bottom: 16.6rem;
  position: relative;
  background: url(../img/index/kids_case_bg01.webp) no-repeat center top/cover;
}
#main .kidsCase::before {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background: url(../img/index/kids_case_bg02.webp) no-repeat center top/100%, url(../img/index/kids_case_bg03.webp) no-repeat center bottom/100%;
  user-select: none;
  pointer-events: none;
  mix-blend-mode: multiply;
  content: "";
}
#main .kidsCase h2 {
  margin-bottom: 3rem;
  line-height: 1.18;
}
#main .kidsCase .comInner {
  margin-bottom: 6.2rem;
}
#main .kidsCase .comLead {
  margin: 0 -2rem;
  letter-spacing: 0.3em;
  line-height: 1.82;
}
#main .kidsCase .comLead .underline {
  color: var(--green);
  letter-spacing: 0.3em;
}
@media all and (max-width: 896px) {
  #main .kidsCase {
    padding-top: 7.2rem;
    padding-bottom: 7rem;
  }
  #main .kidsCase h2 {
    margin-bottom: 2.7rem;
    line-height: 1.34;
    font-size: 2.6rem;
  }
  #main .kidsCase h2 .txtSpan {
    font-size: 3rem;
  }
  #main .kidsCase .comInner {
    margin-bottom: 3rem;
  }
  #main .kidsCase .comLead {
    margin: 0 1rem;
    font-size: 1.6rem;
    letter-spacing: 0.2em;
    line-height: 1.77;
  }
  #main .kidsCase .comLead .underline {
    font-size: 2rem;
    letter-spacing: 0.2em;
  }
}
#main .ortho {
  padding: 13.8rem 0 14rem;
  background: url(../img/index/ortho_bg02.webp) no-repeat center top/cover;
}
@media all and (max-width: 896px) {
  #main .ortho {
    padding: 5.8rem 0 6rem;
  }
}
#main .ortho .heading {
  margin-bottom: 7.8rem;
  text-align: center;
  color: var(--yellow);
  font-size: 9rem;
  line-height: 1.32;
  letter-spacing: 0.4rem;
  font-family: var(--mincho);
  letter-spacing: 0.04em;
  font-style: italic;
}
#main .ortho .heading small {
  display: block;
  color: var(--white);
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.3em;
  font-family: var(--zenKakuGothic);
}
#main .ortho .heading span {
  font-size: 6rem;
  letter-spacing: 0.04em;
}
#main .ortho .heading01 {
  margin-bottom: 6.1rem;
}
#main .ortho .heading02 {
  margin: 0 auto 6.4rem;
  width: fit-content;
  text-align: right;
  color: var(--yellow);
  font-family: var(--zenKakuGothic);
  font-size: 4.4rem;
  line-height: 1.8;
  letter-spacing: 1.3rem;
  letter-spacing: 0.3em;
  font-style: italic;
}
#main .ortho .heading02 small {
  color: var(--white);
  font-size: 2.8rem;
  font-weight: 500;
  letter-spacing: 0.3em;
}
#main .ortho .heading03 {
  margin-bottom: 10.2rem;
  color: var(--white);
  text-align: center;
  font-family: var(--mincho);
  font-size: 6rem;
  font-style: italic;
  line-height: 1.4;
}
#main .ortho .heading03 small {
  font-size: 4rem;
  font-weight: 900;
}
#main .ortho .heading04 {
  margin-bottom: 9.7rem;
  padding: 2.9rem 3rem;
  color: var(--white);
  font-family: var(--zenKakuGothic);
  font-size: 2.6rem;
  line-height: 1.6;
  letter-spacing: 0.06em;
  background: url(../img/index/ortho_bg.webp) repeat center top/10rem;
  border-radius: 2rem;
  text-align: center;
  position: relative;
}
#main .ortho .heading04::after {
  width: 1.7rem;
  height: 1.7rem;
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%) rotate(48deg) skew(7deg);
  bottom: -0.9rem;
  background: url(../img/index/ortho_bg.webp) repeat center top/10rem;
}
@media all and (max-width: 896px) {
  #main .ortho .heading {
    margin-bottom: 0.5rem;
    font-size: 4.6rem;
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 0.04em;
  }
  #main .ortho .heading span {
    font-size: 3rem;
  }
  #main .ortho .heading small {
    margin-bottom: 0.8rem;
    font-size: 2.2rem;
    line-height: 1.6;
    letter-spacing: 0.2em;
  }
  #main .ortho .heading01 {
    margin: 0 -1rem 3.1rem;
  }
  #main .ortho .heading01 small {
    margin: 0;
  }
  #main .ortho .heading02 {
    margin-bottom: 2.2rem;
    font-size: 2.2rem;
    line-height: 1.8;
    text-align: center;
    letter-spacing: 0.2em;
  }
  #main .ortho .heading02 small {
    font-size: 1.6rem;
    letter-spacing: 0.2em;
    display: inline-block;
  }
  #main .ortho .heading03 {
    margin-bottom: 4.1rem;
    font-size: 2.6rem;
    line-height: 1.4;
  }
  #main .ortho .heading03 small {
    font-size: 2rem;
  }
  #main .ortho .heading04 {
    margin-bottom: 4.7rem;
    padding: 1.6rem 3rem 1.8rem;
    font-size: 1.8rem;
    line-height: 1.4;
    border-radius: 1rem;
  }
  #main .ortho .heading04::after {
    bottom: -0.9rem;
  }
}
#main .ortho .lastIcon {
  margin: 8.1rem auto 2rem;
  width: 60.2rem;
}
@media all and (max-width: 896px) {
  #main .ortho .lastIcon {
    margin: 1.6rem auto 2.8rem;
    width: 78.666vw;
  }
}
#main .ortho .list01 {
  margin: 0 -1.7rem;
  display: flex;
  gap: 5.9rem;
  position: relative;
  flex-wrap: wrap;
}
#main .ortho .list01 li {
  width: calc((100% - 23.61rem) / 5);
  text-align: center;
  font-size: 2rem;
  line-height: 1.4;
  letter-spacing: 0.1em;
  color: var(--white);
  font-weight: 500;
  font-feature-settings: "palt";
}
#main .ortho .list01 li .col {
  color: var(--yellow);
  font-weight: 700;
}
#main .ortho .list01 li .image {
  margin-bottom: 1rem;
  aspect-ratio: 1/1;
  overflow: hidden;
  border-radius: 100%;
}
#main .ortho .list01 li .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#main .ortho .list01 li p {
  margin: 0 -3rem;
}
@media all and (max-width: 896px) {
  #main .ortho .list01 {
    margin: 0 0 0;
    justify-content: center;
    gap: 1.5rem 3.5rem;
  }
  #main .ortho .list01 li {
    width: calc(50% - 2.7rem);
    font-size: 1.6rem;
  }
  #main .ortho .list01 li:last-child p {
    margin: 0 -3rem;
  }
  #main .ortho .list01 li .image {
    margin-bottom: 0.8rem;
  }
  #main .ortho .list01 li p {
    margin: 0 -1rem;
  }
}
#main .ortho .infoBox {
  margin: 0 auto 5.3rem;
  position: relative;
}
#main .ortho .infoBox .content {
  max-width: 104rem;
}
#main .ortho .infoBox .posImg {
  width: 24rem;
  position: absolute;
  right: 0;
  top: -23.1rem;
}
#main .ortho .infoBox .posImg02 {
  left: 0;
  right: auto;
  top: -50.6rem;
}
@media all and (max-width: 896px) {
  #main .ortho .infoBox .posImg {
    display: none;
  }
}
#main .ortho .infoBox .head {
  margin-bottom: 6rem;
  padding-bottom: 1.7rem;
  color: var(--white);
  font-family: var(--zenKakuGothic);
  font-size: 3.4rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.06em;
  border-bottom: 0.1rem solid var(--white);
  position: relative;
}
#main .ortho .infoBox .head::before {
  width: 9.5rem;
  height: 12rem;
  content: "";
  position: absolute;
  left: -11.5rem;
  top: -4.6rem;
  background: url(../img/index/ortho_img06.webp) no-repeat center top/100%;
}
#main .ortho .infoBox .list02 {
  margin-bottom: 4.8rem;
}
#main .ortho .infoBox .list02 li {
  padding-bottom: 3.7rem;
  display: flex;
  align-items: flex-start;
  border-bottom: 0.2rem dotted var(--white);
}
#main .ortho .infoBox .list02 li + li {
  margin-top: 4rem;
}
#main .ortho .infoBox .list02 li:last-child {
  border-bottom: none;
}
#main .ortho .infoBox .list02 li .photo {
  width: 26rem;
  border-radius: 2rem;
  overflow: hidden;
}
#main .ortho .infoBox .list02 li .textBox {
  padding: 0 4rem 0 6rem;
  flex: 1;
  color: var(--white);
}
#main .ortho .infoBox .list02 li .textBox .title {
  margin: 0 -2rem 1.1rem 0;
  color: var(--brown2);
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.06em;
  font-family: var(--zenKakuGothic);
  position: relative;
}
#main .ortho .infoBox .list02 li .textBox .title small {
  font-size: 1.6rem;
  letter-spacing: 0.06em;
}
#main .ortho .infoBox .list02 li .textBox .title::before {
  width: 5.5rem;
  height: 5.5rem;
  content: "";
  position: absolute;
  left: -6rem;
  top: -0.9rem;
  background: url(../img/index/ortho_icon02.webp) no-repeat center top/100%;
}
#main .ortho .infoBox .list02 li .textBox .text {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.1em;
  font-feature-settings: "palt";
}
@media all and (max-width: 896px) {
  #main .ortho .infoBox {
    margin-bottom: 3.2rem;
  }
  #main .ortho .infoBox .head {
    margin-bottom: 2rem;
    padding-left: 8.1rem;
    font-size: 2.4rem;
    line-height: 1.3;
  }
  #main .ortho .infoBox .head::before {
    width: 6.2rem;
    height: 8.2rem;
    top: -1.6rem;
    left: 0;
  }
  #main .ortho .infoBox .list02:last-child {
    margin-bottom: 0;
  }
  #main .ortho .infoBox .list02 li {
    padding-bottom: 2.8rem;
    display: block;
  }
  #main .ortho .infoBox .list02 li + li {
    margin-top: 2.2rem;
  }
  #main .ortho .infoBox .list02 li .textBox {
    text-align: justify;
    padding: 0 0 2rem;
  }
  #main .ortho .infoBox .list02 li .textBox .title {
    margin: 0;
    padding: 0 1rem 1.4rem 4rem;
    font-size: 2rem;
    line-height: 1.4;
    letter-spacing: 0.12rem;
    text-align: left;
  }
  #main .ortho .infoBox .list02 li .textBox .title::before {
    width: 3.2rem;
    height: 3.2rem;
    left: 0;
    top: 0.2rem;
  }
  #main .ortho .infoBox .list02 li .textBox .text {
    font-size: 1.4rem;
  }
  #main .ortho .infoBox .list02 li .photo {
    width: 100%;
    aspect-ratio: 335/180;
    border-radius: 1rem;
  }
  #main .ortho .infoBox .list02 li .photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}
#main .ortho .bigHead {
  margin-bottom: 7.2rem;
  color: var(--yellow);
  text-align: center;
  font-family: var(--mincho);
  font-size: 8rem;
  font-style: italic;
  line-height: 1.4;
}
@media all and (max-width: 896px) {
  #main .ortho .bigHead {
    margin: 0 -1rem 3.3rem;
    font-size: 2.6rem;
    line-height: 1.4;
  }
}
#main .ortho .text02 {
  color: var(--white);
  text-align: center;
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.06em;
}
@media all and (max-width: 896px) {
  #main .ortho .text02 {
    text-align: justify;
    font-size: 1.8rem;
    line-height: 1.8;
    letter-spacing: 0.072rem;
  }
}
#main .kidsOrtho {
  padding: 14rem 0;
  background: url(../img/index/kids_ortho_bg01.webp) no-repeat center center/cover;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho {
    padding: 6rem 0 7.5rem;
  }
}
#main .kidsOrtho .content {
  max-width: 138rem;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .heading {
    margin-bottom: 1.9rem;
    line-height: 1.18;
  }
  #main .kidsOrtho .heading small {
    margin-bottom: 0.6rem;
  }
}
#main .kidsOrtho .heading01 {
  margin-bottom: 8rem;
}
#main .kidsOrtho .heading01 small {
  margin-bottom: 0;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .heading01 {
    margin-bottom: 4.9rem;
  }
}
#main .kidsOrtho .list01 {
  margin: 0;
  gap: 3rem 3.8%;
}
#main .kidsOrtho .list01 li {
  width: 13.45%;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .list01 {
    margin: 0 auto;
    width: 94%;
    gap: 1.6rem 3.6rem;
  }
  #main .kidsOrtho .list01 li {
    width: calc(50% - 1.8rem);
  }
  #main .kidsOrtho .list01 li .image {
    margin-bottom: 1rem;
  }
  #main .kidsOrtho .list01 li p {
    line-height: 1.35;
  }
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .lastIcon {
    margin: 2.7rem auto;
  }
}
#main .kidsOrtho .heading02 {
  margin-bottom: 10.5rem;
  text-align: center;
}
#main .kidsOrtho .heading02 .white {
  color: var(--white);
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .heading02 {
    margin: 0 -1.5rem 4.6rem;
    width: auto;
    font-size: 2.2rem;
    line-height: 1.78;
  }
  #main .kidsOrtho .heading02 .white {
    font-size: 2rem;
    letter-spacing: 0.2em;
    font-weight: 500;
  }
}
#main .kidsOrtho .know {
  margin: 0 auto 14.1rem;
  max-width: 80rem;
  position: relative;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .know {
    margin-bottom: 6rem;
  }
}
#main .kidsOrtho .know .bgImg01 {
  width: 50vw;
  position: absolute;
  right: 50%;
  top: -28.3rem;
  text-align: left;
  user-select: none;
  pointer-events: none;
}
#main .kidsOrtho .know .bgImg01 img {
  width: 24rem;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .know .bgImg01 {
    display: none;
  }
}
#main .kidsOrtho .know .bgImg02 {
  width: 50vw;
  position: absolute;
  left: 50%;
  top: -0.8rem;
  text-align: right;
  user-select: none;
  pointer-events: none;
}
#main .kidsOrtho .know .bgImg02 img {
  width: 24rem;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .know .bgImg02 {
    display: none;
  }
}
#main .kidsOrtho .know .ttl {
  margin: 0 auto 1.1rem;
  padding: 0 1.4rem 0 2.4rem;
  width: fit-content;
  position: relative;
  color: var(--white);
  font-weight: 700;
  font-size: 2.8rem;
  font-family: var(--zenKakuGothic);
  letter-spacing: 0.06em;
}
#main .kidsOrtho .know .ttl::before, #main .kidsOrtho .know .ttl::after {
  width: 0.2rem;
  height: 72%;
  position: absolute;
  top: 16%;
  background: var(--white);
  transform: rotate(19deg);
  content: "";
}
#main .kidsOrtho .know .ttl::before {
  left: 0;
  transform: rotate(-19deg);
}
#main .kidsOrtho .know .ttl::after {
  right: 0;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .know .ttl {
    margin-bottom: 0.8rem;
    padding: 0 1rem 0 2rem;
    font-size: 2.4rem;
  }
  #main .kidsOrtho .know .ttl::before, #main .kidsOrtho .know .ttl::after {
    height: 83%;
    top: 14%;
  }
}
#main .kidsOrtho .know .innerBox {
  padding: 1.8rem 4rem 3.4rem;
  border-radius: 2rem;
  background: var(--white);
}
#main .kidsOrtho .know .innerBox .lead {
  margin-bottom: 2.7rem;
  padding-bottom: 1.7rem;
  text-align: center;
  color: var(--green);
  font-size: 4.4rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  border-bottom: 0.1rem solid var(--green);
}
#main .kidsOrtho .know .innerBox .lead .sm {
  font-size: 2.8rem;
  letter-spacing: 0.06em;
}
#main .kidsOrtho .know .innerBox .txtList {
  margin-bottom: 3.2rem;
  display: flex;
  gap: 1.9rem;
}
#main .kidsOrtho .know .innerBox .txtList li {
  padding: 0.9rem 3.9rem 1.1rem;
  text-align: center;
  color: var(--white);
  font-size: 2.8rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  border-radius: 5rem;
  background: var(--green);
}
#main .kidsOrtho .know .innerBox .text {
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.06em;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .know .innerBox {
    padding: 2.4rem 2rem 2rem;
    border-radius: 1rem;
  }
  #main .kidsOrtho .know .innerBox .lead {
    margin-bottom: 2rem;
    padding-bottom: 1.1rem;
    font-size: 2.4rem;
  }
  #main .kidsOrtho .know .innerBox .lead .sm {
    font-size: 1.8rem;
  }
  #main .kidsOrtho .know .innerBox .txtList {
    margin-bottom: 1.4rem;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
  }
  #main .kidsOrtho .know .innerBox .txtList li {
    padding: 0.3rem 3rem 0.5rem;
    font-size: 2rem;
    line-height: 1.4;
  }
  #main .kidsOrtho .know .innerBox .text {
    font-size: 1.6rem;
    text-align: justify;
  }
}
#main .kidsOrtho .problems {
  margin: 0 auto 7.9rem;
  max-width: 120rem;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems {
    margin-bottom: 4.8rem;
  }
}
#main .kidsOrtho .problems .ttl {
  margin-bottom: -4.7rem;
  text-align: center;
  font-weight: 700;
  color: var(--white);
  font-size: 7rem;
  font-style: italic;
  letter-spacing: 0.01em;
  line-height: 1.37;
}
#main .kidsOrtho .problems .ttl .sm {
  font-size: 4rem;
  font-weight: 900;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .ttl {
    margin-bottom: -1.3rem;
    font-size: 2.2rem;
  }
  #main .kidsOrtho .problems .ttl .sm {
    font-size: 1.8rem;
  }
}
#main .kidsOrtho .problems .innerBox {
  padding: 10.8rem 3.8rem 8.2rem;
  position: relative;
  border-radius: 2rem;
  border: 0.2rem solid var(--white);
  border-top: none;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox {
    padding: 8.8vw 4.8vw 10.133vw;
    border-radius: 1rem;
  }
}
#main .kidsOrtho .problems .innerBox::before {
  width: 25%;
  height: 4rem;
  position: absolute;
  left: -0.2rem;
  top: -0.2rem;
  border-top: 0.2rem solid var(--white);
  border-left: 0.2rem solid var(--white);
  border-radius: 2rem 0 0 0;
  box-sizing: border-box;
  content: "";
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox::before {
    width: calc(50% - 8.5rem);
    border-radius: 1rem 0 0 0;
  }
}
#main .kidsOrtho .problems .innerBox::after {
  width: 25%;
  height: 4rem;
  position: absolute;
  right: -0.2rem;
  top: -0.2rem;
  border-top: 0.2rem solid var(--white);
  border-right: 0.2rem solid var(--white);
  border-radius: 0 2rem 0 0;
  box-sizing: border-box;
  content: "";
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox::after {
    width: calc(50% - 8.5rem);
    border-radius: 0 1rem 0 0;
  }
}
#main .kidsOrtho .problems .innerBox .subBox {
  position: relative;
  color: var(--green);
  font-weight: 700;
  font-size: 2.6rem;
  text-align: center;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox {
    font-size: 3.2vw;
  }
}
#main .kidsOrtho .problems .innerBox .subBox img {
  width: 100%;
}
#main .kidsOrtho .problems .innerBox .subBox span {
  width: 23.214%;
  display: block;
  position: absolute;
  font-family: var(--zenKakuGothic);
  line-height: 1.4;
  letter-spacing: 0.06em;
  z-index: 1;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox span {
    width: 26.9%;
    line-height: 1.2;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt01 {
  padding: 0.9rem 1rem 1.1rem;
  width: 28.57%;
  left: 8.3%;
  top: -0.5%;
  color: var(--white);
  font-family: var(--base-font);
  border-radius: 1rem;
  border: 0.2rem solid var(--white);
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt01 {
    width: 26.9%;
    padding: 2.133vw 1.333vw 2.4vw;
    border: none;
    border-radius: 0;
    left: 0;
    top: 0;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt02 {
  padding: 0.9rem 1rem 1.1rem;
  left: 63.55%;
  top: -0.5%;
  color: var(--white);
  font-family: var(--base-font);
  border-radius: 1rem;
  border: 0.2rem solid var(--white);
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt02 {
    width: 26.9%;
    padding: 4.267vw 1.333vw 2.4vw;
    border: none;
    border-radius: 0;
    left: auto;
    right: 0;
    top: 0;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt03 {
  left: 0;
  top: 9.8%;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt03 {
    top: 11.3%;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt04 {
  width: 33.928%;
  top: 13.55%;
  left: 33.2%;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt04 {
    top: 11.1%;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt05 {
  right: 0;
  top: 13.56%;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt05 {
    top: 13%;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt06 {
  left: 0;
  top: 27.4%;
}
#main .kidsOrtho .problems .innerBox .subBox .txt07 {
  right: 0;
  top: 27.4%;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt07 {
    top: 26.3%;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt08 {
  left: 0;
  top: 41.3%;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt08 {
    width: 34.2%;
    top: 39.2%;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt09 {
  width: 33.928%;
  left: 33.2%;
  top: 51.4%;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt09 {
    top: 39.8%;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt10 {
  right: 0;
  top: 41.3%;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt10 {
    width: 34%;
    top: 39.2%;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt11 {
  left: 0;
  top: 67%;
  font-size: 2rem;
  color: var(--white);
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt11 {
    width: 33.5%;
    font-size: 3.2vw;
    top: 54.2%;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt12 {
  right: 0;
  top: 67%;
  font-size: 2rem;
  color: var(--white);
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt12 {
    width: 33.5%;
    font-size: 3.2vw;
    top: 54.2%;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt13 {
  width: 100%;
  left: 0;
  top: 73.4%;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt13 {
    top: 60.9%;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt14 {
  left: 0;
  bottom: -3.9rem;
  font-size: 2rem;
  color: var(--white);
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt14 {
    width: 48%;
    bottom: 15.7%;
    font-size: 3.2vw;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt15 {
  left: 25.5%;
  bottom: -3.9rem;
  font-size: 2rem;
  color: var(--white);
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt15 {
    width: 48%;
    bottom: 15.7%;
    left: auto;
    right: 0;
    font-size: 3.2vw;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt16 {
  left: 51%;
  bottom: -3.9rem;
  font-size: 2rem;
  color: var(--white);
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt16 {
    width: 47%;
    bottom: -5.333vw;
    left: 0;
    font-size: 3.2vw;
  }
}
#main .kidsOrtho .problems .innerBox .subBox .txt17 {
  right: 0;
  bottom: -3.9rem;
  font-size: 2rem;
  color: var(--white);
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .problems .innerBox .subBox .txt17 {
    font-size: 3.2vw;
    bottom: -5.333vw;
    width: 48%;
  }
}
#main .kidsOrtho .text01 {
  margin-bottom: 3.2rem;
  text-align: center;
  color: var(--white);
  font-weight: 500;
  font-size: 2.4rem;
  line-height: 2;
  letter-spacing: 0.01em;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .text01 {
    margin-bottom: 1.8rem;
    font-size: 1.8rem;
    letter-spacing: 0.06em;
  }
}
#main .kidsOrtho .text02 {
  margin-bottom: 12.1rem;
  text-align: center;
  font-style: italic;
  color: var(--yellow);
  font-family: var(--zenKakuGothic);
  font-weight: 700;
  font-size: 4.4rem;
  letter-spacing: 0.3em;
  line-height: 1.8;
}
#main .kidsOrtho .text02 .sm {
  color: var(--white);
  font-weight: 500;
  font-size: 2.8rem;
  letter-spacing: 0.3em;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .text02 {
    margin-bottom: 9.1rem;
    font-size: 2.2rem;
  }
  #main .kidsOrtho .text02 .sm {
    display: inline-block;
    vertical-align: 0.5rem;
    font-size: 2rem;
  }
}
#main .kidsOrtho .alignment {
  margin: 0 auto;
  padding: 5.9rem 4rem 0;
  max-width: 110rem;
  position: relative;
  background: var(--white);
  border-radius: 2rem;
}
@media all and (max-width: 896px) {
  #main .kidsOrtho .alignment {
    padding: 5.6rem 2rem 0;
    border-radius: 1rem;
  }
}
#main .flow {
  padding: 3.6rem 0 20rem;
  background: var(--white) url(../img/index/flow_bg.webp) no-repeat center bottom -9.7rem;
  background-size: 100% auto;
}
@media all and (max-width: 896px) {
  #main .flow {
    padding: 3rem 0 4.7rem;
    background-image: url(../img/index/flow_bg_sp.webp);
    background-position: center bottom;
  }
}
#main .flow .enTxt {
  margin: 0 -7rem 0.9rem -11rem;
  color: var(--grey);
  text-align: center;
  font-family: var(--bacasime);
  font-size: 24.8rem;
  font-weight: 400;
  line-height: 1;
  white-space: nowrap;
  font-style: italic;
}
@media all and (min-width: 1441px) {
  #main .flow .enTxt {
    font-size: min(16.145vw, 24.8rem);
  }
}
@media all and (min-width: 897px) and (max-width: 1440px) {
  #main .flow .enTxt {
    font-size: 23.2rem;
  }
}
@media all and (max-width: 896px) {
  #main .flow .enTxt {
    margin-bottom: 1.8rem;
    margin-left: -9.5rem;
    font-size: 6rem;
    font-weight: 400;
  }
}
#main .flow h2 {
  margin-bottom: 7.3rem;
  color: var(--green);
  text-align: center;
  font-family: var(--mincho);
  font-size: 8rem;
  font-weight: 700;
  line-height: 1;
  font-style: italic;
}
@media all and (max-width: 896px) {
  #main .flow h2 {
    margin-bottom: 4.7rem;
    font-size: 4rem;
    font-weight: 700;
    line-height: 1.2;
  }
}
#main .flow h2 small {
  color: var(--blue);
  font-size: 5rem;
  font-weight: 900;
}
@media all and (max-width: 896px) {
  #main .flow h2 small {
    font-size: 3rem;
  }
}
#main .flow .flowList li {
  margin-bottom: 3rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  border-radius: 2rem;
  background: linear-gradient(90deg, var(--grey8) 29.81%, var(--blue6) 100%);
  position: relative;
}
@media all and (max-width: 896px) {
  #main .flow .flowList li {
    margin-bottom: 4.5rem;
    flex-direction: column;
    border-radius: 1rem;
    background: linear-gradient(90deg, var(--grey8) 29.81%, var(--blue6) 100%);
  }
}
#main .flow .flowList li .step {
  padding: 0 1rem 1rem 0;
  width: 12rem;
  height: 12rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: absolute;
  top: -5rem;
  left: -5rem;
  border-radius: 100%;
  background-color: var(--white);
  color: var(--green);
  font-weight: 700;
  font-family: var(--mincho);
  z-index: 1;
}
@media all and (max-width: 896px) {
  #main .flow .flowList li .step {
    top: -3rem;
    left: -2rem;
    width: 8rem;
    height: 8rem;
    font-size: 1.2rem;
    font-weight: 700;
  }
}
#main .flow .flowList li .step .num {
  margin-left: -0.5rem;
  color: var(--green);
  font-size: 6rem;
  font-weight: 400;
  line-height: 1;
  font-style: italic;
}
@media all and (max-width: 896px) {
  #main .flow .flowList li .step .num {
    font-size: 5rem;
    font-weight: 400;
  }
}
#main .flow .flowList li .photoBox {
  width: 28rem;
  overflow: hidden;
  border-radius: 2rem 0 0 2rem;
}
@media all and (max-width: 896px) {
  #main .flow .flowList li .photoBox {
    width: 100%;
    aspect-ratio: 335/140;
    position: relative;
    border-radius: 1rem 1rem 0 0;
  }
  #main .flow .flowList li .photoBox img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}
#main .flow .flowList li .photoBox img {
  width: 100%;
}
#main .flow .flowList li .textBox {
  padding: 2rem 2rem 2rem 4rem;
  flex: 1;
}
@media all and (max-width: 896px) {
  #main .flow .flowList li .textBox {
    padding: 1.7rem 2rem 3.4rem;
  }
}
#main .flow .flowList li .textBox h3 {
  margin-bottom: 0.2rem;
  color: var(--green);
  font-family: var(--mincho);
  font-size: 3.2rem;
  font-weight: 700;
  letter-spacing: 0.192rem;
}
@media all and (max-width: 896px) {
  #main .flow .flowList li .textBox h3 {
    margin-bottom: 1rem;
    text-align: center;
    font-size: 2.2rem;
    line-height: 1.3;
    letter-spacing: 0.132rem;
  }
}
#main .flow .flowList li .textBox p {
  color: var(--base-color);
  text-align: justify;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.01em;
}
@media all and (max-width: 896px) {
  #main .flow .flowList li .textBox p {
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1.8;
    letter-spacing: 0.14rem;
  }
}
#main .faqBox {
  padding-bottom: 12rem;
  font-feature-settings: "palt";
  position: relative;
}
#main .faqBox .topImg {
  margin: -10.9% 0 0.9rem;
}
#main .faqBox .topImg img {
  width: 100%;
}
#main .faqBox .posImg {
  position: absolute;
  width: 27.8rem;
  right: 0;
  bottom: -4.8rem;
  z-index: 1;
  pointer-events: none;
}
#main .faqBox .posImg img {
  width: 100%;
}
#main .faqBox .content {
  max-width: 94rem;
}
#main .faqBox .heading {
  margin-bottom: 4.4rem;
  color: var(--blue2);
  text-align: center;
  font-family: var(--mincho);
  font-size: 6rem;
  font-weight: 600;
  line-height: 1.4;
}
#main .faqBox .dlBox dl + dl {
  margin-top: 2rem;
}
#main .faqBox .dlBox dt {
  padding: 1.2rem 6rem 1.2rem 4rem;
  color: var(--white);
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.444;
  letter-spacing: 0.1em;
  border-radius: 2.5rem;
  background: url(../img/index/faq_bg.webp) repeat center top/5rem;
  position: relative;
  cursor: pointer;
}
#main .faqBox .dlBox dt::before, #main .faqBox .dlBox dt::after {
  width: 1.4rem;
  height: 0.2rem;
  content: "";
  position: absolute;
  right: 3rem;
  top: 50%;
  transform: translateY(-50%);
  background: var(--white);
  transition: 0.3s;
}
#main .faqBox .dlBox dt::after {
  transform: translateY(-50%) rotate(90deg);
}
#main .faqBox .dlBox dt.on::after {
  transform: translateY(-50%) rotate(0);
}
#main .faqBox .dlBox dd {
  padding: 2rem 7rem 0 4rem;
  text-align: justify;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: 0.06em;
  font-feature-settings: "palt";
  display: none;
}
@media all and (max-width: 896px) {
  #main .faqBox {
    padding-bottom: 11.3rem;
  }
  #main .faqBox .content {
    max-width: inherit;
  }
  #main .faqBox .topImg {
    margin-bottom: 2.1rem;
  }
  #main .faqBox .posImg {
    width: 10.5rem;
    bottom: -1.8rem;
  }
  #main .faqBox .heading {
    margin-bottom: 3.2rem;
    font-size: 3rem;
  }
  #main .faqBox .dlBox dt {
    padding: 0.8rem 5rem 0.8rem 3rem;
    font-size: 1.6rem;
    line-height: 1.4;
    border-radius: 6rem;
    min-height: 5rem;
    display: flex;
    align-items: center;
  }
  #main .faqBox .dlBox dd {
    padding: 1rem 0 0.2rem;
    font-size: 1.4rem;
    line-height: 1.8;
  }
}/*# sourceMappingURL=index.css.map */