/* CSS Document */

@media screen and (max-width:1130px) {

.pc{
	display:none !important;
}
.sp{
	display:block !important;
}
.pc_inline{
	display:none !important;
}
.sp_inline{
	display:inline !important;
}

.pc_table{
	display:table !important;
}
.sp_table{
	display:table !important;
}

img{
	max-width:100%;
	height:auto;
}
.sp_mb00{
	margin-bottom:0 !important;
}
.sp_mr00{
	margin-right:0 !important;
}
.sp_ml00{
	margin-left:0 !important;
}
.sp_mt00{
	margin-top:0 !important;
}
.sp_pb00{
	padding-bottom:0 !important;
}
.sp_pr00{
	padding-right:0 !important;
}
.sp_pl00{
	padding-left:0 !important;
}
.sp_pt00{
	padding-top:0 !important;
}
.sp_center{
	text-align:center;
}

}


@media screen and (max-width:1130px) {
	
body{
	font-size: 15px;
	line-height:1.7;
}
body,
#mainvisual .inner,
header,
footer{
	min-width: 100%;
}

*, *:before, *:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}



main {
    width: 100%;
    left: 0;
}



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

	header

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

header {
	display:none;
}



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

	navi

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

nav{
	display:none;
}
.sp_navi {
	display:block;
	position:fixed;
	top:0;
	left:0;
	width:100%;
	font-size:18px;
	font-weight:bold;
	z-index: 9999;
}
.sp_navi h1{
	text-align: center;
	width: 100%;
	padding: 10px 0;
	background-color: rgba(255,255,255,0.85);
}
.sp_navi h1 span,
.sp_navi h1 img{
	display:block;
	width: auto;
	height: 42px;
	margin: 0 auto;
}
.sp_navi h1 a{
	vertical-align: middle;
}
.sp_navi h1 img{
	z-index: 9999;
	position:relative;
}
.sp_navi dl{
}
.sp_navi dl dt {
	height: 56px;
	font-weight:bold;
	cursor:pointer;
	padding: 0;
	font-size:18px;
	display:block;
	color:#fff;
	line-height: 2;
	background-color: #fff;
}
.sp_navi dl dt i{
	margin-right:2%;
}
.sp_navi dl dd {
	display:none;
}
.sp_navi_wrap {
	width: 100%;
	height: calc(100vh - 58px);
	overflow: auto;
}
.sp_navi ul {
	background:#f58e35;
}
.sp_navi ul li {
	display:block;
	width: 100% ;
	line-height:1;
	font-size:15px;
	font-weight:normal;
}
.sp_navi ul li i{
	margin-right: 4%;
	color: #fff;
	font-size: 28px;
	vertical-align: middle;
	position: relative;
	top: -2px;
	left: -6px;
}
.sp_navi ul li a {
	display:block;
	padding:4% 2% 4% 8%;
	width:100%;
	color:#fff;
	text-decoration:none;
    font-size: 16px;
	border-bottom:1px solid #fff;
}
.sp_link li div{
	display:none;
	background:#069388;
}
.sp_link li div ul{
	position:relative;
	background:#a5d1e8;
	border-bottom:1px solid #fff;
}
.sp_link li div ul:after{
	display:block;
	clear:both;
	content:"";
}
.sp_link li div ul li{
	display:table;
	float:left;
	width:50%;
	box-sizing:border-box;
}
.sp_navi ul.sp_link div ul li a {
    font-size: 14px;
	letter-spacing: 0;
	border-bottom: none;
}
.sp_navi ul.sp_link div ul li:last-of-type a {
	border-bottom: none;
}
.sp_link li div ul li a{
	width: 100%;
	padding:8% 2% 8% 16%;
	box-sizing:border-box;
}
.sp_link li div ul li:nth-child(even) a{
	padding:8% 2% 8% 2%;
}


