@charset "UTF-8";

/*--------------------------------------------------------------- 
			ページ構造の指定
--------------------------------------------------------------- */
html,body {
	width: 100%;
	height: 100%;
	}
body {
	-webkit-text-size-adjust: 100%;
	background:	url("../img/bg_wrap.jpg") repeat-x center top;
	background-attachment: fixed;
	background-color: #FFF;
	text-align: justify;
	text-justify: inter-ideograph;
	font-family:Arial, Verdana, "Noto Sans Japanese", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "游ゴシック", YuGothic, Osaka, sans-serif;
	font-size: 85%;
	line-height: 1.6;
}
body#top {
	background: url("../img/bg_wrap.jpg") repeat-x center top;
	background-attachment: fixed;
}
.contents.top{
	background: url("../img/bg_main.png") no-repeat right 15px;
	}
.contents{
		padding-top: 20px;
		width: 1280px;
		margin: auto;
	}

@media screen and (max-width: 768px){
	.contents, .contents.top{
		background-image: none;
		width: 100%;
		margin: auto;
	}
}


@media screen and (max-width: 768px){
	.pc {
		display: none;
	}
}
@media screen and (min-width: 769px){
	.sp {
		display: none;
	}
}


@media (max-width: 768px) {
	body, body#top {background: none;}
}

/*--------------------------------------------------------------- 
			ヘッダー
--------------------------------------------------------------- */
#header {
	z-index: 1 !important;
	width: 100%;
	margin:auto ;
	position: fixed;
	display: block;
}
/*#top #header {
	margin: -58px auto 0;
	height: 58px;
}*/
#header h1 {
	position: relative;	
}
#header h1 a{
	position: absolute;
	width: 100%;
	margin: 0 auto;
	padding: 0;
	display: block;
	outline: none;
	left: -20px;
}

@media (max-width: 768px) {
	.contents{
		padding-top: 70px;
	}
	#header {
		/*margin: -80px auto 0;
		height: 80px;*/
		box-shadow: none;
	}
	#header_sp {
		position: fixed;
		width: 100%;
		/*margin: 115px auto 0;*/
		z-index: 999;
		height: auto;
		text-decoration: none;
	}
}

/* Toggle Button */
#nav-toggle {
  display: none;
}

@media (max-width: 768px) {
	#header_sp {
		top: 0;
		position: fixed;
		margin-top: 0;
		width: 100%;
		padding: 0;
		/* Fixed reset */
	}
	#header_sp .inner {
		width: 100%;
		padding: 0;
		box-shadow: 0px 10px 10px -6px rgba(0, 0, 0, 0.1);
	}
	#sp-head {
		background: rgba(255, 255, 255, 0.7);
		width: 100%;
		height: 70px;
		z-index: 999;
		position: relative;
	}
	#header_sp h1 {
		position: absolute;
		left: 0;
		top: 10px;
	}
	#header_sp h1 img{
		width: 70%;
	}
	#sp-nav {
		position: absolute;
		/* 開いてないときは画面外に配置 */
		top: -840px;
		background: rgba(16, 89, 103, 0.9);
		width: 100%;
		text-align: center;
		-webkit-transition: .5s ease-in-out;
		-moz-transition: .5s ease-in-out;
		transition: .5s ease-in-out;
	}
	#sp-nav ul {
		display: block;
		list-style: none;
		position: static;
		right: 0;
		bottom: 0;
		font-size: 18px;
		font-weight: bold;
		margin-top: 2px;
	}
	#sp-nav ul li {
		border-bottom: solid 1px #ffffff;
	}
	#header_sp #sp-nav ul li a{
		width: 100%;
		display: block;
		padding: 7px 0;
		color: #fff;
		text-decoration: none;
	}
	#nav-toggle {
		display: block;
		position: absolute;
		width: 50px;
		height: 50px;
		background-color: #0c4f59;
		top: 6px;
		right: 6px;
	}
	/* #nav-toggle 切り替えアニメーション */
	#nav-toggle span {
		display: block;
		position: absolute;
		height: 4px;
		width: 60%;
		background: #ffffff;
		left: 10px;
		-webkit-transition: .35s ease-in-out;
		-moz-transition: .35s ease-in-out;
		transition: .35s ease-in-out;
	}
	#nav-toggle span:nth-child(1) {
		top: 11px;
	}
	#nav-toggle span:nth-child(2) {
		top: 22px;
	}
	#nav-toggle span:nth-child(3) {
		top: 33px;
	}
	.open #nav-toggle span:nth-child(1) {
		top: 22px;
		-webkit-transform: rotate(315deg);
		-moz-transform: rotate(315deg);
		transform: rotate(315deg);
	}
	.open #nav-toggle span:nth-child(2) {
		width: 0;
		left: 50%;
	}
	.open #nav-toggle span:nth-child(3) {
		top: 22px;
		-webkit-transform: rotate(-315deg);
		-moz-transform: rotate(-315deg);
		transform: rotate(-315deg);
	}

	/* #sp-nav スライドアニメーション */
	.open #sp-nav {
		/* #sp-nav top + #sp-head height */
		-moz-transform: translateY(910px);
		-webkit-transform: translateY(910px);
		transform: translateY(910px);
	}
}


