@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: "";}
blockquote, q {quotes: "" "";}
a img {border: 0;}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {display: block;}

body{
font: 95%/1.5 "Lucida Sans Unicode", "Lucida Grande", Arial, "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック",sans-serif;
color:#252525;
-webkit-text-size-adjust: none;
background:url(images/bg.png);
}


/* リンク設定
------------------------------------------------------------*/
a{
margin:0;
padding:0;
text-decoration:none;
outline:0;
vertical-align:baseline;
background:transparent;
font-size:100%;
}

a:hover, a:active{
-webkit-transition:opacity 1s;-moz-transition:opacity 1s;-o-transition:opacity 1s;
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;}


/* フォーム
------------------------------------------------------------*/
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;
width: 500px;
height:100px;
}

input[type="submit"],input[type="reset"],input[type="button"],button[type="submit"],button[type="reset"]{
padding:3px 10px;
background: #2a588b;
background: -moz-linear-gradient(top, #2a588b 0%, #214a78 100%);
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#2a588b), color-stop(100%,#214a78));
background: -webkit-linear-gradient(top, #2a588b 0%,#214a78 100%);
background: -o-linear-gradient(top, #2a588b 0%,#214a78 100%);
background: -ms-linear-gradient(top, #2a588b 0%,#214a78 100%);
background: linear-gradient(to bottom, #2a588b 0%,#214a78 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#2a588b', endColorstr='#214a78',GradientType=0 );
border:0;
border-radius:3px;
-webkit-border-radius:3px;
-moz-border-radius:3px;
line-height:1.5;
font-size:100%;
color:#fff;
height:30px;
}

input[type="submit"]:hover,input[type="reset"]:hover,input[type="button"]:hover,button[type="submit"]:hover,button[type="reset"]:hover{
background: #2a588b;
background: -moz-linear-gradient(top, #214a78 0%, #2a588b 100%);
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#214a78), color-stop(100%,#2a588b));
background: -webkit-linear-gradient(top, #214a78 0%,#2a588b 100%);
background: -o-linear-gradient(top, #214a78 0%,#2a588b 100%);
background: -ms-linear-gradient(top, #214a78 0%,#2a588b 100%);
background: linear-gradient(to bottom, #214a78 0%,#2a588b 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#214a78', endColorstr='#2a588b',GradientType=0 );
}

*:first-child+html input[type="submit"]{padding:3px;}


/* レイアウト
------------------------------------------------------------*/
#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;
background:#efefef;
} 


/* ヘッダー
*****************************************************/
#header .bg{background:#eeeeee;}


/* サイト説明文 + 住所
----------------------------------*/
#header h1,#header p{
	float:left;
	padding:3px 0;
	color: #000;
	font-size:80%;
	font-weight:normal;
}

#header p{
	float:right;
}


/* ロゴ (サイトタイトル)
----------------------------------*/
#header h2{
	clear:both;
	float:left;
	padding: 20px 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: 15px;
	color:#252525;
	background:url(images/arrowSub.png) no-repeat 0 50%;
}

#header ul li a:hover{}


/* トップページ　メイン画像
----------------------------------*/
#mainImg{
	clear:both;
	margin-top:25px;
	line-height:0;
	text-align:center;
	z-index:0;
}

.post{
	margin:0 0 20px 0;
	padding:10px;
	border:1px solid #dadada;
	background: #fff;
}


/* タイポグラフィ
*****************************************************/
h2.title{
	clear: both;
	margin: 30px 0 0;
	padding: 7px 10px;
	font-size: 140%;
	font-weight: bold;
	color: #199ad6;
	border: 1px solid #dadada;
	border-bottom: 0;
	background: #fff url(images/border.png) repeat-x 0 100%;
}

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:15px;}

.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:20px 0;
	padding:5px 0;
	font-size:100%;
	color: #252525;
	border-bottom:3px solid #ccc;
}

.post h2{
	margin:10px 0;
	padding-bottom:2px;
	font-size:130%;
	font-weight:normal;
	color: #333;
	border-bottom:2px solid #515151;
}

.post h3{
	clear: both;
	margin:10px 0;
	font-size:120%;
	font-weight:normal;
	color:#214a78;
	border-bottom:1px solid #515151;
}

.post h4{
	font-size:105%;
	font-weight:normal;
	color:#214a78;
}

.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;}

.post table{
	border: 1px #214a78 solid;
	border-collapse: collapse;
	border-spacing: 0;
	margin:10px 0 20px;
}

.post table th{
	padding:7px 10px 7px 5px;
	border: #214a78 solid;
	border-width: 0 0 1px 1px;
	font-weight:bold;
	color:#fff;
	background:#466f9e;
}

.post table td{
	padding:7px 5px;
	border: 1px #214a78 solid;
	border-width: 0 0 1px 1px;
	background:#fff;
}

.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.alignright, img.alignleft{
	padding:4px;
	margin:0 0 2px 7px;
	display:inline;
}

img.alignleft{margin: 0 7px 2px 0;}

.alignright{float:right;}
.alignleft{float: left;}



/* サイドバー　ウィジェット
*****************************************************/
section.widget, .widgetInfo{
margin: 10px 0 0;
padding: 10px 7px;
border:1px solid #dadada;
background: #fff;
}

#banners img{
max-width:225px;
height:auto;
padding-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 dotted #ccc;
}

section.widget a{
display:block;
padding:3px 0 3px 13px;
text-decoration:underline;
background:url(images/arrow.png) no-repeat 0 50%;
}

section.widget a:hover{
text-decoration:none;
background-position: 3px 50%;
}

#searchform input[type="text"]{
line-height:1.7;
height:24px;
width:100px;
vertical-align:bottom;
}