.sp_navi dt .sp_navi_tel a {
	display: block;
	float: left;
	width: 34%;
	box-sizing: border-box;
	margin-top: 8px;
	margin-left: 3%;
	line-height: 38px;
	background-color: #aacf44;
	border-radius: 4px;
	font-size: 15px;
	color: #FFF;
	font-weight: 500;
	text-align: center;
	font-family: "Jun 34", sans-serif;
}
.sp_navi dt .sp_navi_tel a img {
	height: 18px;
	width: auto;
	margin-right: 5px;
	vertical-align: middle;
}
.sp_navi dt .sp_navi_reserve a {
	display: block;
	float: left;
	width: 38%;
	box-sizing: border-box;
	margin-top: 8px;
	margin-left: 2%;
	line-height: 38px;
	background-color: #aacf44;
	border-radius: 4px;
	font-size: 15px;
	color: #FFF;
	font-weight: 500;
	text-align: center;
	font-family: "Jun 34", sans-serif;
}
.sp_navi dt .sp_navi_reserve a img {
	height: 18px;
	width: auto;
	margin-right: 5px;
	vertical-align: middle;
}


/*ボタンの動き*/
.sp_navi dt a.sp_nav_btn {
    display: block;
	float: right;
    width: 56px;
    height:56px;
    position: relative;
    z-index: 9999999;
	background-color: #f58e35;
}
.sp_navi dt a.sp_nav_btn::after {
	position: absolute;
	width: 56px;
	left: 0;
	bottom: 2px;
	content: 'MENU';
	font-size: 11px;
	text-align: center;
	color: #FFF;
}
.sp_navi dt a.sp_nav_btn span {
    display: block;
    background: #fff;
    width: 26px;
    height: 2px;
    position: absolute;
    left: 15px;
    transition: all 0.4s;
    -webkit-transition: all 0.4s;
    -moz-transition: all 0.4s;
}
.sp_navi dt a.sp_nav_btn span:first-child {
    top: 14px;
}
.sp_navi dt a.sp_nav_btn span:nth-child(2) {
    margin-top: -1px;
    top: 23px;
}
.sp_navi dt a.sp_nav_btn span:last-child {
    top: 30px;
}
.sp_navi dt a.sp_nav_btn.active::after {
	content: 'CLOSE';
}
.sp_navi dt a.sp_nav_btn.active span:first-child {
    -webkit-transform: translateY(8px) rotate(45deg);
    -moz-transform: translateY(8px) rotate(45deg);
    -ms-transform: translateY(8px) rotate(45deg);
    transform: translateY(8px) rotate(45deg);
}
.sp_navi dt a.sp_nav_btn.active span:nth-child(2) {
    opacity: 0;
}
.sp_navi dt a.sp_nav_btn.active span:last-child {
    -webkit-transform: translateY(-8px) rotate(-45deg);
    -moz-transform: translateY(-8px) rotate(-45deg);
    -ms-transform: translateY(-8px) rotate(-45deg);
    transform: translateY(-8px) rotate(-45deg);
}
.top_features_sec02 dd p {
    padding: 8px 30px 20px 30px;
    line-height: 1.4;
    letter-spacing: 1.2px;
}



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

	#mainvisual

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

#mainvisual{
	background-position: center ;
	background-attachment: scroll ;
	height:250px;
	margin-top:62px;
	width:100%;
	left:0;
	background-size: cover;
	top: 0!important;
	background-image: url("../images/mainvisual_slide2_sp.jpg");
}
#mainvisual .inner{
	width: auto;
	height:inherit;
}

#mainvisual h2 {
    top: 20px;
}

/* トップページキャッチフレーズ */
.main_catch{
	position: absolute;
	top:50px;
	width:100%;
	text-align:center;
}
.main_catch h2{
	margin-bottom: 10px;
	font-size:22px;
}
.main_catch p{
	font-size: 15px;
}
.main_open{
	position: absolute;
	top:auto;
	bottom: 50px;
	right: 0;
	left: 0;
	width: 200px;
	margin: auto;
}









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

	#contents

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

.box1{
	width:auto;
	/*margin:0 6% 80px;*/
}
.box2{
	width:auto;
	margin:0 6% 80px;
}
#contents{
	width:auto;
}
#contents_left{
	width:auto;
	float:none;
	margin-right:0;
}
#contents_right{
	width:auto;
	padding:0 6%;
	float:none;
}


