@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;}
table {border-collapse: separate;border-spacing: 0;}
caption, th, td {font-weight: normal;text-align: left;}
blockquote:before, blockquote:after,q:before, q:after {content: "";}
bockquote, q {quotes: "" "";}
a img {border: 0;}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {display: block;}

body{
font:16px verdana,"ヒラギノ角ゴ ProN","Hiragino Kaku Gothic ProN","メイリオ","Meiryo","ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
color:#333333;
-webkit-text-size-adjust: none;
background:#fff;
line-height:30px;
}


/* リンク設定
------------------------------------------------------------*/
a{
margin:0;
padding:0;
text-decoration:none;
outline:0;
vertical-align:baseline;
background:transparent;
font-size:100%;
color:#777;
-webkit-transition: opacity 0.2s ease-out;
-moz-transition: opacity 0.2s ease-out;
-ms-transition: opacity 0.2s ease-out;
transition: opacity 0.2s ease-out;
}

a:hover{
opacity: 0.6;
-webkit-opacity: 0.6;
-moz-opacity: 0.6;
filter: alpha(opacity=60);	/* IE lt 8 */
-ms-filter: "alpha(opacity=60)"; /* IE 8 */
outline: none;
color:#999;
}


/**** Clearfix ****/
nav .panel:after, nav#mainNav:after, .newsTitle:after, .bg:after,.post:after{content:""; display: table;clear: both;}
nav .panel,nav#mainNav,.newsTitle,.bg, .post{zoom: 1;}


#link1 {
margin-top: -10px;
padding-top: 10px;
}


.btn {
background: #FF661C;
border: 0px;
color: #fff;
width: 200px;
padding: 15px 0;
font-size:16px;
}


/* フォーム
------------------------------------------------------------*/
input[type="text"], textarea{
vertical-align:middle;
max-width:90%;
line-height:30px;
height:30px;
padding:1px 5px;
border:1px solid #d4d4d7;
border-radius:3px;
-webkit-border-radius:3px;
-moz-border-radius:3px;
font-size:100%;
color:#555;
background:#fcfcfc;
}

textarea{
height:auto;
line-height:1.5;
}

*:first-child+html input[type="submit"]{padding:3px;}

.required {
background: #555;
font-size:10px;
font-weight: normal;
color: #fff;
margin-left:5px;
padding: 2px 5px;
}

input#btn { transition: all 0.2s; }
input#btn:hover { opacity: 0.5; }
input#btn:active { opacity: 0.3; }

/* レイアウト
------------------------------------------------------------*/
#wrapper, .inner{
margin:0 auto;
width:960px;
}

#header{
overflow:hidden;
background:#fff;
}

#content{
float:left;
width:710px;
padding:30px 0;
}

#sidebar{
float:right;
width:225px;
padding:30px 0;
}

#footer{
clear:both;
padding-top:20px;
border-bottom:1px solid #5d5d5d;
background:#f3f3f3;
} 


/* ヘッダー
*****************************************************/
#header .bg{background:#f3f3f3;}


/* サイト説明文 + 住所
----------------------------------*/
#header p{
float:left;
padding:3px 0;
color: #252525;
font-size:80%;
font-weight:normal;
}

#header p{
float:right;
}

.logo{
clear:both;
float:left;
padding:37px 30px 0 0;
color: #515151;
font-size:160%;
font-weight:bold;
position: relative;
z-index:250;
}


/* ロゴ (サイトタイトル)
----------------------------------*/
nav#mainNav h1{
clear:both;
float:left;
padding:37px 30px 0 0;
color: #515151;
font-size:160%;
font-weight:bold;
}

/* サブナビゲーション
----------------------------------*/
#header ul{
padding-top:40px;
float:right;
}

#header ul li{
display:inline;
margin-left:10px;
font-size:90%;
}

#header ul li a{
padding-left:10px;
color:#000;
background:url(images/arrowSub.png) no-repeat 0 50%;
}

#header ul li a:hover{background-position:3px 50%;}


/* トップページ　メイン画像
----------------------------------*/
#mainImg{
clear:both;
margin-top:20px;
line-height:0;
text-align:center;
z-index:0;
position:relative;
background:#005aaf;
background:url(images/slide_bg.jpg) repeat-x ;
}

