body {
	font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	color: #333;
	font-size: 14px;
	line-height: 150%;
	-webkit-text-size-adjust: 100%;
	text-align: center;
	background: #faf9f2;
}

.fix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}


.fix {
	min-height: 1px;
}


* html .fix {
	height: auto;
	overflow: hidden;
}


a {
	color: #6cb413;
	text-decoration: underline;;
}

img {
	max-width: 100%;
	height: auto;
	-ms-interpolation-mode: bicubic;
	vertical-align: top;
	font-size: 0;
	line-height: 0;
}


p.btn,
div.btn {
	max-width: 48.5%;
}

.btn_desc {
	max-width: 290px;
}

.btn_desc p {
	margin-bottom: 0;
}

.f-l {
	float: left;
}

.f-r {
	float: right;
}

	.c-btn.symptom .f-l,
	.c-btn.symptom .f-r {
		display: inline-block;
		float: none;
		vertical-align: top;
	}

	.c-btn.symptom .f-l {
	margin-right: 3%;
	}

.tac {
	text-align: center;
}


.tar {
	text-align: right;
}


.tal {
	text-align: left!important;
}


.red {
	color: #c00;
}

.f12{
	font-size: 12px;
}


.bold {
	font-weight: bold;
}


.btm10 {
	margin-bottom: 10px!important;
}


.btm15 {
	margin-bottom: 15px!important;
}


.btm20 {
	margin-bottom: 20px!important;
}


.btm0 {
	margin-bottom: 0px!important;
}


.img {
	float: left;
	text-align: center;
	font-weight: bold;
}

.img02 {
	float: right;
	margin-left: 10px;
    text-align: center;
    text-decoration: underline;
}

.img02 a {
	display: inline-block;
	margin-bottom: 0.7em;
}

.waku {
    background: #fff;
    border: solid 1px #dcdcdc;
    padding: 5px;
}

.g-border {
    border: solid 1px #7DBA2F;
    padding: 10px;
    margin: 0 5%;
}

.g-border p {
	padding: 0;
	margin: 0;
}

.g-border .img {
	margin-right: 15px;
	max-width: 40%;
}

.max30 {
	max-width: 30%;
}


.inner {
	width: 100%;
}


.w95 {
	width: 95%!important;
}


.submit {
	padding: 3% 5% 0 5%;
}


.u-line {
	text-decoration: underline;
}


#wrap {
	max-width: 640px;
	margin: 0 auto;
	text-align: left;
	background: #fff;
	padding: 15px 0 10px 0;
}

#main p strong {
    background: #FFFDC5;
}

.point {
	text-align: center;
	font-weight: bold;
	background: #ffcc1d;
	font-size: 114.28%;
	padding: 6px 0;
	width: 94%;
	margin: 0 auto;
}


ul.check {
	background: #fff;
	padding: 20px;
	font-size: 114.28%;
	border: 3px dotted #919191;
	box-shadow: 0 0 5px rgba(9,0,0,0.06);
	width: 94%;
	box-sizing: border-box;
	margin: 0 auto;
	border-radius: 6px;
}


ul.check li {
	background: url(../images/check.gif) 0px 0px no-repeat;
	padding: 5px 0 0 46px;
	list-style-type: none;
	margin: 0 0 22px 0;
	height: 30px;
}


header {
	max-width: 640px;
	margin: 0 auto;
	text-align: center;
	background: url(../images/hd_bg.gif) repeat-x 52px 75px #fff;
	padding-bottom:1px;
}



.header-box,
.footer-box {
	text-align: center;
	padding: 0 3%;
	padding-bottom: 8px;
	margin-bottom: 2px;
}


h1 {
	padding-top: 74px;
	text-align: center;
	margin-bottom: 10px;
}


.logo_b1, .logo_b2 {
	font-size: 80%;
	line-height: 1.4;
}

.logo_b2 {
    border: 1px dotted #888;
    padding: 5px;
    margin: 10px 3% 0;
}

.h-tel,
.f-tel {
	float: left;
}


.h-tel2,
.f-tel2 {
	float: right;
	position: relative;
}


.h-res {
	clear: both;
	padding-top: 5px;
}


.main-image {
	clear: both;
}


.c-btn {
	margin-bottom: 10px;
	padding: 0 3%;
/*	display: table;*/
}

/*.c-btn .btn {
	display: table-cell;
}*/


div.pu {
	padding: 20px;
	text-align: left;
	margin: 0 3%;
	background: #FFF2F2;
	border: solid 1px #FFD6D6;
	color: #f00;
}

p.shindan {
	padding-top: 10px!important;
	clear: both;
}

p.finish {
    font-weight: bold;
    line-height: 1.4em;
    font-size: 18px;
    margin-bottom: 15px;
}