#medical ol.list07{
	padding: 30px 30px 30px 40px;
}
#medical .box2{
  padding: 0 2% !important;
  }
  
#medical .box2 .text p:first-child::after {
    top: 150px;
}

#medical .table-scroll{
   overflow: auto; /*スクロールさせる*/
  white-space: nowrap;
}
  

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

	footer

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



.footer_info .inner{
	width: 100%;
    padding: 40px 5%;
}
.footer_info dl{
	float:none;
	width:100%;
	padding:0 1%;
	background-color: #f2ffd0;
}
.footer_info_overview {
    float: none;
    width: 100%;
}
/*.footer_nav.fixed {
    display: block;
	top: -20px;
    margin-bottom: 20px;
}*/
.footer_nav.fixed {	
    display: block;
    top: 0;
    margin-bottom: 20px;
    /* min-width: 300px; */
    width: 55% !important;
    left: 0;
    right: 0;
    margin: 0 auto 20px;
}
.footer_info dl dt{
	float:none;
	text-align: center;
	margin:0 auto 30px;
}
.footer_info_logo,
.footer_info_logo img{
	width:222px;
	height:148px;
}
.footer_info_overview_logo,
.footer_info_overview_logo img {
width: auto;
    height: auto;
}
.footer_info dl dd{
	float:none;
	margin-left:0;
}
.footer_info_overview_tel{
	padding-bottom:20px;
}

.footer_info_sche{
	float:none;
	width:100%;
	font-size:13.5px;
}
.footer_info_sche p{
	margin:0;
}
.footer_info_sche .schedule {
    padding: 3%;
}
.footer_navi{
	display:none;
}





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

	$top

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

.top_doctor .text{
	width:auto;
	padding:0 2%;
}
.top_doctor .text p:nth-child(2) {
    margin-bottom: 40px;
    text-align: justify;
}
.top_doctor .text p:nth-child(3) {
    margin-bottom: 30px;
    text-align: justify;
}
.top_doctor_img{
	float:none;
	margin-left:0;
}
.top_doctor_img dt{
	margin-bottom: 17px;
	padding: 0 10%;
	text-align:center;
}
.top_doctor_img dd{
	text-align:center;
}
.top_medical2_list a{
	width:46%;
	margin-right:8%;
}
.top_medical2_list a:nth-child(even) {
    margin-right: 0;
}
.top_medical3_list li{
	width:46%;
	margin-right:8%;
}
.top_medical3_list li:nth-child(even) {
    margin-right: 0;
}
.top_medical4_list{
	width:auto;
	margin:0 8%;
}
.top_medical4_list dl{
	float: none;
width: auto;
margin-right: 0;
}
.mainvisual_catch{
	width:100%;
	padding: 35px 3% 40px ;
}



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

	$breadcrumb ぱんくず

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

.breadcrumb {
	width:92%;
	margin:-10px 4% 40px;
}
.breadcrumb li{
	display:inline-block;
}




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

	$共通

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

#contents{
	padding-bottom:0;
}
.box{
	width:auto;
	padding:0 6% 8%;
}
.text{
	float:none;
	width: auto;
	padding:0;
	border:none;
}
 h3.tit01,
 h3.tit02,
 h3.tit03,
 h3.tit04,
 h3.tit05 {
    width: 100%;
	box-sizing:border-box;
	font-size: 21px;
	margin-bottom:25px;
    text-align: center;
}
h4.tit01,
h4.tit02,
h4.tit04{
	font-size:19px;
}
h5.tit01{
	font-size:18px;
}
h3.tit02::before{
bottom:0;
left: 0;
right: 0;
margin: auto;
width: 40px;
height: 57px;
background-image: url(../images/tit02_bg.png);
background-repeat: no-repeat;
background-size: cover;
}
h3.tit04 span span::before{
	display:none;
}

.nowrap{
	white-space:normal;
}