/* お知らせ　
-------------*/
.newsTitle{
	clear:both;
	margin: 0 0 10px;
	padding: 5px 0;
	font-size: 100%;
	color: #333;
	border-bottom: 1px dotted #ccc;
}

.newsTitle h3{
	float:left;
	font-weight: bold;
}

.newsTitle p{
	float: right;
	padding: 0 0 0 10px;
	font-size: .8em;
	background: url(images/arrow.png) no-repeat 0 50%;
}

.newsDetail p{
	float:right;
	padding: 0 0 0 10px;
	font-size:.8em;
}

.news p{
	clear: both;
	padding-bottom: 2px;
	border-bottom: 1px dotted #ccc;
}

.news p:last-child{border:0;}

.news p{
	display:block;
	padding:5px 0;
}

.news a span{
	color:#515151;
}

.news span{/*padding-left:10px;*/}

.news a:hover span{color:#777;}



/* フッター
*****************************************************/
#footer ul{
	padding-bottom:30px;
	font-size:85%;
}

#footer ul li{
	display:inline-block;
	vertical-align:text-top;
	text-align:left;
	padding:5px 0;
	margin-right:40px;
	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:#2b2b2b;
}


/* 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 10px;
	background:none;
}

/* 最新記事リンク */
ul.thumb h3{
	margin: 0px 0px 5px 0px;
	padding: 1px;
	font-weight: bold;
	text-align:center;
	background:#fff;
	border:1px solid #dadada;
}

ul.thumb h3 span{
	display:block;
	padding:2px 3px;
	background:#fff;
}

ul.thumb h3 a{color:#252525;}

ul.thumb h3:hover span{background:#f3f3f3;}


/* トップページ 関連先リンク
------------------------------------------------------------*/
.linksWrap{
	width:735px;
	margin:20px -25px 20px 0;
}

.linksWrap li{
	float:left;
	width: 234px;
	margin:0 4px 0 0;
	padding:2px 0 10px;
	background:none;
}


/* マップサイズ
------------------------------------------------------------*/
iframe.map{
	width: 100%;
}

/* テーブルサイズ
------------------------------------------------------------*/
table.statsDay{
	width: 100%;
}


/* お問い合わせフォーム
------------------------------------------------------------*/
.contact{
    display:table;
}
/*
.contact dl{
    display:table-row;
}
.contact dt,dd{
    display:table-cell;
}
*/
.required{	/* 必須項目 */
	color: #C30;
	font-weight: normal;
}


/* ボックスデザイン
------------------------------------------------------------*/
div.div010-hpd {
	margin: 1em 0;
	border: solid 1px #68B36A;
}
div.div010-hpd h5 {
	margin: 0 0 1em;
	border-bottom: solid 1px #68B36A;
	background: #E6FFE6 url(images/box001.gif);
	padding: 0.5em 5px;
	color: #363;
}
div.div010-hpd p { margin: 0.5em 5px 0.5em 10px; }



/* メインメニュー　PC用
------------------------------------------------------------*/
@media only screen and (min-width: 1025px){
nav#mainNav{
	clear:both;
	position:relative;
	z-index:200;
	background:#199ad6;
}

nav#mainNav ul li{
	float: left;
	position: relative;
	border-right:1px solid #68bbe2;
}

nav#mainNav ul li:first-child{border-left:1px solid #68bbe2;}

nav#mainNav ul li a{
	display: block;
	text-align: center;
	_float:left;
	color:#fff;
	height:40px;
	line-height:40px;
	padding:15px 40px 5px;
}