/*---------------------------------------------------------------*/
#wrapper.top {
	width: 1280px;
	margin: 0 auto;
}
@media screen and (max-width: 768px){
	#wrapper.top ,#wrapper {
		width: 100%;
	}
}

#wrapperInr {
	width: 1100px;
/* 	box-shadow */
	/*box-shadow:0px 0px 9px 1px rgba(0,0,0,0.15);*/
	overflow: hidden; /* 回り込み(float)の解除 + 内部要素の高さを自動補正 */
	zoom: 1; /* for IE6 */
	margin: 0 auto;
}
@media screen and (max-width: 768px){
	#wrapperInr {
		width: 100%;
	}
}
#wrapperInr.top ,#wrapperInr{
	width: 1280px;
}
@media screen and (max-width: 768px){
	#wrapperInr.top, #wrapperInr {
		width: 100%;
	}
}

/*---------------------------------------------------------------*/
#side-nav {
	width: 270px;
	float: left;
	position: fixed
}


@media screen and (max-width: 768px){
	#side-nav {
		display: none;
	}	
	/*.area-banner img {
		padding: 10px; 
		max-width: 200px;
		height: auto;
	}*/
	.area-banner {
		text-align:	center;
		margin: 20px;}
}


/*---------------------------------------------------------------*/
#main {
/*	width: 890px;*/
	width: 920px;
	float: right;
	margin-right: 100px;
}
@media screen and (max-width: 768px){
	#main {
		width: 100%;
		margin-right:0;
	}
}



/*--------------------------------------------------------------- 
			トップページ
--------------------------------------------------------------- */
#topMain {
	height: 688px;
	position: relative;
}

#topMain p, #topKikan p, #topInfo p, #topInfo2 p{
	display: none;
}

@media screen and (max-width: 768px){
	#topMain {
		height: auto;
		margin-bottom: 0;
		line-height: 0;
	}
}



/*---lead---*/
#lead{
	width: 100%;
	 background-image: linear-gradient(90deg, #bee755, #2c96ad 53%, transparent 72% 100%);
	height: 260px;
}
#lead .cont-wrap{
	width: 1280px;
	height: 260px;
	margin: auto;
	padding-right: 130px;
	box-sizing: border-box;

}
#lead .cont-wrap-in{
	width: 100%;
	background-image: linear-gradient(90deg, transparent, #7db75a 35%, #2c96ad);
	height: 260px;
	display: flex;
	padding: 20px 50px 20px 260px;
	box-sizing: border-box;
}
#lead .lead-tex{
	color: #ffffff;
	font-size: 125%;
	margin-left: 50px;
}

@media screen and (max-width: 768px){
	#lead {
		height: 370px;
		padding: 0;
		background-image: none;
	}
	#lead .cont-wrap{
		width: 100%;
		padding-right: 0;
		background-image: none;
	}
	#lead .cont-wrap-in{
		display: block;
		padding:10px;
		height: auto;
		background-image: linear-gradient(10deg, #24788a 21%, #80ba5c 48%);

	}
	#lead .cont-wrap-in img{
		width: 60%;
	}
	#lead .cont-wrap-in p{
		text-align: center;
	}
	#lead .cont-wrap-in p.lead-tex{
		margin: 0;
		text-align: left;
	}
}