/* リスト */
.list08{
	padding:6%;
}
/* テーブル */
.tb01{
	white-space:inherit;
}
.tb01 tr:first-child th, .tb01 tr:first-child td {
    padding: 2% 1% !important;
}
.tb01 td, .tb01 th{
	padding:2% 1%;
}
.tb01 th{
width: 105px;
	font-size:12.5px;
}
.tb01 td{
		font-size:11px;
}
.tb03,.tb03 th{
	white-space:inherit;
}
.tb03.w075par{
	width:100%;
}
.tb04,
.tb04 th{
	white-space:normal;
}
.tb04 th{
	font-size:13px;
}
.tb04 td, .tb04 th{
	padding:2%;
}

/* ボタン */
.btn01 a{
	display:block;
}

/* アンカーリンク */
.ank01{
	width:88%;
	padding:0 6%;
}
.ank01 li{
	width: 49%;
	margin-bottom:3%;
	margin-left:0;
}
.ank01 li:nth-child(even){
	margin-left:2%;
}
.ank02 li{
	float:none;
	width:100%;
	height:auto !important;
	margin-bottom:3%;
	margin-left:0;
}

.ank01 li span{
	font-size:12.5px;
}

/* 画像右寄せ */
.img_fr{
	float:none;
	margin-left:0;
	text-align:center;
}
.img_fr img{
	margin-bottom:15px;
}





/* 他 */

#clinic .box1 {
	padding: 0 2%;
}
#clinic .box1:nth-child(2) {
	margin: 0 auto 40%;
}
#feature{
    padding: 0 2%;
}
#feature .box1 {
    padding: 280px 0 80px;
}
#feature .box1 div::after {
    position: absolute;
    width: 100%;
    height: 300px;
	top: -180px;
}
#feature .box1 div::before {
    top:20%;
}
#counseling{
    padding: 0 2% 20%;
}

#medical .top_medical {
    padding: 0 2%;
}
#medical .box1{
padding: 0 2% !important;
}
#medical .layout01 dt{
    width: 100%;
    display: block;
    padding: 3%;
}
#medical .layout01 dd{
    width: 100%;
    display: block;
}
.layout07 dl {
    float: none;
    width: 100%;
}
#doctor .box1,
#access .box1,
#jobinfo .box1,
#news .box1{
	    padding: 0 2%;
}




.details {
    padding: 4%;
}

.heightLine{
	height:auto !important;
}


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

	$doctor

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

.top_doctor .text p:first-child::after,
#doctor .text p:first-child::after{
	    top: 190px;
}

#doctor .box1 p:nth-child(2),
#doctor .box1 p:nth-child(3),
#doctor .box1 p:nth-child(4){
	text-align:justify;
}

#access .box1 p{
}

/* ごあいさつ */
.doctor_greet{
}
.doctor_greet .text{
	float:none;
	width:auto;
}

/* 経歴、資格 */
.doctor_carr_sec1{
	float:none;
	width:auto;
	margin-right:0;
	margin-bottom:30px;
}


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

	$clinic

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

/* 医院概要 */
.clinic_sec1 dt{
	width:30%;
}
.clinic_sec1 dd{
	width:70%;
}
.clinic_sec1 .schedule .tb01{
	width:100%;
}

/* 院内スライド */
.clinic_slides1 {
	margin-bottom:20px;
}
.clinic_slides1 .flexslider{
	float:none;
	width:100%;
}
.clinic_slides1 .flexslider li div{
	display:block;
	margin-top:5%;
	margin-left:0;
	text-align:center;
}
.clinic_slides1 .flexslider p{
	display:block;
}
.clinic_slides1 .flex-control-nav.flex-control-thumbs{
	position: absolute;
	right: auto;
	width: auto;
	top:auto;
	bottom: -30%;
	z-index: 2;
}
.clinic_slides1 .flex-control-thumbs li {
    position: relative ;
    width: 12% ;
    margin: 0 0 0 2% ;
}
.clinic_slides1 .flex-control-thumbs img{
	border: 3px solid #e0e0e0 ;
}

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

	$access

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





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

	$first

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





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

	$medical

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

.layout01 dt{
	line-height:1.5;
	font-size: 15px;
}
.layout01 dt em{
	display:block;
	margin-right:0;
	font-size: 28px;
	text-align:center;
}



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

	$news

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











}