nav#mainNav ul li a span,nav#mainNav ul li a strong{
	display:block;
	line-height:1.4;
}

nav#mainNav ul li a span{
	font-size: 80%;
	color:#116890;
}

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:#178cc2;
}

nav#mainNav ul ul{width:160px;}

nav#mainNav ul li ul{display: none;}

nav#mainNav ul li:hover ul{
	display: block;
	position: absolute;
	top:60px;
	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:#178cc2;
	border:0;
	border-bottom:1px solid #68bbe2;
}

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:#dbf4ff;}

nav#mainNav ul li:hover ul li:last-child{border:0;}

nav div.panel{
display:block !important;
float:left;
}
  
a#menu{display:none;}


/* フロー図作成（幅600px用）
------------------------------------------------------------*/
/* --- リストエリア --- */
ol.flow {
	width: 600px; /* リストエリアの幅 */
	margin: 0;
	padding: 0;
	list-style-type: none;
}

/* --- リスト項目 --- */
ol.flow li {
	margin-bottom: 12px; /* リスト項目の下マージン */
	padding-bottom: 28px; /* リスト項目の下パディング */
	background: url(images/flow_back.gif) no-repeat center bottom; /* リスト項目の背景 */
}
/* --- 最後のリスト項目 --- */
ol.flow li.last {
	margin-bottom: 0;
	padding-bottom: 0;
	background-image: none;
}

/* --- ボックス --- */
ol.flow dl {
	margin: 0;
}

/* --- タイトルエリア --- */
ol.flow dt {
	padding: 9px 10px 7px; /* タイトルエリアのパディング（上、左右、下） */
	background: #ffffff url(images/flow_600_top.gif) no-repeat top; /* タイトルエリアの背景 */
	border-bottom: 1px #c0c0c0 solid; /* タイトルエリアの下境界線 */
	font-weight: bold;
	font-size: 110%;
	list-style: none;
}
/* --- タイトル --- */
ol.flow dt strong {
	margin-left: 3px;
}

/* --- 本文エリア --- */
ol.flow dd {
	margin: 0;
	padding: 15px 15px; /* 本文エリアのパディング（上下、左右） */
	background: #ffffff url(images/flow_600_bottom.gif) no-repeat bottom; /* 本文エリアの背景 */
	line-height: 150%;
	height: 100px;
}


/* テーブル内の表組み
------------------------------------------------------------*/
span.item1 {
	float:left;
}
 
span.item2 {
	display: block;
	margin-left: 230px;
}

}

/* メインメニュー iPadサイズ以下から
------------------------------------------------------------*/
@media only screen and (max-width:1024px){
	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:#fff url(images/menuOpen.png) no-repeat 5px 8px;
	}
	
	nav#mainNav a#menu span{padding-left:35px;}
	
	nav#mainNav a.menuOpen{
	background:#fff 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;}



/* フロー図作成（幅600px用）
------------------------------------------------------------*/
/* --- リストエリア --- */
ol.flow {
	width: 600px; /* リストエリアの幅 */
	margin: 0;
	padding: 0;
	list-style-type: none;
}

/* --- リスト項目 --- */
ol.flow li {
	margin-bottom: 12px; /* リスト項目の下マージン */
	padding-bottom: 28px; /* リスト項目の下パディング */
	background: url(images/flow_back.gif) no-repeat center bottom; /* リスト項目の背景 */
}
/* --- 最後のリスト項目 --- */
ol.flow li.last {
	margin-bottom: 0;
	padding-bottom: 0;
	background-image: none;
}

/* --- ボックス --- */
ol.flow dl {
	margin: 0;
}

