/*========================
ヘッダー
========================*/
header {
	padding-top: 0.20rem;
	padding-bottom: 0.20rem;
	background-color: #FFF;
	position: relative;
	z-index: 1;
}

@media screen and (max-width: 499px) {
	header {
		padding-top: 0.16rem;
		padding-bottom: 0.16rem;
		background-color: #FFF;
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		box-sizing: border-box;
		z-index: 10;
		transition: all 0.6s ease;
	}

	header.hide {
		transform: translateY(-80px);
		opacity: 0;
	}
}

header h1 {
	width: 3.17rem;
}

@media screen and (max-width: 499px) {
	header h1 {
		width: 2rem;
	}
}

header nav {
	position: absolute;
	top: 50%;
	right: 0.20rem;
	transform: translateY(-50%);
}

@media screen and (max-width: 499px) {
	header nav {
		position: absolute;
		top: 0.5rem;
		left: 0;
		right: inherit;
		transform: none;
		width: 100%;
		box-sizing: border-box;
		background-color: #164979;
		box-shadow: 0 3px 4px rgba(0, 0, 0, 0.2);

	}
}

header nav ul {
	display: flex;
}

@media screen and (max-width: 499px) {
	header nav ul {
		display: block;
		padding-top: 0.1rem;
		padding-bottom: 0.1rem;
	}
}

header nav li {
	padding-left: 0.2rem;
}

@media screen and (max-width: 499px) {
	header nav li {
		padding-left: 0;
	}
}

header nav li a {
	font-size: 0.16rem;
	color: #222;
	text-decoration: none;
	border-bottom: 3px solid #FFF;
	line-height: 1.5;
	display: block;
}

@media screen and (max-width: 499px) {
	header nav li a {
		font-size: 0.18rem;
		color: #FFF;
		border-bottom: 0;
		padding-left: 0.4rem;
		line-height: 3;
		position: relative;
		font-weight: 700;
	}

	header nav li a::before {
		content: "";
		width: 6px;
		height: 8px;
		position: absolute;
		left: 0.2rem;
		top: 49%;
		transform: translateY(-50%);
		background-image: url(../img/common/link_triangle.png);
		background-repeat: no-repeat;
		background-position: center center;
		background-size: contain;
	}
}

header nav li a:hover,
header nav li.now a {
	border-bottom: 3px solid #164979;
}

@media screen and (max-width: 499px) {

	header nav li a:hover,
	header nav li.now a {
		border-bottom: 0;
	}

	header nav li.now a {
		color: rgba(255,255,255,0.8);
	}
}

/*========================
コンテンツエリア
========================*/
#main_cont_wrapper {
	margin-bottom: 0.70rem;
}

@media screen and (max-width: 499px) {
	#main_cont_wrapper {
		margin-bottom: 0rem;
	}
}

/* ページコンテンツエリア */
.page_contents {
	width: 70%;
}

@media screen and (max-width: 499px) {
	.page_contents {
		width: 100%;
		margin-bottom: 0.3rem;
	}
}

/* サイドバー */
.side_bar {
	width: 27%;
}

@media screen and (max-width: 499px) {
	.side_bar {
		width: 100%;
	}
}

.side_bar_box {
	background-color: #F2F2F2;
	border-radius: 3px;
	margin-bottom: 0.3rem;
	padding: 0.2rem;
}

.side_bar_box a.link {
	color: #222;
	text-decoration: none;
}

.side_bar_box .title {
	font-size: 0.15rem;
	line-height: 1.75;
	font-weight: 700;
}

.side_bar_box .text {
	font-size: 0.14rem;
	line-height: 1.75;
}

.event_box,
.news_box {
	margin-bottom: 0.2rem;
	padding-bottom: 0.2rem;
	border-bottom: 1px solid #CCC;
}

.event_box a:hover {
	color: #009245;
	opacity: 0.7;
}

.news_box a:hover {
	color: #F15A24;
	opacity: 0.7;
}

.more_btn a {
	display: block;
	text-align: center;
	font-size: 0.14rem;
	color: #FFF;
	font-weight: 700;
	padding: 0.14rem;
	position: relative;
	border-radius: 3px;
	text-decoration: none;
}

@media screen and (max-width: 499px) {
	.more_btn a {
		font-size: 0.16rem;
		padding: 0.16rem;
	}
}