@media screen and (max-width:886px) {

.top_medical_list a,
.top_medical_list a:nth-child(2n){
    width: 433px;
    float: none;
    margin: 0 auto;
}




#top_feature {
/*height: 400px;*/
height:460px;
}

#top_feature .box1 {
	display: block;
}

.bg-change_no1, .bg-change_no2, .bg-change_no3, .bg-change_no4 {
	    position: relative;
    z-index: 0;
    background: none;
    width: 50%;
	/*width: 100%;*/
    /*height: 200px;*/
	height: 230px;
    float: left;
}

.top_doctor .text p:first-child,
#doctor .box1 .text p:first-child {
    margin-bottom: 0;
}
.top_doctor .text p:first-child::after,
#doctor .box1 .text p:first-child::after {
	display:none;
}

}














@media screen and (max-width:870px) {
	nav li a {
    line-height: 38px !important;
	}
	.header_info {
    padding: 10px 0;
}
/* 下層ページヘッドライン */
#mainvisual h2{
	font-size:22px;
	    /*text-align: justify;*/
    font-weight: 600;
	text-align:center;
	margin-bottom:0;
	line-height: 35px;
	top:20px;
}
/*.mainvisual_catch h2 span {
    font-size:17px;
    text-align: justify;
    font-weight: 600;
}
.mainvisual_catch p {
    font-size: 17px;
    text-align: justify;
    font-weight: 600;
	text-align: center;
}
.mainvisual_catch h2 span:first-child {
    display: block;
	text-align: center;
	line-height: 35px;
}*/
.mainvisual_open {
    position: absolute;
    bottom: 4%;
    right: 0;
    width: 100%;
    left: 0;
}
.mainvisual_open img {

    width: 70%;
    margin: 0 auto;
    display: block;

}

.top_news h3.tit02 {
    float: none;
    width: 100%;
    text-align: center;
    top: -10px;
}
.top_news_flame {
	float: none;
    margin: 0 auto;
    width: 90%;
}
.top_news .box1 .btn02 {
    float: none;
    top: 50px;
    position: relative;
    text-align: center;
}

.top_news .box1 {
    margin: 55px auto 125px;
}
#top_feature h3 {
    top: -45px;
}



.top_medical_list dl dd {
top: 33px;
    left: 35px;
    width: 240px;
}
.top_medical_list a:nth-child(2n) dl dd {
top: 33px;
    right:20px;
    width: 240px;
}
.top_medical_list dl dd:last-child {
    right: 20px;
}
.top_medical_list a:nth-child(2n) dl dd:last-child {
    left: 35px;
}

.clinic_slides1 .flex-control-nav.flex-control-thumbs{
	position: absolute;
	right: auto;
	width: auto;
	top:auto;
	bottom: -47%;
	z-index: 2;
}
.clinic_slides1 .flex-control-thumbs li {
    position: relative ;
    width: 14.3% ;
    margin: 0 0 0 2% ;
}




.schedule_note {
    margin-left: 0;
}

}











@media screen and (max-width:640px) {
	.mainvisual_open img {
		width:85%;
		margin: 0 auto;
		display: block;
	}

	#top_feature {
	/*height: 400px;*/
	height:1360px;
			background-image:url("../images/top_feature_slide1_sp.jpg") !important;
	}

	#top_feature .box1 {
		display: block;
	}

	.bg-change_no1, .bg-change_no2, .bg-change_no3, .bg-change_no4 {
			position: relative;
		z-index: 0;
		background: none;
		/*width: 50%;*/
		width: 100%;
		/*height: 200px;*/
		height: 340px;
		float: left;
	}
	.top_doctor .text p:first-child,
	#doctor .box1 .text p:first-child {
		margin-bottom: 30px;
	}
	.top_doctor .text p:first-child::after,
	#doctor .box1 .text p:first-child::after {
		display:none;
	}
	.footer_nav.fixed {	
		width: 100% !important;
	}
}



@media screen and (max-width:450px) {

.top_medical_list a,
.top_medical_list a:nth-child(2n){
    width: 100%;
}

}




