@charset "utf-8";

/* =Reset default browser CSS.
Based on work by Eric Meyer: http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */
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: 100%;font-style: inherit;font-weight: inherit;margin: 0;outline: 0;padding: 0;vertical-align: baseline;
}
:focus{
	outline: 0;
}

ol, ul{
	list-style: none;
}
caption, th, td{
	font-weight: normal;text-align: left;
}
blockquote:before, blockquote:after,q:before, q:after{
	content: "";
}
blockquote, q{
	quotes: "" "";
}
a img{
	border: 0;
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section{
	display: block;
}

body{
	font:90%/1.8 "Lucida Sans Unicode", "Lucida Grande", Arial, "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","ＭＳ Ｐゴシック",sans-serif;
color:#252525;
-webkit-text-size-adjust: none;
background:#ffffff;
}

html{
	background:#ffffff;
}


/* リンク設定
------------------------------------------------------------*/
a{
	margin:0;
padding:0;
text-decoration:none;
outline:0;
vertical-align:baseline;
background:transparent;
font-size:100%;
color:#0e89d0;
}

a:hover, a:active{
	-webkit-transition:opacity 1s;-moz-transition:opacity 1s;-o-transition:opacity 1s;
outline: none;
color:#47a4d9;
}


/**** Clearfix ****/
nav .panel:after, nav#mainNav:after, .newsTitle:after, .bg:after,.post:after,#footer:after{
	content:""; display: table;clear: both;
}
nav .panel,nav#mainNav,.newsTitle,.bg, .post,#footer{
	zoom: 1;
}


/* レイアウト
------------------------------------------------------------*/
#wrapper, .inner{
	margin:0 auto;
width:960px;
}

#header{
	overflow:hidden;
}

#content{
	width:100%;
padding:30px 0;
}

#sidebar{
	float:right;
width:225px;
padding:30px 0;
}

#footer{
	clear:both;
padding:50px 0 60px 0;
}


/* ヘッダー
*****************************************************/
#header .bg{
	background:#ffffff;
}


/* サイト説明文 + 住所
----------------------------------*/
#header h1,#header p{
	float:left;
padding:3px 0;
font-size:80%;
font-weight:normal;
}

#header p{
	float:right;
}


/* ロゴ (サイトタイトル)
----------------------------------*/
#header h2{
	clear:both;
float:left;
padding:30px 0;
color: #515151;
font-size:160%;
font-weight:bold;
}

/* サブナビゲーション
----------------------------------*/
#header ul{
	font-size:85%;
padding-top:40px;
float:right;
}

#header ul li{
	display:inline;
margin-left:10px;
}

#header ul li:before{
	content:"・";
}

#header ul li a{
	color: #252525;
padding-left:5px;
}

#header ul li a:hover{
	color: #888;
}


/* トップページ　メイン画像
----------------------------------*/
#mainImg{
	clear:both;
margin-top:35px;
line-height:0;
text-align:center;
z-index:0;
}

#mainImg a:hover img{opacity:.9;}

.postWrap{
	margin:0 0 20px 0;
padding:3px;
}

article.archive span{
	padding-left:10px;
}


/* タイポグラフィ
*****************************************************/
h2.title{
	clear:both;
margin:30px 0 60px;
font-size:140%;
text-align:center;
}

h2.title span{
	padding:5px 0 8px 0;
border-bottom:5px solid #000000;
}

.dateLabel{
	margin:0 0 10px;
text-align:right;
font:italic 1em "Palatino Linotype", "Book Antiqua", Palatino, serif;
}

.post p{
	padding-bottom:15px;
}

.post ul{
	margin: 0 0 10px 10px;
}

.post ul li{
	margin:5px 0 0 15px;
list-style:disc;
}

.post ol{
	margin: 0 0 10px 30px;
}

.post ol li{
	list-style:decimal;
}

.post h1, .post h2, .post h3, .post h4{
	clear:both;
}

.post h1{
	margin:20px 0 30px 0;
padding:10px 15px;
font-size:130%;
background:#eeeeee;
}

.post h2{
	margin:20px 0 30px 0;
padding:3px 20px;
font-size:120%;
font-weight:normal;
border-left:5px solid #000000;
}

.post h3{
	margin:25px 0 35px 0;
padding-bottom:10px;
font-size:110%;
font-weight:normal;
border-bottom:1px solid #dddddd;
}

.post h4{
	margin:20px 0 20px 0;
padding-bottom:10px;
font-size:100%;
font-weight:bold;
}

.post blockquote{
	clear:both;
padding:10px 0 10px 20px;
margin:10px 0 25px 10px;
border-left:5px solid #ccc;
}



.post dt{
	font-weight:bold;
}

.post dd{
	padding-bottom:10px;
}

.post ul{
	margin-bottom:20px;
}

.post img{
	max-width:100%;height:auto;
}