#sub_mainImg{
clear:both;
margin-top:20px;
line-height:0;
text-align:center;
z-index:0;
position:relative;
background:#00509E;
background:url(images/sub_main_bg.png) repeat-x ;
}

#sub_mainImg img{
max-width:960px;
}

.post{
margin:0 0 20px 0;
padding:0px;
background:#FFF;
font-size:0.8em;
line-height:1.8em;
letter-spacing: 0.05em;
}

.post-2{
width: 710px;
margin:0 auto 20px;
padding:0px;
background:#FFF;
font-size:0.8em;
line-height:1.8em;
letter-spacing: 0.05em;
}

.slide-relative{
margin:0 auto;
padding:0 auto;
background:url(images/slide/slide-top.jpg) no-repeat center center;
background-size:contain;
position:relative;
width:960px;
height:350px;
}

.slide-absolute{
margin:0 auto;
padding:0 auto;
position:absolute;
width:960px;
height:350px;
}

/* タイポグラフィ
*****************************************************/
h2.title1{
clear:both;
margin-bottom:16px;
padding:7px 5px;
font-size:110%;
border-bottom:1px solid #333;
}

h2.title2{
clear:both;
margin:10px 0 20px;
padding:7px 11px 5px;
font-size:110%;
border-bottom:1px solid #333;
border-left:5px solid #333;
}

h2.title3{
clear:both;
margin-bottom:16px;
padding:7px 5px;
font-size:150%;
color:#1B4D90;
line-height:1em;
border-bottom:1px solid #333;
}

h2.title5{
clear:both;
margin:10px 0 20px;
padding:7px 11px 5px;
font-size:140%;
font-weight:bold;
color:#555;
border-bottom:1px solid #555;
border-left:5px solid #555;
}

h2.top{
clear:both;
padding:0 0 15px 5px;
}

h2.first{margin-top:0;}

.dateLabel{
margin:0 0 10px;
text-align:right;
font:italic 1em "Palatino Linotype", "Book Antiqua", Palatino, serif;
}

.post p{
padding-bottom:0px;
}

.post ul{margin: 0 0 10px 10px;}

.post ul li{
margin-bottom:5px;
padding-left:15px;
background:url(images/bullet.png) no-repeat 0 8px;
}

.post ol{margin: 0 0 10px 30px;}

.post ol li{list-style:decimal;}

.post h1{
margin:-10px 0px 10px;
padding:0px 0;
font-size:150%;
color: #000;
}

.post h2{
margin:0px;
font-size:130%;
font-weight:normal;
color: #333;
}

.post-2 h2{
margin:0px;
font-size:130%;
font-weight:normal;
color: #333;
}

.post h3{
margin:20px 0px 20px 5px;
padding-bottom:5px;
font-size:140%;
font-weight:bold;
color:#555;
border-bottom:1px solid #555;
}

.post-2 h3{
margin:20px 0px 20px 5px;
padding-bottom:5px;
font-size:140%;
font-weight:bold;
color:#555;
border-bottom:1px solid #555;
}

.post blockquote {
clear:both;
padding:10px 0 10px 15px;
margin:10px 0 25px 30px;
border-left:5px solid #ccc;
}
 
.post blockquote p{padding:5px 0;}

.large-table table{
width:100%;
border-collapse: collapse;
border-spacing: 0;
margin:10px 0 20px;
}

.large-table table th{
padding:10px 10px 10px 20px;
border-right: 1px #fff solid;
font-weight:bold;
}

.formth{
width:600px;
}

.large-table table td{
padding:10px 20px;
}

.gray{
background:#ddd;
}

.graybd{
border-bottom:1px solid #ddd;
}

.post dt{font-weight:bold;}

.post dd{padding-bottom:10px;}

.post img{max-width:100%;height:auto;}

img.aligncenter {
display: block;
margin:5px auto;
}

img.alignleft{
margin: 0 15px 0px 0;
display:inline;
}

img.alignright{
margin:0 0 2px 30px;
display:inline;
}

.alignleft{float: left;}
.alignright{float:right;}

.tmtxt{
max-width:380px;
padding:0 30px 0 5px;
float:left;
}

.slotxt{
max-width:380px;
padding:15px 15px 0px 15px;
float:right;
}

.slotxt1{
padding:35px 0 5px;
}

.slotxt2{
font-size:14px;
padding:0px 15px 0px 15px;
letter-spacing: 0.05em;
line-height:1.8;
text-align:center;
}