p.finish span {
    color: #FE7200;
    background: linear-gradient(transparent 40%, #ffff66 40%);
}

section {
	margin: 0 0 30px 0;
}

section section {
	margin: 0 0 20px 0;
}

section p {
	margin-bottom: 1em;
	padding: 0 5%;
}


section ul {
	padding: 0 5%;
}


section .c-btn p {
	padding: 0;
}


section p:last-of-type {
	margin-bottom: 0;
}


h2 {
	background: url(../images/h2bg.gif) 0 0;
	padding: 3% 5%;
	border-top: solid 2px #5cb011;
	border-bottom: solid 2px #5cb011;
	margin-bottom: 20px;
	font-size: 18px;
	color: #333;
}


h3 {
	padding: 2% 5%;
	margin-bottom: 20px;
	font-size: 16px;
	color: #fff;
	text-shadow: 0 -1px 1px #44641d;
	background: -webkit-gradient(linear, left top, left bottom, from(#95ca33), to(#76b22d));
}


h4 {
	background: url(../images/h4bg.gif) 0 0 no-repeat;
	padding: 0 0 1% 22px;
	margin: 0 5% 3% 5%;
	font-size: 15px;
	color: #000;
	border-bottom: solid 2px #dcdcdc;
}


h5 {
	padding: 3px 0 3px 21px;
	margin: 0 5% 3% 5%;
	color: #fff;
	font-size: 14px;
	background: #79bd37;
}


#navi-wrap {
	position: fixed;
	width: 100%;
	z-index: 1;
}


nav {
	max-width: 100%;
}


.gnavi {
	max-width: 100%;
}


.gnavi li {
	float: left;
	text-align: left;
	width: 50%;
	background-color: #76b22d;
	background: -webkit-gradient(linear, left top, left bottom, from(#95ca33), to(#76b22d));
}


.gnavi li .pd {
	width: 100%;
}


.gnavi li .pd li {
	width: 100%;
}


.gnavi li a {
	display: block;
	padding: 0.7em 0.5em 0.3em 0.5em;
	border-right: 1px solid #588126;
	border-bottom: 1px solid #65942c;
	border-top: 1px solid #8dbf30;
	border-left: 1px solid #a3da3d;
}


.pd-sub {
	position: fixed;
	width: 100%;
	top: auto;
	left: 0;
}


.pd-sub li {
	text-shadow: -1px -1px 0 rgba(150, 150, 150, 0.3);
	width: 100%;
}


.pd-sub li a {
	display: block;
	color: #FFF;
	text-decoration: none;
	padding: 8px 0 8px 20px;
	text-align: left;
	background: url(../images/arrow.png) 98% 50% no-repeat #689a1c;
}


.pd-sub li.close a {
	color: #FFF;
	text-decoration: none;
	padding: 10px 0;
	text-align: center;
	background: #83bc2f;
	lay: block;
}


#nav02 {
	background-color: #76B22D;
	margin: 0 0 20px 0;
	max-width: 100%;
}


#nav02 ul {
	max-width: 100%;
}


#nav02 li {
	width: 50%;
	float: left;
	font-weight: bold;
	font-size: 90%;
	text-shadow: -1px -1px 0 rgba(150, 150, 150, 0.3);
	background: -webkit-gradient(linear, left top, left bottom, from(#95ca33), to(#76b22d));
}


#nav02 li a {
	display: block;
	padding: 6%;
	text-decoration: none;
	color: #fff;
	background: url(../images/arrow.png) 98% 50% no-repeat;
	border-right: 1px solid #588126;
	border-bottom: 1px solid #65942c;
	border-top: 1px solid #8dbf30;
	border-left: 1px solid #a3da3d;
}


a.btn-b {
	color: #FFF;
	text-decoration: none;
	background-image: linear-gradient(#edb424,#eda21f);
	-webkit-border-radius: 2em;
	-moz-border-radius: 2em;
	-o-border-radius: 2em;
	border-radius: 2em;
	-webkit-box-shadow: 0px 1px 2px #999;
	-moz-box-shadow: 0px 1px 2px #999;
	-o-box-shadow: 0px 1px 2px #999;
	box-shadow: 0px 1px 2px #999;
	text-shadow: 0 2px 1px #ae691b;
	display: inline-block;
	width: 100%;
	text-align: center;
	padding: 2% 0;
	font-size: 120%;
}


.btmnav {
	text-align: center;
	font-size: small;
}

#main > div {
	margin-bottom: 30px;
}


#main table.time {
	width: 90%;
	margin: 0.75em auto 1.5em;
	border-bottom: 1px solid #f1dfb5;
}


#main table.time th, #main table td {
	font-size: 93%;
	background-color: #ffffff;
	padding: 1em 2.5%;
	text-align: center;
	vertical-align: middle;
	border: 1px solid #ddd;
}


#main table.time th {
	background-color: #ffffe1;
	vertical-align: middle;
	text-align: center;
	font-weight: normal;
}


#main table.time .ampm {
	background: #fff;
}


#main table.ryoukin, #main table.staff, #main table.ct {
	width: 96%;
	margin-left: auto;
	margin-right: auto;
	border-collapse: collapse;
	line-height: 1.8em;
	margin-bottom: 30px;
	color: #330000;
}