.more_btn a::after {
	content: "";
	width: 5px;
	height: 8px;
	background-image: url(../img/common/link_triangle.png);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	position: absolute;
	right: 0.10rem;
	top: 50%;
	transform: translateY(-50%);
}

/* イベント情報のボタン */
.event_wrapper .more_btn a {
	background-color: #8CC63F;
	box-shadow: 0 2px 0 rgba(140, 198, 63, 0.3);
}

.event_wrapper .more_btn a:hover {
	background-color: #009245;
	box-shadow: 0 2px 0 rgba(0, 146, 69, 0.3);
}

/* お知らせのボタン */
.news_wrapper .more_btn a {
	background-color: #F15A24;
	box-shadow: 0 2px 0 rgba(241, 90, 36, 0.3);
}

.news_wrapper .more_btn a:hover {
	background-color: #C1272D;
	box-shadow: 0 2px 0 rgba(193, 39, 45, 0.3);
}


.zoom_btn {
	padding-top: 0.2rem;
	max-width: 3.00rem;
	margin: auto;
}

.zoom_btn a {
	display: block;
	text-align: center;
	font-size: 0.14rem;
	color: #FFF;
	font-weight: 700;
	padding: 0.14rem;
	position: relative;
	border-radius: 3px;
	text-decoration: none;
	background-color: #0071BC;
	box-shadow: 0 2px 0 rgba(0, 113, 188, 0.3);
}


@media screen and (max-width: 499px) {
	.zoom_btn a {
		font-size: 0.16rem;
		padding: 0.16rem;
	}
}

.zoom_btn a::after {
	content: "";
	width: 5px;
	height: 8px;
	background-image: url(../img/common/link_triangle.png);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	position: absolute;
	right: 0.10rem;
	top: 50%;
	transform: translateY(-50%);
}

/*========================
セクションタイトル
========================*/
.sec_title_box {
	margin-bottom: 0.30rem;
}

.sec_title_box .sec_title {
	font-size: 0.22rem;
	font-weight: 700;
	line-height: 1.5;
}

@media screen and (max-width: 499px) {
	.sec_title_box .sec_title {
		font-size: 0.2rem;
	}
}

.sec_title_box .sec_title::after {
	content: "";
	background-color: #005B37;
	width: 0.30rem;
	height: 2px;
	margin-top: 0.15rem;
	display: block;
}

.side_bar .sec_title_box .sec_title {
	text-align: center;
	font-size: 0.20rem;
}

@media screen and (max-width: 499px) {
	.side_bar .sec_title_box .sec_title {
		font-size: 0.18rem;
	}
}

.side_bar .sec_title_box .sec_title::after {
	margin-left: auto;
	margin-right: auto;
}


.side_bar .news_wrapper .sec_title_box .sec_title::after {
	background-color: #F15A24;
}

/*========================
リンクバナー
========================*/
#link_bnr_wrapper {
	background-color: #EEF9D3;
	padding-top: 0.4rem;
	padding-bottom: 0.2rem;
}

@media screen and (max-width: 499px) {
	#link_bnr_wrapper .flex_box {
		display: block;
	}
}

#link_bnr_wrapper li {
	margin-bottom: 0.2rem;
}

@media screen and (max-width: 499px) {
	#link_bnr_wrapper li:last-child {
		margin-bottom: 0;
	}
}

#link_bnr_wrapper li img {
	display: block;
	width: 100%;
}

@media screen and (max-width: 499px) {
	#link_bnr_wrapper {
		padding-top: 0.2rem;
		padding-bottom: 0.2rem;
	}
}

/*========================
フッター
========================*/
footer {
	background-color: #164979;
	padding-top: 0.40rem;
	padding-bottom: 0.4rem;
	text-align: center;
}

footer .logo {
	width: 3.17rem;
	margin: auto;
	margin-bottom: 0.2rem;
}

@media screen and (max-width: 499px) {
	footer .logo {
		width: 2.4rem;
	}
}

footer address {
	font-size: 0.13rem;
	line-height: 1.75;
	color: #FFF;
	margin-bottom: 0.2rem;
}

@media screen and (max-width: 499px) {
	footer address {
		font-size: 0.12rem;
	}
}

footer .copyright {
	font-size: 0.10rem;
	line-height: 1.75;
	color: #FFF;
}
