@charset "utf-8";
/*-----------------------------------------------------
	reset
 ----------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
	border: 0;
	font-family: inherit;
	font-size: 98%;
	font-style: inherit;
	font-weight: inherit;
	margin: 0;
	outline: 0;
	padding: 0;
	vertical-align: baseline;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
nav,
section {
	display: block;
}

audio,
canvas,
video {
	display: inline-block;
	max-width: 100%;
}

html {
	overflow-x:hidden;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust:     100%;
}
a { outline: 0;	text-decoration: none; color:#666; }
a:focus { outline: thin dotted; color:#666; }
a:hover,
a:active { outline: 0; color:#666; text-decoration:none; }
a:hover { text-decoration:underline; }

address {
	margin-top:8px;
}
b,
strong {
	font-weight: 700;
}

cite,
dfn,
em,
i,
b {
	color:#6a3906;
}
mark,
ins {
	text-decoration: none;
}
p {
	margin-bottom: 24px;
	line-height:150%;
}
code,
kbd,
tt,
var,
samp,
pre {
	-webkit-hyphens: none;
	-moz-hyphens:    none;
	-ms-hyphens:     none;
	hyphens:         none;
}

pre {
	border: 1px solid rgba(0, 0, 0, 0.1);
	-webkit-box-sizing: border-box;
	-moz-box-sizing:    border-box;
	box-sizing:         border-box;
	margin-bottom: 24px;
	max-width: 100%;
	overflow: auto;
	padding: 12px;
	white-space: pre;
	white-space: pre-wrap;
	word-wrap: break-word;
}

blockquote,
q {
	-webkit-hyphens: none;
	-moz-hyphens:    none;
	-ms-hyphens:     none;
	hyphens:         none;
	quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: "";
	content: none;
}
ul,
ol {
	list-style: none;
}
ul {
}
ol {
}
li > ul,
li > ol {
}
img {
	-ms-interpolation-mode: bicubic;
	border: 0;
	vertical-align: middle;
}
button,
input,
select,
textarea {
	-webkit-box-sizing: border-box;
	-moz-box-sizing:    border-box;
	box-sizing:         border-box;
	margin: 0;
	max-width: 100%;
	vertical-align: baseline;
}

button,
input {
	line-height: normal;
}

input,
textarea {
	background-image: -webkit-linear-gradient(hsla(0,0%,100%,0), hsla(0,0%,100%,0)); /* Removing the inner shadow, rounded corners on iOS inputs */
}

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
	-webkit-appearance: button;
	cursor: pointer;
}

button[disabled],
input[disabled] {
	cursor: default;
}

input[type="checkbox"],
input[type="radio"] {
	padding: 0;
}

input[type="search"] {
	-webkit-appearance: textfield;
}

input[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
	border: 0;
	padding: 0;
}

textarea {
	overflow: auto;
	vertical-align: top;
}

table {
	border-collapse: separate;
	border-spacing: 0;
	border-width: 1px 0 0 1px;
	margin-bottom: 24px;
	width: 100%;
}

caption,
th,
td {
	font-weight: normal;
	text-align: left;
}

th {
	border-width: 0 1px 1px 0;
	font-weight: bold;
}

td {
	border-width: 0 1px 1px 0;
}

del {
	color: #767676;
}

hr {
	background-color: rgba(0, 0, 0, 0.1);
	border: 0;
	height: 1px;
	margin-bottom: 23px;
}
.clear {
	clear:both;
}
.flt-l { float:left; margin:0 0 24px 0; width:270px; }
.flt-r { float:right; margin:0 0 24px 0; width:270px; }
/*-----------------------------------------------------
	grobal
 ----------------------------------------------------*/
body {
	font-family:
	"メイリオ",
	Meiryo,
    "ヒラギノ角ゴ Pro W3",
	"Hiragino Kaku Gothic Pro",
	"ＭＳ Ｐゴシック",
	"MS PGothic",
	Osaka, sans-serif,
	'Alegreya SC',
	serif;
	background:url(../img/bg/bg-body.png) repeat;
	color:#666;
}
html, body {
	height: 100%;
	width:100%;
	margin: 0;
	padding: 0;
	text-align: center;
}
/*-----------------------------------------------------
	wrapper
 ----------------------------------------------------*/
