@charset "utf-8";
/* CSS Document */

html,body{
	height:100%;
}


body {
	font-family: 'Noto Sans JP', 游ゴシック体, "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic";
	color:#333333;
	font-size:15px;
	font-weight:400;
	line-height:1.75;
	letter-spacing:0.05em;
	text-align:justify;
}
a {
	color: #009fe8;
	text-decoration: none;
}
a:hover {
	color:#d3c49f ;
}
::selection{
	background-color:#d3c49f;
}
::-moz-selection{
	background-color:#d3c49f;
}

body,
#mainvisual .inner,
header,
footer,
nav{
	min-width:1200px;
}



/*============================================================================

	header

============================================================================*/

header {
	width:100%;
	height:116px;
	background:#fff;
}
header .inner{
	position:relative;
	height: inherit;
	box-sizing:border-box;
	margin:auto;
}
/* ロゴ */
header h1{
	position:absolute;
	top:32px;
	left:70px;
}
header h1,
header img{
	width:307px;
	height:46px;
}
/*歯の痛みのある方はお電話ください*/
header p.header_message {
position: absolute;
top: /*61px*/67px;
right: 440px;
font-size: 16px;
color:#555555;
}
header p.header_message::after{
top: /*6px*/8px;
left: 276px;
box-sizing: border-box;
width: 10px;
height: 16px;
border: 7px solid transparent;
border-left: 13px solid #00a0e9;
position: absolute;
content: "";
}
/*キャンセルポリシー*/
a.header_cancelInfo {
	position: absolute;
	top: 31px;
	right: 440px;
	display: block;
	padding: 3px 15px;
	border: 1px solid #49acdc;
	color: #FFF;
	background: #49acdc;
	font-size: 16px;
	text-align: center;
	transition: all .3s;
	z-index: 10;
}
a.header_cancelInfo:hover {
	color: #49acdc;
	background: #FFF;
}
a.header_cancelInfo i {
	font-family: 'Font Awesome 5 Free';
	content: '\f05a';
	font-weight: 900;
	margin-right: 5px;
}

/* 住所 */
.header_info{
	float:right;
	text-align:right;
	padding-top: /*24px*/30px;
}
.header_info li{
}
.header_info_ad{
	font-size:13px;
	margin-right:70px;
	letter-spacing:1.2px;
	color:#555555;
}
.header_info_tel{
	position:relative;
	padding-left:45px;
	margin-right:60px;
	font-size:37.63px;
	text-align:right;
	font-family: 'Roboto', sans-serif;
	font-weight:300;
	line-height:1.3;
	letter-spacing:0.13em;
}
.header_info_tel:before{
	position:absolute;
	top:0;
	bottom:0;
	left:0;
	width:42px;
	height:34px;
	margin:auto;
	background-image:url(../images/tel.png);
	background-repeat:no-repeat;
	content:"";
}
.header_info_tel a{
	color:#555555;
}

.header_insta {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 400px;
	display: flex;
	align-items: center;
}
.header_insta img {
	width: auto;
	height: auto;
}
/*============================================================================

	nav

============================================================================*/

nav {
	position: absolute;
	top:552px;
	width:100%;
	height:102px;
	padding:0 70px;
	z-index:999999;
	background:#fff;
	border-bottom:1px solid #f2eddf;
	box-sizing:border-box;
}
@media screen and (max-width:1255px) {
	nav{
		padding: 0 60px;
	}
}
nav ul{
	height: inherit;
	/*padding-left:20px;*/
	text-align: center;
	display: flex;
	justify-content: space-between;
	align-content: center;
	/*width: 90%;
  	margin: 0 auto;*/
}
nav li {
	display:inline-block ;
	position:relative;
	height:inherit;
}
/*nav li:first-child::before {
    position: absolute;
    content: "";
    background: #e0e0e0;
    left: -50px;
    top: calc(50% - 15px);
    width: 2px;
    height: 35px;
 }*/
nav li::after {
    position: absolute;
    content: "";
    background: #e0e0e0;
    right: 0;
    top: calc(50% - 15px);
    width: 2px;
    height: 35px;
 }
nav li:last-of-type::after{
	content: none;
}
nav li a{
	/*display: table;*/
	display: flex;
	align-items: center;
	padding-left:28px;/*35*/
	/*margin-right:35px;*/
	margin-right: /*25px*/ 20px;
	position:relative;
	line-height: 102px;
	/*font-size:18px;*/
	font-size:/*1.2vw*/ 1vw;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	color:#333;
	text-align:left;
}

@media screen and (max-width:1440px) {
	nav li a{
		/*margin-right:20px;*/
		/*margin-right: 16.7px;*/
		margin-right: 15px;
	}
}
/*アイコン*/
nav li a::before{
	position:absolute;
	top:0;
	bottom:0;
	left:0;
	margin:auto;
	content:"";
	transition: 0.2s ease-out;
}
nav li:nth-child(1) a::before{
	background:url(../images/nav01.png) no-repeat;
	width:24px;
	height:23px;
}
nav li:nth-child(2) a::before{
	background:url(../images/nav02.png) no-repeat;
	width:24px;
	height:23px;
}
nav li:nth-child(3) a::before {
  background: url(../images/nav11.png) no-repeat;
  width: 24px;
  height: 26px;
}
nav li:nth-child(4) a::before {
  background: url(../images/nav08.png) no-repeat;
  width: 22px;
  height: 24px;
}
nav li:nth-child(5) a::before {
  background: url(../images/nav12.png) no-repeat;
  width: 23px;
  height: 28px;
}
nav li:nth-child(6) a::before{
	background:url(../images/nav03.png) no-repeat;
	width:25px;
	height:24px;
}
nav li:nth-child(7) a::before{
	background:url(../images/nav09.png) no-repeat;
	width:16px;
	height:22px;
}
nav li:nth-child(8) a::before{
	background:url(../images/nav04.png) no-repeat;
	width:23px;
	height:24px;
}
/*nav li:nth-child(7) a::before{
	background:url(../images/nav08.png) no-repeat;
	width:21px;
	height:24px;
}*/
/*nav li:nth-child(6) a::before{
	background:url(../images/nav06.png) no-repeat;
	width:22px;
	height:22px;
}*/
nav li:nth-child(9) a::before{
	background:url(../images/nav05.png) no-repeat;
	width:26px;
	height:24px;
}
nav li:nth-child(10) a::before{
	background:url("../images/nav07.png") no-repeat;
	width:22px;
	height:23px;
}
nav li a:hover::before{
	top:-6px;
}

nav li a:hover{
	color:#777;
}
nav li a span{
	display:block;
	position:relative;
}
nav li a span:after{
	background:url(../images/nav_hover.png) no-repeat;
	width:31px;
	height:2px;
	position:absolute;
	bottom:32px;
	left:0;
	right:0;
	margin:auto;
	content:"";
	transition: 0.2s ease-out;
    transform: scaleX(0);
}
nav li a:hover span:after{
	transform: scaleX(1);
}




/* ホバーで出てくるメニュー */

nav ul li div {
	position: absolute;
	display:none;
	width:150%;
	top: 100%;
	left:0%;
	background-color: rgba(255,255,255,1.0);
	border:1px dashed #ccc;

}
nav ul li div a{
	display:block;
	width:100%;
	position:relative;
	padding: 13px 20px;
	border-bottom: 1px dashed #ccc;
	line-height:1.4;
	text-align:left;
	font-size:13px;
	box-sizing:border-box;
	transition:ease-in-out 0.3s;
}
nav ul li div a::after,
nav ul li div a::before{
	display:none;
}
nav ul li div a:hover {
	background-color: #F0F0F0;
	color:#333;
}

.nav_bnr{
	position:absolute;
	height:67px;
	right:70px;
	/*top: 0;
	bottom: 0;*/
	top: auto;
    bottom: 120px;
	margin:auto;
	transition:ease-in-out 0.3s;
}
.nav_sns span {
	display: flex;
	align-items: center;
	height: 102px;
}
.nav_sns img {
	width: 35px;
	height: 35px;
}

nav li.nav_sns a span:after {
	display: none;
}
nav li.nav_sns a {
	padding-left: 10px;
}
@media screen and (max-width:1200px) {
	.nav_bnr a img{
		width: 200px;
	}
}
/*@media screen and (max-width:1400px) {
	.nav_bnr{
		right:0;
	}
}*/
/*@media screen and (max-width:1520px) {
	.nav_bnr{
		top: auto;
		bottom: 120px;
	}
}*/
/*@media screen and (max-width:1580px) {
	.nav_bnr{
		top: auto;
		bottom: 120px;
	}
}*/

/* 矢印 */
.nav_arrow{
}
.nav_arrow img{
	display:block;
	position:absolute;
	top:0;
	right:5%;
	bottom:0;
	margin:auto;
	transition:0.2s ease-in-out;
}
nav ul li div a:hover .nav_arrow img{
	right:3%;
}
/* スクロールで追加されるクラス */
.fixed{
	position:fixed;
	top:0;
	left:0;
}



/*============================================================================

	#mainvisual

============================================================================*/

/* 下層ページのメインビジュアルの高さ、背景画像（トップページの高さはtop.css参照） */