.posttxt1{
padding-left:20px;
}

.posttxt2{
margin-top:-5px;
padding:0 5px;
}

.posttxt3{
margin-bottom:20px;
}

.posttxt4{
margin-left:1em;
vertical-align:middle;
}

.posttxt-right{
margin-top:20px;
margin-bottom:10px;
text-align:right;
float:right;
}

.post strong{
font-size:110%;
font-weight:bold;
color:#214a78;
}

.post-2 strong{
font-size:110%;
font-weight:bold;
color:#214a78;
}

.post strong.large{
margin:0;
font-size:200%;
font-weight:bold;
}

.post span{
vertical-align: middle;
}

.tel-icon{
margin-right:3px;
margin-bottom:2px;
vertical-align: middle;
}

.postbox1{
margin-top:10px;
line-height:1.5;
}

.wel{
width:710px;
margin:0 0 10px 0;
padding:0px;
background:#FFF;
font-size:0.8em;
line-height:1.8em;
letter-spacing: 0.05em;
}

.wel_l{
width:345px;
margin:5px 10px 10px 0;
float:left;
}

.wel_r{
width:345px;
margin:5px 0 10px 10px;
float:right;
}

.wel_c{
width:710px;
margin:5px 0;
}

.staff_interview{
margin:45px 0 10px 0;
border:1px solid #333;
}

.itaku{
border:1px solid #004D9E;
}

.center{
margin:10px auto 15px;
text-align:center;
}

.center2{
margin:10px auto 20px;
text-align:center;
}

.hr1{
margin:35px 0;
border-top: 1px solid #999;
}

.hr2{
margin:20px 0;
border-top: 1px dashed #999;
}

.recruit-2{
	margin-top: 25px;
	padding: 15px 0 10px;
	border-top: 1px solid #999;
	border-bottom: 1px solid #999;
}

.photo1{
padding-top:5px;
}

.recruit{
width:710px;
padding:0px;
margin-top: 20px;
line-height:1.8em;
letter-spacing: 0.05em;
background-color: #333;
}

.recruit_l{
	width:335px;
	margin:5px 10px 30px 0;
	padding-right: 10px;
	float: left;
}

.recruit_r{
	width:335px;
	margin:5px 10px 30px 0;
	padding-left: 10px;
	float: right;
}

.recruit-table table{
width:100%;
border-top-width: 5px;
border-right-width: 1px;
border-bottom-width: 1px;
border-left-width: 1px;
border-style: solid;
border-color: #999 !important;
border-collapse: collapse;
border-spacing: 1px;
margin:5px 0 10px;
}

.recruit-table table th{
width:30% ;
padding:1em;
white-space: nowrap;
text-align-last: justify;
font-weight:bold;
background:#ddd;
border: 1px solid #999;
}

.recruit-table table td{
padding:10px 20px;
border: 1px solid #999;
}

.bgblue{
	background-color: #1B4D90;
	color: #fff;
}

/* サイドバー　ウィジェット
*****************************************************/
section.widget, .widgetInfo{
margin: 0 0 20px;
padding: 3px 0;
border:1px solid #999;
background: #fff;
}

#banners img{
max-width:225px;
height:auto;
margin-bottom:10px;
border:1px solid #999;
}

section.widget h3{
clear:both;
margin:0 0 10px;
padding:5px 0;
font-size:100%;
font-weight:normal;
color: #333;
border-bottom:1px solid #ccc;
}


section.widget p{
clear:both;
padding:0 0 2px 15px;
border-bottom: 1px solid #ccc;
}

section.widget p:last-child{border:0;}

section.widget p a{
display:block;
padding:10px 3px;
color:#333;
background:url(images/arrow.png) no-repeat 0 50%;
}

section.widget a span{
color:#515151;
font-size: 1em;
font-weight:bold;
}

section.widget span{padding-left:10px;}

section.widget a:hover span{color:#777;}

#searchform input[type="text"]{
line-height:1.7;
height:24px;
width:100px;
vertical-align:bottom;
}

.ninka{
margin:0 1em 1.5em;
border:1px solid #999;
font-size: 0.8em;
background: #fff;
text-align:center;
}

.ninka_txt1{
padding:0.3em;
background:#ddd;
}

.ninka_txt2{
padding:0.3em;
}