@media screen and (max-width:410px) {
	.top_medical_list dl dd {
    top: 29px;
    width: 215px;
    left: 30px;
}
.top_medical_list a:nth-child(2n) dl dd {
    top: 29px;
    width: 215px;
    right: 10px;
}
.top_medical_list dl dd p {
    font-size: 13px;
}
.top_medical_list dl dd h4 {
    margin: 0 0 5px;
}
}










@media screen and (max-width:360px) {
	.top_doctor .text p:first-child {
		font-size: 19px;
		}

	.top_medical_list dl dd {
		top: 57px;
		width: 50%;
		text-align: center;
			left: 20px;
	}
	.top_medical_list a:nth-child(2n) dl dd {
		top: 57px;
		width: 50%;
		text-align: center;
			right: 20px;
	}
	.top_medical_list a:nth-child(9) dl dd:nth-of-type(1) {
		top: 57px;
		width: 65%;
		text-align: center;
		left: 20px;
	}
	.top_medical_list dl dd:last-child {
		top: 18px;
	}
	.top_medical_list a:nth-child(2n) dl dd:last-child {
		top: 18px;
	}
	.top_medical_list dl dd p {
		display:none;
	}
	.top_medical_list dl dd h4 {
		margin: 0 0 5px;
	}	
	.main_open{
		position: absolute;
		top:auto;
		bottom: 50px;
		right: 0;
		left: 0;
		width: 50%;
		margin: auto;
	}

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

		.layout

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

	.layout02 dl{
		float:none;
		width:auto;
		height:auto !important;
		margin-right:0;
		padding: 7%;
	}
	.layout03 dt,
	.layout03 dd{
		display:block;
	}
	.layout03 dt,
	.layout03 dd:nth-child(2),
	.layout03 dd:nth-child(3){
			width:auto;
	}
	.layout03 dt{
		padding:2% 20% 2%;
	}
	.layout03 dt img{
		margin-top:10px;
	}
	.layout03 dt,
	.layout03 dd{
		display:block;
	}
	.layout03 dd{
		padding:5% 6% 2%;
	}
	.layout03 dd h5{
		font-size:17px;
		text-align:center;
	}
	.layout03 dd h5 span{
		font-size:26px;
	}



	.layout04 dt,
	.layout04 dd{
		display:block;
	}
	.layout04 dt,
	.layout04 dd:nth-child(2),
	.layout04 dd:nth-child(3){
			width:auto;
	}
	.layout04 dt{
		padding:0 15% 2%;
	}



	.layout05 dt,
	.layout05 dd{
		display:block;
	}
	.layout05 dd{
		padding:5% 6% 2%;
	}
	.layout05 dd h5{
		font-size:17px;
	}
	.layout05 dd h5 span{
		font-size:26px;
	}

	.layout05 dt,
	.layout05 dd:nth-child(2),
	.layout05 dd:nth-child(3){
			width:auto;
	}
	.layout05 dt{
		padding:6% 15%
	}
	.layout05 dd:nth-child(3){
		border:none;
	}



	.layout06 dt,
	.layout06 dd{
		display:block;
	}
	.layout06 dt{
		line-height:1.5;
		font-size:16px;
	}
	.layout06 dt em{
		display:block;
		margin-right:0;
		line-height:1;
	}
	.layout06 dd{
		padding:3% 6% 2%;
	}
	.layout06 dd h5{
		font-size:15px;
	}
	.layout06 dd h5 span{
		font-size:26px;
	}

	.layout06 dt,
	.layout06 dd:nth-child(2),
	.layout06 dd:nth-child(3){
			width:auto;
	}
	.layout06 dt{
		padding:6% 15%
	}
	.layout06 dd:nth-child(3){
		border-left: none;

	}

	.layout08 dl{
		float:none;
		width:auto;
		height:auto !important;
		margin-right:0;
		padding: 7%;
	}
	.layout08 dl::before{
		display:none;
	}

}

/* 主にiPhone5,iPhoneSE用 */
@media screen and (max-width:320px) {
	.sp_inline_iP{
		display:inline !important;
	}
	.footer_nav .footer_nav_inner li a {
		font-size: 14px;
	}
}