#mainvisual{
	display:block;
	position:relative;
	height: 436px;
	background:url(../images/main_under.png) no-repeat center;
	background-size:cover;
	background-position:center ;
	background-repeat:no-repeat;
}
#mainvisual .inner{
	display:table;
	position:relative;
	height: inherit;
	width:1200px;
	margin: 0 auto;
	background-repeat:no-repeat;
}
#mainvisual h2{
	position:relative;
}
/* キャッチフレーズ */
.mainvisual_catch{
	position:absolute;
	/*top:144px;*/
	top:/*15%*/12%;
	right:-10px;
}
.mainvisual_catch h2{
	position:absolute;
}
.mainvisual_catch p{
	position:absolute;
	top: 20px;
    right: 113px;
}
.mainvisual_catch p:before{
	background:url(../images/onpu.gif) no-repeat;
	width:57px;
	height:38px;
	position:absolute;
	top: 12px;
    left: 9px;
	content:"";
}
.mainvisual_open{
	position:absolute;
	bottom: 160px;
    left: 6%;

}


/* 下層ページの見出し */
.mainvisual_headline {
	display: table-cell;
	padding-bottom:2px;
	letter-spacing: 0.15em;
	vertical-align: middle;
	text-align: center;
	text-shadow: 0 0 5px rgba(255,255,255,0.7);
}
.mainvisual_headline h2{
	font-weight:bold;
	font-size: 27px;
	color: #1F2774;
}
.mainvisual_headline p{
	display:inline-block;
	font-size:15px;
	color: #C0AB9A;
}

/* 飾りの英語の棒 */
.mainvisual_headline p::before,
.mainvisual_headline p::after{
	position: relative;
	content:"-";
}
.mainvisual_headline p::before{
	left:-0.5em;
}
.mainvisual_headline p::after{
	right:-0.5em;
}

/* 背景変更用 */
#mainvisual.bg01{
	background-image:url(../images/main_bg01.png);
	background-position: center 0%;
	background-size: cover;
}
#mainvisual.bg02{
	background-image:url(../images/main_bg02.png) ;
	background-position: center 0%;
	background-size: cover;
	
}
#mainvisual.bg03{
	background-image:url(../images/main_bg03.png) ;
	background-position: center 0%;
	background-size: cover;
}
#mainvisual.bg04{
	background-image:url(../images/main_bg04.png) ;
	background-position: center 0%;
	background-size: auto;
}
#mainvisual.bg05{
	background-image:url(../images/main_bg05.png);
	background-position: center 0%;
	background-size: cover;
}


.medical_video {
  text-align: center;
}
.medical_video video {
  width: 660px;
}


/*==================================================================

	#contents

==================================================================*/ 

main{
	display:block;
}
#container{
/*	padding-top:100px;*/
	padding-bottom: 97px;
}

#contents{
	position:relative;
	width:1200px;
	margin:0 auto;
	padding-top:180px;
	padding-bottom: 100px;
}
#contents::after {
	display: block;
	clear: both;
	content: "";
}



#contents_left{
	float:left;
	width:860px;
}
#contents_right{
	float:right;
	width:280px;
	font-size:15px;
	line-height:1.6;
}
.right_medical h3{
	text-align:center;
}
.right_medical h3 a{
	display:block;
	margin:0 30px;
	position:relative;
	padding:20px 0;
	background-color:#fff;
	letter-spacing:2px;
	border:1px dashed #ccc;
	ont-family: "FOT-筑紫A丸ゴシック Std M";
	color:#333;
	font-size:19px;
	transition:0.1s ease-in-out;
}
.right_medical h3 a:before{
	background-color:#fff;
	background-image:url(../images/top_medical_h3.png);
	background-repeat:no-repeat;
	background-position:center;
	width:35px;
	height:39px;
	padding:4px;
	position:absolute;
    top: -30px;
    left: -13px;
	right:0;
	margin:auto;
	content:"";
}
.right_medical h3 a span{
	display:block;
	font-family: 'Roboto', sans-serif;
	font-size:11px;
	letter-spacing:1px;
	color:#00a0e9;
}
.right_medical h3 a:hover{
	color:#ccc;
}

.right_medical ul{
	margin-top:-20px;
	padding:35px 0 20px;
	border:1px dashed #ccc;
}
.right_medical li{
	margin:0 20px 15px;
	margin-left:16px;
}

.right_medical li a{
	display:block;
	position:relative;
	padding:18px 0px 18px 30px;
	line-height:1;
	font-size:16px;
	border:1px dashed #C3C3C3;
	background:#fff;
	color:#333;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	letter-spacing:2.5px;
	transition:ease-in-out 0.2s ;
}
.right_medical li a:before{
	width:100%;
	height:100%;
	position:absolute;
	left:6px;
	top:6px;
	border:1px solid #D9D9D9;
	content:"";
	z-index:-1;
	transition:ease-in-out 0.2s ;
	box-sizing:border-box;
}
.right_medical li a:hover:before{
	left:0;
	top:0;
}
.right_medical li a:after{
	position:absolute;
	top:0;
	bottom:0;
	right:35px;
	width: 9px;
	height:10px;
	margin:auto;
	background:url(../images/arrow03.png) no-repeat;
	transition:0.3s ease-in-out;
	content:"";
}
.right_medical li a:hover{
	background-color:#eeeeee;
}
.right_medical li a i{
	margin-right:7px;
}





/*============================================================================

	$footer

============================================================================*/

footer {
	position:relative;
	width:100%;
	background:#f8f6f2;
}

.footer_info{
	position:relative;
	width:1200px;
	margin:0 auto;
	padding-top:82px;
	padding-bottom:64px;
}
.footer_info_sec1{
	float:left;
	width:513px;
	box-sizing:border-box;
}

h3.footer_logo,h3.footer_logo img{
	width:447px;
	height:41px;
	margin:0 auto 40px;
}
.footer_info_sche{
	margin-bottom:47px;
}
.footer_info_list dl{
	margin-bottom:12px;
}
.footer_info_list dt{
	float:left;
	width:120px;
	height:38px;
	text-align:center;
	line-height:38px;
	color:#00a0e9;
	font-size:16px;
	font-family: 'Roboto', sans-serif;
	border:1px dashed #00a0e9;
	box-sizing:border-box;
}
.footer_info_list dd{
	float:left;
	line-height:38px;
	padding-left:22px;
	letter-spacing:1.2px;
}
.footer_info_list dl:last-child dd a{
	color:#00a0e9;
	font-family: 'Roboto', sans-serif;
	font-weight:500;
	font-size:25px;
	letter-spacing:3px;
}
.footer_info_list dl:last-child dd a:hover{
	color:#555;
}
.footer_info_list p.footer_message{
	margin-left: 25px;
	position: relative;
}
.footer_info_list p.footer_message::before{
/*top: 557px;
left: 139px;*/
	top: 7px;
	left: -25px;
width: 0;
height: 0;
border: 6px solid transparent;
border-bottom: 13px solid #1aaeeb;
position: absolute;
content: "";
}

.footer_info_sec2{
	float:right;
	width:600px;
}
.footer_info_sec2 iframe{
	border:2px solid #fff !important;
	margin-bottom:4px;
	box-sizing:border-box;
}

.footer_access{
	width:100%;
	height:66px;
	line-height:66px;
	border:2px dashed #fff;
	text-align:center;
	box-sizing:border-box;
	font-size:18px;
	letter-spacing:2px;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	color:#00a0e9;
}
.footer_access p{
	position:relative;
	z-index:1;
}
.footer_access p:after{
	background:#fff;
	width:394px;
	height:16px;
	position:absolute;
	bottom:16px;
	left:0;
	right:0;
	margin:auto;
	content:"";
	z-index:-1;
}



.pagetop{
	position:absolute;
	top:-25px;
	right:0;
	transition:ease-in-out 0.3s;
}
.pagetop:hover{
	top:-35px;
}

/* コピーライト */
.copy{
	position:absolute;
	top:0;
	left:0;
	width:70px;
	height:653px;
	background:#fff;
	text-align: center;
	z-index:9999;
}
.copy img{
	position:absolute;
	top:0;
	bottom:0;
	left:0;
	right:0;
	margin:auto;
}










/*==================================================================

	タイトル

==================================================================*/

/*英語メインver*/
h3.tit01 {
	position: relative;
	margin-bottom: 30px;
	padding:14px ;
	letter-spacing: 2px;
	line-height: 1.4;
	color: #555;
	font-size: 28px;
	font-family: 'Roboto', sans-serif;
	font-weight:400;
	text-align: center;
}
h3.tit01 span{
	display:block;
	position:relative;
	letter-spacing: 2px;
	color: #009fe8;
	font-size:16px;
	font-family: "FOT-筑紫A丸ゴシック Std M";
}


/* 日本語メインver */
h3.tit02 {
	position: relative;
	margin-bottom: 30px;
	padding:14px 0;
	letter-spacing: 3.5px;
	color: #555;
	font-size: 26px;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	line-height: 1.4;
	text-align:center;
}
h3.tit02 span{
	display:block;
	color:#00a0e9;
	font-family: 'Roboto', sans-serif;
	font-size:15px;
	letter-spacing:1.5px;
	margin-top:9px;
}

/* 左寄せ（日本語メイン・英語茶色） */
h3.tit03{
	display:table;
	position: relative;
	margin-bottom: 30px;
	padding:14px 0;
	letter-spacing: 3.5px;
	color: #555;
	font-size: 26px;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	line-height: 1.4;
	text-align: left;
}
h3.tit03 span{
	color:#d9a568;
	font-family: 'Roboto', sans-serif;
	font-size:14px;
	letter-spacing:1.5px;
	margin-left:10px;
}
h3.tit03:after{
	background:url(../images/bar.png) repeat-x;
	width:2000px;
	height:3px;
	position:absolute;
	bottom:0;
	right:-140px;
	content:"";
}