img.aligncenter{
	display: block;
margin:5px auto 40px 0;
}

img.alignright{
	margin:0 0 25px 25px;
float:right;
}

img.alignleft{
	margin: 0 25px 25px 0;
float: left;
}


/* フッター　ウィジェット
*****************************************************/
.widgetWrap{
	margin: 0 0 20px;
padding: 3px;
}

#banners img{
	max-width:300px;
height:auto;
margin-bottom:10px;
}

section.widget h3{
	clear:both;
margin:0 0 10px;
padding:5px 0;
font-size:100%;
font-weight:normal;
color: #333;
border-bottom:1px solid #eeeeee;
}

section.widget a{
	color:#000000;
display:block;
border-bottom: 1px solid #eeeeee;
padding:9px 0 5px 0;
}

section.widget ul.sub-menu{
	margin-left:10px;
}

section.widget a:hover{
	background-position: 3px 50%;
color:#999999;
}


/* お知らせ　
-------------*/
.newsTitle{
	clear:both;
margin:0 0 13px;
padding:5px 0;
font-size:100%;
color: #333;
border-bottom:1px solid #eeeeee;
}

.newsTitle h3{
	float:left;
font-weight:normal;
}

.newsTitle p{
	float:right;
padding:0 0 0 10px;
font-size:.8em;
}

.newsTitle p a{
	color:#000000;
}

.newsTitle p a:hover{
	color:#999999;
}

.news p{
	clear:both;
padding-bottom:2px;
border-bottom: 1px solid #eeeeee;
}

.news p a{
	display:block;
padding:6px 0 5px 0;
color:#000000;
}

.news p a:hover{
	color:#999999;
}

.news span{
	padding-left:10px;
}



/* フッター
*****************************************************/
#footerWrapper{
	width:990px;
margin-right:-30px;
}

#footer aside{
	float:left;
width:300px;
margin-right:30px;
}

#copyright{
	clear:both;
padding:50px;
text-align:center;
font-size:90%;
zoom:1;
}


/* トップページ 最新記事3件
------------------------------------------------------------*/
.thumbWrap{
	width:990px;
margin:50px -35px 20px 0;
}

.thumbWrap li{
	float:left;
width:300px;
margin:0 30px 0 0;
padding:2px 0 40px;
background:none;
}

.thumbWrap li p{
	margin:15px 0 20px 0;
}

/* 最新記事リンク */
ul.thumb h3{
	margin-top:10px;
padding:3px;
font-weight:normal;
font-size:100%;
text-align:center;
border: 2px solid #000;
}

ul.thumb h3 span{
	display:block;
padding:5px 3px;
}

ul.thumb h3 a{
	color:#000000;
}

ul.thumb h3 a:hover{
	color:#999999;
}


/* メインメニュー　PC用
------------------------------------------------------------*/
@media only screen and (min-width: 1025px){
nav div.panel{
	display:block !important;
float:left;
}

a#menu{
	display:none;
}		
	
nav#mainNav{
	clear:both;
position:relative;
z-index:200;
background:#ffffff;
}

nav#mainNav ul li{
	float: left;
position: relative;
border-right:1px solid #eeeeee;
}

nav#mainNav ul li:first-child{
	border-left:1px solid #eeeeee;
}

nav#mainNav ul li a{
	display: block;
text-align: center;
_float:left;
color:#000000;
height:35px;
line-height:35px;
padding:10px 40px 5px;
}

nav#mainNav ul li a span,nav#mainNav ul li a strong{
	display:block;
font-size:90%;
line-height:1.4;
}

nav#mainNav ul li a span{
	font-size:70%;
}

nav#mainNav ul li.current-menu-item, nav#mainNav ul li:hover, nav#mainNav ul li.current-menu-parent{
	background:#f6f6f6;
}

nav#mainNav ul ul{
	width:160px;
}

nav#mainNav ul li ul{
	display: none;
}

nav#mainNav ul li:hover ul{
	display: block;
position: absolute;
top:50px;
left:0;
z-index:500;
}

nav#mainNav ul li li{
	padding:0 0 0 10px;
margin:0;
float: none;
height:40px;
line-height:40px;
width:160px;
border:0;
background:#ffffff;
border-bottom:1px solid #eeeeee;
}

nav#mainNav ul li li:first-child{
	border-left:0;
}

nav#mainNav ul li li a{
	width:100%;
height:40px;
padding:0 0 0 ;
line-height:40px;
font-size:95%;
text-align:left;
}

nav#mainNav ul li li.current-menu-item a{
	font-weight:bold;
}

nav#mainNav ul li li:hover{
	background:#f6f6f6;
}

nav#mainNav ul li:hover ul li:last-child{
	border:0;
}
}


/* メインメニュー iPadサイズ以下から
------------------------------------------------------------*/
@media only screen and (max-width:1024px){
#mainNav .inner{
	width:100%;
}
	
