@charset "utf-8";
/* CSS Document */
@import url(//fonts.googleapis.com/css?family=Ubuntu:700);
@import url(//fonts.googleapis.com/earlyaccess/notosansjapanese.css);
@import url(//fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,400;0,600;1,600&display=swap);
@font-face {
  font-family: Yu Gothic;
  src: local("Yu Gothic Medium");
  font-weight: 400;
}
@font-face {
  font-family: Yu Gothic;
  src: local("Yu Gothic Bold");
  font-weight: 700;
}
*, ::before, ::after {
  box-sizing: border-box;
}
html {
  font-size: 62.5%;
}
body {
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  font-style: normal;
  font-weight: normal;
  font-size: 1.2rem;
  color: #333;
  -webkit-text-size-adjust: none;
  -webkit-font-smoothing: antialiased;
  z-index: 0;
  font-feature-settings: "pkna"1;
  overflow-x: hidden;

}
a {
  text-decoration: none;
}
h1, h2, h3, h4, h5, h6 {
  margin-bottom: 0;
  font-weight: 400;
  font-size: inherit;
  font-feature-settings: "palt";
  line-height: 1.65;
}
p {
  margin-bottom: 0;
}
pre {
  margin-bottom: 0;
}
dl {
  margin-bottom: 0;
}
ul {
  margin-bottom: 0;
}
ol {
  margin-bottom: 0;
  list-style: decimal;
  padding-left: 1em;
}

/*-----------------------------------------------------------------*/
#header {
  height: 80px;
  top: 0;
  left: 0;
  width: 100%;
  box-sizing: border-box;
  z-index: 999;
  white-space: nowrap;
}
#header.scroll {
  position: fixed;
  background: rgba(255, 255, 255, 0.8);
  animation-name: anime;
  animation-duration: 0.3s;
  height: 70px;
}
@keyframes anime {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
header .inner {
  position: relative;
  display: flex;
  align-items: center;
  height: 100%;
  justify-content: space-between;
  max-width: 1300px;
  margin: 0 auto;
}
.left {
  display: flex;
  justify-content: space-around;
  align-items: center;
}
.logo img {
  max-width: 100%;
  height: 54px;
  padding-right: 1.6rem;
}
.h_txt {
  font-size: 1.6rem;
  color: #00A0E9;
  line-height: 1.4;
  padding: 0 1.8rem;
}
.right {
  display: flex;
  justify-content: space-around;
  align-items: center;
}
.re_btn {
  padding: 0 2rem;
  text-align: center;
}
.re_btn a {
  color: #FFFFFF;
  transition: 1.0s;
  height: 50px;
  width: 170px;
  background: #0051A3;
  font-size: 1.6rem;
  display: grid;
  align-items: center;
}
.re_btn a:hover {
  opacity: 0.5;
}
.h_tel {
  font-size: 2.4rem;
  font-weight: 400;
  letter-spacing: 0.2rem;
  position: relative;
  padding-left: 3.5rem;
}
.h_tel::after {
  content: "";
  background: url("../image/tel_icon.svg")no-repeat center center;
  width: 35px;
  height: 35px;
  position: absolute;
  top: 0;
  left: 0;
}
.h_tel a {
  color: #007AC5;
}
#mainimg {
  width: 100%;
  position: relative;
}
#mainimg img {
  max-width: 100%;
  object-fit: cover;
  height: 46vw;
}
.main_catch {
  position: absolute;
  top: 19.8%;
  left: 58.8%;
  max-width: 100%;
}
.main_catch img {
  height: 100% !important;
}
.container {
  max-width: 1300px;
  margin: 0 auto;
  padding: 5rem 0;
  position: relative;
}
.ttl01 {
  text-align: center;
  font-size: 5rem;
  padding: 1rem 0;
}
.bg01 {
  background: url("../image/bg01.jpg")no-repeat center;
  background-size: cover;
}
.flex_box {
  display: flex;
  justify-content: space-around;
  align-items: center;
  flex-direction: row;
}
.flex_box ul {
  padding: 3rem;
}
.flex_box li {
  list-style: none;
  font-size: 2rem;
  text-align: left;
  line-height: 2.6;
  position: relative;
  padding-left: 3.4rem;
}
.flex_box li::after {
  content: "";
  background: url("../image/Icon feather-check-square.png") no-repeat center;
  background-size: cover;
  position: absolute;
  width: 20px;
  height: 20px;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
.flex_box_l {
  width: 60%;
  padding: 0 3rem;
}
.triangle {
  display: block;
  text-align: center;
  margin: 0 auto;
  padding-bottom: 3rem;
	width: 10%;
}
.txt02 {
  font-size: 2rem;
  color: #007AC5;
  text-align: center;
  font-weight: 600;
}
.txt03 {
  font-size: 4rem;
  text-align: center;
  color: #007AC5;
  font-weight: 600;
}
.mouthpiece_bg {
  background: url("../image/img_teeth.png")no-repeat 24% top;
  background-size: contain;
  height: 200px;
}
.bg_b {
  background: #DFF5FF;
  padding: 5rem 0;
}
.bg_b2 {
  background: #DFF5FF;
  margin: 5rem 0 10rem 0;
}
.bg_f {
  background: #DFF5FF;
  margin: 5rem 0 0 0;
}
.ttl_eng_w {
  font-size: 8rem;
  font-weight: 600;
  font-family: "MV Boli", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  color: #FFFFFF;
  max-width: 1300px;
  margin: 0 auto;
  position: relative;
  border-bottom: solid #FFFFFF 3px;
}
.ttl_eng_w span {
  display: flex;
  align-items: flex-end;
  line-height: 1.3;
}
.ttl_eng_b {
  font-size: 8rem;
  font-weight: 600;
  font-family: "MV Boli", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  color: #DFF5FF;
  max-width: 1300px;
  margin: 0 auto;
  position: relative;
  border-bottom: solid #DFF5FF 3px;
  padding-top: 8rem;
}
.ttl_eng_b span {
  display: flex;
  align-items: flex-end;
  line-height: 1.3;
}
.h3_ttl01 {
  font-size: 3.8rem;
  font-weight: 600;
  letter-spacing: 1rem;
  align-items: flex-end;
  display: flex;
  max-width: 1300px;
  margin: 0 auto;
  padding-bottom: 3rem;
}
.flex_box_inv {
  display: flex;
  justify-content: space-around;
  margin-bottom: 5rem;
}
.flex_img_area {
  max-width: 42%;
  display: flex;
  justify-content: center;
  position: relative;
  flex-flow: column;
  z-index: 1;
}
.flex_img_area::after {
  background: #007AC5;
  content: "";
  display: block;
  width: 223px;
  height: 268px;
  position: absolute;
  left: -4rem;
  bottom: 3rem;
  z-index: -1;
}
.flex_txt_area {
  padding: 10rem 1rem 14rem 10%;
  font-size: 1.8rem;
  position: relative;
  z-index: 0;
  line-height: 2.4;
}
.flex_txt_area::after {
  content: "";
  display: block;
  width: calc(100% + 169px);
  height: 100%;
  background-color: #fff;
  position: absolute;
  top: 0;
  right: -8rem;
  z-index: -1;
}
.flex_txt_area .box_ttl {
  font-size: 2.8rem;
  font-weight: 600;
  margin-bottom: 2rem;
  line-height: 1.8;
}
.flex_box_inv02 {
  display: flex;
  justify-content: space-around;
}
.flex_img_area02 {
  max-width: 42%;
  display: flex;
  justify-content: center;
  position: relative;
  flex-flow: column;
  z-index: 1;
}
.flex_img_area02::after {
  background: #007AC5;
  content: "";
  display: block;
  width: 223px;
  height: 268px;
  position: absolute;
  right: -4rem;
  bottom: 6rem;
  z-index: -1;
}
.flex_txt_area02 {
  padding: 10rem 10% 14rem 1rem;
  font-size: 1.8rem;
  position: relative;
  z-index: 0;
  line-height: 2.4;
}
.flex_txt_area02::after {
  content: "";
  display: block;
  width: calc(100% + 460px);
  height: 100%;
  background-color: #fff;
  position: absolute;
  top: 0;
  right: -24rem;
  z-index: -1;
}
.flex_txt_area02 .box_ttl {
  font-size: 2.8rem;
  font-weight: 600;
  margin-bottom: 2rem;
  line-height: 1.8;
}
.h3_ttl02 {
  font-size: 3.8rem;
  text-align: center;
  position: relative;
  width: 50%;
  margin: 3rem auto 10rem auto;
}
.h3_ttl02::before {
  content: "||";
  color: #00A0E9;
  transform: rotate(-20deg);
  position: absolute;
  top: 0;
  left: 0;
}
.h3_ttl02::after {
  content: "||";
  color: #00A0E9;
  transform: rotate(20deg);
  position: absolute;
  top: 0;
  right: 0;
}
.flex_box_reason {
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
}
.reason_box {
  margin-bottom: 3rem;
  max-width: 33.333333%;
}
.reason_box_img {
  margin-bottom: 2rem;
}
.reason_box_img img {
  display: block;
  margin: 0 auto 2rem auto;
}
.reason_box_ttl {
  font-size: 2.8rem;
  font-weight: 600;
  margin-bottom: 2rem;
  text-align: center;
}
.reason_box_txt {
  padding: 0 2rem;
  font-size: 1.8rem;
}
.flex_box_feature {
  display: flex;
  padding-bottom: 10rem;
}
.l_box_feature01 {
  position: relative;
  display: flex;
}
.feature_ttl_en {
  font-family: "MV Boli", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  font-size: 10.8rem;
  color: #007AC5;
  transform: translateY(-10rem);
  margin-bottom: -10rem;
}
.feature_ttl_en span {
  font-size: 1.6rem;
  font-family: "MV Boli", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  color: #80D1F6;
  padding-left: 3rem;
}
.feature_ttl {
  font-size: 2.8rem;
  font-weight: 600;
  padding-bottom: 3rem;
}
.r_box_feature01 {
  padding: 0rem 8rem;
  background: #fff;
  transform: translateY(6rem);
}
.feature_txt {
  font-size: 1.8rem;
  line-height: 2.4;
}
.l_box_feature02 {
  padding: 0rem 8rem;
  background: #fff;
  transform: translateY(6rem);
}
.r_box_feature02 {
  position: relative;
  display: flex;
}
.epos {
  padding: 3rem 0;
}
.epos a:hover {
  opacity: 0.5;
}
.info_bg {
  max-width: 1920px;
  position: relative;
}
.info_bg img {
  max-width: 100%;
  height: auto;
  padding: 10rem 0;
}
.info_txt {
  position: absolute;
  top: 25%;
  right: 24%;
  text-align: center;
  font-size: 3.2rem;
  font-weight: 600;
}
.info_btn {
  margin: 2rem 0;
}
.info_btn a {
  padding: 2rem;
  background: #0051A3;
  color: #FFFFFF;
}
.info_btn a:hover {
  opacity: 0.5;
}
.flex_box_flow {
  display: flex;
  position: relative;
  margin-bottom: 10rem;
}
.flex_box_flow:last-child {
  display: flex;
  position: relative;
  margin-bottom: 0rem;
}
.flow_ttl_en {
  font-size: 10rem;
  font-family: "MV Boli", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  font-weight: 600;
  color: #0051A3;
  transform: translateY(-8rem);
  margin-bottom: -8rem;
}
.flow_ttl_en span {
  font-size: 2rem;
  color: #80D1F6;
  padding-left: 3rem;
}
.flex_txt_flow {
  background-color: #FFFFFF;
  padding: 0 8rem;
}
.flow_ttl {
  font-size: 2.8rem;
  font-weight: 600;
  margin-bottom: 2rem;
}
.flow_txt {
  font-size: 1.8rem
}
.flex_box_case {
  display: flex;
  justify-content: space-around;
  align-items: center;
}
.case_ttl {
  font-family: "MV Boli", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  font-size: 10rem;
  font-weight: 600;
  transform: translateY(-12rem);
  margin-bottom: -8rem;
  color: #00A0E9;
}
.case_tab {
  padding: 5rem;
  font-size: 1.8rem;
}
.case_tab table {
  width: 100%;
  height: 100%;
  border: 1px #000000;
  border-collapse: collapse;
}
.case_tab td {
  border: 3px #dff5ff solid;
  background-color: #fff;
  padding: 2rem 1rem;
}
.case_tab th {
  border: 3px #fff solid;
  background-color: #1D74D9;
  padding: 2rem 4rem;
  color: #FFFFFF;
}
.flex_cost
{
	display: flex;
	margin-bottom: 10rem;
}
.cost_box_img
{
	
}
.cost_box_txt
{
	background: #FFFFFF;
	padding: 3rem;
	transform: translateY(5rem);
}
.cost_ttl
{
	font-size: 3.2rem;
	font-weight: 600;
	margin: 3rem 0;
}
.cost_txt
{
	font-size: 1.8rem;
}
.pay
{
	background: #FFFFFF;
	padding: 5rem 2rem;
}
.pay_ttl
{
	font-size: 2.8rem;
	text-align: center;
}
.pay_box
{
	display: flex;
	justify-content: space-around;
	align-items: center;
	flex-wrap: wrap;
}
.pay_txt
{
	padding: 2rem 5rem;
	border: solid 1px #0051A3;
	font-size: 1.8rem;
	color: #0051A3;
}
.flex_clinic
{
	display: flex;
	justify-content: space-around;
}
.clinic_img img
{
	max-width: 100%;
}
.flex_clinic2
{
	display: flex;
	justify-content: space-between;
	padding: 5rem 0;
}
.f_logo
{
	padding: 2rem 0 ;
}

.clinic_info
{
	width: 45%;
}
/*==================================================================

  診療時間

==================================================================*/

.time table {
  width: 100%;
  border-spacing: 0;
  border-collapse: collapse;
  border-top: 1px solid #555;
  border-bottom: 1px solid #555;
  color: #555;
margin: 5rem 5rem 0 0;
}
@media print, screen and (min-width: 641px) {
  .time table {/* pc only */
    font-size: 1.6rem;
  }
}
.time table tr:first-child td,
.time table tr:first-child th {
  padding-top: 3rem;
}
@media only screen and (max-width: 640px) {
  .time table tr:first-child td,
  .time table tr:first-child th {/* sp */
    padding-top: 2rem;
  }
}
.time table tr:first-child th:first-child {
  letter-spacing: 0.2em;
}
.time table tr:last-child td,
.time table tr:last-child th {
  padding-bottom: 3rem;
}
@media only screen and (max-width: 640px) {
  .time table tr:last-child td,
  .time table tr:last-child th {/* sp */
    padding-bottom: 2rem;
  }
}
.time table tr:not(:first-child) th {
  
  font-weight: 400;
  font-size: 1.8rem;
}
@media only screen and (max-width: 640px) {
  .time table tr:not(:first-child) th {/* sp */
    font-size: 1.7rem;
  }
}
.time table tr:not(:first-child) td {
  color: #0051A3;
}
@media only screen and (max-width: 640px) {
  .time table tr:not(:first-child) td {/* sp */
    font-family: source-han-serif-japanese, serif;
    font-weight: 400;
  }
}
.time table td,
.time table th {
  vertical-align: middle;
  padding-top: 20px;
  padding-bottom: 1rem;
  text-align: center;
}
@media only screen and (max-width: 640px) {
  .time table td,
  .time table th {/* sp */
    padding-top: 10px;
    padding-bottom: 10px;
  }
}
.time table th {
  width: 30%;
  line-height: 1.2;
}
@media only screen and (max-width: 640px) {
  .time table th span {/* sp */
    display: block;
  }
}
.time table th span::after {
  content: "";
  width: 7px;
  height: 8px;
  background-color: #c8c8c8;
  -webkit-clip-path: polygon(0 0, 100% 50%, 0 100%);
          clip-path: polygon(0 0, 100% 50%, 0 100%);
  margin-left: 12px;
  margin-right: 12px;
}
@media print, screen and (min-width: 641px) {
  .time table th span::after {/* pc only */
    display: inline-block;
    vertical-align: middle;
  }
}
@media only screen and (max-width: 640px) {
  .time table th span::after {/* sp */
    display: block;
    width: 8px;
    height: 6px;
    -webkit-clip-path: polygon(0 0, 100% 0, 50% 100%);
            clip-path: polygon(0 0, 100% 0, 50% 100%);
    margin-left: auto;
    margin-right: auto;
    margin-top: 5px;
    margin-bottom: 5px;
  }
}
.time table td {
  width: 10%;
  line-height: 1;
}

.time_note {
  margin-top: 30px;
  color: #c26262;
  text-align: right;
  font-weight: bold;
}
@media only screen and (max-width: 640px) {
  .time_note {/* sp */
    margin-top: 20px;
  }
}

.clinic_map iframe {
  width: 100%;
  aspect-ratio: 4/3; 
}
.clinic_map
{
	width: 45%;
}
.copy
{
	background: #0051A3;
	color: #FFFFFF;
	text-align: center;
	padding: 1rem;
}


@media only screen and (min-width: 641px) {
	.h_tel_sp {
display: none;
}
}

/*------------------------------------
sp
--------------------------------------*/

@media only screen and (max-width: 640px) {
	img
	{
		max-width: 100%;
		width: 100%;
	}
	.logo img {
  max-width: 100%;
  height: 26px;
  padding-right: 0.6rem;
}
		.h_txt {
  font-size: 1rem;
  color: #00A0E9;
  line-height: 1.4;
  padding: 0 0.8rem;
}
		.h_tel {
display: none;
}
		.h_tel_sp {
display: block;
}
	
	.re_btn a {
  color: #FFFFFF;
  transition: 1.0s;
  height: 4rem;
  width: 11rem;
  background: #0051A3;
  font-size: 1.0rem;
  display: grid;
  align-items: center;
}
	.re_btn {
  padding: 0 1rem;
  text-align: center;
}
	.h_tel {
display: none;
}
	
	.container {
  max-width: 390px;
  margin: 0 auto;
  padding: 2rem 0;
  position: relative;
}
	
	.bg01 {
  background: url("../image/bg01.jpg")no-repeat center bottom;
  background-size: contain;
}
	.ttl01 {
  text-align: center;
  font-size: 2rem;
  padding: 1rem 0;
}
	.flex_box {
  display: flex;
  justify-content: space-around;
  align-items: center;
flex-flow: column;
}
	.flex_box_l {
  width: 100%;
  padding: 0 2rem;
}
	.flex_box ul {
  padding: 1rem;
}
	.txt03 {
  font-size: 2rem;
  text-align: center;
  color: #007AC5;
  font-weight: 600;
}
	.mouthpiece_bg {
  background: url("../image/img_teeth.png")no-repeat 24% top;
  background-size: contain;
  height: 100px;
}
.flex_box li {
  list-style: none;
  font-size: 1.4rem;
  text-align: left;
  line-height: 2.6;
  position: relative;
  padding-left: 2.4rem;
}
	
	.bg_b {
  background: #DFF5FF;
  padding: 2rem 0;
}
	.ttl_eng_w {
  font-size: 3rem;
  font-weight: 600;
  font-family: "MV Boli", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  color: #FFFFFF;
  max-width: 1300px;
  margin: 0 auto;
  position: relative;
  border-bottom: solid #FFFFFF 3px;
}
	.h3_ttl01 {
  font-size: 1.8rem;
  font-weight: 600;
  letter-spacing: 1rem;
  align-items: flex-end;
  display: flex;
  max-width: 1300px;
  margin: 0 auto;
  padding-bottom: 3rem;
}
	.flex_box_inv {
  display: flex;
  justify-content: space-around;
  margin-bottom: 5rem;
  flex-flow: column;
}
	.flex_img_area {
  max-width: 100%;
  display: flex;
  justify-content: center;
  position: relative;
  flex-flow: column;
  z-index: 1;
}
	.flex_txt_area {
  padding: 4rem 1rem 6rem 2rem;
  font-size: 1.6rem;
  position: relative;
  z-index: 0;
  line-height: 2.4;
}
	.flex_box_inv02 {
  display: flex;
  justify-content: space-around;
  flex-flow: column;
}
	.flex_txt_area02 {
  padding: 4rem 1rem 6rem 1rem;
  font-size: 1.6rem;
  position: relative;
  z-index: 0;
  line-height: 2.4;
}

	.flex_img_area02 {
  max-width: 100%;
  display: flex;
  justify-content: center;
  position: relative;
  flex-flow: column;
  z-index: 1;
}
	.flex_txt_area::after {

    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background-color: #fff;
    position: absolute;
    top: 0;
    right: 0rem;
    z-index: -1;

}
	.flex_img_area02::after {

    background: #007AC5;
    content: "";
    display: block;
    width: 223px;
    height: 268px;
    position: absolute;
    right: 0rem;
    bottom: 2rem;
    z-index: -1;

}
	.flex_txt_area02::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: #fff;
  position: absolute;
  top: 0;
  right: 0rem;
  z-index: -1;
}
	
.h3_ttl02 {
  font-size: 2.0rem;
  text-align: center;
  position: relative;
  width: 80%;
  margin: 3rem auto 4rem auto;
}
	.flex_box_reason {
  display: flex;
  justify-content: space-around;
  flex-flow: column;
}
	.reason_box {
  margin-bottom: 1rem;
  max-width: 100%;
}
	.reason_box_ttl {
  font-size: 1.8rem;
  font-weight: 600;
  margin-bottom: 1rem;
  text-align: center;
}
	.reason_box_txt {
  padding: 0 2rem;
  font-size: 1.6rem;
}
	.l_box_feature01 {
  position: relative;
  display: flex;
  flex-flow: column;
}
	.flex_box_feature {
  display: flex;
  padding-bottom: 5rem;
  flex-flow: column;
}
	.r_box_feature01 {
  padding: 0rem 2rem;
  background: #fff;
  transform: translateY(0rem);
}
.feature_ttl_en {
  font-family: "MV Boli", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  font-size: 4.8rem;
  color: #007AC5;
  transform: translateY(0rem);
  margin-bottom: 0rem;
}
	.feature_ttl {
  font-size: 2rem;
  font-weight: 600;
  padding-bottom: 2rem;
}
	.feature_txt {
  font-size: 1.6rem;
  line-height: 2.4;
		margin-bottom: 6rem;
}
	.l_box_feature02 {
  padding: 0rem 2rem;
  background: #fff;
  transform: translateY(6rem);
}
	.r_box_feature02 {
  position: relative;
  display: flex;
  flex-flow: column;
}
	.info_bg img {
  max-width: 100%;
  height: auto;
  padding: 4rem 0;
}
.info_txt {
  position: absolute;
  top: 20%;
  right: 17%;
  text-align: center;
  font-size: 1.2rem;
  font-weight: 600;
}
	.info_btn a {
  padding: 1rem;
  background: #0051A3;
  color: #FFFFFF;
}

	.flex_box_flow {
  display: flex;
  position: relative;
  margin-bottom: 4rem;
  flex-flow: column;
}
	.flex_txt_flow {
  background-color: #FFFFFF;
  padding: 0 2rem;
}
	.flow_ttl_en {
  font-size: 4rem;
  font-family: "MV Boli", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  font-weight: 600;
  color: #0051A3;
  transform: translateY(0rem);
  margin-bottom: 0rem;
}
	.flow_ttl_en span {
  font-size: 1.4rem;
  color: #80D1F6;
  padding-left: 3rem;
}
	.flow_ttl {
  font-size: 1.8rem;
  font-weight: 600;
  margin-bottom: 1rem;
}
	.flow_txt {
  font-size: 1.6rem;
  padding-bottom: 2rem;
}
.flex_img_flow img {
  width: 100%;
}
	.ttl_eng_b {
  font-size: 3rem;
  font-weight: 600;
  font-family: "MV Boli", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  color: #DFF5FF;
  max-width: 1300px;
  margin: 0 auto;
  position: relative;
  border-bottom: solid #DFF5FF 3px;
  padding-top: 4rem;
}
	.case_ttl {
  font-family: "MV Boli", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  font-size: 3rem;
  font-weight: 600;
  transform: translateY(0rem);
  margin-bottom: 0rem;
  color: #00A0E9;
}
	.case_be {
  padding: 1rem;
}
	.case_af {
  padding: 1rem;
}
	.bg_b2 {
  background: #DFF5FF;
  margin: 1rem 0 10rem 0;
}
	.case_tab {
  padding: 1rem;
  font-size: 1.4rem;
}
	.case_tab th {
  border: 3px #fff solid;
  background-color: #1D74D9;
  padding: 1rem 2rem;
  color: #FFFFFF;
}
	.flex_cost {
  display: flex;
  margin-bottom: 4rem;
  flex-flow: column;
}
	.cost_box_txt {
  background: #FFFFFF;
  padding: 2rem;
  transform: translateY(0rem);
}
	.cost_ttl {
  font-size: 2.4rem;
  font-weight: 600;
  margin: 1rem 0;
}
	.cost_txt {
  font-size: 1.4rem;
}
	.pay_ttl {
  font-size: 1.8rem;
  text-align: center;
  padding-bottom: 2rem;
}
	.pay_txt {
  padding: 1rem 4rem;
  border: solid 1px #0051A3;
  font-size: 1.4rem;
  color: #0051A3;
  margin: 1rem;
}
	.bg_f {
  background: #DFF5FF;
  margin: 0rem 0 0 0;
}
	.flex_clinic2 {
  display: flex;
  justify-content: space-between;
  padding: 5rem 0;
  flex-flow: column;
}
	.clinic_info {
  width: 100%;
		padding: 0 2rem;
}
	.f_logo {
  padding: 2rem 2rem;
}
	.clinic_map {
  width: 100%;
}
}