h4.tit01 {
	position: relative;
	margin-bottom: 28px;
	letter-spacing: 0.2em;
	line-height: 1.7;
	color: #c69358;
	font-size: 22px;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	text-align:left;
}
h4.tit02 {
	position: relative;
	margin-bottom: 28px;
	letter-spacing: 0.2em;
	line-height: 1.7;
	color: #009fe8;
	font-size: 22px;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	text-align:left;
}
h4.tit03 {
	position: relative;
	margin-bottom: 28px;
	letter-spacing: 0.2em;
	line-height: 1.7;
	color: #68b474;
	font-size: 22px;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	text-align:left;
}
.cancel_policy_box h4.tit02 {
	margin-bottom: 15px;
}
 
h5.tit01{
	position: relative;
	margin-bottom: 12px;
	letter-spacing:0.1em;
	color: #555;
	font-size: 17px;
	font-weight: bold;
}


.tit04 {
	position: relative;
	margin-bottom: 28px;
	letter-spacing: 0.2em;
	line-height: 1.7;
	color: #009fe8;
	font-size: 22px;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	text-align:left;
}
.tit04::before {
	content: "";
	display: inline-block;
	width: 30px;
	height: 22px;
	margin-right: 8px;
	background: url("../images/logo3.svg") no-repeat center bottom;
	background-size: contain;
}


/*==================================================================

	共通

==================================================================*/

/*院長略歴*/
.list01 {
	margin: 0 0 15px;
	padding: 0;
	border-width: 0 1px 1px;
}
.list01 dt {
	margin: 0;
	padding: 14px 3px 0px;
}
.list01 dd {
	margin: -38px 0 0;
	padding: 12px 4px 10px 100px;
	border-bottom: 1px dotted #ACACAC;
}

/*院長略歴　年月無し*/
.list02 {
	margin: 0 0 15px;
	border-width: 0 1px 1px;
}
.list02 li {
	margin: 0 0px 0px;
	padding: 6px 4px 6px 0;
	border-bottom: 1px dotted #ddd;
}

/*まる*/
.list03{
}
.list03 li{
	position:relative;
	margin-bottom:10px;
	padding-left:15px;
}
.list03 li:last-child{
	margin-bottom:0;
}
.list03 li:before{
	display: block;
	position: absolute;
	top: 10px;
	left: 0;
	width: 3px;
	height: 3px;
	background-color: #00a0e9;
	border: 1px solid #00a0e9;
	border-radius: 100%;
	content: '';
}
.list03 li i{
	margin-right:8px;
}
.list03.adj {
	padding: 16px 2em;
	background: rgba(255, 255, 255, 0.8);
}
.list03.adj li:before{
	background-color: #c69358;
	border: 1px solid #c69358;
}

/*さんかく*/
.list04 li{
	position: relative;
	margin-bottom:15px;
	padding-left:22px;
	color:#00a0e9;
}
.list04 li:before{
	position:absolute;
	top:0.5em;
	left:7px;
	width: 0;
	height: 0;
	border:5px solid transparent;
	border-left: 5px solid #00a0e9;
	content:"";
}

/*やじるし*/
.list05 li{
	position:relative;
	margin-bottom: 10px;
	line-height:1;
	padding-left:15px;
}
.list05 li:before{
	position:absolute;
	left:0;
	top:0.3em;
	height:5px;
	width:5px;
	transform:rotate(45deg);
	background-color: transparent;
	border-top:1px solid #333;
	border-right:1px solid #333;
	content:"";
}

/* まる & 背景 */
.list06{
	padding:35px 15px 25px 45px;
	border:1px dashed #B1B1B1;
}
.list06:after {
	display: block;
	clear: both;
	content: "";
}
.list06 li{
	position:relative;
	float:left;
	margin-bottom:15px;
	padding-left:0.9em;
	padding-right:5%;
	
}
.list06 li:before{
	display: block;
	content: '';
	position: absolute;
	top: 10px;
	left: 0;
	width: 3px;
	height: 3px;
	background-color: #00a0e9;
	border: 1px solid #00a0e9;
	border-radius: 100%;
}

/*まる & 枠 */
.list07{
	border:1px dashed #B1B1B1;
	padding: 30px ;
	font-size:14.5px;
}
.list07 li{
	padding-left:0.9em;
	margin-bottom:10px;
	position:relative;
}
.list07 li:last-child{
	margin-bottom:0;
}
.list07 li:before{
	display: block;
	content: '';
	position: absolute;
	top: 10px;
	left: 0;
	width: 3px;
	height: 3px;
	background-color: #00a0e9;
	border: 1px solid #00a0e9;
	border-radius: 100%;
}
.list07 li i{
	margin-right:8px;
}

/*チェック*/
.list08{
	margin-bottom:30px;
	padding:35px 10px 20px 45px;
	border:1px dashed #B1B1B1;
}
.list08:after{
	display: block;
	clear: both;
	content: "";
}
.list08 li{
	position:relative;
	float:left;
	margin-right: 5%;
	margin-bottom:20px;
	margin-left: 28px;
	border-bottom: 1px dashed #B1B1B1;
}
.list08 li:before{
	display: block;
	position: absolute;
	top: 3px;
	left: -28px;
	width: 20px;
	height: 20px;
	background-image:url(../images/check.svg);
	background-repeat:no-repeat;
	background-position:left center;
	content: '';
}

/*MOREボタン*/
.btn01{
	position:relative;
	top:10px;
	margin-bottom:10px;
	z-index:1;
}
.btn01 a{
	display:inline-block;
	position:relative;
	padding:13px 80px 13px 50px;
	line-height:1;
	font-size:16px;
	border:1px dashed #d0d0d0;
	background:#fff;
	color:#333;
	text-align:center;
	letter-spacing:2.5px;
	font-family: 'Roboto', sans-serif;
	transition:ease-in-out 0.3s ;
}
.btn01 a:hover{
	background-color:#eeeeee;
}
.btn01 a:before{
	width:100%;
	height:100%;
	position:absolute;
	left:6px;
	top:6px;
	border:1px solid #eeeeee;
	content:"";
	z-index:-1;
	transition:ease-in-out 0.2s ;
}
.btn01 a:hover:before{
	left:0;
	top:0;
}
.btn01 a:after{
	position:absolute;
	top:0;
	bottom:0;
	right:35px;
	width: 9px;
	height:10px;
	margin:auto;
	background:url(../images/arrow03.png) no-repeat;
	transition:0.3s ease-in-out;
	content:"";
}
.btn01 a:hover:after{
	right:25px;
}


/*ボタン 日本語*/
.btn02{
}
.btn02 a{
	display:inline-block;
	position:relative;
	padding:18px 80px 18px 50px;
	line-height:1;
	font-size:16px;
	border:1px dashed #C3C3C3;
	background:#fff;
	color:#333;
	text-align:center;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	letter-spacing:2.5px;
	transition:ease-in-out 0.2s ;
}
.btn02 a:before{
	width:100%;
	height:100%;
	position:absolute;
	left:6px;
	top:6px;
	border:1px solid #D9D9D9;
	content:"";
	z-index:-1;
	transition:ease-in-out 0.2s ;
	box-sizing:border-box;
}
.btn02 a:hover:before{
	left:0;
	top:0;
}
.btn02 a:after{
	position:absolute;
	top:0;
	bottom:0;
	right:35px;
	width: 9px;
	height:10px;
	margin:auto;
	background:url(../images/arrow03.png) no-repeat;
	transition:0.3s ease-in-out;
	content:"";
}
.btn02 a:hover{
	background-color:#eeeeee;
}
.btn02 a i{
	margin-right:7px;
}



/* 画像を右寄せ　※画像サイズはhtmlで調整 */
.img_fr{
	display:block;
	position:relative;
	float:right;
	margin-left:30px;
	margin-bottom:0 !important;
	text-align:center;
}
.img_fr img{
	border-radius:3px;
	margin-bottom:7px;
	
}
/* 画像に対して説明文がある場合は、dlで囲い、dtに画像を、ddにテキストを使う */
.img_fr dd{
	padding-left:20px;
	line-height:1.3;
	font-size:15px; 
	font-weight:bold;
	color: #1F2774;
	text-align:left;
}
.img_flex {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
}
.img_flex img {
	display: block;
	height: 146px;
	margin: 5px;
}
.img_flex img:first-of-type {
	margin-left: 0;
}
.img_flex img:last-of-type {
	margin-right: 0;
}
.img_flex02 img {
	display: block;
	height: 250px;
	margin: 5px;
}
/*アニメーション遅らせて表示*/
.dalay01{
	animation-delay: 0.1s;
}
.dalay02{
	animation-delay: 0.2s;
}
.dalay03{
	animation-delay: 0.3s;
}
.dalay04{
	animation-delay: 0.4s;
}
.dalay05{
	animation-delay: 0.5s;
}
.dalay06{
	animation-delay: 0.6s;
}
.dalay07{
	animation-delay: 0.7s;
}
.dalay08{
	animation-delay: 0.8s;
}
.dalay09{
	animation-delay: 0.9s;
}
.dalay10{
	animation-delay: 1s;
}
.dalay20{
	animation-delay: 2s;
}



.color_red {
  color: #ff0000;
}
.color_blue02 {
	color: #009fe8;
}