#container {
	width: 100%;
	position: relative;
	height:auto !important;
	height: 100%;
	min-height: 100%;
}
#wrapper {
	border-top:5px #20501c solid;
	position:relative;
	min-height: 100%;
	width:100%;
	margin: 0 auto;
	text-align: center;
	padding-bottom:200px;
	clear:both;
}
.page {
	position:relative;
	width:980px;
	margin: 0 auto;
	text-align:center;
	overflow:hidden;
	clear:both;
}
/*-----------------------------------------------------
	header
 ----------------------------------------------------*/
header {
	position: relative;
	width:100%;
	margin:0  auto;
	text-align:center;
	clear:both;
	overflow:hidden;
}

header .head-cont{
	width:980px;
	margin:0 auto;
}

header #headWrap {
	position:relative;
	width:980px;
	text-align:center;
	margin:0 auto;
}

header p.tel {
	margin:13px 0 0 0;
	text-align:right;
}
/*-----------------------------------------------------
	gnavi
 ----------------------------------------------------*/
nav#gnavi {
	position:relative;
	display:block;
	clear:both;
	overflow:hidden;
	border-top:1px solid #5da508;
	border-bottom:4px solid #5da508;
	margin:0 auto;
	padding:1px 0;
	width:100%;
	background:#FFF;
}
nav#gnavi ul {
	width:980px;
	margin:0 auto;
	text-align:center;
}
nav#gnavi ul li {
	position:relative;
	float:left;
	padding:0 0 0 1px;
	display:block;
	border-left:1px solid #CCC;
}

nav#gnavi ul li:after {
	position: absolute;
	left: 0;
	content: '';
	border-left:1px solid #EEE;
	height:42px;
}
nav#gnavi ul li:last-child {
	border-right:1px solid #CCC;
	height:42px;
}
/*-----------------------------------------------------
	Slideshow
 ----------------------------------------------------*/
#slideshow {
	width:100%;
	background:url(../img/bg/bg-slider.png) 0 50% repeat-x;
	height:375px;
	clear:both;
	overflow:hidden;
}
#c-carousel {
	min-height: 375px;
}
#carousel img {
	margin:0 54px;
	float: left;
	display: block;
}

#prevoverlay, #nextoverlay {
	background-color: rgba(255, 255, 255, 0.7);
	display: block;
	height: 400px;
	width: 50%;
	top: 0;
	position: absolute;
}
#prev, #next {
	display: block;
	height: 50px;
	width:28px;
	top: 0;
	position: absolute;
}

#prev {left: 50%; top:280px; margin-left:-517px;}
#next {left: 50%; top:280px; margin-left: 490px;}
#pager {
	position: absolute;
	left: 50%;
	top: 430px;
	margin-left:-90px;
}
#pager a {
	background:url(../images/slideshow/slide-off.png) 0 0 no-repeat;
	display: inline-block;
	width: 21px;
	height: 21px;
	margin: 0 29px 0 0;
}
#pager a:hover {
}
#pager a span {
	display: none;
}
#pager a.selected {
	background:url(../images/slideshow/slide-on.png) 0 0 no-repeat;
}


/*-----------------------------------------------------
	Sidebar
 ----------------------------------------------------*/
#sidebar {
	position:relative;
	border-top:5px solid #478300;
	margin-top:29px;
	float:right;
	width:300px;
}
div.sidebarBox {
	border:1px solid #CCC;
	background:#FFF;
	margin-bottom:19px;
}
div.sidebarBox h1 {
	margin:19px 0 0 0;
}
div.sidebarBox p {
	margin:19px 0;
}
div.sidebarBox p.ttl-timetable {
	margin:0 !important;
	border-bottom:2px solid #478300;
}
div.sidebarBox dl {
	padding:14px;
}
div.sidebarBox dl dt {
	background:url(../img/parts/ttl-sidebar.png) 10px 50% no-repeat #EEE;
	padding:3px 0 3px 25px;
	margin:10px 0;
	text-align:left;
	font-size:110%;
}
div.sidebarBox dl dd {
	padding:3px 0 3px 10px;
	text-align:left;
	color:#666;
}
div.sidebarBox dl dt.dl-img {
	background:none !important;
	padding:3px 0;
	margin:0 0 10px 0;
	text-align:left;
	font-size:110%;
}
/*-----------------------------------------------------
	contents
 ----------------------------------------------------*/

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

