/* CSS Document */


html,body{
	height:100%;width: 100%;
	padding: 0;
	margin: 0;
	font-size: 100%;
	line-height: 1.5;
	color:#333;
	position:relative;
	letter-spacing:1.5px;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
	font-style: normal;
}

/* 共通--------------------------- */

.min,h2,h3,h4{ font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif"; font-weight: 100; }
.noto{font-family: "Noto Sans JP", sans-serif;}
.font_tenor{ font-family: "Tenor Sans", sans-serif;}

h2.basic_h2{ position:relative; font-size: 30px; text-align: center; margin-bottom: 5rem; line-height: 1.8;}
h2.basic_h2 span{ font-size: 48px; font-family: "Tenor Sans", sans-serif;}
h2.basic_h2 small{ font-size: 22px; color: #F8A0A2; font-family: "Tenor Sans", sans-serif;}
h2.basic_h2:after{ position: absolute; bottom: -3rem; left: 0; right: 0; margin: auto; content: ""; border-left: #333 1px solid; display: inline-block; width: 1px; height: 2.2rem;}

a {color:#333;}
.clearfix:after,
.flot_box:after {
  content: "";
  clear: both;
  display: block;
}
.fixed {
    position: fixed;
    top: 0;
    width: 100%;
}
.clear{	clear:both;}
.marumi{border-radius:15px;}

section{width:100%;}
p{ font-size: 15px; line-height: 1.8;}
.hover{ transition:0.5s;}
.hover:hover{
opacity:0.7; transition:0.5s;
filter:alpha(opacity=50);
-ms-filter: “alpha( opacity=50 )”;
}
strong{background:rgba(0, 0, 0, 0) linear-gradient(transparent 90%, rgba(248, 160, 162, .7) 0%) repeat scroll 0 0;}
.inner,#sub section{ width:1000px; margin:0 auto; box-sizing:border-box;}
img{ max-width:100%; height:auto; vertical-align: bottom;}
.left{float:left;}
.rigft{float:rigft;}

i{padding-right:10px;}
.fa-phone{ transform: rotateY( 190deg ); transform: rotateZ( 110deg );}	
.flex{display: flex; justify-content: space-between; flex-wrap: wrap;}
.flex .item03{flex-basis: 50%;}


/* +αサポートメニュー */
.menu_wrap .text-box h2{ font-size: 2.5rem; margin-bottom: 1.5rem;}
.menu_wrap h3{ font-size: 1.1rem; margin-bottom: .5rem;}
.menu_wrap h3 span{ color:#7A2424; font-size: 1.4rem; border-bottom: #7A2424 1px solid; padding-bottom: .2rem; font-weight: 600; }
.menu_wrap .text-box{ background: url("../images/top/menu_bg.jpg") no-repeat 0 0/cover;}
.menu_wrap .text-box .inner{ position: relative; padding: 3rem 0;}
.menu_wrap .text-box .inner img{ position: absolute; bottom: 0; right: -6rem; width: 285px; height: auto;}
.menu_wrap .text-box p strong{ color: #7A2424; background: none; font-size: 1.4rem; margin-bottom: 1.7rem; display: inline-block; }
.menu_wrap .link-box{ background: #F6ECED; padding: 2rem 0;}
.menu_wrap .menu_list{ display: flex; justify-content:space-between; flex-wrap: wrap; }
.menu_wrap .menu_list li.white_box{ position: relative; display: flex; justify-content: space-between; width: 48%; background: #FFF; margin-bottom: 1.5rem; padding: 1.2rem; border-radius: .5rem;}
.menu_wrap .menu_list li.white_box.w_100{ width: 100%;}
.menu_wrap .menu_list li .text{ width: 100%;}
.menu_wrap .menu_list li .text ul li{ list-style: disc; list-style-position: inside; font-size: 14px; margin-left: .2rem; line-height: 1.8;}
.menu_wrap .menu_list li .btn{ position: absolute; bottom: 1rem; right: 1rem; background: #F8A0A2; color: #7A2424; padding: .3rem 1.5rem .3rem .8rem; }
.menu_wrap .menu_list li .btn:before,ul.sp_menu li a:before { content: ''; width: 6px; height: 6px; border: 0; border-top: solid 2px #7A2424; border-right: solid 2px #7A2424; transform: rotate(45deg); position: absolute; top: 0; right: .7rem; bottom: 0; margin: auto; }
.menu_wrap .link-box .catch_text{ position: relative; font-size: 1.8rem; margin-bottom: 2.5rem; text-align: center; }
.menu_wrap .link-box .catch_text span{ font-size: 4rem; font-weight: bold; letter-spacing: 0; margin-left: -.8rem; line-height: 1; background: linear-gradient(90deg, #8c7537 0%, #dbb00b 45%, #fde79d 70%, #dbb10c 85%, #bc7f04 90% 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; display: inline-block; }
.menu_wrap .link-box .catch_text:before { content: ''; width: 100px; height: 1px; border: 0; background: #333; position: absolute; top: 0; left: 2rem; bottom: 0; margin: auto; }
.menu_wrap .link-box .catch_text:after { content: ''; width: 100px; height: 1px; border: 0; background: #333; position: absolute; top: 0; right: 2rem; bottom: 0; margin: auto; }
.menu_wrap .a_wrap{ position: absolute; top:0; left: 0; width: 100%; height: 100%; z-index: 2; transition: 0.5s; }
.menu_wrap .a_wrap:hover{ background:rgba(248,213,213,0.1); border:#F8A0A2 2px solid; border-radius: .5rem; transition: 0.5s;}

/* CSS リンクボタン */
.main_btn a{
	width:95%; max-width: 400px; color: #7A2424; 
	text-align:center;
	font-size:15px;
	display:block;
	margin:20px auto;
	background: #F6ECED;
	border:#7A2424 1px solid;
	padding:8px 10px 8px 0;
	position:relative;
	box-sizing:border-box;
    transition:0.5s;
}
.main_btn a:after {
	position:absolute;
	top:10px;
	right:30px;
    content: "　";
    display: inline-block;
	background:url(../images/top/btn_2.png) no-repeat 50% 50%;
	background-size:15px; 
}
.main_btn a:hover{
    color:#FFF;
	background:#7A2424;
    transition:0.5s;
}
.main_btn a:hover:after {
	position:absolute;
	top:10px;
	right:30px;
    content: "　";
    display: inline-block;
	background:url(../images/top/btn_1.png) no-repeat 50% 50%;
	background-size:15px; 
}
.yura a{
	animation: fluffy1 3s ease infinite;
	-webkit-animation-duration: 1.1s;
	-webkit-animation: fluffy1 1s ease-in-out infinite alternate;
}
@keyframes fluffy1 {
    0% { -webkit-transform:translateX( -3px); }
  100% { -webkit-transform:translateX(  0px); }
}


/* ヘッダー--------------------------- */
header{
	width:100%;
	position:relative;
	margin:0;
	padding:0;
	overflow:hidden;
}
header .top_wrap{
	width:100%;
    padding: 0 4.5rem;
	margin:0 auto 5px;
}
header .top_wrap p{ font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif"; line-height: 1.5;
	float:left;
	font-size:15px;
	color:#7A2424;
	font-weight:normal;
	margin:10px 0 0;
}
header .top_wrap img{
	height:50px;
	float:right;
	margin-left:13px;
}

/* ニューヘッダーナビゲーション--------------------------- */
.nav_wrap{
	width:93%;
	margin:0 auto;
	background:#7A2424;
	padding:10px 50px 10px 50px;
	box-sizing:border-box;
	border-top-left-radius: 20px;
	border-top-right-radius: 20px;
}
.nav_wrap .logo img{
	width:auto;
	height:63px;
}
.nav_wrap .logo{
	float:left;
	width:33%;
	padding-top:5px;
}
.nav_wrap ul{
	width:100%;
	padding-top:15px;
}
.nav_wrap ul li{
	float:left;
	width:8%;
	text-align:center;
	border-right:1px #FFF solid;
}
.nav_wrap ul li.li1{
	margin-left:20px;
	border-left:1px #FFF solid;
}
.nav_wrap ul li a{
	width:100%;
	display:block;
	font-size:1vw;
	color:#FFF;
	letter-spacing:0.5px;
}
.nav_wrap ul li a img{ width: 30px; height: auto; transition:0.5s;}
.nav_wrap ul li a:hover img{
	animation: fluffy2 3s ease infinite;
	-webkit-animation-duration: 1.1s;
	-webkit-animation: fluffy2 1s ease-in-out infinite alternate;
	width:35px;
    transition:0.5s;
}
.remodal-cancel{ font-size: 16px;}
@keyframes fluffy2 {
    0% { -webkit-transform:translateX( -3px); }
  100% { -webkit-transform:translateX(  0px); }
}


/* 求人バナー--------------------------- */
.recruit .main_btn a{
	padding:33px 0;
	background:url(../images/recruit/webp/bg.webp) no-repeat 0% 100%;
	background-size:100% auto;
	border:none;
	border-radius:10px;
	width:960px;
	color:#7A2424;
	font-size:1.6vw;
	letter-spacing:1px;
	font-weight:900;
}
.no-webp .recruit .main_btn a{ background-image:url(../images/recruit/bg.jpg);}
.recruit .main_btn a:after{
	position: absolute;
    top: 40px;
    right: 65px;
    content: " ";
    display: inline-block;
	background: url(../images/top/btn_2.png) no-repeat 50% 50%;
    background-size: 25px;
}
.recruit .main_btn a:hover{
	opacity:0.8;}


/* CSS イラストマップ */
.map_wrap{ background:#F4F4F4; width: 100%; height: 442px; margin-top: 40px; }
.map_wrap .inner{ position:relative; padding-bottom: 50px;}
.map_wrap h2{ position: absolute; top: -25px; right: 0; color: #7A2424; display: flex; justify-content:center; align-items:center; width:600px; height: 70px; font-size: 32px; background: #F8A0A2; border-radius: 90px; padding-top: 10px;}
.map_wrap h2 span{ font-size: 24px;}
.map_wrap .map_img{ position: absolute; width:995px; height:auto; top:-30px; left: -50px;}


/* CSS 診療時間表 */
.hour th,
.hour td{ font-weight: normal;
	text-align: center;
	vertical-align: middle;
	font-size: 15px;
	padding: 12px 10px;}
.hour th{
	letter-spacing: 0.08em;
}
.hour td{border-left: 1px solid #333; color: #7A2424;}
.hour tr:first-child td,.hour tr:first-child th{ color: #333; font-weight: bold;}

/* CSS footer */
#footer .box1 table td{
	font-size:13px;
	vertical-align:top;
}

/* wrap008 症例集  下層ページも利用--------------------------- */
#wrap008 { padding:5rem 0 7rem; background: url("../images/top/webp/w8_bg.webp") no-repeat 0 0/cover;}
#wrap008 .sub_title{ font-size: 24px; text-align: center; background: #7A2424; color: #FFF; padding: 1rem 0;}
#wrap008 h3{ font-family: "Noto Sans JP", sans-serif; color:#7A2424; font-weight: 600; text-align:center; font-size: 1.6vw; margin:0 0 15px;}

#kaijo h3{ margin: 5rem 0 0; background: #7A2424; border: none; color: #FFF; text-align: center; padding: 1rem 0; border-radius: 20px 20px 0 0; font-size: 18px;}
div#kaijo table {
    width: 100%;
    border: 1px solid;
    border-collapse: separate; 
    border-spacing: 0;
    border-radius:0 0 20px 20px; 
    overflow: hidden; 
}
div#kaijo table tr { border: #7A2424 1px solid; }
div#kaijo table tr:nth-child(odd) { background-color: #f8a0a261; }
div#kaijo table th {
    font-weight: 400;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    padding: 1em;
    font-size: 20px;
    color: #000;
    width: 30%;
    border-right: #7A2424 1px solid;
}

div#kaijo table td {
    color: #000;
    font-size: 15px;
    padding: 1em 0 1em 2em;
}

div#kaijo table td span {
    font-size: 1.5em;
    padding: 0 .2em;
}
div#kaijo table tr:last-child th { border-bottom-left-radius: 20px;}
div#kaijo table tr:last-child td { border-bottom-right-radius: 20px;}
#wrap008 .box_01,
#case .box_01{
	width: 31.3%;
	float:left;
	padding-top:60px;
	box-sizing:border-box;
	margin:50px 0 30px 30px;
	background:#F6ECED;
	position:relative;
}
#wrap008 .box_01{
	padding:30px 23px 10px;
	margin: 2rem 0 0 30px;
}
#wrap004 .ml,#wrap008 .ml{ margin-left:0 !important;}

.balloon1 {position: relative; display: block; text-align: center; margin: 40px auto 30px; padding:25px 10px 20px; width: 450px; background: #F8A0A2; border-radius: 20px; box-sizing: border-box; }
.balloon1:before { content: ""; position: absolute; top: 100%; left: 50%; margin-left: -15px; border: 15px solid transparent; border-top: 15px solid #F8A0A2;}
#sub .balloon1 p {color: #7A2424; font-weight: bold; font-size: 20px; line-height: 1.7; margin: 0; padding: 0;}
#sub .balloon1 p span,.age .balloon1 p span{ font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif"; color: #FFF; font-size:25px; background:#7A2424; padding: 5px 10px; border-radius: 10px; margin:0 0 10px; display:inline-block;}

#wrap008 h2.images_title img {
    width: 210px;
    margin: 0 auto 30px;
    display: block;
}
#wrap008 .main_btn a{ border-radius: 2rem; }
.age_wrap{ margin: 7rem auto 0;}
.age_wrap h2{ margin-top: 3rem;}
.age_wrap ul{ display: flex; justify-content: space-between;}
.age_wrap ul li{ width: 180px;}


/* WEB予約導入!!--------------------------- */
    .news_wrap { position:relative; padding: 3rem 6rem 2rem; margin: 50px auto; width: 1000px; box-sizing:border-box; background: #F6ECED;}
    .news_wrap:before{ position: absolute; border: 1px solid #F8A0A2; content: ""; top:15px; bottom: 15px; left: 15px; right: 15px; z-index: 0; }
    .news_wrap h2{ font-size: 32px; color:#333; margin-bottom: 20px; text-align:center; line-height:1.5;}
    .news_wrap h3{ position:relative; font-size: 20px; color:#7A2424; margin-bottom:1.5rem; border-bottom: #7A2424 1px solid; display: inline-block; padding: 0 1rem .3rem 2.5rem; }
    .news_wrap h3:before{ position:absolute; top:0; left:0; content:""; width:26px; height:26px; background:url(../images/top/w2_007.png) no-repeat 50% 50%; background-size:25px;}
    .news_wrap h3 + h3{ margin-top:50px;}
    .news_wrap p{ line-height:1.8; margin-bottom:1rem;}
    .news_wrap .main_btn{ width:330px; max-width: 100%; margin:30px auto 0;}
    .news_wrap table{ width:100%; margin-bottom:30px;}
    .news_wrap table th,.news_wrap table td{ border:#9F484C 2px solid; padding:18px 10px 12px; box-sizing:border-box; text-align:center; font-weight:bold;}
    .news_wrap table th{ font-size:18px; background:#7A2424; color:#FFF;}
    .news_wrap table td{ font-size:22px;}
    .news_wrap table td a{ text-decoration:none;}
    .news_wrap table tr:first-child th{ border-bottom:#FFF 2px solid;}
    .news_wrap .img_yoyaku{ position:absolute; top:50px; right:50px; width:180px; height:180px; content:" "; background:url(../images/reserve/webp/002.webp) no-repeat 0 0/contain;}
    .no-webp .news_wrap .img_yoyaku{ background-image:url(../images/reserve/002.png);}
    .news_wrap .flex .main_btn,.news_wrap .flex .main_btn a{ margin-top:0;}

    #sub .news_wrap{ position:relative;}
    #sub .news_wrap h2{ line-height:1.7; font-size:36px; background:none; padding:0;}
    #sub .news_wrap h2 span{ color:#7A2424; border-bottom: #F8A0A2 5px dotted;}
    #sub .news_wrap img{ width:100%; margin-bottom: 10px;}
    #sub .news_wrap p{ font-size:16px; position: relative; z-index: 999; }
    #sub .news_wrap .btn_img{ width: 400px; margin: 0 auto; position: relative; z-index: 999; }
    #sub .news_wrap h4{ margin-top: 0;}

/* 予約追従ボタン --------------------------- */
.yoyakuarea{ position:fixed; bottom:125px; right:20px; width: 120px; height: 120px; box-sizing: border-box; box-shadow: 0 10px 25px 0 rgba(0, 0, 0, .5); background:#7A2424; border:#7A2424 2px solid; color: #FFF; padding:21px 0 0; border-radius:8px; z-index: 9999; text-align: center; display: block; font-size:17px; line-height: 1.3; font-weight:400; transition: 1.0s ;}
.yoyakuarea img{ width:40px; margin:0 auto 8px;}
.yoyakuarea:hover{ color:#FFF; border-color:#7A2424; background:rgb( 122, 36, 36 ,0.5); transition: .7s ;}
.calendar_btn{  background:#FFF; border:#7A2424 2px solid; color: #7A2424; bottom:260px; padding-top: 15px; letter-spacing:0.1px;}
.calendar_btn img{ width:40px; margin:0 auto 0;}

/* 日本歯科医療評価機構--------------------------- */
.jidv_box{ width:960px; background: rgba(159,72,76,0.1); border:#9F484C 5px double; padding:60px 50px 40px; box-sizing:border-box; margin:50px auto 100px; display:block; text-align:center;}
.jidv_box img{ margin:0 auto; display:block;}
.jidv_box p{ margin:20px 0; font-size:20px; color:#000;}
.jidv_box p.main_btn{ width:500px; margin:30px auto;}
h3.jidv{ color:#9F484C; margin-bottom:50px; font-size:28px; text-align:center; text-decoration:underline;}

.jidv_box.sub_css{ padding:40px 50px 30px; margin-bottom:50px;}
#sub .jidv_box.sub_css h3{ margin:0 0 30px; padding:0; letter-spacing:0;}
.jidv_box.sub_css p.main_btn a{ margin-bottom:30px;}

/* お問いわせ--------------------------- */
.contact_wrap{ position: relative; background:url("../images/top/webp/contact_bg.webp") no-repeat right top/cover; padding: 5rem 0 20rem;}
.contact_wrap:before{ position: absolute; top:-3.3rem; left: 0; right: 0; margin: auto; content: ""; width: 1px; height: 100px; background: #7A2424;}
.contact_wrap .inner{ width: 850px; margin: 0 auto;}
.contact_wrap h2{ position: relative; color: #FFF; font-size: 38px; font-weight: bold; text-align: center; margin-bottom: 2rem;}
.contact_wrap h2:before,.contact_wrap h2:after{ position: absolute; bottom:0; left: 3rem; content: ""; background: url("../images/top/icon_h2_1.png") no-repeat 0 0/contain; width: 38px; height: 56px; display: inline-block;}
.contact_wrap h2:after{ background-image: url("../images/top/icon_h2_2.png"); left: auto; right: 3rem; }
.contact_wrap p{ color: #FFF; text-align: center; font-size: 17px;}
.contact_wrap ul{ display: flex; justify-content: space-between; margin: 2rem 0;}
.contact_wrap ul li a{ position: relative; display: block; background: #FFF; width: 400px; padding: .3rem 0 1.3rem 2rem; text-align: center; font-size: 32px; font-weight: bold; line-height: 1; box-sizing: border-box; border-radius: .3rem; box-shadow: 0 10px 25px 0 rgba(0, 0, 0, .5);}
.contact_wrap ul li:nth-child(2) a{ background:#7A2424; color: #FFF; }
.contact_wrap ul li a span{ font-size: 15px; font-weight: 500; margin:0 0 .7rem -3rem; display: inline-block;}
.contact_wrap ul li a:before{ position: absolute; bottom:1.2rem; left: 3.8rem; content: ""; background: url("../images/top/icon_tell_b.svg") no-repeat 0 0/contain; width: 32px; height: 32px; display: inline-block; }
.contact_wrap ul li:nth-child(2) a:before{ background-image: url("../images/top/icon_calendar_w.svg"); }

/* セカンドオピニオン--------------------------- */
.second-opinion_wrap{ position: relative; width: 900px; box-shadow: 0 10px 25px 0 rgba(0, 0, 0, .3); margin: -18rem auto 5rem; background: #FFF; padding: 3rem 2rem 4rem; box-sizing: border-box;}
.second-opinion_wrap:before{ position: absolute; border: 1px solid #F8A0A2; content: ""; top:15px; bottom: 15px; left: 15px; right: 15px;}
.second-opinion_wrap h2{ font-size: 30px; text-align: center; border-bottom: #333 1px solid; display: table; margin: 0 auto 1.5rem;}
.second-opinion_wrap h2 span{ font-size: 20px;}
.second-opinion_wrap .flex_wrap{ width:665px; display: flex; justify-content: space-between; align-items: center; margin: 0 auto 2rem;}
.second-opinion_wrap img{ margin: 0 auto; display: block;}
.second-opinion_wrap a{ position:relative; z-index: 999;}

/* フッター--------------------------- */

#footer .box1{
	width:47%;
}
.box1{
	width:43%;
	float:left;
	box-sizing:border-box;
	margin:40px 0 0;
}
#footer .box1 a img{ margin-bottom: 1.5rem;}

#footer .box2{
	width:52%;
}
.box2{
	width:57%;
	float:left;
	box-sizing:border-box;
	padding-left:50px;
	margin:40px 0;
}

#footer .box1 p{
	font-size:15px;
	margin-bottom:20px;
}
#footer i{
	color:#F8A0A2;
}
#footer .box1 table{
	margin-bottom:25px;
}
#footer .box2 table{
	margin:20px 0 5px;
}
#footer .box2 img{
	border-bottom:#F6F6F6 2px solid;
	padding-bottom:30px;
}
#footer .hour th, #footer .hour td {
    font-size: 15px;
    padding: 10px 10px;
}
#footer .hour td {
    border-left: 2px solid #F6F6F6;
}
#footer .box2 p{
	margin:10px 0 0;
	font-size:12px;
	text-align:right;
}
#footer .box1 table td {
    line-height: 28px;
	font-size:15px;
}

#footer .foot_link_wrap .inner{ width: 1000px; margin: 0 auto; display: flex; justify-content:space-between; flex-wrap: wrap; }
.foot_link_wrap .inner .min{ font-size: 1.5rem; color: #333; text-align: center; }
.foot_link_wrap .inner .box50{ width: 48%;}
.foot_link_wrap .inner .box100{ width: 100%;}
#footer .foot_link_wrap .inner ul{ margin: 1rem 0 2rem;}
#footer .foot_link_wrap .inner .box50 ul li{ width: calc(97% / 2); margin-bottom: 1rem;}
#footer .foot_link_wrap .inner .box50 ul li a{ padding: .5rem; border: #7A2424 1px solid; }
#footer .foot_link_wrap .inner .box100 ul li{ width: calc(92% / 5); margin-bottom: 1rem;}
#footer .foot_link_wrap .inner .box100 ul li a{ border: none; }


/* wrap007   日本歯科医療評価機構  共通--------------------------- */
#wrap007{
	background:#F8A0A2;
	padding:100px 0 50px;
	text-align:center;
}
#wrap007 .inner{ margin-bottom: 0;}
#wrap007 p{
	color:#7A2424;
	font-size:14px;
	text-align:left;
	letter-spacing:0.12vw;
	line-height:180%;
}
#wrap007 p.text_01{
	font-size:13px;
}
#wrap007 h2 img,.column h2 img{
	width:100px;
	height:auto;
	padding-bottom:35px;
}
#wrap007 h3{
	line-height:normal;
	text-align:left;
	margin-bottom:-10px;
}
#wrap007 .box1 img{
	margin-bottom:13px;
}
#wrap007 h4{
	text-align:left;
	margin-bottom:10px;
}
#wrap007 h4.h4_2{
	margin-top:50px;
	display:block;
}
#wrap007 .box2 .main_btn a{
	width:53%;
	float:right;
	margin-top:103px;
}
#wrap007 .box2 .img_01{
	width:350px;
	display:block;
}
#wrap007 h2.h2{
	letter-spacing:0.1em;
}
.jidv img{
	margin:30px 0;
}
#wrap007 .jidv img{
	margin:30px auto 0;
	width:70%;
	display:block;
}
#wrap007 .jidv2 img{
	width:100%;
	margin:0 auto;
	display:block;
}
#wrap002 h2,
#wrap006 h2,
#wrap007 h2,
.column h2{
	font-size:30px;
	color:#7A2424;
	text-align:center;
	margin-bottom:20px;
	letter-spacing:7px;
}
#footer .inner{ padding: 0; margin-bottom: 70px;}
#footer ul{
	margin:50px 0;
    display: flex; justify-content: space-between;
}

#footer ul li{ width: calc(100%/9);}
#footer ul.list6 li{ width: calc(100%/6);}
#footer ul li a{
    width:100%;
	padding:0;
	display:block;
	box-sizing:border-box;
	font-size:14px;
	text-align:center;
	position:relative;
	letter-spacing:.05rem;
	line-height:1.7;
	border-left:#F6F6F6 2px solid;
	color:#7A2424;
}
#footer ul li:last-child a{
	border-right:#F6F6F6 2px solid;
}


.copy{
	color:#555;
	font-size:12px;
	text-align:center;
	padding:25px 0;
	background:#F8A0A2;
	margin-top:50px;
}

.f, #sub table.price_table td {
    font-family: "Tenor Sans", sans-serif; font-weight: 100;
}

/* スマホナビ--------------------------- */
    .aaa{
        position:fixed;
        top: .5vw;
        right: .5vw;
        z-index:9999;
    }
    .bbb{
        position:absolute;
        top: 3.2vw;
        right: 20vw;
    }
    .aaa img{
        height:50px;
        width:auto;

    }
    .bbb img{
        height:48px;
        width:auto;
    }
.flex_wrap_menu{ display: flex; justify-content: space-between; align-items: flex-start; padding: 2rem 0 0;  }
ul.sp_menu.main{ margin-bottom: 1rem; }
ul.sp_menu.main li a:before{ border-color: #FFF; }
.flex_wrap_menu div{ width: 48%;}
.flex_wrap_menu div p{ position: relative; font-size: 20px; line-height: 1; margin: 0 0 1.5rem; color: #7A2428;}
.flex_wrap_menu div p:before{  content: ""; width: 50px; height: 1px; background:#7A2428; display: inline-block; margin: 0 .8rem .3rem 0;  }
.flex_wrap_menu div p:after{  content: ""; width: 50px; height: 1px; background:#7A2428; display: inline-block; margin: 0 0 .3rem .8rem;  }

ul.sp_menu,ul.sp_menu_age{display: flex; justify-content: space-between; flex-wrap: wrap;}
ul.sp_menu li{ width:47%; text-align:center; position:relative; margin-bottom: 10px; }
ul.sp_menu.type{ margin-bottom: 1rem;}
ul.sp_menu.type li a{ border: #7A2428 1px solid; background: #fbedec; color:#333; border-radius: .3rem; }
ul.sp_menu.column_link li a{ background: #FFF; }
ul.sp_menu.type.support li a{ background: #F9F9F9;}
ul.sp_menu.main li a{ padding:1.02rem 1rem 1.02rem 1.5rem; text-align: left; font-size: 14px; font-weight: 500; }
ul.sp_menu li a{ font-size: 15px; display:block; color:#FFF; padding: .4rem 0; background: linear-gradient(135deg, #7A2428, #A03A40); border-radius:5px;}
ul.sp_menu li a:before{ right: 1rem;}
ul.sp_menu li a img{ width: 30px; height: auto; margin-right: .8rem;}
ul.sp_menu_age li{ width: 19%;}
.menu_logo img{ width: 330px; }

@media screen and (max-width:768px){
    
    
    /* スマホナビ--------------------------- */
    .aaa{
        position:fixed;
        top: 3vw;
        right: 3vw;
        z-index:9999;
    }
    .menu_logo img{ width:220px;}
    ul.sp_menu li{ width: 48%;}
    .flex_wrap_menu{ display: block; padding: 1.3rem 0 0; }
    .flex_wrap_menu div{ width: 100%;}
    .flex_wrap_menu div p{ font-size: 16px;}
    .flex_wrap_menu div p:before,.flex_wrap_menu div p:after{ width: 25px;}
    ul.sp_menu li a:before{ border-width: 1px; width: 5px; height: 5px;}
    ul.sp_menu.main li a{ padding: 0.4rem 0; text-align: center;}
    ul.sp_menu li a{ font-size: 14px; }
    ul.sp_menu li a.small{ font-size: 12px; letter-spacing: 0;}
    ul.sp_menu li a:before{ right: .6rem;}
    ul.sp_menu li a img{ margin-right: 0; width: 26px; margin-bottom: .1rem;}
    ul.sp_menu_age{ justify-content: space-around;}
    ul.sp_menu_age li{ width: 31%; margin-bottom: .5rem;}
    
    
    html,body{
	letter-spacing:0.6px;
    }
    .pc{
        display:none !important;
    }
    .left,
    .right{
        float:none;
    }
    .inner{
        width:100%;
        margin:0 auto;
        padding:0 1.5rem;
    }
    #sub section { width: 100%; margin: 0 0 4rem; padding: 0 1rem;}

    img{max-width:100%;height:auto;}
    img.small_img{
        width:1px !important;}
    .news_wrap .main_btn{ width: 100%;}
    .main_btn a { width: 95%; font-size: 13px; padding: 10px 30px 7px 0; }
    .main_btn a:after { position: absolute; top: 7px; }
    .img_en{ height:13px !important; width:auto;}

    /* 画面外にいる状態 */
    .fadein {
        opacity : 1.0;
        transform : translate(0, 0px);
        transition : all 10ms;
        }

    /* 画面内に入った状態 */
    .fadein.scrollin {
        opacity : 1;
        transform : translate(0, 0);
        }
    
    /* 診療時間の表--------------------------- */
    .hour td {
    border-left: 1px solid #7A2424;
    }
    .hour th, .hour td {
        text-align: center;
        vertical-align: middle;
        font-size: 14px;
        padding: 3px 5px;
        letter-spacing:0.2px;
    }
    .hour th{
        padding:5px 3px 5px 0px;
    }
    

        /* ヘッダー--------------------------- */
        header{
            padding:0;
            background:none;
        }
        #sub header{
            height:auto;
        }


        header .inner {
            padding:0;
            position: absolute;
            top: 43px;
            left: 5%;
            height:auto;
        }
        header .info_box{
            display:none;
        }
        header .top_wrap img{
            display:none;
        }
        header .top_wrap p span{
            display:none;
        }
        header .top_wrap p{
            font-size:0.8em;
            line-height:150%;
            margin-top:20px;
        }
        header nav ul{
            width:100%;
            padding:10px 20px 30px;
            margin:0 auto;
            position:relative;
            z-index:999;
            box-sizing:border-box;
            background:#F9D3D4;
        } 

        /* ヘッダーナビゲーション--------------------------- */
        header .top_wrap {
            width: 93%; padding: 0;
            margin: 0 auto 15px;
        }
        .nav_wrap{
            width:93%;
            padding:10px 15px 5px;
            border-top-left-radius: 10px;
            border-top-right-radius: 10px;
        }
        .nav_wrap .logo img{
            width:100%;
            height:auto;
        }
        .nav_wrap .logo{
            float:none;
            width:100%;
            padding-top:5px;
        }
        
        header nav ul img{
            margin-top:10px;
        }
        
        
        .slick-dots {
            position: absolute;
            bottom: -7px;
        }
        .slick-dots li button:before {
            font-size: 15px !important;
        }
        .slick-dots li {
            margin: 0 2px !important;
        }

    /* +αサポートメニュー */
    .menu_wrap .text-box h2{ font-size: 1.4rem; margin-bottom: .6rem; }
    .menu_wrap h3{ font-size: .8rem;}
    .menu_wrap h3 span{ font-size: 1.2rem; }
    .menu_wrap .text-box .inner{ padding: 2rem 1rem 1rem;}
    .menu_wrap .text-box .inner img{ right: 0; width: 130px; }
    .menu_wrap .text-box p.text{ display: none; }
    .menu_wrap .text-box p strong{ font-size: 13px; margin-bottom: 1rem; line-height: 2; }
    .menu_wrap .link-box{ padding: 0 1rem 1rem;}
    .menu_wrap .link-box .inner{ padding: 0; }
    .menu_wrap .menu_list li.white_box{ width: 100%; margin-bottom: 1rem;}
    .menu_wrap .menu_list li .text ul li{ font-size: 13px; margin-left: 0; line-height: 2;}
    .menu_wrap .menu_list li .btn{ font-size: 11px; padding: .1rem 1.2rem .1rem .5rem; }
    .menu_wrap .menu_list li .btn:before { right: .4rem; border-width: 1.5px; }
    .menu_wrap .link-box .catch_text{ font-size: 1.1rem; margin-bottom: 1rem; }
    .menu_wrap .link-box .catch_text:before,.menu_wrap .link-box .catch_text:after { content: none; }

    /* CSS イラストマップ */
        .map_wrap{ height: auto; margin-top: 0px; padding-bottom: 50px;}
        .map_wrap .inner{ border-top:#FFF 55px solid; padding: 0;}
        .map_wrap h2{ position: static; width:calc(100% - 20px); font-size: 20px; margin: -30px auto 0; box-sizing: border-box;}
        .map_wrap h2 span{ font-size: 20px; margin-left: 15px;}
        .map_wrap h2 span.small{ font-size: 18px; margin-right: -10px; margin-left: 0;}
        .map_wrap .map_img{ position: static; width: 100%; margin-top: 15px;}

    /* CSS リンクボタン */
        .main_btn a {
        width: 95%;
        font-size: 12px;
        }
    
    .yoyakuarea{ position:fixed; bottom:100px; right:30px; box-shadow: 0 10px 25px 0 rgba(0, 0, 0, .5); background:#FFF; border:#F8A0A2 3px solid; padding:15px; border-radius:20px; z-index: 9999; text-align: center; display: block; font-size:20px; font-weight:bold; transition: 1.0s ;}
.yoyakuarea:hover{ color:#FFF; border-color:#7A2424; background:rgb( 122, 36, 36 ,0.5); transition: 1.0s ;}

    
    /* 予約追従ボタン ---------------------------
    .calendar_btn{ bottom:60px; right: 5px; font-size:14px; letter-spacing: 0.5px; display: flex; justify-content: flex-start; padding: 10px 10px 0; border-radius: 5px;}
    .calendar_btn img{ width:18px; margin:0 5px 0 0;}
    .calendar_btn strong{ background: none;}
     */
    .calendar_btn{ display: none;}


    /* お問いわせ--------------------------- */
    .contact_wrap{ background-image: url("../images/top/webp/contact_bg_sp.webp"); padding: 3rem 0 2rem;}
    .contact_wrap .inner{ width:100% ;}
    .contact_wrap h2{ font-size: 24px; margin-bottom: 1.5rem;}
    .contact_wrap h2:before,.contact_wrap h2:after{  left: -0.5rem; width: 28px; height: 41px;}
    .contact_wrap h2:after{ left: auto; right: -0.5rem; }
    .contact_wrap p{ text-align: left; font-size: 15px;}
    .contact_wrap ul{ display: block; margin: 1.5rem 0;}
    .contact_wrap ul li a{ width: 100%; margin-bottom: 1rem;}
    .contact_wrap ul li a:before{ left: 1.8rem; }

    /* セカンドオピニオン--------------------------- */
    .second-opinion_wrap{ width: 100%; box-shadow:none; margin: 0 auto;  padding: 2rem 2rem 1.3rem; }
    .second-opinion_wrap h2{ font-size: 24px;  display:block; margin: 0 auto 1.5rem; padding-bottom: 0.5rem;}
    .second-opinion_wrap h2 span{ font-size: 17px;}
    .second-opinion_wrap p{ font-size: 15px;}
    .second-opinion_wrap .flex_wrap{ width:100%; display:block; margin: 0 auto 1.5rem;}
    .second-opinion_wrap img{ margin: 0 auto .8rem;}




    /* wrap008  症例集 下層と共通--------------------------- */
    #wrap008{
        padding:3rem 0;
    }
    #wrap008 .inner{
        padding:0 20px;
    }
    #wrap008 h2{ font-size: 22px; margin-bottom: 4.2rem; }
    #wrap008 h2 span{ font-size: 40px; line-height: 1.2;}
    #wrap008 h2 small{ font-size: 13px;}
    #wrap008 .sub_title{ font-size: 22px; padding: 0.5rem 0; margin-bottom: 1.5rem;}
    #wrap008 .box_01{
        width:46%;
        margin:10px 0 0 10px;
        padding:15px 10px 15px;
    }
    #wrap008 .ml{
        margin-left:10px !important;
    }
    #wrap008 h3 { font-size: 15px; margin: 0 0 10px;}
    #wrap008 .box_01 .main_btn a { padding: 7px 30px 7px 10px;
        width:95%;
        font-size: 11px;
        margin: 7px auto 0;
    }
    #wrap008 .box_01 .main_btn a:after {
        position: absolute;
        top: 7px;
        right: 15px;
    }
    #wrap008 .box_01 img.img_001{
        margin-top:2px;
    }
    .balloon1 { width: 100%; padding: 15px 0px 10px;}
    #sub .balloon1 p{ font-size: 16px;}
    #sub .balloon1 p span{ font-size: 18px;}

    .age_wrap{ margin: 3rem 0 0;}
    .age_wrap ul{ justify-content: space-around; flex-wrap: wrap;}
    .age_wrap ul li{ width: 45%; margin-bottom: 0.5rem;}
    
    
    /* フッター--------------------------- */
    #footer{ padding: 2rem 0 4rem;} 
    #footer .inner{ margin-bottom: 0; padding: 0 20px;}
    #footer .box1,#footer .box2{ padding: 0; width:100%; float:none;}
    #footer .box1 table td {
        font-size: 3.8vw;
        padding-left: 10px;
    }
    #footer .box1 table i {
        font-size: 35px;
    }
    #footer .box1 table {
        margin-bottom: 10px;
    }
    #footer .box1 p {
        font-size: 14px;
        margin-bottom: 12px;
    }
    #footer .box1 a img{ margin: .5rem 0;}
    #footer .hour th, #footer .hour td {
        font-size: 14px;
        padding: 10px 7px;
    }
    #footer .box2 p {
        font-size: 10px;
    }
    .jidv img {
        margin: 15px auto;
        width: 85%;
        display: block;
    }
    .map{
        width:100%;
        height:300px;
    }
    #footer ul{ display: block;}
    #footer ul li,#footer ul.list6 li{ width: 100%;}
    #footer ul li a,#footer ul li:last-child a{ line-height: 2.4; border: none;}
    
    .foot_link_wrap .inner{ width: 100%; margin: 0; display: block; }
    .foot_link_wrap .inner .min{ font-size: 1.2rem; }
    .foot_link_wrap .inner .box50{ width: 100%;}

    #footer .foot_link_wrap .inner{ width: 100%;}
    #footer .foot_link_wrap .inner ul{ margin: 1rem 0; display: flex; }
    #footer .foot_link_wrap .inner .box50 ul li a{ padding: .3rem; line-height: 1.8; font-size: 12.5px; }
    #footer .foot_link_wrap .inner .box50 ul.column_link li{ width: 100%; }
    #footer .foot_link_wrap .inner .box50 ul.column_link li a{ line-height: 1.8;} 
    #footer .foot_link_wrap .inner .box100 ul{ justify-content:space-around;}
    #footer .foot_link_wrap .inner .box100 ul li{ width: calc(92% / 3);}

    
    .copy{
        padding:20px 0;
        margin-top:0;
        letter-spacing:0px;
    }
    #footer .aa{
        padding-top:0;
        margin-top:-1em;
    }
    
    

/* SPのフッターリンク --------------------------- */
.footer_link
{
	display: block;
	width: 100%;
	position: fixed;
	bottom: 0;
	height: auto;
	z-index:9999;
	background:#F8A0A2;
	padding:6px;
	box-sizing:border-box;
}
.footer_link a {
	-webkit-tap-highlight-color: rgba(0,0,0,0);
	}
.footer_link ul{display:flex; justify-content:space-between;}
.footer_link ul li { width:32%; position:relative; box-sizing:border-box;}
.footer_link ul li:before {
    position: absolute;
    top: 11px;
    left: 13px;
    content: "";
    background: url(../images/common/icon_tel.png) no-repeat left/contain;
    width: 19px;
    height: 19px;
    transition: .5s;
}
.footer_link ul li:nth-child(3):before{ background:url(../images/common/icon_calendar.png) no-repeat left/contain; top:11px; width:18px; height:18px;}

.footer_link ul li a { line-height:1;
	font-size:14px;
	color:#FFF;
	background:#7A2424;
	display: block;
	text-align: center;
	padding:13px 0 13px 20px;
	letter-spacing:1px;
	border-radius:10px;
}
.footer_link ul li.li2 a{
	background:#FFF;
	color:#7A2424; padding-left:24px;
}
.footer_link ul li:nth-child(2) a{ background:#7A2424; color:#FFF;}
.footer_link i{
	font-size:19px;
	margin-top:10px;
	margin-bottom:2px;
	padding-right:6px;
}
.footer_link ul li:last-child a{
	border-right: none;
}
.footer_link ul li a img {
	height: 40px;
	width: auto;
}
.footer_link ul li.br2{
	border-right:#555 1px solid;
	width:49.8%;
}
.footer_link ul li.br3{
	width:49.8%;
}

    div#kaijo{width: 100%;}
    #kaijo h3{ margin-top: 4rem;}
    div#kaijo table th,div#kaijo table td{display: block; width: 100%; padding: 0.7rem;}
	div#kaijo table th{background-color: #f8a0a261; box-sizing: border-box; border-right: none; border-top:#7A2424 1px solid; font-size: 17px; }
    div#kaijo table tr:last-child th{ border-bottom-left-radius: 0;}
	div#kaijo table td{text-align: center; box-sizing: border-box; padding-left: 0; font-size: 13px;}
    div#kaijo table tr:nth-child(odd) {
    background-color: #FFFFFF;
}
	div#news {
		border: double 10px #000;
		padding:20px 20px 15px;
		margin: 20px 8px;
		text-align: left;
		background-color: rgba(235, 232, 227, 0.5);
		width: 95%;
		box-sizing: border-box;
	}

	#news p {
		font-size: 14px;
		line-height: 180%;
		letter-spacing: 0.05vw;
	}
	#news p.title {
		text-align: center;
		font-size: 5vw;
		color: #7a2324;
		margin: 10px auto;
	}
	#news p.right {
		font-size: 14px;
		margin-top: 10px;
	}
	#news ul{width: 100%; font-size: 14px;}
	.flex .item03{flex-basis: 100%;}
    
	.news_wrap { border-width:6px; padding:35px 30px 15px; margin: 30px auto; width:calc(100% - 2rem); box-sizing:border-box;}
	.news_wrap h2{ font-size: 22px; margin-bottom: 15px; }
	.news_wrap h3{ font-size: 16px; line-height:1.6; padding-left:30px;}
	.news_wrap h3 + h3{ margin-top:20px;}
	.news_wrap p{ font-size:14px; line-height:1.8;}
	.news_wrap h3:before{ left:-.2rem; background-size:22px;}
	.news_wrap table th,.news_wrap table td{ width:100%; display:block; padding:13px 10px 7px;}
	.news_wrap table tr:first-child th{ border-bottom:#7A2424 2px solid;}
	.news_wrap table th{ font-size:15px;}
	.news_wrap table td{ font-size:18px;}

    
    /* wrap007  日本歯科医療評価機構 共通--------------------------- */
    #wrap007 {
        padding:20px 0;
    }
    #wrap007 h2 {
        font-size: 28px;
        margin:10px 0 40px;
        letter-spacing: 4px;
    }
    #wrap007 h2.h2 {
        font-size: 1.09em;
        margin: 0 0 10px;
        letter-spacing: 0.06em;
        line-height: 140%;
    }
    #wrap007 h3{
        margin-bottom:-15px;
    }
    #wrap007 p{
        font-size:13px;
    }
    #wrap007 .box2{
        display:none;
    }
	
	.jidv_box{ width:calc(100% - 40px);  padding:30px 20px 10px; margin:30px auto 30px;}
	.jidv_box img{ margin:0 auto; display:block;}
	.jidv_box p{ margin:20px 0; font-size:20px; color:#000;}
	.jidv_box p.main_btn{ width:100%; margin:30px auto;}
	.jidv_box .jidv img{ width:100%;}
	h3.jidv{ margin-bottom:20px; letter-spacing:0; font-size:18px; line-height:1.5;}
	.jidv_box.sub_css{ width:100%; padding:30px 20px 15px;}

    	.recruit  .main_btn a{
	padding:23px 0 18px;
	background-size:100% auto;
	border:none;
	border-radius:10px;
	width:90%;
	font-size:16px;
	line-height:1.7;
	letter-spacing:1px;
	font-weight:900;
	text-align:left;
	padding-left:30px;
	margin:15px auto 20px;
	}
	.recruit  .main_btn a:after{
			position: absolute;
		top: 42%;
		right: 38px;
		content: "　";
		display: inline-block;
		background: url(../images/top/btn_2.png) no-repeat 50% 50%;
		background-size: 25px;
	}
	.recruit  .main_btn img{
		width:30px;
	}
    
    .box1,.box2{
	width:100%;
	float:none;
	box-sizing:border-box;
	margin-bottom:20px;
	padding-left:0;
	margin-top:20px;
}


    
    }