/*マーカー*/
.marker {
	background:linear-gradient(transparent 60%, #DBF4FF 0%);
}


/*==================================================================

	table

==================================================================*/

.nowrap{
	white-space:nowrap;
}
/*フッターの診療時間*/
.tb01{
	margin-bottom:12px;
	border-spacing: 0;
	border-collapse: collapse;
	white-space:nowrap;
}
.tb01 td,.tb01 th{
	border-bottom:1px solid #e4e4e4;
	vertical-align: middle;
}
.tb01 tr:last-child td,.tb01 tr:last-child th{
	border:none;
}
.tb01 th:first-child{
	
}
.tb01 th{
	padding:10px 22px 8px 22px;
	line-height:1;
	white-space:nowrap;
	font-weight:bold;
	text-align:left;

}
.tb01 td{
	padding:10px 13px 8px 13px;
}


/*医院概要*/
.tb02{
	border-spacing: 0;
	text-align: left;
}
.tb02 td,.tb02 th{
	border-bottom:#ddd 1px dotted;
	line-height:1.4;
	font-size:15px;
	vertical-align:top;
}
.tb02 th{
	padding:8px 24px 8px 0;
	white-space:nowrap;
	text-align:left;
	font-weight: normal;
	color:#333;
}
.tb02 td{
	padding:8px 0;
	padding-right:0 !important;
	text-align:left;
}
.tb02 tr:last-child td,.tb02 tr:last-child th{
	border:none;
}

/* 料金表 */
.tb03 {
	width:100%;
	border-spacing: 1px;
	border-collapse: separate;
	background-color: #f0f0f0;
	white-space: nowrap;
}
.tb03 td, .tb03 th {
	padding: 12px 36px;
  text-align: center;
  border: 1px solid #ccc;
}
.tb03 th {
	font-weight: bold;
	white-space: nowrap;
	color: #666;
	background-color: #FAFAFA;
	font-size: 16px;
}
.tb03 th span {
	font-size: 13px;
}
.tb03 td {
	background-color: #ffffff;
	color: #666666;
	text-align: center;
}


/* 症例 */
.tb05 {
	width:100%;
	border-spacing: 1px;
	border-collapse: separate;
	background-color: #f0f0f0;
	white-space: normal;
}
.tb05 td, .tb05 th {
	padding: 12px 36px;
}
.tb05 th {
	font-weight: bold;
	white-space: nowrap;
	color: #666;
	background-color: #FAFAFA;
	font-size: 16px;
}
.tb05 th span {
	font-size: 13px;
}
.tb05 td {
	background-color: #ffffff;
	color: #666666;
}

/*==================================================================

	アンカーリンンク

==================================================================*/

/* 4個並び */
.ank01{
	margin:0 auto 100px;
}
.ank01 li{
	display:table;
	position:relative;
	float:left;
	width:24%;
	height:66px;
	margin-bottom:1.5%;
	margin-left:1.33%;
	line-height:1.4;
}
.ank01 li:nth-child(1),
.ank01 li:nth-child(5),
.ank01 li:nth-child(9){
	margin-left:0;
}
.ank01 li a{
	display: table-cell;
	padding:12px 5px 15px;
	border:1px solid #00408f;
	font-weight:bold;
	font-size:13px;
	color:#00408f;
	text-align:center;
	vertical-align:middle;
	transition:0.1s ease-in-out;
}
.ank01 li a:hover{
	background-color:#00408f;
	color:#fff;
}
.ank01 li i{
	display:block;
	position:absolute;
	left:0;
	right:0;
	bottom:4px;
	margin:auto;
}

#ank01, #ank02, #ank03, .anchor {
	margin-top: -105px;
	padding-top: 105px;
}

/*==================================================================

	.layout

==================================================================*/

/* 1つ並びのレイアウト。画像は無し、左にタイトル、右に文章 */

.layout01{
	padding-bottom:20px;
}
.layout01 dl {
    display: table;
    position: relative;
    top: 5px;
    width: 100%;
    margin-bottom: 5px;
}
.layout01 dl:before{
	position:absolute;
	top:-3px;
	left:0;
	width:100%;
	border-top: 1px dashed #B1B1B1;
	content:"";
}
.layout01 dl:last-child:after{
	position:absolute;
	bottom:-3px;
	left:0;
	width:100%;
	border-top: 1px dashed #B1B1B1;
	content:"";
}
.layout01 dt,
.layout01 dd{
	display:table-cell;
	box-sizing:border-box;
}

.layout01 dt{
	width:28%;
	padding:0 3%;
	border-right: 1px dashed #B1B1B1;
	letter-spacing: 0.1em;
	color: #009fe8;
	font-size:18px;
	font-weight:bold;
	text-align:center;
	vertical-align:middle;
}
/* 数字 */
.layout01 dt em{
    display: block;
    line-height: 1;
	margin:0 8px;
	font-family: 'Roboto Slab', serif;
	font-size:24px;
	font-weight:normal;
	color:#B1B1B1;
}
.layout01 dd{
		padding:3%;
}




/* 2つ並びのレイアウト。最初(dt)にタイトル、画像がその下(dd)、画像の下に文章 */
.layout02{
}
.layout02::after{
	display: block;
	clear: both;
	content: "";
}
.layout02 dl{
	width:40.2%;
	float:left;
	margin-right:4%;
	margin-bottom:25px;
	padding:3% 2.5% 4%;
	border:1px dashed #B1B1B1;
}
.layout02 dl:nth-child(even){
	margin-right:0;
}
.layout02 dl dt{
	margin-bottom:10px;
	font-weight: bold;
	font-size:18px;
	line-height:1.3;
	color: #009fe8;
	text-align:center;
}
/* 数字 */
.layout02 dl dt em{
	margin-right:10px;
	color:#BDA087;
	font-family: 'Roboto Slab', serif;
	font-size:30px;
	font-weight: normal;
}
.layout02 dl dd{
	line-height:1.6;
	font-size:14.5px;
	text-align:center;
}
.layout02 dl dd img{
	width:160px;
	margin-bottom:15px;
}
.layout02 dl dd p{
	margin-bottom:0;
	text-align:justify;
}




/* 1つ並びのレイアウト。画像が左、右にタイトル、タイトル下に文章 */
.layout03{
	padding-bottom:20px;
}
.layout03 dl{
	display:table;
	position:relative;
	margin-bottom:20px;
	border:1px dashed #B1B1B1;
	padding:2%;
}
.layout03 dt,
.layout03 dd{
	display:table-cell;
	box-sizing:border-box;
	vertical-align:middle;
}
.layout03 dt {
    width: 27%;
    padding: 3%;
	color: #009fe8;
    background-color: #fff;
    text-align: center;
}
.layout03 dt img {
    width: 100%;
    padding-bottom: 10px;
}
.layout03 dd {
    width: 73%;
    padding: 1% 3%;
}
.layout03 dd h5{
	color: #009fe8;
	font-size:18px;
	font-weight:bold;
}
.layout03 dd h5 em{
	margin-right:10px;
	font-family: 'Roboto Slab', serif;
	font-weight:normal;
	color:#B1B1B1;
	font-size:30px;
}




/* 1つ並びのレイアウト。画像が左、右にタイトル、タイトル下に文章、タイトルと文章のエリア(dd)は背景色が別の色 */

.layout04{
	padding-bottom:20px;
}
.layout04 dl{
	display:table;
	position:relative;
	margin-bottom:20px;
	border:1px dashed #B1B1B1;
	padding:2%;
}
.layout04 dt,
.layout04 dd{
	display:table-cell;
	box-sizing:border-box;
}
.layout04 dt{
	width:27%;
	padding-right:2%;
	vertical-align:middle;
}
.layout04 dt img{
	width:100%;
}
.layout04 dd{
	width:73%;
	padding:3%;
	background-color:#fff;
	vertical-align:middle;
}
.layout04 dd h5{
	color: #009fe8;
	font-size:18px;
	font-weight:bold;
}
.layout04 dd h5 span{
	margin-right:10px;
	font-family: 'Roboto Slab', serif;
	color:#B1B1B1;
	font-size:30px;
	font-weight: normal;
}



/* 1つ並びで3列に区切られたレイアウト。画像が左、画像の下にタイトル、右に文章 */
.layout05{
	padding-bottom:20px;
}
.layout05 dl{
	display:table;
	position:relative;
	margin-bottom:20px;
	border:1px dashed #B1B1B1;
	padding:2%;
	font-size:14px;
}
.layout05 dt,
.layout05 dd{
	display:table-cell;
	box-sizing:border-box;

}
.layout05 dt{
	width:25%;
	background-color:#fff;
	text-align:center;
		vertical-align:middle;
}
.layout05 dt img {
    width: 100%;
    padding-bottom: 10px;
}
.layout05 dd{
	padding:1% 3%;
	vertical-align:top;
}
.layout05 dd:nth-child(2){
	width:36.5%;
}
.layout05 dd:nth-child(3){
	width:38.5%;
	border-left:1px solid #e2e2e2;
}

.layout05 dd h5 em{
	margin-right:10px;
	color:#BDA087;
	font-family: "Times New Roman", Times, serif;
	font-size:30px;
	font-weight: normal;
}
.layout05 dd h5{
	font-size:15px;
	font-weight:bold;
}
.layout05_text1{
}

.layout05_text1 ul{
	margin-bottom:15px;
}

.layout05_text1 ul li{
	text-indent:-1em;
	margin-left:1em;
}


/* 1つ並びで3列に区切られたレイアウト。左がタイトル、真ん中と右に文章 */
.layout06{
	padding-bottom:20px;
}
.layout06 dl {
    display: table;
    position: relative;
    padding-bottom: 5px;
    font-size: 14px;
}
.layout06 dl:before{
	position:absolute;
	top:-3px;
	left:0;
	width:100%;
	border-top: 1px dashed #B1B1B1;
	content:"";
}
.layout06 dl:last-child:after{
	position:absolute;
	bottom:-3px;
	left:0;
	width:100%;
	border-top: 1px dashed #B1B1B1;
	content:"";
}
.layout06 dt,
.layout06 dd{
	display:table-cell;
	box-sizing:border-box;

}
.layout06 dt{
	width:28%;
	padding:0 3%;
	border-right: 1px dashed #B1B1B1;
	letter-spacing: 0.1em;
	color: #009fe8;
	font-size:18px;
	font-weight:bold;
	text-align:center;
	vertical-align:middle;
}
/* 数字 */
.layout06 dt em{
	display:block;
	color:#ccc;
	font-family: 'Roboto Slab', serif;
	font-size:30px;
	font-weight: normal;
}
.layout06 dd {
    padding: 2% 3%;
    vertical-align: top;
}
.layout06 dd:nth-child(2){
	width:40%;
}
.layout06 dd:nth-child(3){
	width:35%;
	border-left:1px solid #e2e2e2;
}

