@charset "utf-8";
body{
	color: #000;
	font-family:'メイリオ',Meiryo,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro',Verdana,'ＭＳ Ｐゴシック',sans-serif;
	font-size: 13px;
	line-height: 1.8;
	background: #fff;
	text-align: center;
	min-width:320px;
	background-image:url(../img/bg01.jpg);
	background-repeat:repeat;
	background-position:center top;
	background-size :auto;
	overflow-x: hidden;
}

#bg_line{
	width: 100%;
	height: 100%;
	opacity: 0.5;
	position: absolute;
	background-image:
	url(../img/dot01.gif),
	url(../img/dot01.gif);
	background-repeat:
	repeat-y,
	repeat-y;
	background-position:
	left top,
	right top;
	background-size :
	30px auto,
	30px auto;
}


img,object{
	border: 0;
	vertical-align: bottom;
}

.red{
	color: #ef2e2e;
}

.fw{
	font-weight: bold;
}

.topics_ttl{
	/*color:#069;*/
	padding: 5px 0 0 0;
	font-weight: bold;
}

.bnr{
	display: inline-block;
	filter:drop-shadow(0px 0px 3px rgba(0,0,0,0.1))
}



@media (max-width: 1200px) {
	#bg_line{
		background-image: none;
	}
}


/* ---------------------------------------*/
/* ヘッダー */
/* ---------------------------------------*/
.hdn{
	position:absolute;
	top:0;
	left:0;
	width:0;
	height:0;
	visibility:hidden;
}


#header_bg{
	width: 100%;
	position: relative;
	overflow:hidden;
}



#header{
	width: 100%;
	height: 270px;
	margin: 0 auto;
	overflow: hidden;
	background-image:url(../img/header_bg01.jpg);
	background-repeat:no-repeat;
	background-position:center -10px;
	background-size :auto;
	position: relative;
	z-index: 10;
}


#head_logo{
	width: 100%;
	text-align:center;
	margin:0 auto;
	position: absolute;
	bottom: -1%;
}

#head_logo img{
	max-width: 650px;
}




.shadow01{
	width: 100%;
	height: 40px;
	position: absolute;
	bottom:5%;
	left: 0;
	overflow: hidden;
	background-image:url(../img/shadow01.png);
	background-repeat:repeat-x;
	background-position:center top;
	background-size :auto;
	z-index: 0;
}





@media (max-width: 750px) {
	#header{
		height: 200px;
		background-size : auto 80%;
	}

	#head_logo img{
		width: 100%;
		max-width: 500px;
	}
}


@media (max-width: 480px) {
	#header{
		height: 135px;
		background-size : auto 85%;
	}

	#head_logo img{
		max-width: 340px;
	}
}


	
/* ---------------------------------------*/
/* ナビゲーション */
/* ---------------------------------------*/

#gnav{
	max-width: 1060px;
	margin: 0 auto;
	padding: 20px 0 30px 0;
}

#gnav ul{
	display: flex;
	justify-content: center;
	text-align:center;
}

#gnav ul li{
	padding: 4px;
}


@media (max-width: 750px) {

	#gnav{
		padding: 10px 0 20px 0;
	}

	#gnav ul{
		flex-wrap: wrap;
	}

	#gnav ul li{
		width: 22%;
	}

}



/* ---------------------------------------*/
/* コンテンツ */
/* ---------------------------------------*/


h2{
	padding: 0 0 15px 0;
	margin: 0 auto;
	font-size: 150%;
	font-weight: bold;
	text-align:left;
	max-width: 1120px;
	filter: drop-shadow(3px 3px 3px rgba(0,0,0,0.1));
}


h2 img{
	max-width: 200px;
}


p.date{
	text-align: left;
}

#contents_bg{
	position: relative;
}


.contents{
	text-align: left;
	font-size: 15px;
	width: 100%;
	max-width: 1120px;
	margin: 0 auto;
	padding: 0 0 60px 0;
	filter: drop-shadow(3px 3px 4px rgba(0,0,0,0.1));
}

.pict{
	margin: 0 auto;
	text-align: center;
	background-color: #000;
}

.bn03{
	padding: 0 0 40px 0;
	filter: drop-shadow(2px 2px 3px rgba(0,0,0,0.2));
}

.more p{
	font-size: 115%;
	font-weight: bold;
	color: #888;
	padding: 0 0 5px 0;
}

.more ul{
	overflow: hidden;
}

.more ul li{
	color:#999;
	float:left;
	border-radius: 18px;
	padding: 3px 10px;
	border:solid 1px #aaa;
	margin-right: 10px;
}


.dot01{
	width: 100%;
	height: 30px;
	margin: 0 0 30px 0;
	overflow: hidden;
	background-image:url(../img/dot01.gif);
	background-repeat:repeat-x;
	background-position:center top;
	background-size :auto 100%;
	z-index: 0;
	opacity: 0.7;
}

#light{
	position: absolute;
	top:0;
	left: 0;
}



@media (max-width: 750px) {

	.contents{
		padding:0;
	}
	
	h2 img{
		max-width: 180px;
	}



	.dot01{
		height: 18px;
		margin: 0 0 20px 0;
	}


}



