section, nav, article, aside, hgroup, header, footer, figure, figcaption, details {
  display: block;
}

html, body, div, span, applet, object, iframe, strong, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, legend, caption, tbody, tfoot, thead, table, label, tr, th, td, figure {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  vertical-align: baseline;
}

html {
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: "Hiragino Kaku Gothic Pro", Meiryo, "MS PGothic", sans-serif;
  color: #3c4747;
  line-height: 1.6;
  background: #ddd;
}

li {
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

a {
  text-decoration: none;
  color: #008aff;
}

img {
  vertical-align: top;
  max-width: 100%;
  width: auto;
  height: auto;
}

hr {
  height: 1px;
  background-color: #ccc;
  border: 0;
}

.video-container {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}

.video-container iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
  z-index: 1;
}

.sp_only {
  display: block;
}

.sp_only_inline {
  display: inline;
}

.pc_only,
.pc_only_inline {
  display: none;
}

.wrap {
  max-width: 750px;
  padding: 0 2.6666666667vw;
  margin: 0 auto;
}

.to_top {
  transition: top 0.6s ease, opacity 0.6s ease;
  position: relative;
  top: 50px;
  opacity: 0;
}

.isAnimate.show.to_top {
  top: 0;
  opacity: 1;
}

.to_top_left {
  transition: all 1s ease;
  position: relative;
  top: 50px;
  left: 50px;
  opacity: 0;
}

.isAnimate.show.to_top_left {
  top: 0;
  left: 0;
  opacity: 1;
}

.to_top_right {
  transition: all 1s ease;
  position: relative;
  top: 50px;
  right: 50px;
  opacity: 0;
}

.isAnimate.show.to_top_right {
  top: 0;
  right: 0;
  opacity: 1;
}

.contents {
  max-width: 750px;
  margin: 0 auto;
  font-size: 3.4666666667vw;
  background: #fff;
  text-align: center;
  overflow: hidden;
}

em,
.f_bold {
  font-weight: bold;
}

.left {
  text-align: left;
}

.red {
  color: #e93d3d;
}

.sup {
  vertical-align: super;
  font-size: 0.5em;
}

.bg {
  background: #ccc;
  color: #fff;
  padding: 0 0.3em;
}

.marker {
  background: linear-gradient(to bottom, transparent 60%, #ffff6d 60%, #ffff6d 90%, #ffff6d 90%, transparent 90%);
}

.note {
  font-size: 1.8666666667vw;
  line-height: 1.5;
  margin-left: 1em;
  text-align: left;
  color: #a3a3a3;
}
.note li {
  margin: 0 0 0.3em;
  text-indent: -1em;
}

ol.note {
  margin-left: 2.7em;
}
ol.note li {
  text-indent: -2.7em;
}

.btn_area h3 {
  display: inline-block;
  font-size: 4vw;
  font-weight: bold;
  line-height: 1.2;
  padding: 0 1em;
  position: relative;
}
.btn_area h3:before, .btn_area h3:after {
  content: "";
  display: block;
  width: 0.2666666667vw;
  height: 1em;
  background: #3c4747;
  position: absolute;
  bottom: 0;
  left: 0;
  transform: rotate(-30deg);
}
.btn_area h3:after {
  left: auto;
  right: 0;
  transform: rotate(30deg);
}
.btn_area .btn + p {
  font-size: 2.6666666667vw;
  font-weight: normal;
  line-height: 1.4 !important;
}

/*=======================================
	p1
=======================================*/
.p1_mv .sec1 .wrap {
  background: #f5f5f5;
  padding-top: 2.6666666667vw;
  padding-bottom: 2.6666666667vw;
}
.p1_mv .sec2 {
  padding-top: 9.3333333333vw;
  position: relative;
}
.p1_mv .sec2 .wrap {
  position: absolute;
  bottom: 22.6666666667vw;
  left: 0;
  width: 100%;
  box-sizing: border-box;
}
.p1_mv .sec3 {
  margin-top: -13.3333333333vw;
  position: relative;
  z-index: 1;
}

.p1_worries .sec1 {
  position: relative;
  z-index: 1;
}
.p1_worries .sec2 {
  margin-top: -21.3333333333vw;
  padding-bottom: 13.3333333333vw;
}
.p1_worries .sec2 .wrap p {
  font-size: 4.2666666667vw;
  font-weight: bold;
  margin: 4vw 0 6.6666666667vw;
}
.p1_worries .sec2 .wrap figure {
  margin-bottom: 18.6666666667vw;
}
.p1_worries .sec2 .box {
  border: 1px solid #0148a8;
  padding: 2.6666666667vw;
}
.p1_worries .sec2 .box figure {
  padding: 0 9.8666666667vw;
  margin: -13.3333333333vw 0 0;
}
.p1_worries .sec2 .box p {
  margin: 6.6666666667vw 0 4vw;
  letter-spacing: 0.1em;
}

.p1_feature .sec1 {
  background: #e1fdfe;
  padding-bottom: 8vw;
}
.p1_feature .sec1 figure {
  padding: 0 1.3333333333vw;
  margin-bottom: 7.2vw;
}
.p1_feature .sec1 figure.a {
  margin-top: -24vw;
}
.p1_feature .sec1 figure.c {
  margin-bottom: 0;
}
/*=======================================
	p2
=======================================*/
.p2_reason .sec1 {
  overflow-x: hidden;
  margin-bottom: 9.3333333333vw;
}
.p2_reason .sec1 p {
  font-family: "Yu Mincho", "YuMincho", serif;
  color: #0148a8;
  font-weight: bold;
  font-size: 5.0666666667vw;
}
.p2_reason .sec1 .loop {
  position: relative;
  display: flex;
  width: 100vw;
  margin: 9.3333333333vw 0;
  overflow: hidden;
}
.p2_reason .sec1 .loop ul {
  display: flex;
  flex-flow: row nowrap;
  padding: 0;
}
.p2_reason .sec1 .loop li {
  width: 300vw;
  margin-right: 3.4666666667vw;
}
.p2_reason .sec1 .loop ul:first-child {
  animation: loop 100s -50s linear infinite;
  backface-visibility: hidden;
  will-change: transform;
}
.p2_reason .sec1 .loop ul + ul {
  animation: loop2 100s linear infinite;
}
@keyframes loop {
  0% {
    transform: translateX(100%);
  }
  to {
    transform: translateX(-100%);
  }
}
@keyframes loop2 {
  0% {
    transform: translateX(0);
  }
  to {
    transform: translateX(-200%);
  }
}
.p2_reason .sec2 .h {
  margin-bottom: 7.2vw;
}
.p2_reason .sec2 .wrap {
  padding: 0 4vw;
}
.p2_reason .sec2 section {
  box-shadow: 0 2px 7px 4px rgba(0, 0, 0, 0.08);
  border-radius: 0.6666666667vw;
  margin-bottom: 10.6666666667vw;
}
.p2_reason .sec2 .head {
  background: #e1fdfe;
  padding: 4vw 0 4vw 24vw;
  line-height: 1.2;
  position: relative;
}
.p2_reason .sec2 .head:before {
  content: "";
  display: block;
  width: 21.2vw;
  height: 23.4666666667vw;
  background-image: url("../images/p2_reason_num1.png");
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: -2vw;
  left: 2.6666666667vw;
}
.p2_reason .sec2 .head h3 {
  font-size: 7.2vw;
  color: #2db4ff;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: bold;
}
.p2_reason .sec2 .head h3 .s {
  font-size: 0.818em;
}
.p2_reason .sec2 .head h3 .sup {
  font-size: 0.3em;
}
.p2_reason .sec2 .head p {
  font-size: 3.7333333333vw;
  font-weight: bold;
  margin-top: 0.2em;
}
.p2_reason .sec2 .inner {
  padding: 4vw 5.3333333333vw;
  background: #fff;
}
.p2_reason .sec2 .inner figure {
  margin-bottom: 1em;
}
.p2_reason .sec2 .inner p {
  text-align: left;
  margin-bottom: 1em;
}
.p2_reason .sec2 .num2 .head:before {
  background-image: url("../images/p2_reason_num2.png");
}
.p2_reason .sec2 .num3 .head:before {
  background-image: url("../images/p2_reason_num3.png");
}
.p2_reason .sec2 .num3 .head h3 {
  font-size: 6.4vw;
  letter-spacing: -0.08em;
}
.p2_reason .sec2 .num3 .head p {
  margin-top: 0;
  margin-bottom: 0.2em;
}
.p2_reason .sec2 .num3 .note {
  margin-bottom: 5.3333333333vw;
}
.p2_reason .sec2 .num3 .btn_result {
  margin: 0 -2.6666666667vw;
}
.p2_reason .sec2 .num3 .change_b p {
  font-size: 3.7333333333vw;
  text-align: center;
}
.p2_reason .sec2 .num3 .change_b figure + p {
  font-weight: bold;
  color: #0148a8;
  margin-top: 2em;
}

.p2_price .sec2 .wrap {
  padding: 0 5.3333333333vw;
}
.p2_price .sec2 .txt {
  background: #dffcfd;
  padding: 5.3333333333vw 0 2.6666666667vw;
}
.p2_price .sec2 p {
  font-size: 4.2666666667vw;
  font-weight: bold;
  line-height: 1.8;
  margin-bottom: 4.8vw;
}

/*=======================================
	p3
=======================================*/
.p3_merit .box {
  background: #fff;
  border: 1.3333333333vw solid #e5f6ff;
  padding: 4vw;
}
.p3_merit p {
  font-size: 3.2vw;
  line-height: 2;
}
.p3_merit figure {
  margin: 1em 0;
}
.p3_merit .sec1 {
  margin-bottom: 12vw;
}
.p3_merit .sec1 .box {
  margin-top: -15.2vw;
  position: relative;
  z-index: 1;
}
.p3_merit .sec1 .l {
  font-size: 4.2666666667vw;
  font-weight: bold;
  color: #2db4ff;
  margin: 1.5em 0;
}
.p3_merit .sec1 .note {
  text-align: right;
}
.p3_merit .sec2 .h {
  margin-bottom: 4vw;
}
.p3_merit .sec2 section {
  margin-bottom: 4.8vw;
}
.p3_merit .sec2 section figure {
  margin-left: auto;
  margin-right: auto;
}
.p3_merit .sec2 h2 {
  max-width: 88vw;
  margin: 0 auto 4vw;
}
.p3_merit .sec2 .a figure {
  max-width: 68.8vw;
}
.p3_merit .sec2 .b {
  margin-bottom: 12vw;
}
.p3_merit .sec2 .b h2 {
  max-width: 60vw;
}
.p3_merit .sec2 .b figure {
  max-width: 55.4666666667vw;
}

.p3_needs .sec2 {
  background: #e8fcfd url("../images/p3_needs_3_bg.jpg") no-repeat center top;
  background-size: contain;
  padding-bottom: 10.6666666667vw;
}
.p3_needs .sec2 h2 {
  transform: translateY(-50%);
}
.p3_needs .sec2 h2 span {
  display: inline-block;
  background: #0148a8;
  color: #fff;
  font-size: 6vw;
  font-weight: bold;
  line-height: 1.2;
  padding: 3.4666666667vw 4vw;
  position: relative;
}
.p3_needs .sec2 h2 span:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border: 1.6vw solid transparent;
  border-top: 2.5333333333vw solid #0148a8;
  position: absolute;
  bottom: -3.6vw;
  left: 50%;
  transform: translateX(-50%);
}
.p3_needs .sec2 .txt {
  margin-bottom: 4vw;
}
.p3_needs .sec2 .txt p {
  font-size: 6.4vw;
  font-weight: bold;
  line-height: 1.2;
  margin-bottom: 0.5em;
}
.p3_needs .sec2 .txt p em {
  display: inline-block;
  background: #fff;
  color: #3cb9fe;
  padding: 0.2em 0.4em;
  margin: 0.3em 0;
  box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.1);
}
.p3_needs .sec2 .txt .s {
  font-size: 4.2666666667vw;
}
.p3_needs .sec2 figure {
  max-width: 86.6666666667vw;
  margin: 0 auto 5.3333333333vw;
  padding: 3.4666666667vw;
  background: #fff;
  box-sizing: border-box;
  box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.1);
}
.p3_needs .sec2 figure figcaption {
  font-size: 6.4vw;
  font-weight: bold;
  line-height: 1.2;
  margin-top: 3.2vw;
}
.p3_needs .sec2 figure + p {
  font-size: 4.2666666667vw;
  font-weight: bold;
}
.p3_needs .sec2 figure + p:after {
  content: "";
  display: block;
  width: 16vw;
  height: 7.2vw;
  background: url("../images/p3_needs_3_arrow.png") no-repeat;
  background-size: contain;
  margin: 1.8666666667vw auto;
}