.layout06 dd h5{
	font-size:15px;
	font-weight:bold;
}
.layout06_text1{
}
.layout06_text1 ul{
	margin-bottom:15px;
}
.layout06_text1 ul li span{
	display:block;
}


/* 3つ並びのレイアウト。 */
.layout07{
}
.layout07::after{
	display: block;
	clear: both;
	content: "";
}
.layout07 dl{
float: left;
width: 26%;
margin-right: 2%;
margin-bottom:20px;
padding: 3%;
border-radius: 10px;
	background-color:#F7F7F7;
}
.layout07 dl:nth-child(3n){
	margin-right:0;
}
.layout07 dl dt{
	margin-bottom: 7px;
	padding-bottom: 7px;
	border-bottom: 1px dashed #ddd;
	font-size: 17px;
	font-weight: bold;
	text-align: center;
}
.layout07 dl dt em{
	margin-right:8px;
	font-size:24px;
font-family: 'Quicksand', sans-serif;
}
.layout07 dl dd{
	line-height:1.5;
}

/* 3つ並びのレイアウト。矢印付き */
.layout08{
	overflow:hidden;
}
.layout08 dl{
	position:relative;
float: left;
width: 24.6%;
margin-right: 4.1%;
margin-bottom:25px;
padding: 3%;
border-radius: 10px;
	background-color:#F7F7F7;
}
.layout08 dl::before {
    position: absolute;
    right: -17px;
    top: 0;
    height: 7px;
    width: 7px;
    transform: rotate(45deg);
    background-color: transparent;
    border-top: 2px solid #33409A;
    border-right: 2px solid #33409A;
    content: "";
    bottom: 0;
    margin: auto;
}
.layout08 dl:nth-child(3n){
	margin-right:0;
}

.layout08 dl dt{
	margin-bottom: 7px;
	padding-bottom: 7px;
	border-bottom: 1px dashed #ddd;
	font-size: 17px;
	font-weight: bold;
	text-align: center;
}
.layout08 dl dt em{
	margin-right:8px;
	font-size:24px;
font-family: 'Quicksand', sans-serif;
}
.layout08 dl dd{
	line-height:1.5;
}


/* layout11 */
/*
.layout11{
  position: relative;
}
.layout11_box{
  padding: 8px;
  background: #FAFAFA;
}
[class^="layout11_image"] p{
  margin-bottom: 0;
}
[class^="layout11_image"] img{
  width: 100%;
  height: auto;
}
[class^="layout11_text"]{
  margin-top: 8px;
}
[class^="layout11_text"] dl{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
[class^="layout11_text"] dl dt{
  background: #009fe8;
  color: #fff;
  font-weight: bold;
  text-align: center;
  padding: 12px;
  border: 1px solid #009fe8;
  width: 20%;
  margin-bottom: 2px;
}
[class^="layout11_text"] dl dd{
  padding: 12px;
  background: #fff;
  border: 1px solid #009fe8;
  width: 74%;
  margin-bottom: 2px;
}
[class^="layout11_text"] .desc{
  background: #fff;
  border: 1px solid #009fe8;
  padding: 16px;
}
[class^="layout11_text"] .desc p{
  margin-bottom: 0;
}
*/

/* layout11 ver.1 */
/*
.layout11_text01 dl dt{
  margin-left: 0;
}

/* layout11 ver.2 */
/*
.layout11_image02{
  display: flex;
  justify-content: space-between;
}
.layout11_image02 span{
  position: relative;
  display: block;
  width: 47%;
}
.layout11_image02 span:last-child::before{
  position: absolute;
  top: 0;
  bottom: 0;
  left: -42px;
  margin: auto;
  display: flex;
  align-items: center;
  content: "\f054";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  font-size: 24px;
  color: var(--main-color);
  line-height: 1;
}
.layout11_text02 dl{
  width: 100%;
}
.layout11_text02 dl dt{
  margin-left: 2px;
  margin-bottom: 2px;
  width: 15%;
}
.layout11_text02 dl dt:nth-of-type(odd){
  margin-left: 0;
}
.layout11_text02 dl dd{
  width: calc(35% - 1px);
}
.layout11_text02 .desc{
  width: 100%;
}
*/


/* layout11 */
.layout11 {
 position: relative;
}

.layout11_box {
  margin: 0 0 40px;
 padding: 10px 12px;
 background: #f8f6f2;
}

[class^=layout11_image] img {
 width: 100%;
 height: auto;
}

[class^=layout11_text] {
 margin-top: 8px;
}

[class^=layout11_text] dl {
 display: flex;
 flex-wrap: nowrap;
 justify-content: space-between;
}

[class^=layout11_text] dl dt {
   background: #009fe8;
 color: #fff;
 font-weight: bold;
 text-align: center;
 padding: 12px;
 border: 1px solid #009fe8;
 width: 20%;
 margin-bottom: 2px;
}

[class^=layout11_text] dl dd {
 padding: 12px;
 background: #fff;
  border: 1px solid #009fe8;
 width: 80%;
 margin-bottom: 2px;
}

[class^=layout11_text] .desc {
 background: #fff;
 border: 1px solid #009fe8;
 padding: 16px;
}

[class^=layout11_text] .desc p {
 margin-bottom: 0;
}

/* layout11 ver.1 */
.layout11_text01 dl dt {
 margin-left: 0;
}

/* layout11 ver.2 */
.layout11_image02 {
 display: flex;
 justify-content: space-between;
}

.layout11_image02 span {
 position: relative;
 display: block;
 width: 47%;
}

.layout11_image02 span:last-child::before {
 position: absolute;
 top: 0;
 bottom: 0;
  left: -38px;
 margin: auto;
 display: flex;
 align-items: center;
 content: "\f054";
 font-family: "Font Awesome 5 Free";
 font-weight: 900;
 font-size: 24px;
  color: #555;
 line-height: 1;
}

.layout11_text02 dl dt {
 margin-bottom: 5px;
}
.layout11_text02 dl dd {
 margin-left: 5px;
 margin-bottom: 5px;
}




/*-----△241219追加css-----*/
/*注意書き*/
.caution {
 background: var(--bg-color);
 display: block;
 position: relative;
 padding: 25px;
 border-radius: 15px;
}

.caution span {
 width: 55px;
 height: 55px;
 background: var(--main-color);
 display: flex;
 justify-content: center;
 align-items: center;
 position: absolute;
 top: -15px;
 left: -5px;
 border-radius: 50%;
 font-size: 25px;
 font-weight: 600;
 color: #fff;
 z-index: 2;
}

.caution span::before {
 position: absolute;
 width: 15px;
 height: 20px;
 bottom: -3px;
 right: -3px;
 margin: auto;
 -webkit-clip-path: polygon(100% 85%, 40% 0, 0 53%);
 clip-path: polygon(100% 85%, 40% 0, 0 53%);
 background-color: var(--main-color);
 z-index: 1;
 content: "";
}

.caution p:nth-of-type(1) {
 font-size: 18px;
 margin: 0 0 15px;
 padding: 0 0 0 40px;
 font-family: var(--HGW6);
 color: var(--main-color);
}





/*==================================================================

	box

==================================================================*/

.box1{
	position:relative;
	width:1200px;
	margin:0 auto 50px;
}
.box2{
	margin-bottom:100px;
}
.text {
	position:relative;
	margin-bottom: 50px;
}
.text02 {
	position:relative;
	margin-bottom: 80px;
}
.text p {
	margin-bottom:1em;
}
.text:last-child{
	margin-bottom:0;
}



/*==================================================================

	.top_greeting

==================================================================*/

.top_greeting{
	background:#f8f6f2;
	padding-top:67px;
	padding-bottom:88px;
}
.top_greeting h3.tit03{
	margin-top:36px;
}
.top_greeting h3.tit03:before{
	background:url(../images/top_greeting_h3.png) no-repeat;
	width:38px;
	height:29px;
	position:absolute;
	top:-6px;
	left:77px;
	content:"";
}

.top_greeting .text{
	position:absolute;
	z-index:2;
	line-height:2.1;
	letter-spacing:1.5px;
}
.doctor_name{
	display:table;
	position:relative;
	color:#71bee2;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	padding-top:7px;
}
.doctor_name:before{
	background:url(../images/kirakira.png) no-repeat;
	width:25px;
	height:20px;
	position:absolute;
	top: -6px;
    right: -17px;
	content:"";
}


/*ご挨拶横のスライド*/
.greet_slide{
	position:relative;
	float:right;
	width:721px;
	height:498px;
	margin:0;
	margin-top:-104px !important;
}
.greet_slide .swiper-pagination-bullet{
	background:url(../images/slide_off.png) no-repeat;
	width:15px;
	height:13px;
	border-radius:0;
	margin: 0 6px !important;
	opacity:1 !important;
}
.greet_slide .swiper-pagination-bullet-active{
	background:url(../images/slide_on.png) no-repeat;
}