article {
	position:relative;
	border-top:5px solid #478300;
	width:583px;
	margin-top:29px;
	border-left:1px solid #DDD;
	border-right:1px solid #DDD;
	border-bottom:1px solid #DDD;
	background:#FFF;
	padding:18px 29px 29px 29px;
	float:left;	
	text-align:left;
}
article .oldH,
article h2,
article h3 {
	margin-bottom:24px;
	clear:both;
}
article p {
	margin-bottom:24px;
}
article .oldH{
	border-bottom:1px dashed #CCC;
}
article section h2 {
	position:relative;
	background:#555;
	color:#FFF;
	padding:5px 0 5px 20px;
	-moz-border-radius:5px;
    -webkit-border-radius:5px;
	border-radius:5px;
	clear:both;
	overflow:hidden
	z-index:0;
	line-height:150%;
	font-size:110%;
	behavior: url(../PIE.htc);
}
article section h2:after {
	position:absolute;
	content: '';
	left:7px;
	top:6px;
	border-left:4px solid #478300;
	height:20px;
	z-index:10;
	behavior: url(../PIE.htc);
}
article section h3 {
	position:relative;
	padding:5px 0 5px 20px;
	background:url(../img/parts/icon-triangle.png) 0 50% no-repeat !important;
	border-bottom:1px solid #999;
	border-left:none !important;
	clear:both;
	overflow:hidden;
}
article section ul {
	list-style:disc !important;
	margin-left:18px;
}
article section h4 {
	background:#666;
	font-size:110%;
	line-height:150%;
	margin-bottom:24px;
	padding:5px;
	color:#FFF;
	clear:both;
	overflow:hidden;
}
h2.ttl {
	width:100%;
	display:block;
	clear:both;
	overflow:hidden;
	text-align:center;
	background:url(../img/bg/bg-ttl-h2.png) 0 50% repeat-x;
	border-bottom:2px solid #478300;
}
article h3 {
	border-left:5px solid #478300;
}

ul#panList {
	display:block;
	position:relative;
	width:980px;
	margin:0 auto;
	text-align:center;
	border-right:2px solid #478300;
	border-bottom:2px solid #478300;
	border-left:2px solid #478300;
	-moz-border-radius:0 0 4px 4px;
    -webkit-border-radius:0 0 4px 4px;
	border-radius:0 0 4px 4px;
	background:#FFF;
	clear:both;
	overflow:hidden;
	behavior: url(../PIE.htc);
}
ul#panList li {
	float:left;
	margin-top:3px;
}
ul#panList li a {
	position:relative;
	margin-right:18px;
	width:38px;
	height:26px;
	display:block;
	padding:0;
	margin-top:-3px;
}
/*---------- top ----------*/

.contents {
	position:relative;
	border-top:5px solid #478300;
	width:580px;
	margin-top:29px;
	border-left:1px solid #DDD;
	border-right:1px solid #DDD;
	border-bottom:1px solid #DDD;
	background:#FFF;
	padding:30px;
	float:left;
}
section#news {
	position:relative;
	width:100%;
	display:block;
	float:left;
	text-align:left;
}
section#news .oldH {
	width:100%;
	border-bottom:1px solid #DDD;
}
section#news div#newsBox {
	clear:both;
	overflow:hidden;
	min-height:150px;
}
section#news div#newsBox ul {
	margin:17px 0;
}
section#news div#newsBox ul li {
	border-bottom:1px dotted #DDD;
	line-height:150%;
	display:block;
	text-align:left;
	width:100%;
	overflow:hidden;
	padding:6px 0;
}
section#news div#newsBox ul dl {
	margin:0;
	padding:0;	
}
section#news div#newsBox ul li dl dt{
	float:left;
	width:10%;
	text-align:left;
	padding:2px;
	color:#333;
	margin-right:5%;
}
section#news div#newsBox ul li dl dd {
	float:left;
	width:70%;
	padding:2px;
}
p.newsList {
	position:absolute;
	top:10px;
	right:-20px;
	width:100px;
	font-size:85%;
	margin:0;
	color:#8e6942;
}
p.newsList a,
p.newsList a:link {
	color:#8e6942;
}

#facebookBox {
	display:block;
	clear:both;
	overflow:hidden;
	margin:20px 0 40px 0;
	background:#FFF;
}

/*---------- menu ----------*/

