@charset "utf-8";
.about-main {
  background: url(../../uploads/2026/01/about-main.jpg) no-repeat;
  background-size: cover;
}
.invi-main {
  background: url(../../uploads/2026/01/invisalign-main.jpg) no-repeat;
  background-size: cover;
}
.flow-main {
  background: url(../../uploads/2026/01/flow-main.jpg) no-repeat;
  background-size: cover;
}
.doctor-main {
  background: url(../../uploads/2026/01/doctor-main.jpg) no-repeat;
  background-size: cover;
}
.clinic-main {
  background: url(../../uploads/2026/01/doctor-co-main.jpg) no-repeat;
  background-size: cover;
}
.price-main {
  background: url(../../uploads/2026/01/price-main.jpg) no-repeat;
  background-size: cover;
}
.sub-main {
  padding: 255px 0 100px;
}
.sub-tit {
  font-size: clamp(24px, 3.333vw, 4.8rem);
  width: fit-content;
  margin: 0 auto;
}
.sub-grd-tit {
  font-size: clamp(20px, 2.778vw, 4rem);
  padding: 0.5em 0;
  background: linear-gradient(90deg, #018dd4 0%, #31c8c9 100%);
}
.wrap-st1 h3 {
  color: #016ab4;
  font-size: clamp(20px, 2.222vw, 3.2rem);
  margin-bottom: 50px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.25em;
}
.wrap-st1 h3::before,
.wrap-st1 h3::after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  flex: 1;
  background: #016ab4;
}
.wrap-st1 .flex-wrap {
  align-items: flex-start;
  gap: 40px;
}
.wrap-st1 .img-box {
  max-width: 41.667vw;
  width: 100%;
}
.wrap-st1 .txt-box {
  flex: 1;
}
.wrap-st2 {
  background: #63bac1;
  padding: 60px 7.812%;
}
.wrap-st2 h3 {
  font-size: clamp(20px, 1.667vw, 2.4rem);
  border: solid #fff;
  border-width: 2px 0 2px 0;
  padding: 20px 0;
  margin-bottom: 45px;
}
.ma-m {
  margin-bottom: 40px;
}
.ma-ml {
  margin-bottom: 60px;
}
.ma-l {
  margin-bottom: 80px;
}
.ma-xl {
  margin-bottom: 100px;
}
/*about*/
.about-sec1 {
  background: url(../../uploads/2026/01/top-bg4.jpg) no-repeat;
  padding: 60px 0;
}
.box-tit.size-s {
  font-size: clamp(16px, 1.944vw, 2.8rem);
}
.about-sec1 .tit-stripe-box {
  margin-bottom: 40px;
}
.about-sec2 .inner {
  background: #f3f3f3;
  padding-top: 80px;
  padding-bottom: 80px;
}
.about-sec3 .inner {
  padding-top: 80px;
  padding-bottom: 120px;
}

/*invi*/