/*---Area-video---*/
.Area-video{
	width: 100%;
	margin: 30px auto 10px;
	text-align: center;
/*	background: #111111;*/
}
.Area-video #player1{
	width: 750px;
	text-align: center;
	margin-left: 80px;
}
	@media screen and (max-width: 768px){
		.Area-video{
			margin-top: 10px;
		}
		.Area-video #player1{
			width: 100%;
			margin-left: 0px;
		}
	}

/*---NEWS---*/
#news{
	width: 100%;
	background:	url("../img/bg_news.png") no-repeat right bottom;
}
#top-news {	
	width: 1200px;
	height: 300px;
	padding: 50px 30px 15px 200px;
	margin: 0 6em 1.5em 3em;
	margin: auto;
}
#top-news #top-newsInr {
	height: 220px;
	overflow-x: auto;
	overflow-y: scroll;
	zoom: 1;
}
#top-news h2, #top-news dl, #top-news dl dt, #top-news dl dd {		/*余白リセット*/
	line-height: 100%;
	margin: 0;
	padding: 0;
}
#top-news h2 {
	float: left;
	text-align: center;
	margin: 9px 40px 0 10px;
}
#top-news dl {
	overflow: hidden; /* 回り込み(float)の解除 + 内部要素の高さを自動補正 */
	zoom: 1; /* for IE6 */
	margin: 0;
	margin-right: 20px;
	background-color: #F4F4F4;
	padding: 10px;
	margin-bottom: 5px;
}
#top-news dl dt, 
#top-news dl dd {
	display: block;
	line-height: 130%;
	font-size: 94%;
	font-weight: normal;
	padding: 8px 4px;
}
#top-news dl dt {
	clear: left; /* 環境別での表示崩れを防ぐ */
	float: left;
	text-align: center;
	width: 16%;
	color: #67BB77;
	font-weight: bold;
}
#top-news dl dd {
	float: left;
	width: 75%;
	padding-left: 8px;
}
#top-news a {
	text-decoration: underline;
}
#top-news a:hover {
	text-decoration: none;
}

@media screen and (max-width: 768px){
	#news{
		background:	url("../img/bg_news.png") no-repeat right top;
	}
	#top-news {
		margin: 0;
		padding: 0px 10px 20px 0;
		width: 100%;
		height: 230px;
	}
	#top-news #top-newsInr {
		height: 160px;
	}
	#top-news h2 {
		width: auto;
		margin: 10px 5px 10px 25px;
		float: none;
		text-align: left;
	}
	#top-news dl dt, #top-news dl dd {
		padding: 8px 4px 0;
	}
	#top-news dl{
		margin: 0 3px 5px 10px;
		border-bottom: 0;
		padding: 5px 10px;
	}
	#top-news dl dt {
		font-size: 110%;
		font-weight: bold;
		width: 27%;
		margin-bottom: 1px;
	}
	#top-news dl dd {
		font-size: 110%;
		width: 70%;
		margin-bottom: 6px;
	}
}



.top-end {
	font-family: "Noto Sans Japanese", "游ゴシック", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, sans-serif;
	font-size: 130%;
	font-weight: bold;
	text-align: center;
/*	margin: 2em;*/
	display: block;
	margin: -14em 1.5em 5.4em;
	padding: 0.7em 0.5em 0.5em;
	line-height: 1.7;
	background-color: #FEFEF1;
	border: solid 3px #FEA758;
}
@media screen and (max-width: 768px){
	.top-end {
		font-size: 125%;
		margin: 0.5em 1em 1.5em;
	}
}


a img{
    transition: 0.3s;
}
a img:hover{
    opacity: 0.8;
}

/*--------------------------------------------------------------- 
			フッター
--------------------------------------------------------------- */
#footer {
	clear: both;
    width: 100%;
    height: 200px;
	margin: 0 auto;
	background: url("../img/bg_footer.jpg") center top;
}
#footerInr {
	width: 1280px;
	display: flex;
	justify-content: space-around;
	margin: auto;
    text-align: center;
	height: 50px;
	font-size: 83%;
	padding: 30px;
}
#footer p {
	color: #000000;
}

@media screen and (max-width: 768px){
	#footer {
		height: 200px;
	}
	#footerInr {
		display: block;
		font-size: 90%;
		line-height: 1.2;
		width: 100%;
		padding: 30px 10px;
	}
	#footer img{
		max-width: 100%;
	}
	#footer .img-org{
		padding: 0 50px;
	}
}