article section.menu {
	font-size:95%;
}
article section.menu dl dt {
	margin-bottom:15px;
}
article section.menu p em {
	margin-bottom:15px;
	background:#999;
	color:#FFF;
	padding:7px;
	text-align:center;
	font-size:120%;
	text-align:left;
	display:block;
	width:97%;
}
article section.menu h3 {
	position:relative;
	background:#555 !important;
	color:#FFF;
	padding:5px 0 5px 20px;
	-moz-border-radius:5px;
    -webkit-border-radius:5px;
	border-radius:5px;
	clear:both;
	overflow:hidden
	z-index:0;
	line-height:150%;
	font-size:110%;
	behavior: url(../PIE.htc);
}
article section.menu h3:after {
	position:absolute;
	content: '';
	left:7px;
	top:6px;
	border-left:4px solid #478300;
	height:20px;
	z-index:10;
	behavior: url(../PIE.htc);
}
article section.menu h5 {
	position:relative;
	padding:2px 0 2px 20px;
	margin-bottom:15px;
	background:url(../img/parts/icon-triangle.png) 0 50% no-repeat !important;
	border-bottom:1px solid #999;
	border-left:none !important;
	clear:both;
	overflow:hidden;
	font-size:120%;
}
.ttl-squ {
	background:url(../img/parts/icon-square.png) 0 50% no-repeat !important;
	border-bottom:1px solid #CCC;
	color:#333;
	clear:both;
	padding:5px 0 5px 15px;
	overflow:hidden;
	font-size:120%;
}
div.menuBox-l {
	float:left;
	max-width:340px;
	margin:0 0 10px 0;
}
div.menuBox-r {
	float:right;
	max-width:340px;
	margin:0 0 10px 0;
}
article section.menu ul {
	margin:0 0 24px 20px !important;
}
article section.menu ol {
	margin:0 0 24px 25px !important;
	list-style:decimal !important;
}
.ty2 {
	width:280px;
}

/*---------- about + nakayabe ----------*/

table.aboutTable {
	border-collapse:collapse;
	text-align:center;
	margin:0;
	width:100%;
}
table.aboutTable th {
	text-align:left;
	border-right:1px solid #478300;
	border-bottom:1px solid #DDD;
	padding:6px;
	vertical-align:middle;
	width:30%;
	text-align:left;
	color:#333;
	font-weight:normal;
}
table.aboutTable td {
	text-align:center;
	border-bottom:1px solid #DDD;
	padding:6px 0 6px 30px;
	vertical-align:middle;
	text-align:left;
}
ul.menu-about {
	margin:32px 0;
	display:block;
	overflow:hidden;
}
ul.menu-about li {
	float:left;
	margin-right:21px;
}
ul.menu-about li:last-child {
	margin-right:0;
}
#gmap {
	width:100%;
	height:181px;
}



/*---------- acupuncture ----------*/

.lBox {
	float:left;
	width:270px;
	margin:0 18px 24px 0;
	min-height:130px;
}
.rBox {
	float:right;
	width:270px;
	margin:0 0 24px 18px;
	min-height:130px;
}

table.priceTable {
	border-collapse:collapse;
	text-align:center;
	border-top:1px solid #DDD;
	border-left:1px solid #DDD;
	margin:24px 0 0 0;
	width:100%;
}
table.priceTable caption {
	text-align:center;
	background:#666;
	color:#FFF;
	padding:6px;
}
table.priceTable th {
	text-align:center;
	border-right:1px solid #DDD;
	border-bottom:1px solid #DDD;
	background:#e3dcdc;
	padding:6px;
	vertical-align:middle;
	width:25%;
	color:#333;
	font-weight:normal;
}
table.priceTable td {
	text-align:center;
	border-right:1px solid #DDD;
	border-bottom:1px solid #DDD;
	padding:6px;
	width:25%;
	vertical-align:middle;
	text-align:center;
}

/*---------- faq ----------*/
ul.faqList {
	position:relative;
}
ul.faqList li {
	display:block;
	overflow:hidden;
	background:url(../img/p/faq/line-qanda.png) 0 100% repeat-x;
	margin-bottom:20px;
	padding-bottom:10px;
}
ul.faqList li:last-child {
	background:none;
}
ul.faqList dl dt {
	background:url(../img/p/faq/icon-q.png) 0 50% no-repeat;
	font-size:150%;
	font-weight:700;
	padding:10px 0 10px 50px;
}
ul.faqList dl dd {
	background:url(../img/p/faq/icon-a.png) 0 0 no-repeat;
	padding:0 0 10px 50px;
}


/*-----------------------------------------------------
	footer
 ----------------------------------------------------*/