/*----------------------------
pad
-----------------------------*/
@media only screen and (min-width: 641px) and (max-width: 845px) {
	.ttl01 {
  text-align: center;
  font-size: 3rem;
  padding: 1rem 0;
}
	.txt03 {
  font-size: 3rem;
  text-align: center;
  color: #007AC5;
  font-weight: 600;
}
	.mouthpiece_bg {
  background: url("../image/img_teeth.png")no-repeat 24% top;
  background-size: contain;
  height: 130px;
}
	.ttl_eng_w {
  font-size: 6rem;
  font-weight: 600;
  font-family: "MV Boli", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  color: #FFFFFF;
  max-width: 1300px;
  margin: 0 auto;
  position: relative;
  border-bottom: solid #FFFFFF 3px;
}
	.h3_ttl01 {
  font-size: 2.8rem;
  font-weight: 600;
  letter-spacing: 1rem;
  align-items: flex-end;
  display: flex;
  max-width: 1300px;
  margin: 0 auto;
  padding-bottom: 1rem;
}
.flex_img_area::after {
  background: #007AC5;
  content: "";
  display: block;
  width: 223px;
  height: 100px;
  position: absolute;
  left: 0rem;
  bottom: 8rem;
  z-index: -1;
}
	.flex_txt_area {
  padding: 6rem 1rem 6rem 6%;
  font-size: 1.8rem;
  position: relative;
  z-index: 0;
  line-height: 2.4;
}
	.flex_txt_area::after {
  content: "";
  display: block;
  width: calc(100% + 169px);
  height: 100%;
  background-color: #fff;
  position: absolute;
  top: 0;
  right: 0rem;
  z-index: -1;
}
	.flex_txt_area02 {
  padding: 6rem 6% 6rem 1rem;
  font-size: 1.8rem;
  position: relative;
  z-index: 0;
  line-height: 2.4;
}
	.flex_img_area02::after {

    background: #007AC5;
    content: "";
    display: block;
    width: 223px;
    height: 100px;
    position: absolute;
    right: 0rem;
    bottom: 12rem;
    z-index: -1;

}
	.h3_ttl02 {
  font-size: 2.8rem;
  text-align: center;
  position: relative;
  width: 50%;
  margin: 2rem auto 6rem auto;
}
	.reason_box_ttl {
  font-size: 2rem;
  font-weight: 600;
  margin-bottom: 2rem;
  text-align: center;
}
	.reason_box {
  margin-bottom: 3rem;
  max-width: 50%;
}
	.flex_box_feature {
  display: flex;
  padding-bottom: 10rem;
  flex-flow: column;
}
	.l_box_feature01 {
  position: relative;
  display: flex;
  flex-flow: column;
}
	.r_box_feature01 {
  padding: 2rem 4rem;
  background: #fff;
  transform: translateY(0rem);
  margin-bottom: -8rem;
}
	.l_box_feature02 {
  padding: 0rem 4rem;
  background: #fff;
  transform: translateY(6rem);
}
	.r_box_feature02 {
  position: relative;
  display: flex;
  flex-flow: column;
}
	
	.l_box_feature02 {
  padding: 0rem 4rem;
  background: #fff;
  transform: translateY(6rem);
  margin-bottom: 6rem;
}
	.flex_box_feature:last-child {
  display: flex;
  padding-bottom: 2rem;
  flex-flow: column;
}
	.info_txt {
  position: absolute;
  top: 24%;
  right: 17%;
  text-align: center;
  font-size: 2.4rem;
  font-weight: 600;
}
	.info_bg img {
  max-width: 100%;
  height: auto;
  padding: 6rem 0;
}
	.flex_box_flow {
  display: flex;
  position: relative;
  margin-bottom: 10rem;
  flex-flow: column;
}
	.flex_txt_flow {
  background-color: #FFFFFF;
  padding: 0 4rem;
}
	
	.flex_img_flow img
	{
		max-width: 100%;
		width: 100%;
	}
	.ttl_eng_b {
  font-size: 6rem;
  font-weight: 600;
  font-family: "MV Boli", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  color: #DFF5FF;
  max-width: 1300px;
  margin: 0 auto;
  position: relative;
  border-bottom: solid #DFF5FF 3px;
  padding-top: 8rem;
}
	.case_ttl {
  font-family: "MV Boli", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  font-size: 8rem;
  font-weight: 600;
  transform: translateY(-12rem);
  margin-bottom: -8rem;
  color: #00A0E9;
}
	
	.flex_box_case img
	{
		width: 100%;
		max-width: 100%;
	}
	.case_be {
  padding: 0 2rem;
}
	.case_af {
  padding: 0 2rem;
}
	.case_tab {
  padding: 3rem;
  font-size: 1.6rem;
}
	.case_tab th {
  border: 3px #fff solid;
  background-color: #1D74D9;
  padding: 2rem 3rem;
  color: #FFFFFF;
		width: 30%;
}
	.flex_cost {
  display: flex;
  margin-bottom: 10rem;
  flex-flow: column;
}
	.cost_box_img img
	{
		width: 100%;
		max-width: 100%;
	}
	.cost_box_txt {
  background: #FFFFFF;
  padding: 3rem;
  transform: translateY(0rem);
}
	.pay_txt {
  padding: 2rem 5rem;
  border: solid 1px #0051A3;
  font-size: 1.8rem;
  color: #0051A3;
  margin: 2rem;
}
}
