@charset "UTF-8";

body{
	background-color:#F7F6F1;
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
	font-size: 15px;
	color:#444444;
	text-align: justify;
}


.clearfix:after {
	content: "."; 
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

.clearfix {
	min-height: 1px;
}

* html .clearfix {
	height: 1px;
	/*ﾂ･*//*/
	height: auto;
	overflow: hidden;
	/**/
}


.clear{clear: both;}
.cf:before,
.cf:after {
    content: " ";
    display: table;
}
.cf:after {
    clear: both;
}
.cf {
    *zoom: 1;
}

.iframe-content {
	position: relative;
	width: 100%;
	padding: 75% 0 0 0;
}
.iframe-content iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.pagination span, .pagination a {
	display:block;
	float:left;
	margin: 2px 2px 2px 0;
	padding:6px 9px 5px 9px;
	text-decoration:none;
	width:auto;
	color:#fff;
	background: #B3B3B3;
}
.pagination a:link,
.pagination a:visited,
.pagination a:hover,
.pagination a:active{
	color:#fff;
}
.pagination a:hover,
.pagination .current{
	background: #401C05;
}

.paragraph table{
}
.paragraph table,
.paragraph table th,
.paragraph table td{
	border:solid 1px #988074;
}
.paragraph table th{
	background-color:#3F1D01;
	color:#FFF;
	text-align:center;
	padding:5px;
}
.paragraph table td{
	padding:5px;
}
.paragraph table.timeschedule td{
	text-align: center;
}

.paragraph a:link,
.paragraph a:visited{
	color:#4B3B30;
}

.paragraph a:hover,
.paragraph a:active{
	color:#545454;
	text-decoration:none;
}

hr.hr_top{
	height: 0;
	margin: 0;
	padding: 0;
	border: 0;
	border-top: 1px dashed #aaa;
	width: 50%;
	float: right;
}

blockquote {
    position: relative;
    padding: 10px 15px 10px 50px;
    box-sizing: border-box;
    font-style: italic;
    background: #efefef;
    color: #555;
}
blockquote:before{
    display: inline-block;
    position: absolute;
    top: 10px;
    left: -3px;
    vertical-align: middle;
    content: "“";
    font-family: sans-serif;
    color: #cfcfcf;
    font-size: 90px;
    line-height: 1;
}


.top_detail{
	background: url(../img/arrow.gif) no-repeat;
	padding-left: 20px;
	float: right;
}
.top_detail a{
	text-decoration: none;
	color: #444;
}
h2.top_head{
	margin: 0;
}
p.top_head_en{
	font-size: 12px;
	margin: 0;
}
.top_intro_in{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.top_intro_box{
	width: 48%;
	height: auto;
	margin: 10px auto;
}
.top_intro_box a{
	display: block;
	text-decoration: none;
}
.top_intro_box img{
	max-width: 100%;
	height: auto;
}
.top_intro_box h3{
	margin: 0;
	text-align: center;
	padding: 5px;
}
.top_intro_box p{
	margin: 0;
	font-size: 14px;
}
.top_intro_box h3.top_intro_c_light{
	background-color: #D5C8B3;
}
.top_intro_box h3.top_intro_c_heavy{
	background-color: #765C4B;
}
.top_intro_box a h3.top_intro_c_light{
	color: #4B3B30;
}
.top_intro_box a h3.top_intro_c_heavy{
	color: #fff;
}
.top_intro_box a p{
	color: #444;
	margin-top: 5px;
}

.top_treatment_box{
	background-color: #fff;
	border-top: solid 5px #765C4B;
	border-left: solid 1px #E7E0D4;
	border-right: solid 1px #E7E0D4;
	border-bottom: solid 1px #E7E0D4;
}
.top_treatment_box a{
	display: block;
	text-decoration: none;
}
.top_treatment_box h3{
	border-bottom:solid 1px #CAA36A;
	margin: 0; padding: 10px 10px 8px;
}
.top_treatment_box a h3{
	color:#4B3B30;
}
.top_treatment_box_in{
	padding: 10px;
}
a .top_treatment_box_in{
	color: #444;
}
.top_treatment_box_in img{
	max-width: 100%;
	height: auto;
	display: block;
	margin: 0 auto;
}
.top_treatment_box_in p{
	margin: 10px 0 0;
}

.top_news{
	background-color: #fff;
	border: solid 1px #E7E0D4;
	padding: 10px;
}
.top_news h2{
	font-size: 15px;
	background: url(../img/border_01.png) repeat-x;
	background-position: bottom;
	padding-bottom: 10px;
	margin-bottom: 20px;
}
.top_news_box{
	border-left: solid 3px #663300;
	padding-left: 10px;
	margin: 10px 0;
}
.top_news_box h3{
	font-size: 15px;
	margin: 0; padding: 0;
}
.top_news_box p{
	font-size: 13px;
	margin: 0; padding:0;
}
.top_news_box h3 a{
	color: #444;
}

.top_professional{
	background-color: #fff;
	border: solid 1px #E7E0D4;
	padding: 10px;
}
.top_professional h2{
	font-size: 15px;
	background: url(../img/border_01.png) repeat-x;
	background-position: bottom;
	padding-bottom: 10px;
	margin-bottom: 20px;
}

.top_timetable{
	background-color: #fff;
	border: solid 1px #E7E0D4;
	padding: 10px;
}
.top_timetable h2{
	font-size: 15px;
	background: url(../img/border_01.png) repeat-x;
	background-position: bottom;
	padding-bottom: 10px;
	margin-bottom: 20px;
}
.top_timetable table, .top_timetable th, .top_timetable td{
	border:solid 1px #988074;
	font-size: 14px;
}
.top_timetable th, .top_timetable td{
	padding: 10px 3px;
}
.top_timetable table th{
	background-color:#3F1D01;
	color:#FFF;
	text-align:center;
}
.top_timetable table td{
	text-align:center;
}

.top_cases{
	background-color: #fff;
	border: solid 1px #E7E0D4;
	padding: 10px;
}
.top_cases img{
	max-width: 100%;
	height: auto;
}
.top_cases ul{
	margin: 0; padding: 0;
	list-style: none;
}
.top_cases ul li{
	margin: 10px 0;
}
.top_cases ul li:last-child{
	margin-bottom: 0;
}
.top_cases ul li a{
	color: #444;
}
.top_cases_arrow{
	position: relative;
	display: inline-block;
	padding: 0 0 0 16px;
	vertical-align: middle;
	text-decoration: none;
}
.top_cases_arrow::before,
.top_cases_arrow::after{
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	content: '';
	vertical-align: middle;
}
.top_cases_arrow::before{
	width: 12px;
	height: 12px;
	-webkit-border-radius: 50%;
	border-radius: 50%;
	background: #7a0;
}
.top_cases_arrow::after{
	left: 3px;
	width: 3px;
	height: 3px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.top_tour{
	background-color: #fff;
	border: solid 1px #E7E0D4;
	padding: 10px;
}
.top_tour img{
	max-width: 100%;
	height: auto;
}

.footer{
	border-bottom: 3px solid #CAA36A;
	background-color: #EDEBE0;
}
.footer h3{
	margin: 5px 0; padding: 0;
}
.footer ul{
	margin: 0; padding: 0;
	list-style: none;
}
.footer h3 a,
.footer ul li a{
	color: #444;
	text-decoration: none;
}
.footer ul li{
	margin: 5px 0;
}


.footer_info .footer_intro{
	font-size: 13px;
	margin: 15px 0 5px;
}
.footer_info .footer_tel{
	font-size: 32px;
	text-align: center;
	font-weight: bold;
}
.footer_info .footer_tel a{
	text-decoration: none;
	color: #444;
}
.footer_tel_icon{
	background: url(../img/footer_tel.png) no-repeat;
	background-size: 21px 29px;
	background-position: 0 50%;
	padding-left: 25px;
}
.footer_info .footer_form{
	background-color: #3F1D00;
	border-radius: 5px;
	text-align: center;
	margin-top: 15px;
}
.footer_info .footer_form a{
	display: block;
	color: #fff;
	text-decoration: none;
	padding: 10px;
}
.footer_address{
	font-size: 13px;
	margin-top: 15px;
}
.copyrights{
	text-align: center;
	font-size: 13px;
	margin-top: 20px;
}

.sub_title{
	background: url(../img/sub_title_bg.png);
}
.sub_title .sub_title_in h1:first-letter {
	font-size: 50px;
	color: #85AD33;
}
.sub_title .sub_title_in h1 {
  position: relative;
  padding-bottom: 10px;
}
.sub_title .sub_title_in h1::after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: '';
  width: 100%;
  height: 0;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #fff;
}
.sub_title .sub_title_in h1 span {
	font-size: 13px;
	font-family: 'Libre Baskerville', serif;
}

.breadcrumbs{
	font-size: 13px;
	letter-spacing: -1px;
}
.breadcrumbs a{
	color: #444;
}

.nodal_point{
	background: url(../img/sub_title_bg.png) repeat-x;
	background-size: 10px;
}
.onecolumn_box{
	background: #ffffff;
	border-radius: 5px;
	box-shadow: 0 2px rgba(0,0,0,0.2);
}
.onecolumn_box a{
	display: block;
	padding: 5px;
	color: #444;
	text-decoration: none;
}
.onecolumn_box h2{
	margin: 0; padding: 0;
	text-align: center;
	border-top:solid 5px #765C4B;
	border-bottom:solid 1px #CAA36A;
	font-size: 20px;
	line-height: 1;
	padding: 10px 0;
}
.onecolumn_box h2 span{
	font-size: 13px;
}
.onecolumn_box img{
	display: block;
	margin: 10px auto;
	max-width: 100%;
	height: auto;
}
p.sub_detail{
	background: url(../img/arrow.gif) no-repeat;
	padding-left: 20px;
	margin: 5px 0;
}
.twocolumn_contents{
	background-color: #fff;
}
.twocolumn_contents img{
	max-width: 100%;
	height: auto;
}
.paragraph h2 {
  position: relative;
  padding: .25em 0 .5em .75em;
  border-left: 6px solid #85AD33;
}
.paragraph h2::after {
  position: absolute;
  left: 0;
  bottom: 0;
  content: '';
  width: 100%;
  height: 0;
  border-bottom: 1px solid #ccc;
}
.paragraph h3{
	background-color: #401C05;
	border-radius: 5px;
	color: #ffffff;
	padding: 15px 10px;
}
.message h3{
	background-color: #85AD33;
}
.paragraph h4{
	padding: .25em 0 .25em .75em;
  border-left: 6px solid #ccc;
}

.mb15{margin-bottom:15px;}

/* ******************************************************************** */
/* スマホのみ */
/* ******************************************************************** */

@media screen and (max-width: 767px){
	.wrapper{
		margin: 0 5px;
		padding-bottom: 20px;
	}

	.top_treatment_box, .top_news, .top_professional, .top_timetable, .top_cases, .top_tour{
		margin: 10px 0;
	}
	.top_treatment{
		padding-bottom: 30px;
	}
	.top_contents_middle{
		padding-top: 30px;
	}
	h2.top_head{
		font-size: 18px;
		text-align: center;
	}
	p.top_head_en{
		text-align: center;
	}
	.top_intro h3{
		font-size: 15px;
	}

	.sub_title{
		padding: 5px 5px 15px; margin: 0;
	}
	.sub_title h1{
		font-size: 24px;
	}
	.sub_title .sub_title_in h1:first-letter{
		font-size: 24px;
	}

	.onecolumn_box{
		width: 90%;
		height: auto;
		margin: 10px auto;
	}
	.twocolumn_contents{
		margin-bottom: 20px;
	}
	.twocolumn_contents_in{
		padding: 0 10px;
	}

	.sidenav_menu,
	.sidenav_box{
		display: none;
	}
	.sidenav_contact img{
		width: 250px;
		height: auto;
		display: block;
		margin: 0 auto;
	}

	.footer_sitemap h3{
		background-color: #7a0;
	}
	.footer_sitemap h3 a{
		color: #ffffff;
		display: block;
		padding: 5px 0;
	}
	.footer_sitemap ul{
		display: -webkit-box; display: -ms-flexbox; display: flex;
		-ms-flex-wrap: wrap; flex-wrap: wrap;
		-webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between;
	}
	.footer_sitemap ul li{
		width: 49%;
		background-color: #ffffff;
	}
	.footer_sitemap ul li a{
		display: block;
		padding: 3px 0;
	}

	.footer_menu{
		text-align: center;
	}

	.paragraph{
		margin-bottom: 20px;
	}
	.paragraph img{
		display: block;
		margin: 10px auto;
	}
	.tour img{
		width: 320px;
		height: auto;
	}
}

/* ******************************************************************** */
/* スマホとタブレット */
/* ******************************************************************** */

@media screen and (max-width: 1023px){
	.top_mv_mobile img{
		max-width: 100%;
		height: auto;
	}
	.top_mv_in img{
		display: none;
	}
	.top_intro{
		margin: 15px 0;
	}
	.footer{
		padding: 10px;
	}
	.footer_info{
		margin: 15px 0;
	}
}

/* ******************************************************************** */
/* タブレットのみ */
/* ******************************************************************** */

@media screen and (min-width : 768px) and (max-width: 1023px) {
	.wrapper{
		margin: 0 10px;
		padding-bottom: 20px;
	}
	.top_intro_box{
		width: 23%;
	}
	.top_news{
		margin-bottom: 10px;
	}
	.top_contents_left_flexbox, .top_contents_right{
		display: flex;
		justify-content: space-between;
	}
	.top_professional, .top_timetable, .top_cases, .top_tour{
		width: 49%;
		margin: 10px 0;
	}
	.footer{
		padding: 30px 0 10px;
	}
	.footer_info{
		width: 400px;
		margin: 0 auto 30px;
	}
	.footer_sitemap{
		display: flex;
		justify-content: space-around;
	}
	.sub_title{
		padding: 5px 10px 30px; margin: 0;
	}
}


/* ******************************************************************** */
/* タブレットとPC
/* ******************************************************************** */

@media print, screen and (min-width:768px){
	.top_treatment{
		margin-bottom: 40px;
	}
	.top_treatment_box_wrapper{
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.top_treatment_box{
		width: 49%;
		margin: 10px 0;
	}
	.top_contents_middle{
		padding-top: 50px;
	}
	.onecolumn_box_wrapper{
		display: flex;
		justify-content: space-around;
		flex-wrap: wrap;
	}
	.onecolumn_box{
		width: 310px;
		margin-bottom: 20px;
	}
	.twocolumn_contents{
		width: 730px;
		margin: 0 auto;
	}
	.twocolumn_contents_in{
		padding: 0 40px;
	}
	.sidenav_contact img{
		max-width: 100%;
		height: auto;
	}
	.sidenav_menu p{
		margin: 0; padding: 10px 5px 8px;
		background-color: #E7E0D4;
	}
	.sidenav_menu p a{
		color: #444;
		font-weight: bold;
		text-decoration: none;
	}
	.sidenav_menu ul{
		margin: 0; padding: 0 5px;
		list-style: none;
	}
	.sidenav_menu ul li{
		border-bottom: 1px dotted #aaa;
	}
	.sidenav_menu ul li:last-child{
		border: none;
	}
	.sidenav_menu ul li a{
		display: block;
		padding: 5px 0 5px 16px;
		color: #444;
	}
	.sidenav_arrow{
	position: relative;
	display: inline-block;
	vertical-align: middle;
	text-decoration: none;
	}
	.sidenav_arrow::before,
	.sidenav_arrow::after{
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	content: '';
	vertical-align: middle;
	}
	.sidenav_arrow::before{
	width: 12px;
	height: 12px;
	-webkit-border-radius: 50%;
	border-radius: 50%;
	background: #BFE580;
	}
	.sidenav_arrow::after{
	left: 5px;
	box-sizing: border-box;
	width: 3px;
	height: 3px;
	border: 3px solid transparent;
	border-left: 3px solid #fff;
	}

	.sidenav_box{
		background-color: #fff;
	}
	.sidenav_box img{
		max-width: 100%;
		height: auto;
	}
	.sidenav_box a{
		display: block;
		text-decoration: none;
		color: #444;
		padding: 10px;
	}
	.sidenav_box p.sidenav_box_title{
		padding: 0 0 5px; margin: 0 0 10px 0;
		border-bottom: 1px dotted #aaa;
		font-weight: bold;
		background: url(../img/arrow.gif) no-repeat right top;
	}
	.sidenav_box table, .sidenav_box th, .sidenav_box td{
		border:solid 1px #988074;
		font-size: 14px;
	}
	.sidenav_box th, .sidenav_box td{
		padding: 10px 3px;
	}
	.sidenav_box table th{
		background-color:#3F1D01;
		color:#FFF;
		text-align:center;
	}
	.sidenav_box table td{
		text-align:center;
	}
	.sidenav_box p.side_time_addinfo{
		text-align: center;
		margin: 10px 0 0 0; padding: 0;
	}

	.footer_arrow{
		position: relative;
		display: inline-block;
		padding: 0 0 0 16px;
		vertical-align: middle;
		text-decoration: none;
	}
	.footer_arrow::before,
	.footer_arrow::after{
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		margin: auto;
		content: '';
		vertical-align: middle;
	}
	.footer_arrow::before{
		left: 4px;
		box-sizing: border-box;
		width: 4px;
		height: 4px;
		border: 4px solid transparent;
		border-left: 4px solid #BFE580;
	}

	.paragraph{
		margin-bottom: 40px;
	}

	.paragraph img.right{
		float: right;
		margin: 0 0 20px 30px;
	}
	.paragraph img.left{
		float: left;
		margin: 0 30px 20px 0;
	}

	img.catch_image{
		float: left;
		width: 300px;
		height: auto;
		margin: 0 30px 20px 0;
	}

	.img_flex{
		display: -webkit-box; display: -ms-flexbox; display: flex;
		-webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between;
		-ms-flex-wrap: wrap; flex-wrap: wrap;
	}
	.img_flex_list{
		width: 49%;
		height: auto;
	}
	.img_flex_list img{
		display: block;
		margin: 0 auto;
	}

	.tour img{
		margin: 0 0 10px 0;
	}

}

/* ******************************************************************** */
/* PC（小画面）とPC（大画面） */
/* ******************************************************************** */

@media print, screen and (min-width : 1024px){
	.container{
		margin-top: 40px;
	}
	.top_mv_mobile img{
		display: none;
	}
	.top_mv{
		background: url(../img/main_img.png) repeat-x;
	}
	.top_mv .top_mv_in{
		width: 1000px;
		margin: 0 auto;
	}
	.wrapper{
		width: 1000px;
		height: auto;
		margin: 0 auto;
		padding-bottom: 40px;
	}
	hr.hr_top{
		width: 400px;
	}
	a:hover .top_detail,
	a:active .top_detail,
	.top_detail a:hover,
	.top_detail a:active,
	.top_cases ul li a:hover,
	.top_cases ul li a:active,
	.footer h3 a:hover,
	.footer h3 a:active,
	.footer ul li a:hover,
	.footer ul li a:active{
		color: #3F1D00;
		text-decoration: underline;
	}
	.top_intro{
		margin: 10px 0 30px;
	}
	.top_intro_in{
		margin-top: 10px;
	}
	.top_intro_box{
		width: 210px;
		margin: 0;
	}
	.top_contents_left{
		float: left;
		width: 720px;
	}
	.top_contents_right{
		float: right;
		width: 250px;
	}
	.top_news{
		margin-bottom: 20px;
	}
	.top_news a:hover,
	.top_news a:active{
		text-decoration: none;
	}
	.top_contents_left_flexbox{
		display: flex;
		justify-content: space-between;
	}
	.top_professional{
		width: 350px;
	}
	.top_timetable{
		width: 350px;
	}
	.top_timetable th, .top_timetable td{
		padding-top: 3px;
		padding-bottom: 3px;
	}
	.top_timetable p{
		margin-bottom: 0;
		text-align: center;
	}
	.top_cases{
		margin-bottom: 20px;
	}
	.footer{
		padding: 30px 0 10px;
	}
	.footer_in{
		width: 1000px;
		height: auto;
		margin: 0 auto;
	}
	.footer_info{
		float: right;
		width: 340px;
	}
	.footer_sitemap{
		float: left;
		width: 600px;
		display: flex;
		justify-content: space-between;
	}
	.footer_button {
		display: inline-block;
		outline: none;
	}
	.footer_button::before,
	.footer_button::after {
	  position: absolute;
	  z-index: -1;
	  display: block;
	  content: '';
	}
	.footer_button,
	.footer_button::before,
	.footer_button::after {
	  -webkit-box-sizing: border-box;
	  -moz-box-sizing: border-box;
	  box-sizing: border-box;
	  -webkit-transition: all .3s;
	  transition: all .3s;
	}
	.footer_button:hover,
	.footer_button:active {
	  background-color: #85AD33;
	  border-radius: 5px;
	}
	.sub_title{
		padding: 20px 0 50px; margin: 0;
	}
	.sub_title .sub_title_in{
		width:1000px;
		margin:0 auto;
		height:auto;
	}
	.onecolumn_box_wrapper{
		justify-content: space-between;
	}
	.onecolumn_box a:hover p,
	.onecolumn_box a:visited p{
		text-decoration: underline;
	}
	.twocolumn_contents{
		float: left;
	}
	.sidenav{
		width: 250px;
		float: right;
	}
	.sidenav_contact{
		margin-bottom: 20px;
	}
	.sidenav_menu{
		background-color: #fff;
		margin-bottom: 20px;
	}
	.sidenav_box{
		margin-bottom: 20px;
	}
}