footer {
	position: absolute;
	background:#478300;
	color:#FFF;
	left:0;
    bottom:0;
    width: 100%;
	magin:0;
	padding:0;
}
#footerBox {
	position:relative;
	max-width:980px;
	margin:0 auto;
	text-align:center;
	clear:both;
}
#footerBox div.footerBox-l {
	width:250px;
	float:left;
	text-align:left;
	font-size:80%;
}
#footerBox div.footerBox-l p.ttl-footer {
	margin:10px 0 !important;
}
#footerBox div.footerBox-r {
	width:720px;
	float:left;
	display:block;
	margin-top:1.5%;
	text-align:left;
	font-size:80%;
	border-left:2px solid #FFF;
}
footer nav#fnavi ul li {
	float:left;
	margin:0;
	padding: 0 18px;
	text-align:left;
	border-right:1px solid #a9c588;
	line-height:100%;
}
#footerBox ul.footer-bnr {
	display:block;
	clear:both;
	padding:18px 0 0 18px;
	*padding:10px 0 0 18px;
}
#footerBox ul.footer-bnr li {
	float:left;
	padding:0 10px 0 0;
}
footer nav#fnavi ul li:last-child {
	border:none;
}
footer a,
footer a:link {
	color:#FFF;
}
footer a:hover {
	color:#FFF;
	text-decoration:underline;
}
footer div#copy {
	display:block;
	width:100%;
	background:#000;
	clear:both;
	margin-top:10px;
	overflow:hidden;
}
footer small {
	position:relative;
	clear:both;
	display:block;
	width:980px;
	text-align:left;
	margin:0 auto;
	font-size:80%;
	color:#FFF;
	padding:5px 0;
	overflow:hidden;
}
#BtnPageTop {
	position:absolute;
	right:0;
	bottom:0;
	height:61px;
	width:201px;
	z-index:0;
	bottom:-25px;
	*bottom:61px;
}

@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) {
#prev,
#next {
	display:none !important;
}
}
.top_menu{
	width:580px;
	margin:30px 0;
}
.top_menu img{
	width:100%;
	margin-bottom:10px;
}
.top_menu li{
	width:32%;
	float:left;
	margin-right:2%;
	text-align:left;
	line-height:1.5;
	background-color:#f0f0d8;
}
.top_menu li a{
	display:block;
	padding:5%;
	text-decoration:none;
}
.top_menu li:last-child{
	margin-right:0;
}
.top_menu li p{
	text-align:center;
	font-size:18px;
	margin-bottom:5px;
	color:#478300;
}
.side_bnr li{
	margin-bottom:10px;
}
.page_link{
	margin:10px 0 30px !important;
}
.page_link li{
	background-color:#478300;
	color:#fff;
	width:30%;
	float:left;
	padding:1%;
	margin-right:2%;
	text-align:center;
	font-size:13px;	
}
.page_link li:last-child{
	margin-right:0;
}
.page_link li a{
	display:block;
	color:#fff;
	text-decoration:none;
}

/* 160818 追加 */
.top_concept{
	text-align:left;
	
}
.top_concept_st{
	font-weight:bold;
	font-size:16px;
	margin-bottom:5px;
	color:#478300;
}
.ex_list li{
	margin-bottom:10px;	
}


/* 20161121 バナー追加 */
.banner {
	margin:30px 0 !important;
}
.banner .linkbox {
	list-style: none;
	font-size:130%;
	text-align:center;
	background:#478300;
	width:280px;
	float:left;
	margin-right:20px;
	letter-spacing: 3px;
}
.banner #last {
	margin-right:0;
}
.banner .linkbox a{
	display:block;
	color:#FFFFFF;
	padding:20px;
}
.banner .linkbox a:hover{
	color:#FFFFFF;
	background:#80C035;
	text-decoration:none;
}


/*-------------------------------

170213追記

-------------------------------*/

.head-cont .oldH{
	float:left;
}

h1{
	width:100%;
	background:#20501c;
	padding-bottom:5px;
}

h1 p{
	width:980px;
	color:#fff;
	text-align:left;
	margin:0 auto;
	font-size:12px;
}

.ttl-footer{
	font-size:28px;
	font-family:'Meiryo UI','メイリオ',Verdana,'ＭＳ Ｐゴシック','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro',sans-serif;}


footer .ttl-footer a:hover{
	text-decoration:none!important;
}

/* 170517 追記*/ 

.times{
	margin-top: 30px;
}

/* トピックスASP版 */

.siz14, #diaryPro #diary .text li{
	font-size: 14px;
}