nav#mainNav{
	clear:both;
width:100%;
margin:0 auto 20px;
padding:0;
border-top:1px solid #eeeeee;
border-bottom:1px solid #eeeeee;
}

nav#mainNav a.menu{
	width:100%;
display:block;
height:50px;
line-height:50px;
text-align:left;
color:#000000;
background:url(images/menuOpen.png) no-repeat 10px 13px;
}

nav#mainNav a#menu span{
	padding-left:35px;
}

nav#mainNav a.menuOpen{
	background:url(images/menuOpen.png) no-repeat 10px -29px;
border-bottom:1px solid #eeeeee;
}

nav#mainNav a:hover#menu{
	cursor:pointer;
}

nav .panel{
	display: none;
width:100%;
position: relative;
right:0;
top:0;
z-index:1;
}

nav#mainNav ul{
	margin:0 0 20px;padding:0;
}

nav#mainNav ul li{
	float: none;
clear:both;
width:100%;
height:auto;
line-height:1.2;
}

nav#mainNav ul li a,nav#mainNav ul li.current-menu-item li a{
	display: block;
padding:15px;
text-align:left;
color:#000000;
border-bottom:1px solid #eeeeee;
}

nav#mainNav ul li a span{
	display:none;
}
 
nav#mainNav ul li a:hover,nav#mainNav ul li.current-menu-item > a,nav#mainNav ul li a:active, nav#mainNav ul li li.current-menu-item a, nav#mainNav ul li.current-menu-item li a:hover, nav#mainNav ul li.current-menu-item li a:active{
	background:#f6f6f6;
}

nav#mainNav ul li li{
	float:left;
border:0;
}

nav#mainNav ul li li a, nav#mainNav ul li.current-menu-item li a, nav#mainNav ul li li.current-menu-item a{
	padding-left:30px;
font-size:90%;
}

nav#mainNav ul li li a, nav#mainNav ul li.current-menu-item li a, nav#mainNav ul li li.current-menu-item a{
	padding-left:40px;
background:url(images/sub1.png) no-repeat 20px 18px;
}

nav#mainNav ul li li.current-menu-item a,nav#mainNav ul li li a:hover, nav#mainNav ul li.current-menu-item li a:hover{
	background:#f6f6f6 url(images/sub1.png) no-repeat 20px -62px;
}
	
nav#mainNav ul li li:last-child a{
	background:url(images/subLast.png) no-repeat 20px 20px;
}
nav#mainNav ul li li.current-menu-item:last-child a,nav#mainNav ul li li:last-child a:hover,nav#mainNav ul li.current-menu-item li:last-child a:hover{
	background:#f6f6f6 url(images/subLast.png) no-repeat 20px -65px;
}

nav div.panel{
	float:none;
}

#header ul li a,#header ul li a:hover{
	background-position:0 50%;
}
}


/* 959px以下から 1カラム表示
------------------------------------------------------------*/
@media only screen and (max-width: 959px){
#wrapper, #header, .inner{
	width:100%;
}

#header h1, #header p{
	padding:5px 10px;
}
#header h2{
	padding:20px 10px 0;
}
#header ul{
	padding:20px 10px 40px;
}


nav#mainNav ul, .thumbWrap{
	margin:0 auto;
}
nav#mainNav ul ul{
	padding:0;
}

nav div.panel{
	float:none;
}

#mainImg img{
	width:100%;height:auto;
margin-top:-35px;
}

#content, #sidebar{
	clear:both;
width:95%;
float:none;
margin:0 auto;
padding:20px 0 10px;
}

#banners{
	width:100%;margin:0 auto;text-align:center;
}
#banners p{
	display:inline;margin:0 1% 0 0;
}
#banners p img{
	width:31%;height:auto;
}

.thumbWrap{
	width:100%;margin:10px auto 0;text-align:center;
}
.thumbWrap ul.thumb li{
	width:30%; float:left;margin:0 1% 0 2%;
}
.thumbWrap img{
	width:100%;height:auto;
}

#footerWrapper{
	width:95%;margin:0 auto;
}

#footer aside{
	float:none;width:100%;
}


}


/* 幅644px以下から ヘッダー等微調節
------------------------------------------------------------*/
@media only screen and (max-width: 644px){
#header{
	text-align:center;
}
#header h2,#header h1,#header p,#header ul{
	float:none;
}
#headerInfo{
	width:250px;margin:0 auto;
}
#footer ul{
	text-align:left;padding:15px;
}
#footer ul ul{
	padding:0;
}
}

/* 幅330px以下から ヘッダー等微調節
------------------------------------------------------------*/
@media only screen and (max-width: 330px){
#calendar_wrap table{
	width:100%;
}
#banners p img{
	width:31%;height:auto;
}
}