.p3_anxiety {
  background: #f3fbfe;
  padding: 12vw 0;
}
.p3_anxiety section {
  margin-bottom: 6.6666666667vw;
}
.p3_anxiety h2 {
  font-size: 7.0666666667vw;
  font-weight: bold;
  line-height: 1.4;
  color: #fff;
  border-radius: 0.8vw 0.8vw 0 0;
  padding: 5.3333333333vw 4vw;
  background: #5fc5fd;
  background: linear-gradient(to bottom, #5fc5fd 0%, #0371ce 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#5fc5fd", endColorstr="#0371ce",GradientType=0 );
}
.p3_anxiety h2 .s {
  display: block;
  text-align: left;
  font-size: 2.6666666667vw;
  font-weight: normal;
  line-height: 1;
  margin-left: 1em;
}
.p3_anxiety h2 .sup {
  font-size: 0.3em;
  margin-left: 0.5em;
}
.p3_anxiety .inner {
  background: #fff;
  border: 0.9333333333vw solid #b7e4fd;
  border-top: none;
  padding: 5.3333333333vw;
  border-radius: 0 0 0.8vw 0.8vw;
}
.p3_anxiety .inner figure {
  margin-bottom: 1.5em;
}
.p3_anxiety .inner p {
  font-size: 3.7333333333vw;
  font-weight: bold;
  margin-bottom: 1.5em;
}
.p3_anxiety .sec1 .b {
  max-width: 36.8vw;
  margin-left: auto;
  margin-right: auto;
}
.p3_anxiety .sec3 {
  margin-bottom: 0;
}

/*=======================================
	p4
=======================================*/
.p4_case {
  padding-bottom: 10.6666666667vw;
  background-image: repeating-linear-gradient(90deg, #cfeafd, #cfeafd 1px, transparent 1px, transparent 14px), repeating-linear-gradient(0deg, #cfeafd, #cfeafd 1px, #fff 1px, #fff 14px);
}
.p4_case .title {
  padding: 5.3333333333vw 0;
}
.p4_case .title p {
  border: 0.2666666667vw solid #3c4747;
  padding: 26.6666666667vw 8vw 5.3333333333vw;
  background: #fff;
  text-align: left;
  font-size: 3.2vw;
  font-weight: bold;
  margin-top: -24.5333333333vw;
}
.p4_case section {
  margin-bottom: 8vw;
}
.p4_case section .wrap {
  padding: 0 5.3333333333vw;
}
.p4_case .h {
  background: #fff;
  border: 2.6666666667vw solid #e5fdff;
  padding: 4vw 6.6666666667vw;
  margin-bottom: 4vw;
}
.p4_case .h h2 {
  font-size: 4vw;
  font-weight: bold;
  margin-bottom: 0.1em;
}
.p4_case .h p {
  font-size: 3.2vw;
  text-align: left;
}
.p4_case .slick-slide {
  background: #fff;
  border-radius: 1.0666666667vw;
  border: 1px solid #ccc;
  padding: 4.8vw;
  margin: 0 1.6vw;
  box-sizing: border-box;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}
.p4_case .slick-slide > p {
  background: #f6fbfe;
  padding: 1em;
  font-size: 3.2vw;
  border-radius: 1.3333333333vw;
  margin-bottom: 4.8vw;
}
.p4_case .slick-dots {
  display: flex;
  justify-content: center;
  margin-top: 4.2666666667vw;
}
.p4_case .slick-dots li {
  width: 1.8666666667vw;
  height: 1.8666666667vw;
  margin: 0 1.0666666667vw;
  border-radius: 50%;
  background: #e9eff2;
}
.p4_case .slick-dots li.slick-active {
  background: #0148a8;
}
.p4_case .slick-dots li button {
  font-size: 0;
  line-height: 0;
  border: none;
  background: none;
  outline: none;
}
.p4_case .slick-arrow {
  width: 6.9333333333vw;
  height: 6.9333333333vw;
  background: rgba(103, 189, 237, 0.6);
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 2.1333333333vw;
  transform: translateY(-50%);
  z-index: 1;
  cursor: pointer;
}
.p4_case .slick-arrow.next {
  left: auto;
  right: 2.1333333333vw;
}
.p4_case .slick-arrow:after {
  content: "";
  display: block;
  width: 2.1333333333vw;
  height: 2.1333333333vw;
  border-right: 3px solid #fff;
  border-bottom: 3px solid #fff;
  box-sizing: border-box;
  position: absolute;
  top: 50%;
  left: 40%;
  transform: translateY(-50%) rotate(135deg);
}
.p4_case .slick-arrow.next:after {
  left: 30%;
  transform: translateY(-50%) rotate(-45deg);
}
.p4_case .flex figure {
  margin: 0 0 1em;
  text-align: center;
}
.p4_case .flex figure img {
  display: inline;
}
.p4_case .flex .detail {
  text-align: left;
}
.p4_case .flex dl {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  line-height: 1.4;
  font-size: 3.4666666667vw;
  padding: 0.3em 0;
}
.p4_case .flex dt, .p4_case .flex dd {
  margin-bottom: 1em;
}
.p4_case .flex dt {
  width: 21.3333333333vw;
  background: #0148a8;
  color: #fff;
  font-size: 3.4666666667vw;
  font-weight: bold;
  text-align: center;
  padding: 0.3em 0;
  margin-right: 1em;
}
.p4_case .flex dd {
  width: 47.4666666667vw;
  font-size: 3.4666666667vw;
  font-weight: bold;
  color: #0148a8;
}
.p4_case .flex dd em {
  font-size: 1.4em;
}
.p4_case .flex dd span {
  display: block;
  font-size: 2.6666666667vw;
  font-weight: normal;
  color: #333;
}
.p4_case .flex ul {
  font-size: 3.2vw;
  border-top: 1px solid #e5e5e5;
  line-height: 1.4;
}
.p4_case .flex li {
  display: flex;
  align-items: center;
  padding: 0.5em 0;
  border-bottom: 1px solid #e5e5e5;
}
.p4_case .flex li p {
  flex: 1;
}
.p4_case .flex h4 {
  width: 21.3333333333vw;
  font-weight: bold;
}
.p4_case .note {
  text-align: left;
  margin-top: 1.5em;
}
.p4_case .attention {
  max-width: 77.3333333333vw;
  margin: 0 auto;
  color: #fc4141;
  font-size: 2.4vw;
  text-align: left;
}
.p4_case .attention a {
  text-decoration: underline;
}
.p4_case .sec2 .h p {
  text-align: center;
}

.p4_cta > figure {
  margin-top: -5.3333333333vw;
  position: relative;
  z-index: 1;
}
.p4_cta .howto {
  background: url("../images/p4_cta_bg.jpg") no-repeat center;
  background-size: cover;
  padding: 6.6666666667vw 0 8vw;
}
.p4_cta h2 {
  margin-bottom: 0.2em;
}
.p4_cta h2 span {
  display: inline-block;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-size: 6.6666666667vw;
  font-weight: bold;
  color: #2db4ff;
  line-height: 1;
  padding: 0 4vw;
  position: relative;
}
.p4_cta h2 span:before,
.p4_cta h2 span:after {
  content: "";
  display: block;
  width: 1px;
  height: 1em;
  background: #2db4ff;
  position: absolute;
  bottom: 0;
  left: 0;
  transform: rotate(-35deg);
}
.p4_cta h2 span:after {
  left: auto;
  right: 0;
  transform: rotate(35deg);
}
.p4_cta .howto_detail {
  padding-bottom: 10.6666666667vw;
}
.p4_cta .howto_detail .wrap.a {
  font-size: 4.2666666667vw;
  margin-top: 2em;
  margin-bottom: 1.5em;
}
.p4_cta .howto_detail .wrap.a ul {
  font-weight: bold;
  text-align: left;
  padding-left: 16vw;
}
.p4_cta .howto_detail .wrap.a li span {
  text-decoration: underline;
}
.p4_cta .howto_detail .wrap.a + figure {
  margin-bottom: 2em;
}
.p4_cta .howto_detail .btn_area {
  margin-top: -2em;
  margin-bottom: 5.3333333333vw;
}
.p4_cta .howto_detail .btn_area + .note {
  padding: 0 6.6666666667vw;
}

.p4_dentition .sec1 {
  padding: 8vw 0 0;
  background-image: repeating-linear-gradient(90deg, #cfeafd, #cfeafd 1px, transparent 1px, transparent 14px), repeating-linear-gradient(0deg, #cfeafd, #cfeafd 1px, #fff 1px, #fff 14px);
}
.p4_dentition .sec1 .wrap {
  padding: 0 4vw;
}
.p4_dentition .sec1 .h {
  margin-bottom: 11.2vw;
}
.p4_dentition .sec1 .inner {
  background: #fff;
  border: 0.6666666667vw solid #62c7ff;
  padding: 4vw;
  padding-top: 0;
  font-size: 3.7333333333vw;
  font-weight: bold;
}
.p4_dentition .sec1 h2 {
  background: #63c6fd;
  color: #fff;
  font-size: 5.0666666667vw;
  font-weight: normal;
  line-height: 1;
  padding: 8vw 0;
  margin-top: -16.8vw;
  margin-bottom: 5.3333333333vw;
  position: relative;
  z-index: 1;
}
.p4_dentition .sec1 h2:before {
  content: "";
  display: block;
  border: 1px solid #fff;
  position: absolute;
  top: 2.1333333333vw;
  left: 2.1333333333vw;
  bottom: 2.1333333333vw;
  right: 2.1333333333vw;
}
.p4_dentition .sec1 h2 em {
  font-weight: normal;
  display: block;
  font-size: 8vw;
  margin-top: 1.8666666667vw;
}
.p4_dentition .sec1 h2 em span {
  font-size: 0.8333333em;
}
.p4_dentition .sec1 figure {
  margin: 5.3333333333vw 0 4vw;
}
.p4_dentition .sec1 .list {
  display: flex;
  justify-content: center;
  color: #0148a8;
  line-height: 1.2;
  margin: 1em 0;
}
.p4_dentition .sec1 .list li {
  background: #e5fdff;
  margin: 0 1.0666666667vw;
  padding: 0.2em 0.5em;
  border-radius: 6.6666666667vw;
}
.p4_dentition .sec1 .list li:first-child {
  margin-left: 0;
}
.p4_dentition .sec1 .list li:last-child {
  margin-right: 0;
}
.p4_dentition .sec1 .box {
  border: 0.2666666667vw solid #0148a8;
  padding: 2.6666666667vw;
  padding-top: 0;
  margin-top: 8vw;
}
.p4_dentition .sec1 .box h3 {
  margin-top: -0.8em;
  margin-bottom: 0.8em;
}
.p4_dentition .sec1 .box h3 span {
  display: inline-block;
  font-size: 4.2666666667vw;
  color: #0148a8;
  line-height: 1.2;
  background: #fff;
  padding: 0 0.5em;
}
.p4_dentition .sec1 .box .a {
  text-align: left;
  margin-left: 1em;
}
.p4_dentition .sec1 .box .a li {
  line-height: 1.4;
  text-indent: -1em;
  margin-bottom: 0.4em;
}
.p4_dentition .sec1 .box p {
  text-align: left;
  font-size: 0.7em;
  line-height: 1.4;
  padding-left: 9.3333333333vw;
  margin-bottom: 1em;
  position: relative;
}
.p4_dentition .sec1 .box p:before {
  content: "";
  display: block;
  width: 2.9333333333vw;
  height: 2.9333333333vw;
  box-sizing: border-box;
  border-left: 0.2666666667vw solid #3c4747;
  border-bottom: 0.2666666667vw solid #3c4747;
  position: absolute;
  top: 0.1em;
  left: 4.2666666667vw;
}
.p4_dentition .sec2 {
  font-size: 3.2vw;
  font-weight: bold;
  padding: 6.6666666667vw 0 10.6666666667vw;
  /*		h3{
  			display: inline-block;
  			font-size: calc(100vw / ( 750 / 30 ));
  			line-height: 1.2;
  			padding: 0 1em;
  			position: relative;

  			&:before,
  			&:after{
  				content: "";
  				display: block;
  				width: calc(100vw / ( 750 / 2 ));
  				height: 1em;
  				background: #3c4747;
  				position: absolute;
  				bottom: 0;
  				left: 0;
  				transform: rotate(-30deg);
  			}
  			&:after{
  				left: auto;
  				right: 0;
  				transform: rotate(30deg);
  			}
  		}
  		.btn + p{
  			font-size: calc(100vw / ( 750 / 20 ));
  			font-weight: normal;
  			line-height: 1.4;
  		}*/
}
.p4_dentition .sec2 p {
  line-height: 2.4;
  margin: 0 0 2em;
}
.p4_dentition .sec2 .u_line {
  display: inline-block;
  border-bottom: 0.2666666667vw solid #3c4747;
}
.p4_dentition .sec2 .note {
  max-width: 82.6666666667vw;
  margin: 0 auto;
}

/*=======================================
	p5
=======================================*/
.p5_commit {
  background: #eef5ff;
  padding-bottom: 12vw;
}
.p5_commit section {
  background: #fff;
  padding: 5.3333333333vw 4vw;
  margin-bottom: 5.3333333333vw;
}
.p5_commit section .title {
  position: relative;
}
.p5_commit section .title .num {
  font-family: "Yu Mincho", "YuMincho", serif;
  font-size: 26.6666666667vw;
  font-weight: bold;
  line-height: 1;
  font-style: italic;
  color: #e5f6ff;
  position: absolute;
  top: 0;
  left: -0.15em;
}
.p5_commit section .title h2 {
  font-family: "Yu Mincho", "YuMincho", serif;
  font-size: 7.2vw;
  font-weight: bold;
  color: #0148a8;
  position: relative;
  z-index: 1;
  padding-left: 1.5em;
}
.p5_commit section .title p {
  font-size: 4vw;
  font-weight: bold;
  color: #3c4747;
  line-height: 1.4;
  margin: 0.5em 0 0;
}
.p5_commit section .title:after {
  content: "";
  display: block;
  width: 9.3333333333vw;
  height: 1.3333333333vw;
  background: #0148a8;
  margin: 5.3333333333vw auto;
}
.p5_commit section p,
.p5_commit section figure {
  margin-bottom: 1.5em;
}
.p5_commit .sec1 .title + p {
  text-align: left;
  max-width: 74.6666666667vw;
  margin: 0 auto 5.3333333333vw;
}
.p5_commit .sec1 .flex {
  display: flex;
  margin-bottom: 8vw;
}
.p5_commit .sec1 .flex figure {
  width: 33.3333333333vw;
}
.p5_commit .sec1 .flex .txt {
  width: 56vw;
  background: #fff;
  box-sizing: border-box;
  padding: 4vw 3.2vw;
  box-shadow: 2px 0 6px rgba(0, 0, 0, 0.1);
  margin-top: 8vw;
  margin-left: -4.5333333333vw;
  text-align: left;
  position: relative;
}
.p5_commit .sec1 .flex .txt:after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  border-right: 0.2666666667vw solid #7f7f7f;
  border-bottom: 0.2666666667vw solid #7f7f7f;
  position: absolute;
  bottom: -1.8666666667vw;
  right: -1.8666666667vw;
  z-index: 1;
}
.p5_commit .sec1 .flex h3 {
  font-size: 4.5333333333vw;
  line-height: 1.2;
  font-weight: bold;
  margin-bottom: 0.5em;
}
.p5_commit .sec1 .flex h3 span {
  font-size: 0.67em;
}
.p5_commit .sec1 .flex p {
  font-size: 2.9333333333vw;
  margin-bottom: 0;
}
.p5_commit .sec1 .flex:nth-child(even) {
  flex-direction: row-reverse;
}
.p5_commit .sec1 .flex:nth-child(even) .txt {
  margin-left: auto;
  margin-right: -4.5333333333vw;
}
.p5_commit .sec1 .flex:nth-child(even) .txt:after {
  border-right: none;
  border-left: 0.2666666667vw solid #7f7f7f;
  right: auto;
  left: -1.8666666667vw;
}
.p5_commit .sec1 .flex + figure {
  margin: 13.3333333333vw 0 9.3333333333vw;
}
.p5_commit .sec1 .flex + figure figcaption {
  font-size: 1.8666666667vw;
  color: #a3a3a3;
  line-height: 1;
  text-align: right;
  margin-top: 1em;
}
.p5_commit .sec2 p {
  line-height: 2;
}
.p5_commit .sec3 {
  margin-bottom: 0;
}
.p5_commit .sec3 p {
  line-height: 2;
}

.p5_clinic .sec1 {
  background: #e1fdfe;
  padding: 14.6666666667vw 0 22.6666666667vw;
}
.p5_clinic .sec1 .wrap {
  padding: 0 4vw;
}
.p5_clinic .sec1 .inner {
  background: #fff;
  font-family: "Yu Mincho", "YuMincho", serif;
  padding: 6.6666666667vw 0;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
}
.p5_clinic .sec1 h2 {
  background: #63c7fe;
  color: #fff;
  font-size: 7.3333333333vw;
  font-weight: bold;
  line-height: 1.2;
  padding: 4vw 0 3.2vw;
  margin-bottom: 5.3333333333vw;
}
.p5_clinic .sec1 h2 span {
  font-size: 0.654em;
  display: block;
}
.p5_clinic .sec1 p {
  line-height: 2;
  font-weight: bold;
}
.p5_clinic .sec1 figure {
  max-width: 52.8vw;
  margin: 2em auto 0;
}
.p5_clinic .sec2 {
  padding-bottom: 10.6666666667vw;
}
.p5_clinic .sec2 h2 {
  display: inline-block;
  background: #0148a8;
  color: #fff;
  font-size: 4.6666666667vw;
  font-weight: bold;
  border-radius: 1.3333333333vw;
  padding: 0.5em 1em;
  margin-top: -9.8666666667vw;
  margin-bottom: 8.5333333333vw;
  position: relative;
}
.p5_clinic .sec2 h2 span {
  position: relative;
}
.p5_clinic .sec2 h2 span:after {
  content: "";
  display: block;
  width: 94%;
  height: 1.3333333333vw;
  background: #ffff6d;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
.p5_clinic .sec2 h2:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border: 1.6vw solid transparent;
  border-top: 2.9333333333vw solid #0148a8;
  position: absolute;
  bottom: -4vw;
  left: 50%;
  transform: translateX(-50%);
}
.p5_clinic .sec2 .a {
  padding: 0 4vw;
  margin-bottom: 4.8vw;
}
.p5_clinic .sec2 .a + p {
  max-width: 77.3333333333vw;
  margin: 0 auto;
  font-size: 3.2vw;
  text-align: left;
  color: #0148a8;
}
.p5_clinic .sec2 .a + p span {
  color: #a3a3a3;
}
.p5_clinic .sec2 .note {
  text-align: right;
  padding-right: 9.3333333333vw;
}
.p5_clinic .sec2 .b {
  margin: 8vw 0 6.6666666667vw;
  padding: 0 2.6666666667vw;
}
.p5_clinic .sec2 .b figcaption {
  font-size: 1.8666666667vw;
  line-height: 1;
  text-align: right;
  color: #a3a3a3;
}
.p5_clinic .sec2 .box {
  max-width: 81.3333333333vw;
  margin: 0 auto 6.6666666667vw;
  border: 1px solid #0148a8;
}
.p5_clinic .sec2 .box h3 {
  background: #0148a8;
  color: #fff;
  font-size: 3.2vw;
  line-height: 1.2;
  padding: 0.8em 0;
}
.p5_clinic .sec2 .box .inner {
  padding: 4vw 5.3333333333vw;
  color: #0148a8;
  font-weight: bold;
}
.p5_clinic .sec2 .box h4 {
  position: relative;
  margin-bottom: 0.2em;
}
.p5_clinic .sec2 .box h4:after {
  content: "";
  display: block;
  width: 100%;
  height: 0.4vw;
  background: #0148a8;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
.p5_clinic .sec2 .box h4 span {
  font-size: 3.2vw;
  line-height: 1.2;
  display: inline-block;
  background: #fff;
  padding: 0 1em;
  position: relative;
  z-index: 1;
}
.p5_clinic .sec2 .box p {
  font-size: 2.6666666667vw;
  text-align: left;
}
.p5_clinic .sec2 .box p:first-of-type {
  margin-bottom: 1em;
}
.p5_clinic .sec2 .btn_area h3 {
  line-height: 1.6;
}
.p5_clinic .sec2 .btn_area h3:before, .p5_clinic .sec2 .btn_area h3:after {
  height: 2.5em;
  bottom: 0.2em;
}

.p5_flow {
  border-top: 1.3333333333vw solid #0148a8;
  padding: 10.6666666667vw 0;
}
.p5_flow h2 {
  font-size: 6.6666666667vw;
  font-weight: bold;
  color: #63c7fe;
  line-height: 1.2;
}
.p5_flow h2:after {
  content: "";
  display: block;
  width: 9.3333333333vw;
  height: 1.3333333333vw;
  background: #63c7fe;
  margin: 0.5em auto 1em;
}
.p5_flow h2 + p {
  font-size: 4.2666666667vw;
  font-weight: bold;
  margin-bottom: 5.3333333333vw;
}
.p5_flow .outer {
  position: relative;
}
.p5_flow .outer:after {
  content: "";
  display: block;
  width: 6.6666666667vw;
  height: 100%;
  background: #e5fdfe;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.p5_flow section {
  max-width: 78.6666666667vw;
  margin: 0 auto 14.6666666667vw;
  border-radius: 1.0666666667vw;
  box-shadow: 0 0.5333333333vw 1.8666666667vw rgba(0, 0, 0, 0.25);
  background: #fff;
  position: relative;
  z-index: 1;
}
.p5_flow section h3 {
  background: #63c7fe;
  color: #fff;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-size: 5.3333333333vw;
  font-weight: bold;
  line-height: 1.2;
  padding: 1em 0 0.5em;
  border-radius: 1.0666666667vw 1.0666666667vw 0 0;
}
.p5_flow section h3 span {
  font-size: 1.375em;
  font-weight: normal;
  font-style: italic;
  margin-right: 0.2em;
  position: relative;
  bottom: -0.05em;
}
.p5_flow section h3 span:before {
  content: "step";
  font-size: 4.4vw;
  position: absolute;
  top: -1em;
  left: -0.25em;
}
.p5_flow section .inner {
  text-align: left;
  padding: 5.3333333333vw;
}
.p5_flow section p {
  font-size: 3.2vw;
  line-height: 2;
  margin-bottom: 1em;
}
.p5_flow .sec2 figure {
  position: relative;
}
.p5_flow .sec2 figure:after {
  content: "";
  display: block;
  width: 28.9333333333vw;
  height: 16.9333333333vw;
  background: url("../images/p5_flow_2b.png") no-repeat;
  background-size: contain;
  position: absolute;
  top: -1.6vw;
  right: 3.4666666667vw;
}
.p5_flow .sec3 figure {
  position: relative;
}
.p5_flow .sec3 figure:after {
  content: "";
  display: block;
  width: 34.1333333333vw;
  height: 20.5333333333vw;
  background: url("../images/p5_flow_3b.png") no-repeat;
  background-size: contain;
  position: absolute;
  top: -2.8vw;
  right: -8.2666666667vw;
}
.p5_flow .sec4 {
  margin-bottom: 8vw;
}
.p5_flow .btn_area {
  margin-bottom: 6.6666666667vw;
}
.p5_flow .btn_area + .note {
  padding: 0 5.3333333333vw;
}

/*=======================================
	p6
=======================================*/
.p6_entrust .sec1 {
  margin-bottom: 6.6666666667vw;
}
.p6_entrust .sec1 .note {
  margin-top: -12vw;
  padding: 0 5.3333333333vw;
}
.p6_entrust .sec2 {
  background: #dffcfd;
  padding-bottom: 6.6666666667vw;
}
.p6_entrust .sec2 figure {
  margin-bottom: 10.6666666667vw;
}
.p6_entrust .sec2 ul {
  font-family: "Yu Mincho", "YuMincho", serif;
  font-size: 4.8vw;
  font-weight: bold;
  color: #0148a8;
  text-align: left;
  padding: 0 2.6666666667vw;
  margin-bottom: 5.3333333333vw;
}
.p6_entrust .sec2 li {
  position: relative;
  padding-left: 6.6666666667vw;
  margin-bottom: 0.3em;
}
.p6_entrust .sec2 li span {
  display: block;
  font-family: "Hiragino Kaku Gothic Pro", Meiryo, "MS PGothic", sans-serif;
  font-size: 1.8666666667vw;
  font-weight: normal;
  color: #a3a3a3;
  text-align: right;
  line-height: 1;
}
.p6_entrust .sec2 li:before {
  content: "";
  display: block;
  width: 4.5333333333vw;
  height: 4.5333333333vw;
  background: url("../images/icon_check.png") no-repeat;
  background-size: contain;
  position: absolute;
  top: 0.3em;
  left: 0;
}
.p6_entrust .sec2 .wrap figure {
  max-width: 48vw;
  margin: 0 auto;
}

.p6_think .sec1 .c {
  max-width: 78.6666666667vw;
  margin: 10.6666666667vw auto;
}
.p6_think .sec2 .wrap {
  background: url("../images/p6_chance_bg.jpg") no-repeat center top;
  background-size: cover;
  padding: 0 4vw;
  padding-bottom: 12vw;
}
.p6_think .sec2 .outer {
  background: #fff;
  margin-top: -14.6666666667vw;
  position: relative;
  z-index: 1;
  box-shadow: 0 0.5333333333vw 1.8666666667vw rgba(0, 0, 0, 0.25);
}
.p6_think .sec2 h2 {
  background: #63c6fd;
  color: #fff;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-size: 7.3333333333vw;
  font-weight: bold;
  line-height: 1.4;
  padding: 0.5em 0;
}
.p6_think .sec2 h2 span {
  display: block;
  font-size: 0.69em;
}
.p6_think .sec2 .inner {
  padding: 5.3333333333vw;
}
.p6_think .sec2 .inner > p {
  margin-bottom: 1.3em;
  font-size: 3.7333333333vw;
  font-weight: bold;
  line-height: 1.8;
}
.p6_think .sec2 .inner > p em {
  font-size: 1.2857em;
  color: #2db4ff;
}
.p6_think .sec2 .inner figure {
  margin-bottom: 2em;
}
.p6_think .sec2 .inner .btn_area {
  margin-bottom: 5.3333333333vw;
}
.p6_think .sec2 ul.a {
  font-size: 3.7333333333vw;
  font-weight: bold;
  text-align: left;
  padding-left: 10.6666666667vw;
}

.p6_faq {
  padding: 10.6666666667vw 0;
}
.p6_faq h2 {
  font-size: 6vw;
  font-weight: bold;
  color: #63c7fe;
  line-height: 1.2;
}
.p6_faq h2:after {
  content: "";
  display: block;
  width: 9.3333333333vw;
  height: 1.3333333333vw;
  background: #63c7fe;
  margin: 0.5em auto 1em;
}
.p6_faq .wrap {
  padding: 0 5.3333333333vw;
}
.p6_faq dl {
  text-align: left;
}
.p6_faq dt {
  background: #63c7fe;
  color: #fff;
  border-radius: 0.625vw;
  padding: 1em 12.5vw 1em 9.375vw;
  margin-bottom: 3.125vw;
  position: relative;
  cursor: pointer;
}
.p6_faq dt:before {
  content: "Q.";
  position: absolute;
  top: 1em;
  left: 4.6875vw;
}
.p6_faq dt:after {
  content: "";
  display: block;
  width: 2.1875vw;
  height: 2.1875vw;
  border-right: 0.3125vw solid #fff;
  border-bottom: 0.3125vw solid #fff;
  box-sizing: border-box;
  position: absolute;
  top: 48%;
  right: 4.6875vw;
  transform: translateY(-50%) rotate(45deg);
}
.p6_faq dt.open:after {
  top: 52%;
  transform: translateY(-50%) rotate(-135deg);
}
.p6_faq dd {
  padding: 0 1em 2em;
  font-size: 3.75vw;
}
.p6_faq dd p,
.p6_faq dd .note {
  margin-bottom: 4.6875vw;
}

.p6_msg {
  background: #e1fdfe;
  padding: 12vw 0;
}
.p6_msg .wrap {
  padding: 0 4vw;
}
.p6_msg .outer {
  background: #fff;
  padding: 6.6666666667vw 0;
  box-shadow: 0 0.5333333333vw 1.8666666667vw rgba(0, 0, 0, 0.25);
}
.p6_msg h2 {
  background: #63c7fe;
  color: #fff;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-size: 7.3333333333vw;
  font-weight: bold;
  line-height: 1.4;
  padding: 0.2em 0;
}
.p6_msg h2 span {
  display: block;
  font-size: 0.69em;
}
.p6_msg .inner {
  padding: 6.6666666667vw 1.3333333333vw 0;
}
.p6_msg .inner p {
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: bold;
}
.p6_msg .inner figure {
  max-width: 52.8vw;
  margin: 9.3333333333vw auto;
}
.p6_msg .inner .u_line {
  text-decoration: underline;
}
.p6_msg .btn_area p {
  font-family: "Hiragino Kaku Gothic Pro", Meiryo, "MS PGothic", sans-serif;
  font-weight: normal;
}

/*=======================================
	footer
=======================================*/
footer .sec1 {
  padding: 10.6666666667vw 0;
}
footer .sec1 .wrap {
  padding: 0 6.6666666667vw;
}
footer .sec1 ul {
  font-size: 2.4vw;
  line-height: 1.4;
  text-align: left;
}
footer .sec1 li {
  margin: 0 0 0.5em;
  padding-left: 1.3em;
  position: relative;
}
footer .sec1 li:before {
  content: "";
  display: block;
  width: 0.8em;
  height: 0.8em;
  background: #3c4747;
  border-radius: 50%;
  position: absolute;
  top: 0.35em;
  left: 0;
}
footer .sec2 {
  background: #63c6fd;
  color: #fff;
  padding: 13.3333333333vw 0 14.6666666667vw;
  font-size: 2.4vw;
}
footer .sec2 a {
  color: #fff;
}
footer .sec2 figure {
  max-width: 72vw;
  margin: 0 auto 5.3333333333vw;
}
footer .sec2 ul li {
  margin-top: 2em;
}

/*=======================================
	fixed_bnr
=======================================*/
footer .sec2 {
  padding-bottom: 21.3333333333vw;
}

.top-menu-sp {
  position: fixed;
  bottom: 0;
  z-index: 99998;
  width: 100%;
}

.top-menu-sp .nav-social {
  font-size: 0;
}

.top-menu-sp .nav-social .nav-item {
  display: inline-block;
  vertical-align: middle;
}

.top-menu-sp .nav-social .nav-item.link__contact {
  background-color: #32c332;
  width: 40%;
}

.top-menu-sp .nav-social .nav-item.link__reservation {
  background-image: linear-gradient(to right, #00b7ed, #53d3fa);
  width: 100%;
}

.top-menu-sp .nav-social .nav-item .nav-link {
  color: #fff;
  text-align: center;
  display: block;
  height: 60px;
  line-height: 60px;
  text-decoration: none;
  font-size: 4.2666666667vw;
}

.top-menu-sp .nav-social .nav-item .nav-link span:before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 6.9333333333vw;
  height: 6.9333333333vw;
  margin-right: 0.5em;
}

.top-menu-sp .nav-social .nav-item .nav-link span.forBook:before {
  background: url(../images/kirelign-icon-reservation.png) center no-repeat;
  background-size: contain;
}

/******************************************************************************************

	pc size

******************************************************************************************/
@media only screen and (min-width: 640px) {
  .sp_only,
  .sp_only_inline {
    display: none;
  }
  .pc_only {
    display: block;
  }
  .pc_only_inline {
    display: inline;
  }
  .wrap {
    max-width: 640px;
    padding: 0 17.0666px;
    /*	margin: 0 auto;*/
  }
  .contents {
    max-width: 640px;
    font-size: 22.18658px;
  }
  .note {
    font-size: 11.94662px;
  }
  .btn_area h3 {
    font-size: 25.5999px;
  }
  .btn_area h3:before, .btn_area h3:after {
    width: 2px;
  }
  .btn_area .btn + p {
    font-size: 17.0666px;
  }
  /*=======================================
  	p1
  =======================================*/
  .p1_mv .sec1 .wrap {
    padding-top: 17.0666px;
    padding-bottom: 17.0666px;
  }
  .p1_mv .sec2 {
    padding-top: 59.7331px;
  }
  .p1_mv .sec2 .wrap {
    bottom: 145.0661px;
  }
  .p1_mv .sec3 {
    margin-top: -85.333px;
  }
  .p1_worries .sec2 {
    margin-top: -136.5328px;
    padding-bottom: 85.333px;
  }
  .p1_worries .sec2 .wrap p {
    font-size: 27.30656px;
    margin: 25.5999px 0 42.6665px;
  }
  .p1_worries .sec2 .wrap figure {
    margin-bottom: 119.4662px;
  }
  .p1_worries .sec2 .box {
    padding: 17.0666px;
  }
  .p1_worries .sec2 .box figure {
    padding: 0 63.14642px;
    margin: -85.333px 0 0;
  }
  .p1_worries .sec2 .box p {
    margin: 42.6665px 0 25.5999px;
  }
  .p1_feature .sec1 {
    padding-bottom: 51.1998px;
  }
  .p1_feature .sec1 figure {
    padding: 0 8.5333px;
    margin-bottom: 46.07982px;
  }
  .p1_feature .sec1 figure.a {
    margin-top: -153.5994px;
  }
  /*=======================================
  	p2
  =======================================*/
  .p2_reason .sec1 {
    margin-bottom: 59.7331px;
  }
  .p2_reason .sec1 p {
    font-size: 32.42654px;
  }
  .p2_reason .sec1 .loop {
    margin: 59.7331px 0;
  }
  .p2_reason .sec1 .loop li {
    width: 2074px;
    margin-right: 26px;
  }
  .p2_reason .sec2 .h {
    margin-bottom: 46.07982px;
  }
  .p2_reason .sec2 .wrap {
    padding: 0 25.5999px;
  }
  .p2_reason .sec2 section {
    border-radius: 4.26665px;
    margin-bottom: 68.2664px;
  }
  .p2_reason .sec2 .head {
    padding: 25.5999px 0 25.5999px 153.5994px;
  }
  .p2_reason .sec2 .head:before {
    width: 135.67947px;
    height: 150.18608px;
    top: -12.79995px;
    left: 17.0666px;
  }
  .p2_reason .sec2 .head h3 {
    font-size: 46.07982px;
  }
  .p2_reason .sec2 .head p {
    font-size: 23.89324px;
  }
  .p2_reason .sec2 .inner {
    padding: 25.5999px 34.1332px;
  }
  .p2_reason .sec2 .num3 .head h3 {
    font-size: 40.95984px;
  }
  .p2_reason .sec2 .num3 .note {
    margin-bottom: 34.1332px;
  }
  .p2_reason .sec2 .num3 .btn_result {
    margin: 0 -17.0666px;
  }
  .p2_reason .sec2 .num3 .change_b p {
    font-size: 23.89324px;
  }
  .p2_price .sec2 .wrap {
    padding: 0 34.1332px;
  }
  .p2_price .sec2 .txt {
    padding: 34.1332px 0 17.0666px;
  }
  .p2_price .sec2 p {
    font-size: 27.30656px;
    margin-bottom: 30.71988px;
  }
  /*=======================================
  	p3
  =======================================*/
  .p3_merit .box {
    border: 8.5333px solid #e5f6ff;
    padding: 25.5999px;
  }
  .p3_merit p {
    font-size: 20.47992px;
  }
  .p3_merit .sec1 {
    margin-bottom: 76.7997px;
  }
  .p3_merit .sec1 .box {
    margin-top: -97.27962px;
  }
  .p3_merit .sec1 .l {
    font-size: 27.30656px;
  }
  .p3_merit .sec2 .h {
    margin-bottom: 25.5999px;
  }
  .p3_merit .sec2 section {
    margin-bottom: 30.71988px;
  }
  .p3_merit .sec2 h2 {
    max-width: 563.1978px;
    margin: 0 auto 25.5999px;
  }
  .p3_merit .sec2 .a figure {
    max-width: 440.31828px;
  }
  .p3_merit .sec2 .b {
    margin-bottom: 76.7997px;
  }
  .p3_merit .sec2 .b h2 {
    max-width: 383.9985px;
  }
  .p3_merit .sec2 .b figure {
    max-width: 354.98528px;
  }
  .p3_needs .sec2 {
    padding-bottom: 68.2664px;
  }
  .p3_needs .sec2 h2 span {
    font-size: 38.39985px;
    padding: 22.18658px 25.5999px;
  }
  .p3_needs .sec2 h2 span:after {
    border: 10.23996px solid transparent;
    border-top: 16.21327px solid #0148a8;
    bottom: -23.03991px;
  }
  .p3_needs .sec2 .txt {
    margin-bottom: 25.5999px;
  }
  .p3_needs .sec2 .txt p {
    font-size: 40.95984px;
  }
  .p3_needs .sec2 .txt .s {
    font-size: 27.30656px;
  }
  .p3_needs .sec2 figure {
    max-width: 554.6645px;
    margin: 0 auto 34.1332px;
    padding: 22.18658px;
  }
  .p3_needs .sec2 figure figcaption {
    font-size: 40.95984px;
    margin-top: 20.47992px;
  }
  .p3_needs .sec2 figure + p {
    font-size: 27.30656px;
  }
  .p3_needs .sec2 figure + p:after {
    width: 102.3996px;
    height: 46.07982px;
    margin: 11.94662px auto;
  }
  .p3_anxiety {
    padding: 76.7997px 0;
  }
  .p3_anxiety section {
    margin-bottom: 42.6665px;
  }
  .p3_anxiety h2 {
    font-size: 45.22649px;
    border-radius: 5.11998px 5.11998px 0 0;
    padding: 34.1332px 25.5999px;
  }
  .p3_anxiety h2 .s {
    font-size: 17.0666px;
  }
  .p3_anxiety .inner {
    border: 5.97331px solid #b7e4fd;
    padding: 34.1332px;
    border-radius: 0 0 5.11998px 5.11998px;
  }
  .p3_anxiety .inner p {
    font-size: 23.89324px;
  }
  .p3_anxiety .sec1 .b {
    max-width: 235.51908px;
  }
  /*=======================================
  	p4
  =======================================*/
  .p4_case {
    padding-bottom: 68.2664px;
  }
  .p4_case .title {
    padding: 34.1332px 0;
  }
  .p4_case .title p {
    border: 2px solid #3c4747;
    padding: 170.666px 51.1998px 34.1332px;
    font-size: 20.47992px;
    margin-top: -157.01272px;
  }
  .p4_case section {
    margin-bottom: 51.1998px;
  }
  .p4_case section .wrap {
    padding: 0 34.1332px;
  }
  .p4_case .h {
    border: 17.0666px solid #e5fdff;
    padding: 25.5999px 42.6665px;
    margin-bottom: 25.5999px;
  }
  .p4_case .h h2 {
    font-size: 25.5999px;
  }
  .p4_case .h p {
    font-size: 20.47992px;
  }
  .p4_case .slick-slide {
    border-radius: 6.82664px;
    padding: 30.71988px;
    margin: 0 10.23996px;
  }
  .p4_case .slick-slide > p {
    font-size: 20.47992px;
    border-radius: 8.5333px;
    margin-bottom: 30.71988px;
  }
  .p4_case .slick-dots {
    margin-top: 27.30656px;
  }
  .p4_case .slick-dots li {
    width: 11.94662px;
    height: 11.94662px;
    margin: 0 6.82664px;
  }
  .p4_case .slick-arrow {
    width: 44.37316px;
    height: 44.37316px;
    left: 13.65328px;
  }
  .p4_case .slick-arrow.next {
    left: auto;
    right: 13.65328px;
  }
  .p4_case .slick-arrow:after {
    width: 13.65328px;
    height: 13.65328px;
  }
  .p4_case .flex dl {
    font-size: 22.18658px;
  }
  .p4_case .flex dt, .p4_case .flex dd {
    margin-bottom: 1em;
  }
  .p4_case .flex dt {
    width: 136.5328px;
    font-size: 22.18658px;
  }
  .p4_case .flex dd {
    width: 295.25218px;
    font-size: 22.18658px;
  }
  .p4_case .flex dd span {
    font-size: 17.0666px;
  }
  .p4_case .flex ul {
    font-size: 20.47992px;
  }
  .p4_case .flex h4 {
    width: 136.5328px;
  }
  .p4_case .attention {
    max-width: 494.9314px;
    font-size: 15.35994px;
  }
  .p4_cta > figure {
    margin-top: -34.1332px;
  }
  .p4_cta .howto {
    padding: 42.6665px 0 51.1998px;
  }
  .p4_cta h2 span {
    font-size: 42.6665px;
    padding: 0 25.5999px;
  }
  .p4_cta .howto_detail {
    padding-bottom: 68.2664px;
  }
  .p4_cta .howto_detail .wrap.a {
    font-size: 27.30656px;
  }
  .p4_cta .howto_detail .wrap.a ul {
    padding-left: 102.3996px;
  }
  .p4_cta .howto_detail .btn_area {
    margin-bottom: 34.1332px;
  }
  .p4_cta .howto_detail .btn_area + .note {
    padding: 0 42.6665px;
  }
  .p4_dentition .sec1 {
    padding: 51.1998px 0 0;
  }
  .p4_dentition .sec1 .wrap {
    padding: 0 25.5999px;
  }
  .p4_dentition .sec1 .h {
    margin-bottom: 71.67972px;
  }
  .p4_dentition .sec1 .inner {
    border: 4.26665px solid #62c7ff;
    padding: 25.5999px;
    font-size: 23.89324px;
  }
  .p4_dentition .sec1 h2 {
    font-size: 32.42654px;
    padding: 51.1998px 0;
    margin-top: -107.51958px;
    margin-bottom: 34.1332px;
  }
  .p4_dentition .sec1 h2:before {
    top: 13.65328px;
    left: 13.65328px;
    bottom: 13.65328px;
    right: 13.65328px;
  }
  .p4_dentition .sec1 h2 em {
    font-size: 51.1998px;
    margin-top: 11.94662px;
  }
  .p4_dentition .sec1 figure {
    margin: 34.1332px 0 25.5999px;
  }
  .p4_dentition .sec1 .list li {
    margin: 0 6.82664px;
    border-radius: 42.6665px;
  }
  .p4_dentition .sec1 .box {
    border: 2px solid #0148a8;
    padding: 17.0666px;
    margin-top: 51.1998px;
  }
  .p4_dentition .sec1 .box h3 span {
    font-size: 27.30656px;
  }
  .p4_dentition .sec1 .box p {
    padding-left: 59.7331px;
  }
  .p4_dentition .sec1 .box p:before {
    width: 18.77326px;
    height: 18.77326px;
    border-left: 2px solid #3c4747;
    border-bottom: 2px solid #3c4747;
    left: 27.30656px;
  }
  .p4_dentition .sec2 {
    font-size: 20.47992px;
    padding: 42.6665px 0 68.2664px;
  }
  .p4_dentition .sec2 .u_line {
    border-bottom: 2px solid #3c4747;
  }
  .p4_dentition .sec2 .note {
    max-width: 529.0646px;
  }
  /*=======================================
  	p5
  =======================================*/
  .p5_commit {
    padding-bottom: 76.7997px;
  }
  .p5_commit section {
    padding: 34.1332px 25.5999px;
    margin-bottom: 34.1332px;
  }
  .p5_commit section .title .num {
    font-size: 170.666px;
  }
  .p5_commit section .title h2 {
    font-size: 46.07982px;
  }
  .p5_commit section .title p {
    font-size: 25.5999px;
  }
  .p5_commit section .title:after {
    width: 59.7331px;
    height: 8.5333px;
    margin: 34.1332px auto;
  }
  .p5_commit .sec1 .title + p {
    max-width: 477.8648px;
    margin: 0 auto 34.1332px;
  }
  .p5_commit .sec1 .flex {
    margin-bottom: 51.1998px;
  }
  .p5_commit .sec1 .flex figure {
    width: 213.3325px;
  }
  .p5_commit .sec1 .flex .txt {
    width: 358.3986px;
    padding: 25.5999px 20.47992px;
    margin-top: 51.1998px;
    margin-left: -29.01322px;
  }
  .p5_commit .sec1 .flex .txt:after {
    border-right: 2px solid #7f7f7f;
    border-bottom: 2px solid #7f7f7f;
    bottom: -11.94662px;
    right: -11.94662px;
  }
  .p5_commit .sec1 .flex h3 {
    font-size: 29.01322px;
  }
  .p5_commit .sec1 .flex p {
    font-size: 18.77326px;
  }
  .p5_commit .sec1 .flex:nth-child(even) .txt {
    margin-right: -29.01322px;
  }
  .p5_commit .sec1 .flex:nth-child(even) .txt:after {
    border-left: 2px solid #7f7f7f;
    left: -11.94662px;
  }
  .p5_commit .sec1 .flex + figure {
    margin: 85.333px 0 59.7331px;
  }
  .p5_commit .sec1 .flex + figure figcaption {
    font-size: 11.94662px;
  }
  .p5_clinic .sec1 {
    padding: 93.8663px 0 145.0661px;
  }
  .p5_clinic .sec1 .wrap {
    padding: 0 25.5999px;
  }
  .p5_clinic .sec1 .inner {
    padding: 42.6665px 0;
  }
  .p5_clinic .sec1 h2 {
    font-size: 46.93315px;
    padding: 25.5999px 0 20.47992px;
    margin-bottom: 34.1332px;
  }
  .p5_clinic .sec1 figure {
    max-width: 337.91868px;
  }
  .p5_clinic .sec2 {
    padding-bottom: 68.2664px;
  }
  .p5_clinic .sec2 h2 {
    font-size: 29.86655px;
    border-radius: 8.5333px;
    margin-top: -63.14642px;
    margin-bottom: 54.61312px;
  }
  .p5_clinic .sec2 h2 span:after {
    height: 8.5333px;
  }
  .p5_clinic .sec2 h2:after {
    border: 10.23996px solid transparent;
    border-top: 18.77326px solid #0148a8;
    bottom: -25.5999px;
  }
  .p5_clinic .sec2 .a {
    padding: 0 25.5999px;
    margin-bottom: 30.71988px;
  }
  .p5_clinic .sec2 .a + p {
    max-width: 494.9314px;
    font-size: 20.47992px;
  }
  .p5_clinic .sec2 .note {
    padding-right: 59.7331px;
  }
  .p5_clinic .sec2 .b {
    margin: 51.1998px 0 42.6665px;
    padding: 0 17.0666px;
  }
  .p5_clinic .sec2 .b figcaption {
    font-size: 11.94662px;
  }
  .p5_clinic .sec2 .box {
    max-width: 520.5313px;
    margin: 0 auto 42.6665px;
  }
  .p5_clinic .sec2 .box h3 {
    font-size: 20.47992px;
  }
  .p5_clinic .sec2 .box .inner {
    padding: 25.5999px 34.1332px;
  }
  .p5_clinic .sec2 .box h4:after {
    height: 2.55999px;
  }
  .p5_clinic .sec2 .box h4 span {
    font-size: 20.47992px;
  }
  .p5_clinic .sec2 .box p {
    font-size: 17.0666px;
  }
  .p5_flow {
    border-top: 8.5333px solid #0148a8;
    padding: 68.2664px 0;
  }
  .p5_flow h2 {
    font-size: 42.6665px;
  }
  .p5_flow h2:after {
    width: 59.7331px;
    height: 8.5333px;
  }
  .p5_flow h2 + p {
    font-size: 27.30656px;
    margin-bottom: 34.1332px;
  }
  .p5_flow .outer:after {
    width: 42.6665px;
  }
  .p5_flow section {
    max-width: 503.4647px;
    margin: 0 auto 93.8663px;
    border-radius: 6.82664px;
    box-shadow: 0 3.41332px 11.94662px rgba(0, 0, 0, 0.25);
  }
  .p5_flow section h3 {
    font-size: 34.1332px;
    border-radius: 6.82664px 6.82664px 0 0;
  }
  .p5_flow section h3 span:before {
    font-size: 28.15989px;
  }
  .p5_flow section .inner {
    padding: 34.1332px;
  }
  .p5_flow section p {
    font-size: 20.47992px;
  }
  .p5_flow .sec2 figure:after {
    width: 185.17261px;
    height: 108.37291px;
    top: -10.23996px;
    right: 22.18658px;
  }
  .p5_flow .sec3 figure:after {
    width: 218.45248px;
    height: 131.41282px;
    top: -17.91993px;
    right: -52.90646px;
  }
  .p5_flow .sec4 {
    margin-bottom: 51.1998px;
  }
  .p5_flow .btn_area {
    margin-bottom: 42.6665px;
  }
  .p5_flow .btn_area + .note {
    padding: 0 34.1332px;
  }
  /*=======================================
  	p6
  =======================================*/
  .p6_entrust .sec1 {
    margin-bottom: 42.6665px;
  }
  .p6_entrust .sec1 .note {
    margin-top: -76.7997px;
    padding: 0 34.1332px;
  }
  .p6_entrust .sec2 {
    padding-bottom: 42.6665px;
  }
  .p6_entrust .sec2 figure {
    margin-bottom: 68.2664px;
  }
  .p6_entrust .sec2 ul {
    font-size: 30.71988px;
    padding: 0 17.0666px;
    margin-bottom: 34.1332px;
  }
  .p6_entrust .sec2 li {
    padding-left: 42.6665px;
  }
  .p6_entrust .sec2 li span {
    font-size: 11.94662px;
  }
  .p6_entrust .sec2 li:before {
    width: 29.01322px;
    height: 29.01322px;
  }
  .p6_entrust .sec2 .wrap figure {
    max-width: 307.1988px;
  }
  .p6_think .sec1 .c {
    max-width: 503.4647px;
    margin: 68.2664px auto;
  }
  .p6_think .sec2 .wrap {
    padding: 0 25.5999px;
    padding-bottom: 76.7997px;
  }
  .p6_think .sec2 .outer {
    margin-top: -93.8663px;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
  }
  .p6_think .sec2 h2 {
    font-size: 46.93315px;
  }
  .p6_think .sec2 .inner {
    padding: 34.1332px;
  }
  .p6_think .sec2 .inner > p {
    font-size: 23.89324px;
  }
  .p6_think .sec2 .inner .btn_area {
    margin-bottom: 34.1332px;
  }
  .p6_think .sec2 ul.a {
    font-size: 23.89324px;
    padding-left: 68.2664px;
  }
  .p6_faq {
    padding: 68.2664px 0;
  }
  .p6_faq h2 {
    font-size: 38.39985px;
  }
  .p6_faq h2:after {
    width: 59.7331px;
    height: 8.5333px;
  }
  .p6_faq .wrap {
    padding: 0 34.1332px;
  }
  .p6_faq dt {
    border-radius: 3.41332px;
    padding: 1em 68.2664px 1em 51.1998px;
    margin-bottom: 17.0666px;
  }
  .p6_faq dt:before {
    left: 25.5999px;
  }
  .p6_faq dt:after {
    width: 11.94662px;
    height: 11.94662px;
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
    right: 25.5999px;
  }
  .p6_faq dd {
    font-size: 20.47992px;
  }
  .p6_faq dd p,
  .p6_faq dd .note {
    margin-bottom: 25.5999px;
  }
  .p6_msg {
    padding: 76.7997px 0;
  }
  .p6_msg .wrap {
    padding: 0 25.5999px;
  }
  .p6_msg .outer {
    padding: 42.6665px 0;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
  }
  .p6_msg h2 {
    font-size: 46.93315px;
  }
  .p6_msg .inner {
    padding: 42.6665px 8.5333px 0;
  }
  .p6_msg .inner figure {
    max-width: 337.91868px;
    margin: 59.7331px auto;
  }
  /*=======================================
  	footer
  =======================================*/
  footer .sec1 {
    padding: 68.2664px 0;
  }
  footer .sec1 .wrap {
    padding: 0 42.6665px;
  }
  footer .sec1 ul {
    font-size: 15.35994px;
  }
  footer .sec2 {
    padding: 85.333px 0 93.8663px;
    font-size: 15.35994px;
  }
  footer .sec2 figure {
    max-width: 460.7982px;
    margin: 0 auto 34.1332px;
  }
  /*=======================================
  	fixed_bnr
  =======================================*/
  .top-menu {
    width: 100%;
  }
  .top-menu-sp .nav-social {
    font-size: 0;
  }
  .top-menu-sp .nav-social .nav-item {
    display: inline-block;
    vertical-align: middle;
  }
  .top-menu-sp .nav-social .nav-item.link__contact {
    background-color: #32c332;
    width: 40%;
  }
  .top-menu-sp .nav-social .nav-item.link__reservation {
    background-image: linear-gradient(to right, #00b7ed, #53d3fa);
    width: 100%;
  }
  .top-menu-sp .nav-social .nav-item .nav-link {
    color: #fff;
    text-align: center;
    display: block;
    height: 60px;
    line-height: 60px;
    text-decoration: none;
    font-size: 20px;
  }
  .top-menu-sp .nav-social .nav-item .nav-link span:before {
    content: "";
    display: inline-block;
    vertical-align: middle;
    width: 30px;
    height: 30px;
    margin-right: 0.5em;
  }
  .top-menu-sp .nav-social .nav-item .nav-link span.forBook:before {
    background: url(../images/kirelign-icon-reservation.png) center no-repeat;
    background-size: contain;
  }
}/*# sourceMappingURL=style.css.map */