/* ---------------------------------------*/
/* サイドコンテンツ */
/* ---------------------------------------*/
#left-column{
	padding: 25px;
	background: #ffffff;
	box-shadow: 0 0 6px 0 rgba(204, 204, 204, 0.5);
}


#left-column .column{
	margin: 0 0 25px 0;
	margin: 0 0 25px 0;
}


#left-column .column p.img{
	margin-bottom: 15px;
	text-align:center;
}

#left-column .column p.txt{

}

#left-column .column .pager{
	border-top: 1px solid #f1f1f1; 
	border-bottom: 1px solid #f1f1f1;
	padding: 10px;
}

#left-column .column .pager p.left{
	float: left;
}

#left-column .column .pager p.right{
	float: right;
}

#left-column .attention{
	margin: 0 0 20px 0;
	padding: 20px 15px;
	background: #ffffff;
	box-shadow: 0 0 6px 0 rgba(204, 204, 204, 0.5);
}

#left-column .attention p.ttl{
	border-bottom: 1px dotted #CCC;
	margin: 0 0 5px 0;
}

#left-column .attention ul.list{
	list-style: disc;
	margin: 0 0 10px 0;
}



#right-column{
	margin:0 auto;
	padding: 20px 0 0 0;
}


#right-column .right_bn{
	text-align:center;
}

#right-column .right_bn li{
	padding: 0 0 20px 0;
}

#right-column .news{
	margin: 5px 0 20px 0;
}

#right-column .news .ttl{
	position: relative;
	margin: 0 0 10px 0;
}

#right-column .news ul{
	background-color: #fff;
	padding: 3px 10px 12px 10px;
}


#right-column .news ul li{
	padding:10px 0;
	border-bottom: solid 1px #ccc;
	font-weight: bold;
	text-indent: -1em;
	padding-left:1em;
}



@media (min-width: 1120px) {

	#left-column{
		float: left;
		width: 740px;
	}

	#left-column .column{
		margin: 0 0 20px 0;
		padding: 0 0 20px 0;
		/*
		background: #ffffff;
		box-shadow: 0 0 6px 0 rgba(204, 204, 204, 0.5);
		*/
	}


	#left-column .column p.img{
		margin-bottom: 15px;
		text-align:center;
	}

	#left-column .column p.txt{

	}

	#left-column .column .pager{
		border-top: 1px solid #f1f1f1; 
		border-bottom: 1px solid #f1f1f1;
		padding: 10px;
	}

	#left-column .column .pager p.left{
		float: left;
	}

	#left-column .column .pager p.right{
		float: right;
	}

	#left-column .attention{
		margin: 0 0 20px 0;
		padding: 20px 15px;
		background: #ffffff;
		box-shadow: 0 0 6px 0 rgba(204, 204, 204, 0.5);
	}

	#left-column .attention p.ttl{
		border-bottom: 1px dotted #CCC;
		margin: 0 0 5px 0;
	}

	#left-column .attention ul.list{
		list-style: disc;
		margin: 0 0 10px 0;
	}

	#left-column .attention ul.list li{
		color: #004d99;
		text-decoration: underline;
		display: inline;
		margin: 0 10px 0 0;
	}

	#right-column{
		float: right;
		width: 300px;
		padding: 0;
	}
}/*@media*/




/* ---------------------------------------*/
/* footer */
/* ---------------------------------------*/

#footer_bg{
	background: #000;
	overflow:hidden;
	background-image:url(../img/footer_bg01.jpg);
	background-repeat:no-repeat;
	background-position:center top;
	background-size :auto 100%;
	min-height: 180px;
	position: relative;
	filter: drop-shadow(0px 0px 5px rgba(0,0,0,0.3));
}

#footer_top{
	padding: 6% 0 0 0;
	width: 100%;
	max-width: 1300px;
	box-sizing: border-box;
	margin: 0 auto;
	overflow: hidden;
}


#footer_logo{
	width:38%;
	padding: 0 0 0 4%;
	margin: 10px auto;
	position: relative;
	box-sizing: border-box;
	float: left;
	text-align: center;
}

#footer_menu{
	box-sizing: border-box;
	width:62%;
	padding: 0 2%;
	float: right;
	overflow: hidden;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	text-align:center;
}


#footer_menu li{
	display: inline;
	color:#222;
	padding:4px 4px;
	font-weight: bold;
	max-width: 180px;
}




.fiction{
	color: #fff;
	padding: 15px 5px 45px 5px;
}

.copyright{
	width: 100%;
	text-align: center;
	color: #fff;
	position: absolute;
	bottom: 5px;
	left: 0;
}



@media (max-width: 750px) {

	#footer_bg{
		background-size :auto 100%;
	}


	#footer_menu{
		padding: 5% 0 0 4%;
	}


	#footer_logo{
		padding: 4% 0 0 4%;
	}
	
	#footer_menu li{
		width: 27%;
	}
	

	.copyright{
		bottom: 0;
	}
	
}/*@media*/