/* --- タイトルエリア --- */
ol.flow dt {
	padding: 9px 10px 7px; /* タイトルエリアのパディング（上、左右、下） */
	background: #ffffff url(images/flow_600_top.gif) no-repeat top; /* タイトルエリアの背景 */
	border-bottom: 1px #c0c0c0 solid; /* タイトルエリアの下境界線 */
	font-weight: bold;
	font-size: 110%;
	list-style: none;
}
/* --- タイトル --- */
ol.flow dt strong {
	margin-left: 3px;
}

/* --- 本文エリア --- */
ol.flow dd {
	margin: 0;
	padding: 15px 15px; /* 本文エリアのパディング（上下、左右） */
	background: #ffffff url(images/flow_600_bottom.gif) no-repeat bottom; /* 本文エリアの背景 */
	line-height: 150%;
	height: 100px;
}

/* テーブル内の表組み
------------------------------------------------------------*/
span.item1 {
	float:left;
}
 
span.item2 {
	display: block;
	margin-left: 230px;
}
	
}


/* 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, .linksWrap{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, .linksWrap{
	-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{max-width:100%;height:auto;}
	.linksWrap img{width:100%;height:auto;}



/* フロー図作成（幅400px用）
------------------------------------------------------------*/
/* --- リストエリア --- */
ol.flow {
	width: 600px; /* リストエリアの幅 */
	margin: 0;
	padding: 0;
	list-style-type: none;
}

/* --- リスト項目 --- */
ol.flow li {
	margin-bottom: 12px; /* リスト項目の下マージン */
	padding-bottom: 28px; /* リスト項目の下パディング */
	background: url(images/flow_back.gif) no-repeat center bottom; /* リスト項目の背景 */
}
/* --- 最後のリスト項目 --- */
ol.flow li.last {
	margin-bottom: 0;
	padding-bottom: 0;
	background-image: none;
}

/* --- ボックス --- */
ol.flow dl {
	margin: 0;
}

/* --- タイトルエリア --- */
ol.flow dt {
	padding: 9px 10px 7px; /* タイトルエリアのパディング（上、左右、下） */
	background: #ffffff url(images/flow_600_top.gif) no-repeat top; /* タイトルエリアの背景 */
	border-bottom: 1px #c0c0c0 solid; /* タイトルエリアの下境界線 */
	font-weight: bold;
	font-size: 110%;
	list-style: none;
}
/* --- タイトル --- */
ol.flow dt strong {
	margin-left: 3px;
}

/* --- 本文エリア --- */
ol.flow dd {
	margin: 0;
	padding: 15px 15px; /* 本文エリアのパディング（上下、左右） */
	background: #ffffff url(images/flow_600_bottom.gif) no-repeat bottom; /* 本文エリアの背景 */
	line-height: 150%;
	height: 100px;
}


/* テーブル内の表組み
------------------------------------------------------------*/
span.item1 {
	float:left;
}
 
span.item2 {
	display: block;
	margin-left: 230px;
}

}


/* 幅644px以下から ヘッダー等微調節
------------------------------------------------------------*/
@media only screen and (max-width: 644px){
	#header{text-align:center;}
	#header h1,#header p{float:none;}
	#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;}



/* フロー図作成（幅400px用）
------------------------------------------------------------*/
/* --- リストエリア --- */
ol.flow {
	width: 400px; /* リストエリアの幅 */
	margin: 0;
	padding: 0;
	list-style-type: none;
}

/* --- リスト項目 --- */
ol.flow li {
	margin-bottom: 12px; /* リスト項目の下マージン */
	padding-bottom: 28px; /* リスト項目の下パディング */
	background: url(images/flow_back.gif) no-repeat center bottom; /* リスト項目の背景 */
}
/* --- 最後のリスト項目 --- */
ol.flow li.last {
	margin-bottom: 0;
	padding-bottom: 0;
	background-image: none;
}

/* --- ボックス --- */
ol.flow dl {
	margin: 0;
}

/* --- タイトルエリア --- */
ol.flow dt {
	padding: 9px 10px 7px; /* タイトルエリアのパディング（上、左右、下） */
	background: #ffffff url(images/flow_400_top.gif) no-repeat top; /* タイトルエリアの背景 */
	border-bottom: 1px #c0c0c0 solid; /* タイトルエリアの下境界線 */
	font-weight: bold;
	font-size: 110%;
	list-style: none;
}
/* --- タイトル --- */
ol.flow dt strong {
	margin-left: 3px;
}

/* --- 本文エリア --- */
ol.flow dd {
	margin: 0;
	padding: 15px 15px; /* 本文エリアのパディング（上下、左右） */
	background: #ffffff url(images/flow_400_bottom.gif) no-repeat bottom; /* 本文エリアの背景 */
	line-height: 150%;
	height: auto;
	min-height: 100px;
}

/* テーブル内の表組み
------------------------------------------------------------*/
span.item1 {
	float:left;
}
 
span.item2 {
	display: block;
	margin-left: 230px;
}

}