/* お知らせ　
-------------*/
.newsTitle{
clear:both;
margin:0 0 20px;
padding:5px 0;
font-size:100%;
color: #333;
border-bottom:1px solid #ccc;
}

.newsTitle h3{
float:left;
font-weight:normal;
}

.newsTitle p{
float:right;
padding:0 0 0 10px;
font-size:.8em;
background:url(images/arrow.png) no-repeat 0 50%;
}

.news p{
clear:both;
padding-bottom:2px;
border-bottom: 1px solid #ccc;
}

.news p:last-child{border:0;}

.news p a{
display:block;
padding:5px 0;
color:#333;
font-style:italic;
font:italic 110% "Palatino Linotype", "Book Antiqua", Palatino, serif;
}

.news a span{
color:#515151;
font:normal 90% Arial, 'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ Ｐゴシック',sans-serif;
}

.news span{padding-left:10px;}

.news a:hover span{color:#777;}



/* 枠付 Table
*****************************************************/

table.normal {
  border-collapse: collapse;
  margin-left:1em;
  width: 8;
  table-layout: fixed;
}

table.normal tr {
  background-color: #fff;
  border: 1px solid #999;
}

table.normal th,
table.normal td {
  padding: 0.5em;
  border-right: 1px solid #999;
}

table.normal th {
  background-color: #ddd;
}



/* 枠無し表 Table
*****************************************************/

.normal-table{
  margin-top:0;
  width: 100%;
}
.normal-table td:first-child{
  width: 0;
  white-space: nowrap;
  padding-left: 0;
  padding-right:1em;
  text-align-last: justify;
}

.normal-table td:{
  padding:0 !important;
}



/* フッター
*****************************************************/
#footer ul{
font-size:12px;
padding:10px 0 30px 0;
}

#footer ul li{
display:inline-block;
vertical-align:text-top;
text-align:left;
padding:5px 0;
margin-right:30px;
background:url(images/arrow.png) no-repeat 0 12px;
}

#footer ul li	a{
display:block;
padding:0 0 0 12px;
overflow:hidden;
}

#footer ul li	a:hover{text-decoration:underline;}

#footer ul li li{
display:block;
padding:0;
margin:0 0 0 10px;
background-position:0 5px;
}


*:first-child+html #footer ul li{display:inline;}
*:first-child+html #footer ul ul,*:first-child+html #footer ul li li a,*:first-child+html #footer ul li li{display:none;}

#copyright{
clear:both;
padding:10px;
text-align:center;
font-size:75%;
zoom:1;
color:#fff;
background:#000;
}


/* page navigation
------------------------------------------------------------*/
.pagenav{
clear:both;
width: 100%;
height: 30px;
margin: 5px 0 20px;
}

.prev{float:left}

.next{float:right;}

#pageLinks{
clear:both;
color:#2a588b;
text-align:center;
}


/* トップページ 最新記事3件
------------------------------------------------------------*/
.thumbWrap{
width:735px;
margin:20px -25px 20px 0;
}

.thumbWrap li{
float:left;
width: 220px;
margin:0 25px 0 0;
padding:2px 0 40px;
background:none;
}

/* 最新記事リンク */
ul.thumb h3{
margin-top:10px;
padding:1px;
font-weight:normal;
font-size:100%;
text-align:center;
background:#25252;
border:1px solid #dadada;
}

ul.thumb h3 span{
display:block;
padding:2px 3px;
background:#f3f3f3;
}

ul.thumb h3 a{color:#252525;}

ul.thumb h3:hover span{background:#fff;}



/* メインメニュー　PC用
------------------------------------------------------------*/
@media only screen and (min-width: 1025px){
nav div.panel{
display:block !important;
padding:25px 0 0 0;
float:left;
}

a#menu{display:none;}
	
nav#mainNav{
position:relative;
z-index:200;
}

nav#mainNav ul li{
float: left;
position: relative;
border-right:1px dotted #ccc;
}

nav#mainNav ul li:first-child{border-left:1px dotted #ccc;}

nav#mainNav ul li a{
display: block;
text-align: center;
_float:left;
color:#333;
height:35px;
line-height:34px;
padding:12px 30px 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%;
color:#ccc;
}

nav#mainNav ul li.current-menu-item a, nav#mainNav ul li a:hover, nav#mainNav ul li a:active, nav#mainNav ul li.current-menu-parent a{
background:#f3f3f3;
}

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:-2px;
z-index:500;
}