/*-----  doctor02.html -----*/
.doctor02_case{
	width: 80%;
	margin: 0 auto;
}
/*==================================================================

	.top_medical

==================================================================*/

/*初期設定*/

/*
.top_medical{
	padding-top:96px;
}
.top_medical h3.tit02:before{
	background:url(../images/top_medical_h3.png) no-repeat;
	width:35px;
	height:39px;
	position:absolute;
	top: -28px;
    left: -10px;
    right: 0;
	margin:auto;
	content:"";
}


.top_medical_list a{
	float:left;
	position:relative;
	top:0;
	left:0;
	margin-right:30px;
	width:276px;
	height:348px;
	box-sizing:border-box;
	margin-bottom:58px;
	border:1px dashed #a4a4a4;
	text-align:center;
	z-index:1;
	transition:ease-in-out 0.3s;
}
.top_medical_list a:after{
	border:1px solid #d3d3d3;
	width:100%;
	height:100%;
	position:absolute;
	bottom:-6px;
	right:-6px;
	content:"";
	z-index:-2;
	transition:ease-in-out 0.3s;
	box-sizing:border-box;
}
.top_medical_list a:hover:after{
	bottom:0;
	right:0;
}
.top_medical_list dl{
	position:relative;
	background:#fff;
	width:100%;
	height:100%;
}
.top_medical_list dl:before{
	width:0;
	height:100%;
	position:absolute;
	top:0;
	left:0;
	content:"";
	transition:ease-in-out 0.3s;
}
.top_medical_list dl.medical_blue:before{
	background:#e5f5fd;
}
.top_medical_list dl.medical_green:before{
	background:#eff8f1;
}
.top_medical_list dl.medical_yellow:before{
	background:#fff9ea;
}
.top_medical_list dl.medical_brown:before{
	background:#faf5ee;
}
.top_medical_list a:hover dl:before{
	width:100%;
}
.top_medical_list a:nth-child(4),.top_medical_list a:nth-child(8){
	margin-right:6px;
}
.top_medical_list a:nth-child(5){
	clear:both;
}

.top_medical_list dt{
	position:relative;
	padding-top:31px;
	margin-bottom:10px;
}

.top_medical_list dt:before{
	position:absolute;
	top:13px;
	left:18px;
	letter-spacing:1.3px;
	font-family: 'Roboto Condensed', sans-serif;
}
.top_medical_list a:nth-child(1) dt:before{
	content:"General Dentistry";
}
.top_medical_list a:nth-child(2) dt:before{
	content:"Pediatric Dentistry";
}
.top_medical_list a:nth-child(3) dt:before{
	content:"Periodontal Disease";
}
.top_medical_list a:nth-child(4) dt:before{
	content:"Dental Surgery";
}
.top_medical_list a:nth-child(5) dt:before{
	content:"Implant";
}
.top_medical_list a:nth-child(6) dt:before{
	content:"Cosmetic Dentistry";
}
.top_medical_list a:nth-child(7) dt:before{
	content:"Preventive Dentistry";
}
.top_medical_list a:nth-child(8) dt:before{
	content:"Orthodontic";
}
.top_medical_list .medical_blue dt:before{
	color:#00a0e9;
}
.top_medical_list .medical_green dt:before{
	color:#76cc85;
}
.top_medical_list .medical_yellow dt:before{
	color:#fcc02e;
}
.top_medical_list .medical_brown dt:before{
	color:#d19e5b;
}

.top_medical_list dt:after{
	
}

.top_medical_list dl dt img{
	transition:ease-in-out 0.3s;
}
.top_medical_list a:hover dl dt img{
	opacity:0.7 !important;
	-webkit-filter: blur(1px);
     -moz-filter: blur(1px);
     -ms-filter: blur(1px);
     -o-filter: blur(1px);
     filter: blur(1px);
}

.top_medical_list dd h4{
	position:relative;
	font-size:22px;
	letter-spacing:1.5px;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	margin-bottom:17px;
	z-index:3;
}
.top_medical_list .medical_blue h4{
	color:#00a0e9;
}
.top_medical_list .medical_green h4{
	color:#76cc85;
}
.top_medical_list .medical_yellow h4{
	color:#fcc02e;
}
.top_medical_list .medical_brown h4{
	color:#d19e5b;
}


.top_medical_list dd p{
	display:table;
	position:relative;
	color:#333;
	width:231px;
	margin:0 auto;
	letter-spacing:1px;
	z-index:2;
}
.top_medical_list dd p:after{
	width:100%;
	height:13px;
	position:absolute;
	bottom:3px;
	left:0;
	content:"";
	z-index:-1;
}
.top_medical_list .medical_blue p:after{
	background:#e5f5fd;
}
.top_medical_list .medical_green p:after{
	background:#eff8f1;
}
.top_medical_list .medical_yellow p:after{
	background:#fff9ea;
}
.top_medical_list .medical_brown p:after{
	background:#faf5ee;
}

.top_medical_list dd.btn{
	display:table;
	width: 181px;
    position: absolute;
	bottom:-23px;
    left: -6px;
    right: 0;
    margin: auto;
    padding: 13px 74px 13px 40px;
	line-height:1;
	font-size:16px;
	border:1px dashed #a4a4a4;
	background:#fff;
	color:#333;
	text-align:center;
	letter-spacing:2.5px;
	font-family: 'Roboto', sans-serif;
	transition:ease-in-out 0.3s ;
	box-sizing:border-box;
}
.top_medical_list a:hover dd.btn{
	left:0;
	bottom:-29px;
}
.top_medical_list dd.btn:after{
	border:1px solid #d3d3d3;
	border-top:none;
	width:100%;
	height:25px;
	background:#fff;
	position:absolute;
	bottom:-6px;
	right:-6px;
	content:"";
	z-index:-1;
	transition:ease-in-out 0.3s ;
}
.top_medical_list a:hover dd.btn:after{
	bottom:0;
	right:0;
}
.top_medical_list dd.btn:before{
	width:9px;
	height:10px;
	position:absolute;
	top:0;
	bottom:0;
	right:35px;
	margin:auto;
	content:"";
	transition:ease-in-out 0.3s;
}
.top_medical_list .medical_blue dd.btn:before{
	background:url(../images/arrow_blue.png) no-repeat;	
}
.top_medical_list .medical_green dd.btn:before{
	background:url(../images/arrow_green.png) no-repeat;
}
.top_medical_list .medical_yellow dd.btn:before{
	background:url(../images/arrow_yellow.png) no-repeat;
}
.top_medical_list .medical_brown dd.btn:before{
	background:url(../images/arrow_brown.png) no-repeat;
}
.top_medical_list a:hover dd.btn:before{
	right:25px;
}

*/

.top_medical{
	padding-top:96px;
}
.top_medical h3.tit02:before{
	background:url(../images/top_medical_h3.png) no-repeat;
	width:35px;
	height:39px;
	position:absolute;
	top: -28px;
    left: -10px;
    right: 0;
	margin:auto;
	content:"";
}

.top_medical_list a{
	float:left;
	position:relative;
	top:0;
	left:0;
	margin-right:30px;
	width:276px;
	height:348px;
	box-sizing:border-box;
	margin-bottom:58px;
	border:1px dashed #a4a4a4;
	text-align:center;
	z-index:1;
	transition:ease-in-out 0.3s;
}
.top_medical_list a:after{
	border:1px solid #d3d3d3;
	width:100%;
	height:100%;
	position:absolute;
	bottom:-6px;
	right:-6px;
	content:"";
	z-index:-2;
	transition:ease-in-out 0.3s;
	box-sizing:border-box;
}
.top_medical_list a:hover:after{
	bottom:0;
	right:0;
}
.top_medical_list dl{
	position:relative;
	background:#fff;
	width:100%;
	height:100%;
}
.top_medical_list dl:before{
	width:0;
	height:100%;
	position:absolute;
	top:0;
	left:0;
	content:"";
	transition:ease-in-out 0.3s;
}
.top_medical_list dl.medical_blue:before{
	background:#e5f5fd;
}
.top_medical_list dl.medical_green:before{
	background:#eff8f1;
}
.top_medical_list dl.medical_yellow:before{
	background:#fff9ea;
}
.top_medical_list dl.medical_brown:before{
	background:#faf5ee;
}
.top_medical_list a:hover dl:before{
	width:100%;
}
.top_medical_list a:nth-child(4),.top_medical_list a:nth-child(8){
	margin-right:6px;
}
.top_medical_list a:nth-child(5){
	clear:both;
}

.top_medical_list dt{
	position:relative;
	padding-top:31px;
	margin-bottom:10px;
}

.top_medical_list dt:before{
	position:absolute;
	top:13px;
	left:18px;
	letter-spacing:1.3px;
	font-family: 'Roboto Condensed', sans-serif;
}
.top_medical_list a:nth-child(1) dt:before{
	content:"General Dentistry";
}
.top_medical_list a:nth-child(2) dt:before{
	content:"Pediatric Dentistry";
}
.top_medical_list a:nth-child(3) dt:before{
	content:"Periodontal Disease";
}
.top_medical_list a:nth-child(4) dt:before{
	content:"Dental Surgery";
}
.top_medical_list a:nth-child(5) dt:before{
	content:"Implant";
}
.top_medical_list a:nth-child(6) dt:before{
	content:"Cosmetic Dentistry";
}
.top_medical_list a:nth-child(7) dt:before{
	content:"Preventive Dentistry";
}
.top_medical_list a:nth-child(8) dt:before{
	content:"Orthodontic";
}
.top_medical_list a:nth-child(9) dt:before{
	content:"Whitening";
}
.top_medical_list .medical_blue dt:before{
	color:#00a0e9;
}
.top_medical_list .medical_green dt:before{
	color:#76cc85;
}
.top_medical_list .medical_yellow dt:before{
	color:#fcc02e;
}
.top_medical_list .medical_brown dt:before{
	color:#d19e5b;
}