/* 幅450px以下から ヘッダー等微調節
------------------------------------------------------------*/
@media only screen and (max-width: 450px){


/* フロー図作成（幅300px用）
------------------------------------------------------------*/
/* --- リストエリア --- */
ol.flow {
	width: 300px; /* リストエリアの幅 */
	margin: 0;
	padding: 0;
	list-style-type: none;
}

/* --- リスト項目 --- */
ol.flow li {
	margin-bottom: 12px; /* リスト項目の下マージン */
	padding-bottom: 28px; /* リスト項目の下パディング */
	background: url(images/flow_back.gif) no-repeat center bottom; /* リスト項目の背景 */
}
/* --- 最後のリスト項目 --- */
ol.flow li.last {
	margin-bottom: 0;
	padding-bottom: 0;
	background-image: none;
}

/* --- ボックス --- */
ol.flow dl {
	margin: 0;
}

/* --- タイトルエリア --- */
ol.flow dt {
	padding: 9px 10px 7px; /* タイトルエリアのパディング（上、左右、下） */
	background: #ffffff url(images/flow_300_top.gif) no-repeat top; /* タイトルエリアの背景 */
	border-bottom: 1px #c0c0c0 solid; /* タイトルエリアの下境界線 */
	font-weight: bold;
	font-size: 110%;
	list-style: none;
}
/* --- タイトル --- */
ol.flow dt strong {
	margin-left: 3px;
}

/* --- 本文エリア --- */
ol.flow dd {
	margin: 0;
	padding: 15px 15px; /* 本文エリアのパディング（上下、左右） */
	background: #ffffff url(images/flow_300_bottom.gif) no-repeat bottom; /* 本文エリアの背景 */
	line-height: 150%;
	height: auto;
	min-height: 100px;
}


/* テーブル内の表組み
------------------------------------------------------------*/
span.item1:after {
	content: "\A";
	white-space: pre;
}
 
span.item2 {
	margin-left: 10px;
}

}

/* 施工事例
------------------------------------------------------------*/
.contents {
	width: 100%;
	align-items:flex-start;
}
.contents img {
	width: 100%;
}
.text-center {
	text-align: center;
}
.flexbox {
	display: flex;
}
.box_before {
	width: 45%;
	margin-top :0;
	position: relative;
}
.box_after {
	width: 55%;
	margin: auto .5rem;
	position: relative;
}
.box_before2 {
	width: 50%;
	margin-top :0;
	position: relative;
}
.box_after2 {
	width: 50%;
	margin: auto .5rem;
	position: relative;
}
.contents p {
  position: absolute;
  top: 0;/*画像の左上に配置*/
  left: 0;
  margin: 0; /*余計な隙間を除く*/
  color: white;/*文字を白に*/
  background: skyblue;/*背景色*/
  font-size: 15px;
  line-height: 1;/*行高は1に*/
  padding: 5px 10px;/*文字周りの余白*/
  }
@media screen and (max-width: 767px) {
	.flexbox {
		display: block;
	}
	.flexbox .box_before {
		width: 100%;
		margin: 0 auto;
	}
	.flexbox .box_after {
		width: 100%;
		margin: 0 auto;
	}
	.flexbox .box_before2 {
		width: 100%;
		margin: 0 auto;
	}
	.flexbox .box_after2 {
		width: 100%;
		margin: 0 auto;
	}
}


/* タブ表示
------------------------------------------------------------*/
.tab-wrap {
    display: flex;
    flex-wrap: wrap;
}
.tab-label {
    color: White;
    background: LightGray;
    margin-right: 5px;
    padding: 3px 12px;
    order: -1;
}
.tab-content {
    width: 100%;
    display: none;
}
/* アクティブなタブ */
.tab-switch:checked+.tab-label {
    background: DeepSkyBlue;
}
.tab-switch:checked+.tab-label+.tab-content {
     display: block;
}
/* ラジオボタン非表示 */
.tab-switch {
    display: none;
}