nav#mainNav ul li li{
padding:0 0 0 10px;
margin:0;
float: none;
height:40px;
line-height:40px;
width:160px;
background:#f3f3f3;
border:0;
border-bottom:1px dotted #ccc;
}

nav#mainNav ul li li:first-child{border-left:0;}

nav#mainNav ul li li a{
width:100%;
height:40px;
padding:0;
line-height:40px;
font-size:95%;
text-align:left;
}

nav#mainNav ul li li a span{padding:0 10px;}

nav#mainNav ul li li a:hover,nav#mainNav ul li li.current-menu-item a{color:#999;}

nav#mainNav ul li:hover ul li:last-child{border:0;}
}

/* メインメニュー iPadサイズ以下から
------------------------------------------------------------*/
@media only screen and (max-width:1024px){

	.logo{
	float:none;
	text-align:center;
	padding:15px 5px;
	}

	nav#mainNav{
	clear:both;
	width:98%;
	margin:10px auto;
	border:1px solid #d5d5d5;
	}
	
	nav#mainNav a.menu{
	width:100%;
	display:block;
	height:37px;
	line-height:37px;
	font-weight: bold;
	text-align:left;
  background: url(images/menuOpen.png) no-repeat 5px 8px;
	}
	
	nav#mainNav a#menu span{padding-left:35px;}
	
	nav#mainNav a.menuOpen{
	background: url(images/menuOpen.png) no-repeat 5px -34px;
	}
	
	nav#mainNav a#menu:hover{cursor:pointer;}
	
	nav .panel{
	display: none;
	width:100%;
	position: relative;
	right: 0;
	top:0;
	z-index: 1;
	}

	nav#mainNav ul{margin:0;padding:0;}

	nav#mainNav ul li{
	float: none;
	clear:both;
	width:100%;
	height:auto;
	line-height:1.2;
	}

	nav#mainNav ul li:first-child{border-top:1px solid #d5d5d5;}
	nav#mainNav ul li li:first-child{border-top:0;}

	nav#mainNav ul li a,nav#mainNav ul li.current-menu-item li a{
	display: block;
	padding:15px 10px;
	text-align:left;
	border-bottom:1px dashed #ccc;
	background:#fff;
	}
	
	nav#mainNav ul li:last-child a{border:0;}
	nav#mainNav ul li li:last-child a{border:0;}
	nav#mainNav ul li li:last-child a{border-bottom:1px dashed #ccc;}

 	nav#mainNav ul li a span{display:none;}
 
	nav#mainNav ul li.current-menu-item a,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:40px;
	background:#fff 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:#fff url(images/subLast.png) no-repeat 20px 20px;}
	nav#mainNav ul li li:last-child.current-menu-item 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;}
	
	#mainImg{margin-bottom:20px;}
}


/* 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 10px;}


	nav#mainNav ul, .thumbWrap{margin:0 auto;}
	nav#mainNav ul ul{padding:0;}

	nav div.panel{float:none;}
	
	#mainImg img{width:98%;height:auto;}

	#content, #sidebar{
	clear:both;
	width:95%;
	float:none;
	margin:0 auto;
	padding:10px 0;
	}
	
	#banners{width:100%;margin:0 auto;text-align:center;}
	#banners p{display:inline;margin:0 10px;}
  #banners p img{width:100%;height:auto;}
	
	section.widget_search{text-align:center;}

	#footer{margin:0;border:0;text-align:center;}
	
	#footer ul{	text-align:center;	}
	#footer ul li{margin-right:20px;}
	
	.thumbWrap{
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	width:100%;
	margin:0 auto;
	padding-top:20px;
	overflow:auto;
  border:1px solid #dadada;
	}
	.thumbWrap ul.thumb li{width:30%; float:left;margin:0 1% 0 2%;}
  .thumbWrap img{width:100%;height:auto;}
}


/* 幅644px以下から ヘッダー等微調節
------------------------------------------------------------*/
@media only screen and (max-width: 644px){
	#header{text-align:center;}
	#header h2,#header ul{float:none;}
	#headerInfo{width:250px;margin:0 auto;}
	img.alignright, img.alignleft{display: block;	margin:5px auto;}
	.alignright,.alignleft{float:none;}
	#footer ul{text-align:left;padding:15px;}
	#footer ul ul{padding:0;}
}