/* PCで表示しない--------------------------- */

@media screen and (min-width:769px){
	.sp,.footer_link,
	header nav ul li a i,.bbb{
		display:none !important;
	}
	input#gnav{display: none;}
	
element.style {
    opacity: 1;
    transform: translateY(0px);
}
}

@media screen and (min-width: 768px) and (max-width: 1380px) {
    .nav_wrap ul li a{ font-size: 1vw;}
	header .top_wrap img{
		width:auto;
		height:40px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	#wrap005 .maru {
    width: 22vw;
    position: absolute;
    top: 300px;
}
}


@media screen and (min-width: 410px) and (max-width: 767px) {
	#wrap005 .maru{
	width:30vw;
	}
	
	
}

@media screen and (max-width:321px){
	
	.inner{
		padding: 10px 10px;
	}
	#wrap005 .inner {
    width: 100%;
    padding: 0 10px;
	}
	#wrap002 .box_01 p, #wrap003 .box_01 p {
    font-size: 10px;
	}
	
.Opening {
    height: 399px;
}
header nav ul li {
    width: calc(85%/2);
}

header .top_wrap p {
    font-size: 0.67em;
}
.Opening div.logo_02 {
    position: absolute;
    top: 29%;
    left: -11px;
    width: 73%;
    height: auto;
    z-index: 1;
}
.remodal {
    padding: 27px 8px !important;
}
.footer_link ul li {
    width: 48.0%;
}
#wrap001 .inner {
    padding: 0 10px 0;
}
#wrap002 h2 {
    font-size: 18px;
}
#wrap002 .text_02 {
    font-size: 1.4em;
}
#wrap003 h4 {
    font-size: 4.7vw;
    line-height: 160%;
}

#wrap005 .maru {
    width: 33.9vw;
}
#wrap005 table td {
    font-size: 12px;
}
#wrap008 .box_01 .main_btn a {
    font-size: 10px;
}
#concept .box_01 p {
    font-size: 0.76em;
}
#sub h5 {
    font-size: 14px;
}
#sub .main_btn a {
    width: 95%;
    font-size: 10px;
}
#dr p.text_01, #flow p.text_01, #schedule p.text_01 {
    font-size: 1.1em;
}
#flow .text_02 {
    font-size: 1em;
}
#sub h4 {
    font-size: 3.8vw;
}
#sub h3 {
    font-size: 4.3vw;
}
.inner, #sub section {
    padding: 0 10px;
}
#footer .hour th, #footer .hour td {
    font-size: 13px;
    padding: 5px 6px;
}

}

.top_case_note{
		text-align:center;
		margin:1rem 0;
		line-height: 1.6;
	    font-size: 14px;
	}