.invi-sec1 .inner {
  padding-top: 60px;
  padding-bottom: 80px;
}
.invi-wrap {
  gap: 40px;
}
.invi-wrap .co {
  flex: 1;
  padding: 40px 30px;
}
.invi-wrap .co-tit {
  font-size: clamp(18px, 1.667vw, 2.4rem);
  padding: 10px 0;
  margin-bottom: 20px;
}
.invi-wrap .org {
  border: 1px solid rgba(240, 115, 32, 1);
  box-shadow: 6px 6px 0px 0px rgba(240, 115, 32, 1);
}
.invi-wrap .org .co-tit {
  background: #f07320;
}
.invi-wrap .blue {
  border: 1px solid rgba(1, 106, 180, 1);
  box-shadow: 6px 6px 0px 0px rgba(1, 106, 180, 1);
}
.invi-wrap .blue .co-tit {
  background: #016ab4;
}
.invi-wrap ul {
  padding: 0 0 0 6.34%;
}
.invi-wrap ul li {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  margin-bottom: 10px;
}
.invi-wrap ul li:last-child {
  margin-bottom: 0;
}
.invi-wrap ul li::before {
  content: "";
  background: #f07320;
  width: 15px;
  height: 15px;
  display: inline-block;
  clip-path: circle(50% at 50% 50%);
  margin-right: 10px;
  margin-top: calc((2em - 15px) / 2);
}
/*flow*/
.flow-sec1 .inner {
  background: #f3f3f3;
  padding-top: 60px;
  padding-bottom: 80px;
}
.flow-co {
  align-items: flex-start;
  justify-content: space-between;
  gap: 40px;
  background: #fff;
  padding: 40px 60px;
}
.flow-tit {
  font-size: clamp(18px, 1.944vw, 2.8rem);
  background: linear-gradient(90deg, #e3f2fe 0%, #fefbb7 100%);
  padding: 10px 0 10px 40px;
  margin-bottom: 30px;
}
.flow-tit em {
  background: #00256a;
  font-size: clamp(20px, 2.5vw, 3.6rem);
  padding: 10px 12px 17px 12px;
  border-radius: 110px;
  margin-right: 20px;
}
.flow-co .img-box {
  max-width: max(22.25vw, 320px);
  width: 100%;
}
.flow-co .txt-box {
  flex: 1;
}
.flow-sec2 .inner {
  padding-top: 80px;
  padding-bottom: 120px;
}
/*doctor*/
.doctor-sec1 .cs-inner::before,
.doctor-sec1 .cs-inner::after {
  content: "";
  position: absolute;
  display: block;
  width: 414px;
  height: 414px;
  background-image: repeating-linear-gradient(
    90deg,
    #c4d9f2,
    #c4d9f2 3px,
    transparent 3px,
    transparent 6px
  );
  z-index: -1;
}
.doctor-sec1 .cs-inner::before {
  position: absolute;
  clip-path: polygon(100% 0, 0 0, 0 100%);
  top: 0;
  left: 0;
}
.doctor-sec1 .cs-inner::after {
  position: absolute;
  clip-path: polygon(100% 100%, 0 100%, 100% 0);
  bottom: 80px;
  right: 0;
}
.doctor-sec1 .cs-inner {
  padding-top: 70px;
  padding-bottom: 80px;
  padding-right: 5.55%;
  position: relative;
  z-index: 1;
}
.dr-tit {
  font-size: clamp(20px, 2.222vw, 3.2rem);
  color: #016ab4;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.25em;
}
.dr-tit::after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  flex: 1;
  background: #016ab4;
}
.dr-wrap {
  gap: 60px;
  align-items: flex-start;
  justify-content: space-between;
}
.dr-wrap .blue-box {
  border: 1px solid #016ab4;
  box-shadow: 6px 6px 0px 0px #016ab4;
  padding: 40px 11% 90px;
}
.blue-box .blue-tit {
  background: #016ab4;
  padding: 10px 0;
  margin-bottom: 20px;
}
.dr-wrap .img-box {
  max-width: max(40.28vw, 320px);
  width: 100%;
  position: relative;
}
.dr-wrap .txt-box {
  flex: 1;
}
.dr-wrap .ic-wrap {
  position: absolute;
  right: 0;
  bottom: 0;
  max-width: max(13.89vw, 150px);
  width: 100%;
  transform: translate(20%, 20%);
}
.doctor-sec2 .inner {
  background: #f3f3f3;
  padding-top: 80px;
  padding-bottom: 80px;
  margin-bottom: 120px;
}
.clinic-main {
  padding: 116px 0;
}
.doctor-sec3 .inner {
  padding-top: 60px;
  padding-bottom: 80px;
}
.doctor-sec3 .img-box {
  max-width: max(33.34vw, 350px);
  width: 100%;
}
.doctor-sec3 .flex-wrap {
  gap: 40px;
  justify-content: center;
}
.doctor-sec4 .inner {
  background: #f3f3f3;
  padding-top: 60px;
  padding-bottom: 60px;
}
.simple-table {
  max-width: max(66.667vw, 800px);
  width: 100%;
  margin: 0 auto;
}
.simple-table th {
  text-align: left;
  width: 25%;
  padding: 20px 0 20px 10px;
  font-weight: 400;
  border-bottom: 1.5px solid #018dd4;
}
.simple-table td {
  text-align: left;
  width: 75%;
  padding: 20px 0;
  border-bottom: 1.5px solid #000000;
}