#main table.ryoukin, #main table.ct {
	width: 90%;
}

#main table.ct td {
    border-top: 1px solid #999;
    border-bottom: none;
    border-right: none;
    border-left: none;
    padding: 1em 2.5%;
    text-align: left;
}


#main table.staff th {
	background-color: rgb(247, 245, 238);
	padding: 10px;
	text-align: center;
	border: #dddddd solid 1px;
	vertical-align: middle;
	font-size: 100%;
}


#main table.ryoukin td, #main table.staff td {
	background-color: #fff;
	padding: 10px;
	border: #dddddd solid 1px;
	width: auto;
	text-align: center;
	font-size: 100%;
}

#main table.ryoukin .td01 {
	background: #f7f7f7;
}

#main table.ryoukin th.jihi {
    background: #EAF2FF;
}

#main table.staff td {
	padding: 10px 20px;
}


.staff_catch {
	font-size: 130%;
	text-align: center;
	font-weight: bold;
	color: #F16D5C;
}


#main table.ryoukin th {
	background-color: #FFFFE1;
	padding: 10px;
	text-align: center;
	border: #ddd solid 1px;
	vertical-align: middle;
}


table.ct {
	width: 90%;
	margin: 0 auto;
}


table.ct th {
	background-color: #f7f7f7;
	font-weight: bold;
	padding: 1em 2.5%;
	border-bottom: 1px solid #CFC4BB;
	text-align: left;
}


ul.list_normal {
	padding-left: 4em;
}


ul.list_normal li {
	font-weight: bold;
	padding-left: 0em;
}


.desc {
	border: 1px solid #ffc560;
	background: #fffceb none repeat scroll 0 0;
	padding: 15px;
	width: 90%;
	box-sizing: border-box;
	margin: 0 auto;
	clear: both;
}


.desc span {
	display: block;
	font-weight: bold;
	margin-bottom: 10px;
}


.desc p {
	padding: 0;
}


.tel {
	font-size: 186%;
	font-weight: bold;
	font-family: Century Gothic,Arial, Helvetica, sans-serif;
	color: #FF6600;
	margin: 10px 0;
	display: inline-block;
}


.map {
	margin: 0 5% 20px;
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
}


.map iframe, .map object, .map embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}


#foot-content {
	background: url(../images/fcng.gif) 0 0;
	max-width: 640px;
	margin: 0 auto;
	padding: 10px 0;
}


.switch {
	float: left;
	margin: 0 0 0 5%;
	background: url(../images/pc.png) right 50% no-repeat;
	padding-right: 25px;
}


.pagetop {
	float: right;
	margin: 0 5% 0 0;
	background: url(../images/pt.png) right 50% no-repeat;
	padding-right: 25px;
}


footer {
	border-top: 1px solid #ebebeb;
	padding-top: 10px;
	background-color: #7AB72C;
	color: #fff;
	font-size: small;
	max-width: 640px;
	margin: 0 auto;
}


footer p {
	clear: both;
	padding: 0;
}


footer img {
	vertical-align: top;
}


#socialbuttons {
	padding: 0 5%;
	margin: 1em auto 0 auto;
	text-align: center;
	width: 90%;
}


#socialbuttons div {
	float: left;
}


.gallery-cell {
	width: 100%;
	list-style-type: none;
}


.top_about_list {
	padding: 20px 20px 20px 40px;
	border: 4px solid #c59968;
	border-radius: 10px;
	margin: 0 3%;
}


.top_about_list li {
	font-size: 114.28%;
	margin-bottom: 1.5em;
	font-weight: bold;
}


.top_about_list li strong {
	color: #ea6300;
	text-decoration: underline;
}


.top_about_list li:last-child {
	margin-bottom: 0;
}

/*WEB予約*/

.form-title {
	font-weight: bold;
}

.form {
    padding: 10px 5%;
}

.form p {
    margin: 0 0 20px 0!important;
    padding: 0 0 0 10px;
    border-left: solid 2px #492F22;
}

input[type=text],input[type=email], textarea {
	width: 100%;
}

/*よくある質問*/

.qa-box dl,.qa {
    margin: 0 5% 3% 5%;
}

.qa-box dt,
.qa h4 {
    background: url(../images/q.gif) 0 3px no-repeat;
    font-size: 108%;
    font-weight: bold;
    color: #000;
    border-bottom: dashed 1px #999;
    padding: 5px 0 10px 36px;
}

.qa-box dd,
.qa p {
    background: url(../images/a.gif) 0 5px no-repeat;
    color: #000;
    margin: 10px 0 0;
    padding: 1% 0 3% 36px;
}

.qa-box dl,
.qa {
	margin: 0 5% 3% 5%;
}

.qa h4 {
	margin: 0;
}

/*Youtube最適化*/
.video-container {
	position: relative;
	padding-bottom: 56.25%;
	padding-top: 30px;
	height: 0;
	overflow: hidden;
	z-index:1;
}
 
.video-container iframe,  
.video-container object,  
.video-container embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