.top_medical_list dt:after{
	
}

.top_medical_list dl dt img{
	transition:ease-in-out 0.3s;
}
.top_medical_list a:hover dl dt img{
	opacity:0.7 !important;
	-webkit-filter: blur(1px);
     -moz-filter: blur(1px);
     -ms-filter: blur(1px);
     -o-filter: blur(1px);
     filter: blur(1px);
}

.top_medical_list dd h4{
	position:relative;
	font-size:22px;
	letter-spacing:1.5px;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	margin-bottom:17px;
	z-index:3;
}
.top_medical_list .medical_blue h4{
	color:#00a0e9;
}
.top_medical_list .medical_green h4{
	color:#76cc85;
}
.top_medical_list .medical_yellow h4{
	color:#fcc02e;
}
.top_medical_list .medical_brown h4{
	color:#d19e5b;
}


.top_medical_list dd p{
	display:table;
	position:relative;
	color:#333;
	width:231px;
	margin:0 auto;
	letter-spacing:1px;
	z-index:2;
}
.top_medical_list dd p:after{
	width:100%;
	height:13px;
	position:absolute;
	bottom:3px;
	left:0;
	content:"";
	z-index:-1;
}
.top_medical_list .medical_blue p:after{
	background:#e5f5fd;
}
.top_medical_list .medical_green p:after{
	background:#eff8f1;
}
.top_medical_list .medical_yellow p:after{
	background:#fff9ea;
}
.top_medical_list .medical_brown p:after{
	background:#faf5ee;
}

.top_medical_list dd.btn{
	display:table;
	width: 181px;
    position: absolute;
	bottom:-23px;
    left: -6px;
    right: 0;
    margin: auto;
    padding: 13px 74px 13px 40px;
	line-height:1;
	font-size:16px;
	border:1px dashed #a4a4a4;
	background:#fff;
	color:#333;
	text-align:center;
	letter-spacing:2.5px;
	font-family: 'Roboto', sans-serif;
	transition:ease-in-out 0.3s ;
	box-sizing:border-box;
}
.top_medical_list a:hover dd.btn{
	left:0;
	bottom:-29px;
}
.top_medical_list dd.btn:after{
	border:1px solid #d3d3d3;
	border-top:none;
	width:100%;
	height:25px;
	background:#fff;
	position:absolute;
	bottom:-6px;
	right:-6px;
	content:"";
	z-index:-1;
	transition:ease-in-out 0.3s ;
}
.top_medical_list a:hover dd.btn:after{
	bottom:0;
	right:0;
}
.top_medical_list dd.btn:before{
	width:9px;
	height:10px;
	position:absolute;
	top:0;
	bottom:0;
	right:35px;
	margin:auto;
	content:"";
	transition:ease-in-out 0.3s;
}
.top_medical_list .medical_blue dd.btn:before{
	background:url(../images/arrow_blue.png) no-repeat;	
}
.top_medical_list .medical_green dd.btn:before{
	background:url(../images/arrow_green.png) no-repeat;
}
.top_medical_list .medical_yellow dd.btn:before{
	background:url(../images/arrow_yellow.png) no-repeat;
}
.top_medical_list .medical_brown dd.btn:before{
	background:url(../images/arrow_brown.png) no-repeat;
}
.top_medical_list a:hover dd.btn:before{
	right:25px;
}



/*==================================================================

	.top_features

==================================================================*/


.top_features{
	padding-top:58px;
}
.top_features h3.tit02{
	margin-bottom:23px;
}

.top_features_list dl{
	margin-bottom:50px;
}
.top_features_list dt{
	float:left;
	position:relative;
	width:750px;
	height:457px;
	overflow:hidden;
}
.top_features_list dl:nth-child(even) dt{
	float:right;
}

.top_features_list dt:before{
	width:730px;
	height:437px;
	box-sizing:border-box;
	border-bottom:1px solid #c5e3f2;
	border-right:1px solid #c5e3f2;
	position:absolute;
	bottom:0;
	right:0;
	content:"";
}
.top_features_list dl:nth-child(2) dt:before{
	border-bottom:1px solid #eadfc3;
	border-right:1px solid #eadfc3;
}
.top_features_list dl:nth-child(3) dt:before{
	border-bottom:1px solid #c7e6cc;
	border-right:1px solid #c7e6cc;
}

.top_features_list dt:after{
	background:url(../images/point01.png) no-repeat;
	width:64px;
	height:44px;
	position:absolute;
	bottom: 8px;
    right: 37px;
	content:"";
}
.top_features_list dl:nth-child(2) dt:after{
	background:url(../images/point02.png) no-repeat;
	width:71px;
	height:44px;
}
.top_features_list dl:nth-child(3) dt:after{
	background:url(../images/point03.png) no-repeat;
	width:70px;
	height:44px;
}

.top_features_list dd{
	float:right;
	width:400px;
	padding-top:87px;
	overflow:hidden;
}
.top_features_list dl:nth-child(even) dd{
	float:left;
}

.top_features_list dd h4{
	display:table;
	width:100%;
	overflow:hidden;
	position:relative;
	color:#49acdc;
	font-size:30px;
	letter-spacing:2.5px;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	margin-bottom:17px;
}
.top_features_list dl:nth-child(2) dd h4{
	color:#a89361;
}
.top_features_list dl:nth-child(3) dd h4{
	color:#68b474;
}
.top_features_list dd h4 .overlay_blue{
	background:#49acdc;
}
.top_features_list dd h4 .overlay_green{
	background:#68b474;
}
.top_features_list dd h4 .overlay_brown{
	background:#a89361;
}

.top_features_list dd p{
	line-height:2.2;
	letter-spacing:1.5px;
}
.top_features_list dd .btn01{
	float:right;
	margin-top:36px;
}


/*アニメーション*/
.overlay,
.animate-elm.-max-width:before,
.animate-elm.-transform:before {
	background-color: #fff;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 1;
	-webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0s;
	transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0s;
}
 
.overlay-max-width,
.animate-elm.-max-width:before {
	max-width: 100%;
}
 
.overlay-transform,
.animate-elm.-transform:before {
	-webkit-transform: translateX(0%);
	transform: translateX(0%);
}
 
/*.animate-elm {
	width:730px;
	height:437px;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: 50% 50%;
	position: relative;
	overflow: hidden;
}*/
 
.animate-elm.-max-width:before,
.animate-elm.-transform:before {
	content: "";
}
 
.animate-elm.show.-max-width:before,
.animate-elm.show .overlay-max-width {
	max-width: 0;
}
 
.animate-elm.show.-transform:before,
.animate-elm.show .overlay-transform {
	-webkit-transform: translateX(101%);
	transform: translateX(101%);
}


/*==================================================================

	.top_informatin

==================================================================*/

.top_information {
	width: 100%;
	max-width: 1000px;
   margin: 60px auto 2em;
   padding: 2em 2.5em 2.5em;
	background: #E9F8FF;
	 position: relative;
}

.top_information p { 
	margin:0;
	text-align: left;
}

.top_information::before,
.top_information::after {
   content: '';
   width: 20px;
   height: 30px;
   position: absolute;
}

.top_information::before {
   border-left: 1px solid #009fe8;
   border-top: 1px solid #009fe8;
   top: 0;
   left: 0;
}

.top_information::after {
   border-right: 1px solid #009fe8;
   border-bottom: 1px solid #009fe8;
   bottom: 0;
   right: 0;
}

.top_information.adj02 {
	background: #f8f6f2;
}
.top_information.adj02 p { 
	text-align: left;
}
.top_information.adj02::before {
   border-left: 1px solid #c69358;
   border-top: 1px solid #c69358;
   top: 0;
   left: 0;
}
.top_information.adj02::after {
   border-right: 1px solid #c69358;
   border-bottom: 1px solid #c69358;
   bottom: 0;
   right: 0;
}
/*==================================================================

	$doctor

==================================================================*/

.doctor_greet .doctor_img{
	float:right;
	width:400px;
}

.doctor_greet .text{
	float:left;
	width:760px;
}

.doctor_carr{
}
.doctor_carr h4.tit01{
	margin-bottom:7px;
}
.doctor_carr_sec1{
	margin-top:60px;
	width:500px;
	padding: 20px 30px;
	background-color:#f8f6f2;
	font-size:14px;
}
.doctor_carr_sec1:last-child{
	margin-right:0;
}
.doctor_carr .tb02 td,.doctor_carr .tb02 th{
	font-size:14px;
}
.doctor_carr_sec1 table{
	width:100%;
}



/*==================================================================

	.news

==================================================================*/

.top_news{
	padding-top:75px;
	padding-bottom:59px;
}
.top_news h3.tit01{
	float:left;
	width:226px;
	height:226px;
	background:url(../images/top_news_h3.png) no-repeat center;
	box-sizing:border-box;
	padding-top:93px;
}
.top_news h3.tit01:before{
	background:url(../images/hata.gif) no-repeat;
	width:25px;
	height:35px;
	position:absolute;
	top:50px;
	left:0;
	right:0;
	margin:auto;
	content:"";
}
.top_news .btn01{
	float:right;
	margin-top:8px;
}