/*price*/

.price-sec1 .inner {
  background: #f3f3f3;
  padding-top: 60px;
  padding-bottom: 60px;
}
.f-18 {
  font-size: clamp(15px, 1.25vw, 1.8rem);
}
.price-table {
  width: 100%;
}
.price-table th {
  font-size: clamp(15px, 1.25vw, 1.8rem);
  font-weight: 600;
  width: 50%;
  background: #016ab4;
  color: #fff;
  padding: 20px 0;
  text-align: center;
  border-bottom: 1px solid #ffffff;
}
.price-table td {
  font-size: clamp(15px, 1.25vw, 1.8rem);
  background: #fff;
  font-weight: 600;
  width: 50%;
  padding: 20px 0;
  text-align: center;
  border: 1px;
  border-width: 1px, 1px, 1px, 0px;
  border-style: solid;
  border-color: #016ab4;
}
.price-sec2 .inner {
  padding-top: 80px;
  padding-bottom: 120px;
}
@media screen and (max-width: 820px) {
  .wrap-st1 .flex-wrap {
    gap: 20px;
  }
  .invi-wrap .co {
    padding: 10px;
  }
  .invi-wrap {
    gap: 20px;
  }
  .invi-wrap ul {
    padding: 0;
  }
  .flow-co {
    padding: 20px;
  }
  .flow-tit {
    padding: 5px 0 5px 10px;
  }
  .doctor-sec1 .cs-inner::before,
  .doctor-sec1 .cs-inner::after {
    width: 200px;
    height: 200px;
  }
  .dr-wrap .blue-box {
    padding: 30px 5%;
  }
}
@media screen and (max-width: 680px) {
  .sub-main {
    padding: 150px 0 50px;
  }
  .about-sec1 {
    padding: 30px 0;
  }
  .about-sec1 .tit-stripe-box {
    margin-bottom: 30px;
  }
  .about-sec2 .inner {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .about-sec3 .inner {
    padding-top: 60px;
    padding-bottom: 40px;
  }
  .wrap-st1 .img-box {
    max-width: 100%;
  }
  .wrap-st1 h3 {
    margin-bottom: 30px;
  }
  .wrap-st2 {
    padding: 30px 20px;
  }
  .wrap-st2 h3 {
    margin-bottom: 30px;
    padding: 10px 0;
    line-height: 2;
  }
  .ma-m,
  .ma-ml,
  .ma-l,
  .ma-xl {
    margin-bottom: 30px;
  }
  .tc.sp-tl {
    text-align: left;
  }
  .invi-sec1 .inner {
    padding-top: 30px;
    padding-bottom: 40px;
  }
  .flow-tit em {
    padding: 5px 6px 8px 6px;
  }
  .flow-co {
    gap: 20px;
  }
  .flow-sec2 .inner {
    padding-top: 30px;
    padding-bottom: 40px;
  }
  .dr-wrap .ic-wrap {
    transform: translate(20%, 0%);
  }
  .doctor-sec1 .cs-inner {
    padding-left: 5.55%;
  }
  .doctor-sec1 .cs-inner::before,
  .doctor-sec1 .cs-inner::after {
    width: 100px;
    height: 100px;
  }
  .doctor-sec1 .cs-inner::after {
    bottom: 60px;
  }
  .doctor-sec1 .cs-inner {
    padding-bottom: 60px;
  }
  .doctor-sec2 .inner {
    padding-top: 60px;
    padding-bottom: 60px;
    margin-bottom: 30px;
  }
  .clinic-main {
    padding: 60px 0;
  }
  .price-sec1 .inner {
    padding-top: 30px;
    padding-bottom: 30px;
  }
  .price-sec2 .inner {
    padding-top: 30px;
    padding-bottom: 40px;
  }
	.flow-co .txt-box {
		width:100%;
	}
}