/*PAGETOP*/
.pagetop {
	position: fixed;
	right: 1%;
	display: block;
	z-index: 10;
	margin-right: 40px;
	padding: 50px 0;
}



/*--------------------------------------------------------------- 
			ページ共通
--------------------------------------------------------------- */

#page {
/*	background: url("../img/bg_main.jpg") no-repeat center top;*/
	/*min-height: 730px; ---#box-whiteに移動---*/
	height: auto !important; /* for IE6 */
	height: 700px; /* for IE6 */
/*	background-color: #FFF;*/
	margin-bottom: 40px;
	padding: 120px 20px 30px;
}
#page #box-white{
	background-color: #ffffff;
	min-height: 700px;
	box-shadow: 0px 0px 15px 2px rgba(114, 114, 114, 0.35);
	padding-bottom: 40px;
}
.pageInr {
	width: 720px;
	margin: 30px auto 40px;
}

@media screen and (max-width: 768px){
	#page {
		background: #ffffff;
		width: 100%;
		/*min-height: 350px; ---#box-whiteに移動---*/
		/*border: none;*/
		padding: 0;
	}
	#page #box-white{
		background-color: #ffffff;
		border: none;
		min-height: 550px;
		box-shadow:none;
	}
	.pageInr {
		width: 95%;
	}
	.pageInr img {
		max-width: 100%;
		height: auto;
	}
}

.pageInr p{
	margin: 0 0.5em;
}


#page h2{
	font-family: Arial, Verdana, "Noto Sans Japanese", "游ゴシック", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, sans-serif;
	color: #ffffff;
	background:url("../img/bg_h2.jpg") no-repeat top center;
	text-shadow:2px 2px 4px #38a1b9,2px -2px 4px #38a1b9,-2px 2px 4px #38a1b9,-2px -2px 4px #38a1b9;
	font-size: 220%;
	font-weight: bold;
	text-align: right;
	letter-spacing: 1px;
	margin: 0;
	position: relative; /* for IE6 */
	padding: 7px 0;
	height: 110px;
}
#page h2 {
	padding: 5px 20px 5px 30px;
}
@media screen and (max-width: 768px){
	#page h2 {
		font-size: 170%;
		letter-spacing: 1px;
		padding: 0.3em 10px;
		margin: 0;
	}
}

h3 {
	font-family: Arial, Verdana, "Noto Sans Japanese", "游ゴシック", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, sans-serif;
	color: #007FCC;
	font-size: 150%;
	font-weight: bold;
	line-height: 140%;
	text-align: left;
	/*background: linear-gradient(100deg, #123479, #54409B);*/
	margin: 1.5em 0 0.8em;
	position: relative; /* for IE6 */
	padding: 3px 5px;
	border-bottom: solid 4px #ffffff;
	border-image: linear-gradient(135deg, #0f849d 80%, #ffffff 100%) 1;
}
h3:before {
	content: "";
    position: absolute;
	width: 60px;
	left: 0;
	bottom: -4px;
    border-bottom: 4px solid #7fb759;
}

h4 {
	font-family: Arial, Verdana, "Noto Sans Japanese", "游ゴシック", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, sans-serif;
	color: #1E6FA4;
	font-size: 122%;
	font-weight: bold;
	line-height: 130%;
	text-align: left;
	position: relative;
	margin: 1.8em 0.3em 0.8em;
	zoom: 1; 
  	padding: 0.35em 1em 0.25em;
	background-color: #F1F1F1;
}

h5 {
	font-size: 108%;
	color: #D96D00;
	font-weight: bold;
	text-align: left;
	position: relative;
	margin: 1.2em 0.8em 0.5em;
	padding-left: 14px;
	border-bottom: solid 1px #D96D00;
}

h5:before {
	border: solid 2px #D96D00;
	border-radius: 50%;
	content: "";
	height: 5px;
	width: 5px;
	left: 0;
	position: absolute;
	top: 6px;
}
/*.areaInt h5 {
	margin-left: -20px;
}*/
h6 {
	font-size: 105%;
	font-weight: bold;
	text-align: left;
	margin: 1em 0 0.3em;
}