.top_news_flame{
	float:right;
	width:915px;
	margin-top:30px;
}
.news_text{
}
.news_text p {
	margin-bottom:10px;
}
/* タイトル */
.news_text p strong{
	float:left;
	margin-left:20px;
	font-size:16px;
	padding-top:5px;
	color:#528ea9;
	font-weight:normal;
}
/* 日付 */
.date{
	display: table;
    float: left;
	width:140px;
	height:42px;
	line-height:42px;
	color:#009fe8;
	text-align:center;
	border:1px solid #cde4ee;
	font-family: 'Roboto', sans-serif;
	margin-right:20px;
}
/* お知らせのブロックのボーダー */
.news_text .line{
	clear:both;
	padding-top:20px;
	margin-bottom: 30px;
	padding-bottom: 30px;
	border-bottom:1px dashed #ccc;
}
/* お知らせの高さ */
.scroll_area{
	height:160px;
}
/*トップのお知らせ*/
.top_news ul li {
	margin-bottom:13px;
}
.top_news ul li a{
	font-size:16px;
	color:#333;
}
.top_news ul li a:hover{
	color:#A3A3A3;
}
.top_news ul li a span{
	float:left;
	width:670px;
	padding:5px 0 ;
}
.top_news ul li a em{
	display: table;
    float: left;
	width:140px;
	height:42px;
	line-height:42px;
	color:#009fe8;
	text-align:center;
	border:1px solid #cde4ee;
	font-family: 'Roboto', sans-serif;
	margin-right:20px;
}
.top_news ul li:nth-child(even) a em{
	color:#df9457;
	border:1px solid #e7dec7;
}



/*==================================================================

	$access

==================================================================*/

.access .footer_access{
	border:none;
	margin-bottom:30px;
}

.access .footer_access p:after{
	background:#badff0;
	opacity:0.7;
}
.access_map{
	margin-bottom:40px;
}
.access_map dt{
	margin-bottom:10px;
}
.access_map dt i{
	margin-right:7px;
}
.access .btn02{
	text-align:center;
	margin-bottom:50px;
}
.access_info{
	border: 1px dashed #d2c9b6;
	padding: 25px 30px 5px;
}
.access_info dt i{
	margin-right:7px;
}
.access_train,.access_bus,.access_car,.access_bike{
	margin-bottom:25px;
}
.access_train dt,.access_bus dt,.access_car dt,.access_bike dt{
	padding-left: 0;
	margin-bottom:5px;
	font-size:17px;
	font-weight:bold;
}
.access_train dd,.access_bus dd,.access_car dd,.access_bike dd{
	font-size:14.5px;
}



/*==================================================================

	$clinic

==================================================================*/

/* 院内スライド（サムネイル右、1列） */
.clinic_slides1{
	margin-bottom:200px;
}
.clinic_slides1 .flexslider{
/*	position:relative;
	float:left;
	width:82%;*/
}
.clinic_slides1 .flexslider .slides img {
    width: 800px;
    height: 500px;
}
.clinic_slides1 .flexslider li div{
	position: absolute;
    top: 50px;
    right: 0;
    background-color: #fff;
	border:1px dashed #C3C3C3;
    width: 480px;
    height: 400px;
    padding: 10px;
}
.clinic_slides1 .flexslider li div h4{
	position: relative;
    font-size: 22px;
	padding:80px 0 20px;
    font-family: "FOT-筑紫A丸ゴシック Std M";
    color: #009fe8;
    /* color: #8dc031; */
    margin: 0 auto;
	text-align:center;
}
.clinic_slides1 .flexslider p{
	display:table-cell;
	padding:8px 40px;
	vertical-align:middle;
	font-size:16px;
	line-height:2;
	text-align: left !important;
}
.clinic_slides1 .flex-control-nav.flex-control-thumbs{
	margin: 30px 0px 0px;
    position: absolute;
    overflow: hidden;
    z-index: 10;
    bottom: -150px;
    width: 100%;
    right: 0px;
    left: 0px;
    padding: 0px 2%;
    display: table;
    text-align: center;
}
.clinic_slides1 .flex-control-thumbs li {
	display:inline-block;
	position:relative;
	width: 15%;
	margin: 0 0 0 1%;
	background-color:#fff;
}
.clinic_slides1 .flex-control-thumbs li img{
	    width: 100%;
    height: auto;
    display: block;
    opacity: 1;
    cursor: pointer;
	border: 1px dashed #e0cea9 !important;
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -ms-transition: all 1s ease;
    -o-transition: all 1s ease;
    transition: all 1s ease;
}






/* 医院概要 */

.clinic_sec1{
	position:relative;
	width:700px;
	margin:0 auto;
}
.clinic_sec1 ul{
	margin-bottom:15px;
}
.clinic_sec1 li{
	padding: 11px 0;
	border-bottom:1px dashed #ccc;
}
.clinic_sec1 li:first-child{
	padding:0 0 8px 0 ;
}
.clinic_sec1 li:last-child{
	border:none;
}
.clinic_sec1 dl:after {
	display: block;
	clear: both;
	content: "";
}
.clinic_sec1 dt{
	float:left;
	box-sizing:border-box;
	width:25%;
	padding-left:2px;
	font-weight:bold;
	color: #555;
}
.clinic_sec1 dd{
	float:left;
	width:75%;
}
.clinic_sec1 .schedule .tb01{
	border: 1px solid #e4e4e4;
	width:100%;
	font-size:14px;
}
.clinic_sec1 .schedule .tb01 tr:first-child th,
.clinic_sec1 .schedule .tb01 tr:first-child td{
	background-color:#f2f7fa;
	color:#1F2774;
	font-weight:bold;
}
.clinic_sec1 .schedule .tb01 tr:first-child{
}
.clinic_sec1 .schedule li{
	border-bottom:none;
	
}





/*==================================================================

	$facilities

==================================================================*/





/* 機器紹介2 */
.facilities_equip2 dl{
	float:left;
	position: relative;
	width:49%;
	margin-bottom:30px;
	background-color: #fff;
	border:1px dashed #C3C3C3;
	text-align:justify;
}
.facilities_equip2 dl:after{
display: block;
clear: both;
content: "";
}
.facilities_equip2 dl:nth-child(2n){
float: right;
}

/* 機器紹介名前 */
.facilities_equip2 dt{
float: left;
width: 50%;
padding: 3%;
box-sizing: border-box;
}
.facilities_equip2 dt img{
	width:100%;
}
.facilities_equip2 dd{
	float: right;
	width: 50%;
	padding: 40px 30px 18px 0px;
	box-sizing: border-box;
}
.facilities_equip2 dd h4{
	font-size:19px;
	font-family: "FOT-筑紫A丸ゴシック Std M";
    color: #009fe8;
		margin-bottom: 20px;
}
.facilities_equip2 dd p{
	margin-top:7px;
}


/*==================================================================

	$case

==================================================================*/
.case_wrapper {
	margin-top: 64px;
}
.grid_area {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 16px;
}

.photo {
  position: relative;
  overflow: hidden;
  margin: 0;
}

.photo img {
  width: 100%;
  display: block;
  height: auto;
}

.photo figcaption {
  position: absolute;
	left: 8px;
	bottom: 8px;
  background-color: rgba(0, 0, 0, 0.6);
  color: #fff;
  font-size: 0.8rem;
  padding: 2px 8px 4px;
  border-radius: 4px;
  z-index: 1;
  pointer-events: none;
}

.top_case_wrap {
	width: 90%;
	max-width: 400px;
	margin: 40px auto;
	padding: 2% 2%;
	background: #e5f5fd;
	border-radius: 4px;
}
.top_case_wrap_inner {
	padding: 20px 20px 30px;
	background: rgba(255,255,255,0.9);
	display: flex;
	justify-content: center;
	align-items: center;
}
.top_case_wrap h3.tit02 {
  margin-bottom: 12px;
  padding: 12px 0 10px;
  font-size: 20px;
}

/*ver.02*/
/*

.grid_area {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 16px;
}

.photo {
  margin: 0;
  text-align: center;
}

.photo img {
  width: 100%;
  display: block;
  height: auto;
}

.caption {
	width: 100%;
	padding: 4px 0;
	background: #FAFAFA;
	color: #666666;
	  font-size: 0.875rem;
}
*/

/*==================================================================

	$qa

==================================================================*/

.qa1{
}
.qa1 dl{
	margin-bottom:25px;
	padding-bottom:25px;
	border-bottom:1px dotted #c1c1c1;
}
.qa1 dl dt{
	position:relative;
	margin-bottom: 15px;
	padding-left:40px;
	font-weight:bold;
}
.qa1 dl dt:before{
	position: absolute;
	top:-5px;
	left:0;
	margin-right:7px;
	line-height: 1;
	font-family:"Times New Roman", Times, serif;
	font-weight:normal;
	font-size:28px;
	color:#262E7C;
	content:"Q.";
}
.qa1 dl dd{
	position:relative;
	padding-left:40px;
}
.qa1 dl dd:before{
	position: absolute;
	top:-5px;
	left:0;
	margin-right:7px;
	line-height: 1;
	font-family:"Times New Roman", Times, serif;
	font-weight:normal;
	font-size:28px;
	color:#C0AB9A;
	content:"A.";
}

.case_img {
	display: flex;
}
.case_img > dl {
	width: 48%;
	margin-right: 4%;
	margin-bottom: 20px;
}
.case_img > dl:last-of-type {
	margin-right: 0;
}
.case_img img {
	width: 100%;
	height: auto;
	margin-top: 20px;
}
.case_img img:first-of-type {
	margin-top: 0;
}
.case_img dt {
	font-size:1.4em;
	font-family: "FOT-筑紫A丸ゴシック Std M";
	color: #009fe8;
	text-align: center;
    border: 1px solid;
	margin-bottom: 10px;
}
.case_img_none {
	display: none;
}