@charset "utf-8";

/********** 1 共通 **********/

/* スマートフォンのPC表示切り替えボタンを非表示に */
#viewPCMode{
	display: none;
}

/* float clear */
.cf:before,
.cf:after {
	content: "";
	display: table;
}
.cf:after {
	clear: both;
}
/* For IE 6/7 (trigger hasLayout) */
.cf {
	zoom: 1;
}

/* スマートフォン用 */
#sp_page_index_link_wrap {
	display: none;
}
.sp_button {
	display: none;
}
#spm_wrap {
	display: none;
}
/* レスポンシブアコーディオン用 */
.acc_title + input {
	display: none;
}
.acc_icon {
	display: none;
}

/* 隠す */
.hide {
	display: block;
	width: 0px;
	height: 0px;
	margin: 0px;
	padding: 0px;
	clip: rect(0,0,0,0);
	overflow: hidden;
}
hr.hide {
	border: none;
}

/* 承認枠 */
#approval_table {
	font-size: 1.4rem;
}

/********** 2 基本設定 **********/

/* フォント */
body {
	font-family: Meiryo, メイリオ, 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Osaka, 'MS PGothic', sans-serif;
	color: #333333;
}
em {
	font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Osaka, 'MS PGothic', sans-serif;
}

.mincho {
	font-family: serif;
}

/* リンク */
a:link {
	color: #0d59b7;
	text-decoration: underline;
}
a:visited {
	color: #660099;
	text-decoration: underline;
}
a:active {
	color: #cc0000;
	text-decoration: underline;
}
a:hover {
	color: #000000;
	text-decoration: underline;
}

a img {
	border: none;
}

input[type="button"],
input[type="submit"],
button {
	cursor: pointer;
	font-family: sans-serif;
	font-size: 1.6rem;
}

input[type="text"],
textarea,
select {
	font-family: sans-serif;
	font-size: 1.6rem;
}

/* 外部リンク */
.external_link_text {
	display: none;
}

/* 基本タグ */
p {
	margin: 1em 0px;
	word-break: normal;
	word-wrap: break-word;
}

hr {
	clear: both;
}

/* テーブル */
#main_body table {
	border-color: #666666;
	border-collapse: collapse;
	border-style: solid;
	margin: 0px 0px 10px;
	max-width: 100%;
}
#main_body th {
	background: #f5f5f5;
	border-color: #666666;
	border-collapse: collapse;
	border-style: solid;
	border-width: 1px;
	padding: 0.5em;
}
#main_body td {
	border-color: #666666;
	border-collapse: collapse;
	border-style: solid;
	border-width: 1px;
	padding: 0.5em;
}
/* テーブル（borderを「0」に設定した場合は罫線を表示させない） */
/*
#main_body table[border="0"],
#main_body table[border="0"] th,
#main_body table[border="0"] td {
	border-width: 0px;
}
*/
/* テーブル内のpタグのマージンを0にする */
#main_body table p {
	margin: 0px 0px 1em;
}
#main_body table p:last-child {
	margin: 0px;
}

/* 見出し */
#main_header {
	margin-bottom: 20px;
}
#main_header h1 {
	margin: 0px;
	padding: 0.8em 20px;
	background: #435d1e;
	border: none;
	color: #ffffff;
	font-size: 3.2rem;
	font-weight: bold;
	line-height: 1.4;
}

#main_body h2 {
	clear: both;
	margin: 20px 0px;
	padding: 0.8em 20px;
	background: #76a32e;
	border: none;
	color: #000000;
	font-size: 2.8rem;
	font-weight: bold;
	line-height: 1.4;
}
#main_body h2 a{
	color: #160B91;
}
#main_body h2 a:hover,
#main_body h2 a:focus,
#main_body h2 a:active,
#main_body h2 a:visited{
	color: #000000;
}

#main_body h3 {
	clear: both;
	margin: 20px 0px;
	padding: 20px 20px;
	background: #f2f6cc;
	border: none;
	color: #000000;
	font-size: 2.1rem;
	font-weight: bold;
	line-height: 1.4;
}

#main_body h4 {
	clear: both;
	margin: 20px 0px;
	padding: 18px 20px;
	background: transparent;
	border: 1px solid #557624;
	color: #000000;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.4;
}

#main_body h5 {
	clear: both;
	margin: 20px 0px;
	padding: 13px 20px;
	background: transparent;
	border: 1px solid #c3d600;
	color: #000000;
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 1.4;
}

#main_body h6 {
	clear: both;
	margin: 20px 0px;
	padding: 0.5em 20px;
	background: transparent;
	border: none;
	border-bottom: 1px solid #67710e;
	color: #000000;
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 1.4;
}

/********** 3 ヘッダ **********/

/* ヘッダ */
#header {
	font-size: 1.5rem;
	position: static;
	top: -200px;
}

#header2 {
	width: 98%;
	max-width: 1080px;
	margin: 0px auto;
	padding: 15px 0;
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
	-webkit-box-pack: start;
		-ms-flex-pack: start;
			justify-content: flex-start;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
}
#he_left {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	min-width: 280px;
	margin-left: 0;
	margin-right: auto;
}
#he_left a.link_honbun{
	display: block;
	margin: 0 5px 0 0;
	padding: 8px 13px;
	background:#eaeaea;
	font-size: 1.2rem;
	line-height: 1em;
	color: currentColor;
	text-decoration: none;
	border-radius: 5px;
}
#he_left #logo {
	margin: 0px;
}
#he_left #logo a {
	display: block;
}
#he_left #logo img {
	max-width: 100%;
	height: auto;
}

#he_right {
	width: 430px;
	margin-right: 20px;
}

ul#header_link {
	margin: 0px;
	padding: 0px;
	list-style: none;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	-webkit-box-pack: justify;
		-ms-flex-pack: justify;
			justify-content: space-between;
	-webkit-box-align: center;
		-ms-flex-align: center;
			align-items: center;
}
ul#header_link > li > a {
	display: block;
	margin: 0;
	padding: 8px 13px;
	background:#eaeaea;
	font-size: 1.2rem;
	line-height: 1em;
	color: currentColor;
	text-decoration: none;
	border-radius: 5px;
}

#he_left a.link_honbun:hover,
#he_left a.link_honbun:focus,
ul#header_link > li > a:hover,
ul#header_link > li > a:focus{
	background: #76a32e;
	color: #000000;
}

/* アクセシビリティ機能 */
#hl_func {
	position: relative;
}

#acc_func_box {
	display: none;
	position: absolute;
	top: 100%;
	left: -100px;
	z-index: 100;
	background: #76a32e;
	-webkit-box-shadow: 0px 3px 10px -2px rgba(0, 0, 0, 0.5);
	box-shadow: 0px 3px 10px -2px rgba(0, 0, 0, 0.5);
	border-radius: 5px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	margin: 0px;
	padding: 10px 10px;
	color: #000000;
}
#acc_func_box a{
	color: currentColor;
}
#acc_func_box.func_menu_open {
	display: block;
}
#acc_func_box ul{
	margin: 0;
	padding: 0;
	list-style: none;
	text-align: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	-webkit-box-pack: start;
		-ms-flex-pack: start;
			justify-content: flex-start;
	-webkit-box-align: start;
		-ms-flex-align: start;
			align-items: flex-start;
	width: 370px;
}
#acc_func_box ul li {
	display: block;
	margin-bottom: 15px;
}

#acc_func_box ul li#hl_yomiage,
#acc_func_box ul li#hl_ruby {
	width: calc(50% - 5px);
}
#acc_func_box ul li#hl_yomiage{
	margin-left: 0;
	margin-right: auto;
	margin-bottom: 0;
}
#acc_func_box ul li#hl_ruby{
	margin-left: auto;
	margin-right: 0;
	margin-bottom: 0;
}

#acc_func_box ul li#hl_yomiage a,
#acc_func_box ul li#hl_ruby a{
	display: block;
	margin: 0;
	padding: 10px;
	background: #fff;
	border-radius: 5px;
	font-size: 1.3rem;
	line-height: 1em;
	text-align: center;
	text-decoration: none;
}

#acc_func_box ul li#haikei_color{
	margin-left: 10px;
	margin-right: 30px;
}

#acc_func_box dl {
	margin: 0px;
	padding: 0px;
	font-size: 1.4rem;
	line-height: 1.8rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: nowrap;
		flex-wrap: nowrap;
	-webkit-box-align: center;
		-ms-flex-align: center;
			align-items: center;
}
#acc_func_box dl dt {
	display: block;
	vertical-align: middle;
	margin: 0px 5px 0px 0px;
	padding: 6px 0px;
	font-weight: bold;
	font-size: 1.4rem;
	/* width: 5em; */
}
#acc_func_box dl dd {
	display: inline-block;
	vertical-align: middle;
	margin: 0px 0px 0px 2px;
	padding: 0px;
}
#acc_func_box dl dd a {
	display: block;
	background: #ffffff;
	border-radius: 3px;
	color: #000000;
	text-decoration: none;
	padding: 5px 7px;
	font-size: 1.3rem;
}
#acc_func_box dl dd a#moji_large {
	font-size: 1.7rem;
}
#acc_func_box dl dd a#haikei_white {
	background: #ffffff !important;
	color: #000000 !important;
}
#acc_func_box dl dd a#haikei_black {
	background: #000000 !important;
	color: #ffffff !important;
}
#acc_func_box dl dd a#haikei_blue {
	background: #0000ff !important;
	color: #ffff00 !important;
}
.button_close {
	border: none;
	background: #ffffff;
	color: #000000;
	border-radius: 100%;
	margin: 0px;
	padding: 0px;
	width: 2.5rem;
	height: 2.5rem;
	position: absolute;
	z-index: 10;
}
.button_close:before,
.button_close:after{
	content: '';
	display: block;
	width: 1px;
	height: 1.8rem;
	background: #037088;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	position: absolute;
	top: calc(50% - 0.9rem);
	left: calc(50% - 0px);
}

.button_close:before{
	-webkit-transform: rotate(45deg);
		-ms-transform: rotate(45deg);
			transform: rotate(45deg);
}
.button_close:after{
	-webkit-transform: rotate(-45deg);
		-ms-transform: rotate(-45deg);
			transform: rotate(-45deg);
}
#func_menu_close.button_close{
	right: 10px;
	top: 12px;
}

/* 検索 */
#top_search_keyword {
	width: 300px;
	background: #f3f7cc;
	padding: 10px 10px 0;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

#cse-search-box {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	-webkit-box-pack: start;
		-ms-flex-pack: start;
			justify-content: flex-start;
	-webkit-box-align: start;
		-ms-flex-align: start;
			align-items: flex-start;
}
#cse-search-box label[for="tmp_query"]{
	display: block;
	margin: 10px 0;
	width: 100%;
	font-size: 1.4rem;
	line-height: 1em;
}
#tmp_query {
	display: block;
	vertical-align: middle;
	border: none !important;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 210px !important;
	height: 3.5rem !important;
	font-size: 1.4rem;
}
.submit_wrap{
	display: block;
	position: relative;
}
.submit_wrap:before{
	content: url(/img/common/search_mejiron.png);
	position: absolute;
	right: 0;
	bottom: 100%;
}
#submit {
	display: block;
	border: none;
	background: #000000;
	color: #ffffff;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 70px;
	height: 3.5rem;
	margin: 0px;
	padding: 0px;
	font-size: 1.6rem;
	line-height: 35px;
	font-weight: bold;
	white-space: nowrap;
}

#cse_filetype {
	display: inline-block;
	vertical-align: middle;
}
#cse_filetype fieldset {
	border: none;
	margin: 0px;
	padding: 0px 0px 0px 10px;
}
#cse_filetype fieldset legend {
	margin: 0px;
	padding: 0px;
	display: none;
}
#cse_filetype fieldset span {
	font-size: 1.4rem;
	display: inline-block;
}
#cse_filetype fieldset span input {
	margin: 4px;
	vertical-align: middle;
}

/* ID検索 */
#top_search_page_id{position: relative;}
#search_open_page_id_detail{
	position: absolute;
	display: none;
	-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	-webkit-box-pack: start;
		-ms-flex-pack: start;
			justify-content: flex-start;
	-webkit-box-align: stretch;
		-ms-flex-align: stretch;
			align-items: stretch;
	background: #f3f7cc;
	z-index: 10;
	width: 300px;
	left: -10px;
	top: 100%;
	padding: 10px;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
}
#search_open_page_id_detail.open{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}
input#open_page_id {
	width: calc(100% - 140px);
	border: none;
}

label[for="open_page_id"] {
	display: block;
	width: 100%;
}

input#open_page_id_submit {
	width: 70px;
	margin: 0;
	background: #000000;
	border: none;
	color: #ffffff;
	font-weight: bold;
	height: 3.5rem;
}

#top_search_page_id_ttl {
	text-align: right;
}
button#search_page_id_title {
	border: none;
	background: none;
	font-weight: bold;
	font-size: 1.4rem;
	margin: 4px 0 0;
	padding: 5px 40px 5px 5px;
	color: #435d1e;
	position: relative;
}
button#search_page_id_title:after{
	content: '';
	display: block;
	width: 10px;
	height: 10px;
	border: 2px solid #435d1e;
	border-left: none;
	border-top: none;
	-webkit-transform: rotate(45deg);
		-ms-transform: rotate(45deg);
			transform: rotate(45deg);
	position: absolute;
	right: 10px;
	top: calc(50% - 10px);
}

#open_page_id_message{
	padding: 10px 0 0;
}

#search_open_page_id_detail .button_close{
	right: 10px;
	top: calc(1em + 20px);
	background: #435d1e;
	color: #ffffff;
}
#search_open_page_id_detail .button_close:before,
#search_open_page_id_detail .button_close:after{
	background: #ffffff;
	color: #000000;
}
/* ID検索ここまで */

/* グローバルナビ */
ul#gnav {
	margin: 10px 0 0;
	padding: 0;
	list-style: none;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: nowrap;
		flex-wrap: nowrap;
	-webkit-box-pack: justify;
		-ms-flex-pack: justify;
			justify-content: space-between;
	-webkit-box-align: stretch;
		-ms-flex-align: stretch;
			align-items: stretch;
}
ul#gnav > li {
	margin: 0 0px;
}

ul#gnav > li:first-child{
	margin-left: 0;
}
ul#gnav > li:last-child{
	margin-right: 0;
}

ul#gnav > li > a,
ul#gnav > li > button {
	display: block;
	border: none;
	border: 1px solid #76a32e;
	background: none;
	background-repeat: no-repeat;
	background-position: center top 8px;
	color: #333;
	font-family: Meiryo, メイリオ, 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Osaka, 'MS PGothic', sans-serif;
	text-decoration: none;
	text-align: center;
	margin: 0px;
	padding: 52px 0px 6px;
	font-size: 1.4rem;
	line-height: 2rem;
	width: 100px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
ul#gnav > li > a:hover,
ul#gnav > li > button:hover,
ul#gnav > li > a:focus,
ul#gnav > li > button:focus {
	background-color: #76a32e;
	color: #000000;
}

ul#gnav > li.open > button {
	background-color: #557624;
	color: #ffffff;
}

ul#gnav > li#gnav1 > a {
	background-color: #f5e9b3;
	background-image: url(/img/common/gnav/gn_icon_bousai.png);
	border-color: #f5e9b3;
	border-radius: 5px;
	color: #333;
}
ul#gnav > li#gnav1 > a:hover,
ul#gnav > li#gnav1 > a:focus {
	background-color: #dfb602;
}

ul#gnav > li#gnav2 > button {
	background-image: url(/img/common/gnav/gn_icon_bunrui.png);
}
ul#gnav > li#gnav2.open > button {
	background-image: url(/img/common/gnav/gn_icon_bunrui_on.png);
}

ul#gnav > li#gnav3 > button {
	background-image: url(/img/common/gnav/gn_icon_mokuteki.png);
	background-position: center top 10px;
}
ul#gnav > li#gnav3.open > button {
	background-image: url(/img/common/gnav/gn_icon_mokuteki_on.png);
}

ul#gnav > li#gnav4 > a {
	background-image: url(/img/common/gnav/gn_icon_soshiki.png);
}

li#gnav2,
li#gnav3 {
	position: relative;
}

.open #life_menu,
.open #mokuteki_menu{
	display: block;
	text-align: right;
}
#life_menu,
#mokuteki_menu {
	display: none;
	background: #557624;
	color: #ffffff;
	position: absolute;
	left: 0;
	top: calc(100% + 10px);
	z-index: 110;
	outline: 1px solid #ffffff;
}
#life_menu ul,
#mokuteki_menu ul {
	margin: 0;
	padding: 0;
	list-style: none;
	text-align: center;
}
#life_menu li,
#mokuteki_menu li{
	margin: 0;
	padding: 0;
	border-bottom: 1px solid rgba(255,255,255,0.5);
}
#life_menu li a,
#mokuteki_menu li a{
	display: block;
	color: currentColor;
	text-decoration: none;
	margin: 0;
	padding: 5px 20px;
	white-space: nowrap;
}
#life_menu li a:hover,
#life_menu li a:focus,
#mokuteki_menu li a:hover,
#mokuteki_menu li a:focus{
	text-decoration: underline;
}

#life_menu .button_close,
#mokuteki_menu .button_close{
	position: relative;
	display: inline-block;
	margin: 10px;
}


/* 固定ヘッダここから */
@media screen and (min-width: 1080px){
	.header_fixed #header {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		background: #557624;
		z-index: 100;
		-webkit-transition: top 0.5s ease;
		-o-transition: top 0.5s ease;
		transition: top 0.5s ease;
		color: #ffffff;
	}
	.header_fixed #header2{
		-webkit-box-align: start;
			-ms-flex-align: start;
				align-items: flex-start;
	}

	.header_fixed #he_left #logo a{
		display: block;
		width: 214px;
		height: 76px;
		background: url(/img/common/logo_fixed.png);
	}
	.header_fixed #he_left #logo a img{
		display: none;
	}

	.header_fixed #he_right{
		width: auto;
		margin: 0;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: nowrap;
			flex-wrap: nowrap;
		-webkit-box-pack: end;
			-ms-flex-pack: end;
				justify-content: flex-end;
		-webkit-box-align: stretch;
			-ms-flex-align: stretch;
				align-items: stretch;
	}

	.header_fixed ul#gnav{
		margin: 0;
	}
	.header_fixed ul#gnav > li > a,
	.header_fixed ul#gnav > li > button{
		padding-top: 50px;
		padding-bottom: 3px;
	}
	.header_fixed ul#gnav > li > a:hover,
	.header_fixed ul#gnav > li > a:focus,
	.header_fixed ul#gnav > li > button:hover,
	.header_fixed ul#gnav > li > button:focus {
		background-color: #76a32e;
		border-color: #76a32e;
		color: #000;
	}

	.header_fixed ul#header_link > li > a,
	.header_fixed li#keep_page_wrap > button{
		display: block;
		background: rgba(0,0,0,0.2);
		color: #ffffff;
		border: none;
		margin: 0;
		padding: 10px;
		width: 100%;
		border-radius: 5px;
		font-size: 1.2rem;
		line-height: 1em;
		font-family: Meiryo, メイリオ, 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Osaka, 'MS PGothic', sans-serif;
		-webkit-box-sizing: border-box;
				box-sizing: border-box;
	}
	.header_fixed ul#header_link > li > a:hover,
	.header_fixed ul#header_link > li > a:focus,
	.header_fixed li#keep_page_wrap > button:hover,
	.header_fixed li#keep_page_wrap > button:focus {
		background: #76a32e;
		color: #000000;
	}

	.header_fixed #he_left a.link_honbun{
		display: none;
	}
	.header_fixed #top_search_keyword{
		background: rgba(0,0,0,0.5);
		display : none;
	}

	.header_fixed ul#header_link{
		-webkit-box-ordinal-group: 3;
		-ms-flex-order: 2;
		order: 2;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		-webkit-box-align: stretch;
		-ms-flex-align: stretch;
		align-items: stretch;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		margin: 0 0 0 10px;
	}
	.header_fixed ul#header_link > li{
		display: none;
	}
	.header_fixed ul#header_link > li.fixed_on{
		display: block;
	}

	.header_fixed ul#gnav{
		-webkit-box-pack: end;
			-ms-flex-pack: end;
				justify-content: flex-end;
	}
	.header_fixed ul#gnav > li{
		margin-left: 10px;
	}
	.header_fixed ul#gnav > li > a,
	.header_fixed ul#gnav > li > button{
		width: 155px;
		border: 1px solid #c3d600;
		color: inherit;
	}

	.header_fixed ul#gnav li#gnav1 > a{
		background-color: #dfb602;
		border-color: #dfb602;
		color: #000000;
	}
	.header_fixed ul#gnav li#gnav1 > a:hover,
	.header_fixed ul#gnav li#gnav1 > a:focus {
		background-color: #dfc44e;
		border-color: #dfc44e;
	}

	/* アンカーリンク対応 */
	body.detail div[class^="detail_"] a[href] {
		position: relative;
		z-index: 10;
	}
	body.detail div[class^="detail_"] a:not([href]) {
		padding-top: 11rem;
		margin-top: -11rem;
	}

}
/* 固定ヘッダここまで */

ul#gnav > li#gnav2 > button{
	background-image: url(/img/common/gnav/gn_icon_bunrui_on.png);
}
ul#gnav > li#gnav3 > button{
	background-image: url(/img/common/gnav/gn_icon_mokuteki_on.png);
}
ul#gnav > li#gnav4 > a{
	background-image: url(/img/common/gnav/gn_icon_soshiki_on.png);
}


/* マイページ */
#keep_page_wrap{
	display: none;
}
.header_fixed #keep_page_wrap{
	display: block;
}
.header_fixed li#keep_page_wrap > button#ktp_viewsw.open{
	background-color: #76a32e;
	color: #000000;
}
.header_fixed li#keep_page_wrap{
	position: relative;
}
#keep_page {
	display: none;
}
.header_fixed .open#keep_page{
	display: block;
	position: absolute;
	top: calc(100% + 10px);
	right: 0;
	background: #76a32e;
	padding: 10px;
	padding-right: 4.5rem;
	width: 35rem;
	color: #000000;
	border-radius: 5px;
}
#ktp_list_wrap2 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	-webkit-box-pack: start;
		-ms-flex-pack: start;
			justify-content: flex-start;
	-webkit-box-align: stretch;
		-ms-flex-align: stretch;
			align-items: stretch;
	font-size: 1.5rem;
}

#ktp_list_wrap2 > button.btn_func {
	display: block;
	width: calc(50% - 5px);
	padding: 20px;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
	background: #ffffff;
	border-radius: 5px;
	line-height: 1.2em;
	border: none;
}
#ktp_list_wrap2 > button.btn_func:nth-child(odd){
	margin-right: 10px;
}

ul#ktp_item_list {
	width: 100%;
	margin: 10px 0 0;
	padding: 0;
	list-style: none;
	display: block;
}
ul#ktp_item_list:empty{
	margin: 0;
}

ul#ktp_item_list li {
	display: block;
	padding: 15px;
	padding-right: 40px;
	margin: 0 0 1px;
	background: #ffffff;
	position: relative;
}
button.ktp_item_del.button_close {
	background: #67710e;
	position: absolute;
	right: 10px;
	bottom: 14px;
}
button.ktp_item_del.button_close:before,
button.ktp_item_del.button_close:after{
	background: #ffffff;
}
.header_fixed li#keep_page_wrap button#kpt_all_close {
	position: absolute;
	right: 10px;
	bottom: 10px;
	background: #ffffff;
	width: 2.5rem;
	height: 2.5rem;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
	border-radius: 50%;
	padding: 0;
}

/* マイページここまで */

/* グローバルナビ（動的メニュー） ※使用する場合は要調整 */

/********** 4 パンくず **********/

/* パンくず */
#pankuzu_wrap {
	background: #f0f0ee;
	padding: 15px 0px 10px;
}
#pankuzu_wrap > div {
	width: 98%;
	max-width: 1080px;
	margin-left: auto;
	margin-right: auto;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.pankuzu {
	clear: both;
	margin-bottom: 5px;
	padding: 3px 0px 3px 5.5rem;
	position: relative;
}
.pankuzu .icon_current {
	display: none;
}
.pankuzu:first-child .icon_current {
	display: block;
	width: 4rem;
	height: auto;
	background: #333333;
	border-radius: 3px;
	color: #ffffff;
	font-size: 1.0rem;
	line-height: 1em;
	padding: 5px 0px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	position: absolute;
	top: 0.4rem;
	left: 0px;
	text-align: center;
}

/********** 5 フッタ **********/

/* フッタ */
#footer {
	font-size: 1.5rem;
}

#to_page_top a {
	display: block;
	position: fixed;
	right: 10px;
	bottom: -100px;
	z-index: 200;
	-webkit-transition: bottom 0.5s ease;
	-o-transition: bottom 0.5s ease;
	transition: bottom 0.5s ease;
}
.fixed#to_page_top a{
	bottom: 10px;
}

#footer_navi {
	width: 40%;
}
#footer_navi ul.footer_navi_list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	-webkit-box-pack: start;
		-ms-flex-pack: start;
			justify-content: flex-start;
	-webkit-box-align: start;
		-ms-flex-align: start;
			align-items: flex-start;
	margin: 0px;
	padding: 0px;
	list-style: none;
}
#footer_navi ul.footer_navi_list li {
	display: block;
	margin: 0 5px 10px;
	padding: 0;
}
#footer_navi ul.footer_navi_list li a{
	display: block;
	margin: 0;
	padding: 9px 30px 7px 10px;
	border: 2px solid rgba(251,249,48,0.5);
	border-radius: 100em;
	text-decoration: none;
	line-height: 1em;
	position: relative;
}
#footer_navi ul.footer_navi_list li a:after{
	content: '';
	display: block;
	width: 5px;
	height: 5px;
	border: 2px solid #ffffff;
	border-left: none;
	border-bottom: none;
	position: absolute;
	right: 12px;
	top: 50%;
	-webkit-transform: rotate(45deg) translateY(-50%);
		-ms-transform: rotate(45deg) translateY(-50%);
			transform: rotate(45deg) translateY(-50%);
}
#footer_navi ul.footer_navi_list li a:hover,
#footer_navi ul.footer_navi_list li a:focus{
	background: rgba(0,0,0,0.3);
	border-color: transparent;
}

#author_info {
	background: #557624;
	color: #ffffff;
}
#author_info a{
	display: block;
	color: currentColor;
}
#author_box {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: nowrap;
		flex-wrap: nowrap;
	-webkit-box-pack: justify;
		-ms-flex-pack: justify;
			justify-content: space-between;
	-webkit-box-align: stretch;
		-ms-flex-align: stretch;
			align-items: stretch;
	width: 98%;
	max-width: 1080px;
	margin: 0px auto;
	padding: 45px 0px;
}
#author_box p {
	margin: 0px;
	line-height: 1.8;
}
.author_wrap{
	width: 20%;
	text-align: center;
}
.f_author_detail_wrap{
	width: 40%;
}

#author_box p.f_author {
	font-size: 3.2rem;
	font-weight: normal;
	line-height: 1em;
	margin: 0 0 20px;
}
p.f_number{
	font-size: 1.3rem;
	line-height: 1em;
}
#author_box p span {
	display: inline-block;
	margin-right: 1em;
}

dl.f_detail_text {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	margin: 20px 0 0;
	padding: 0;
}
dl.f_detail_text dt{
	margin: 0;
	padding: 5px 10px;
	background: rgba(0,0,0,0.3);
	white-space: nowrap;
	border-radius: 5px;
	font-size: 1.2rem;
	line-height: 1em;
}
dl.f_detail_text dd{
	margin: 0 0 0 10px;
	padding: 1px 0 0 0;
	font-size: 1.5rem;
	
}

ul.author_detail_link {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	margin: 40px 0 0;
	padding: 0;
	list-style: none;
}
ul.author_detail_link li{
	display: block;
}
ul.author_detail_link li a{
	display: block;
	border: 1px solid rgba(255,255,255,0.5);
	text-decoration: none;
	margin: 0px 10px 10px 0;
	padding: 6px 10px 4px;
}
ul.author_detail_link li a:hover,
ul.author_detail_link li a:focus{
	background: rgba(0,0,0,0.3);
	border-color: transparent;
}

#copyright p {
	margin: 0px;
	padding: 15px 0px 0px;
	text-align: center;
	font-size: 1.4rem;
	line-height: 2rem;
}

/* おすすめ情報（回遊ボタン） */
#osusume_banner {
	position: fixed;
	left: 10px;
	bottom: 10px;
	z-index: 90;
	border-radius: 5px;
	border: 2px solid #fff;
	overflow: hidden;
}
#osusume_banner_box {
	width: auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: nowrap;
		flex-wrap: nowrap;
	-webkit-box-pack: start;
		-ms-flex-pack: start;
			justify-content: flex-start;
	-webkit-box-align: stretch;
		-ms-flex-align: stretch;
			align-items: stretch;
	border-radius: 5px;
	overflow: hidden;
}

#osusume_banner_ttl {
	display: block;
}
#osusume_banner_ttl a {
	display: block;
	color: #000000;
	background: #3a511a;
	padding: 10px 10px;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
}

#osusume_banner_list {
	display: none;
	vertical-align: bottom;
	background: #3a511a;
	padding: 0;
	max-width: calc(100vw - 260px);
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
#osusume_banner.open #osusume_banner_list {
	display: block;
}

#osusume_banner_list_box {
	position: relative;
	padding-right: 4rem;
}
#osusume_banner_list_box ul {
	margin: 8px 0 0;
	padding: 0px 0px 0px 10px;
	list-style: none;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: nowrap;
		flex-wrap: nowrap;
	-webkit-box-pack: start;
		-ms-flex-pack: start;
			justify-content: flex-start;
	-webkit-box-align: center;
		-ms-flex-align: center;
			align-items: center;
}
#osusume_banner_list_box ul li {
	display: block;
	vertical-align: top;
	margin: 0 10px 0 0;
}
#osusume_banner_list_box ul li:last-child{
	margin-right: 0;
}
#osusume_banner_list_box ul li img {
	width: 100%;
	height: auto;
}

#osusume_banner_close {
	display: block;
	text-align: left;
	text-indent: -9999em;
	overflow: hidden;
	position: absolute;
	bottom: 0px;
	right: 0.9rem;
}

/********** 6 バナー **********/

/* バナー広告 */
ul.banner_list {
	margin: 0px;
	padding: 0px;
	list-style: none;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	-webkit-box-pack: start;
		-ms-flex-pack: start;
			justify-content: flex-start;
}
ul.banner_list li {
	width: 200px;
	margin: 5px 10px;
}
ul.banner_list li img {
	width: 100%;
	height: auto;
}

.banner_text {
	display: block;
	padding: 10px;
	font-size: 1.4rem;
	line-height: 1.3;
	text-align: left;
}

/* バナー広告（縦並び） */
ul.banner_list.banner_list_side {
	display: block;
	max-width: 300px;
	margin: 0px auto 10px;
}
ul.banner_list.banner_list_side li {
	display: block;
	width: 100%;
	margin: 0px auto 10px;
}

/********** 7 リスト **********/

/* リスト（横並び） */
.navigation ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
.navigation ul li,
.navigation > div {
	display: inline-block;
	vertical-align: middle;
	margin: 5px 10px 5px 0px;
	padding-right: 15px;
	border-right: 1px solid #666666;
	line-height: 1.4;
}
.navigation ul li:last-child,
.navigation > div:last-child {
	border-right: none;
	margin-right: 0px;
	padding-right: 0px;
}

/* リスト（一覧） */
.info_list ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
.info_list ul li {
	margin: 0px;
	padding: 8px 0px 8px 0px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
}

/* リスト（日付） */
.info_list.info_list_date ul li {
	width: 100%;
	display: table;
}
.info_list.info_list_date ul li > span {
	display: table-cell;
	vertical-align: top;
}
.info_list.info_list_date ul li > span.article_date {
	width: 11em;
}

/* リスト（サムネイル） */
.info_list.info_list_thum ul li {
	padding-left: 0px;
}
.info_list.info_list_thum ul li:before {
	display: none;
}

.list_pack {
	width: 100%;
	display: table;
}

.list_pack .article_img {
	display: table-cell;
	vertical-align: middle;
	width: 200px;
	padding-right: 20px;
}
.list_pack .article_img span {
	display: block;
}
.list_pack .article_img span:empty {
	height: 150px;
	background: url(/img/common/noimage.png) no-repeat center center #d5e2c0;
}
.list_pack .article_img span img {
	width: 100%;
	height: auto;
}

.list_pack .article_txt {
	display: table-cell;
	vertical-align: middle;
}
.list_pack .article_txt .article_date,
.list_pack .article_txt .article_title {
	display: block;
}

/* リスト（担当課） */
.article_section:before {
	content: '（';
}
.article_section:after {
	content: '）';
}
.article_section:empty:before,
.article_section:empty:after {
	display: none;
}

/* リスト（一覧リンク） */
div.link_ichiran {
	margin-top: 20px;
	text-align: right;
}

/* リスト（newアイコン） */
img.icon_new {
	vertical-align: top;
}

/* リスト（新着情報） */
.section_information {
	margin: 0px 0px 30px;
/* 	background: #f5f5f5; */
	border: 1px solid #76a32e;
}

.section_information h2,
#main_body .section_information h2 {
	margin: 0px;
	padding: 20px 20px 0px;
	background: transparent;
	border: none;
	font-size: 2.1rem;
	font-weight: bold;
	line-height: 1em;
}

.section_information p.no_data {
	margin: 0px;
	padding: 20px;
}

.section_information_list ul {
	margin: 0px;
	padding: 10px 20px;
	list-style: none;
}
.section_information_list ul li {
	width: 100%;
	display: table;
	margin: 0px;
	padding: 8px 0px 8px 20px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
}
.section_information_list ul li:before {
	content: '';
	width: 5px;
	height: 5px;
	border: 2px solid #deb514;
	position: absolute;
	top: calc(8px + 0.5em);
	left: 0px;
	-webkit-transform: rotate(45deg);
		-ms-transform: rotate(45deg);
			transform: rotate(45deg);
	border-left: none;
	border-bottom: none;
}
.section_information_list ul li > span {
	display: table-cell;
	vertical-align: top;
}
.section_information_list ul li > span.article_date {
	width: 11em;
}

.section_information_list div.link_box {
	padding: 0px 20px 20px;
	text-align: right;
}
.section_information_list div.link_box span {
	display: inline-block;
	vertical-align: middle;
	margin: 0px 0px 0px 10px;
	padding: 0px;
	line-height: 1.4;
}
.section_information_list div.link_box span:first-child {
	border-left: none;
	margin-left: 0px;
	padding-left: 10px;
}
.section_information_list div.link_box span a{
	display: block;
	text-decoration: none;
	border: 2px solid #557624;
	padding: 10px 60px 10px 20px;
	border-radius: 10rem;
	color: currentColor;
	font-size: 1.4rem;
	line-height: 1em;
	position: relative;
	-webkit-transition: background-color 0.15s ease,color 0.15s ease;
	-o-transition: background-color 0.15s ease,color 0.15s ease;
	transition: background-color 0.15s ease,color 0.15s ease;
}
.section_information_list div.link_box span a:after{
	content: '';
	display: block;
	width: 5px;
	height: 5px;
	border: 2px solid #557624;
	position: absolute;
	right: 20px;
	top: 50%;
	-webkit-transform: translateY(-50%) rotate(45deg);
		-ms-transform: translateY(-50%) rotate(45deg);
			transform: translateY(-50%) rotate(45deg);
	border-left: none;
	border-bottom: none;
	-webkit-transition: border-color 0.15s ease;
	-o-transition: border-color 0.15s ease;
	transition: border-color 0.15s ease;
}
.section_information_list div.link_box span a:hover,
.section_information_list div.link_box span a:focus{
	background-color: #557624;
	color: #ffffff;
}
.section_information_list div.link_box span a:hover:after,
.section_information_list div.link_box span a:focus:after{
	border-color: #ffffff;
}


/* リスト（新着情報サムネイル） */
.section_information_thum {
	width: 100%;
	display: table;
	margin: 0px;
	padding: 15px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.section_information_thum > div {
	display: table-cell;
	vertical-align: top;
}
.section_information_thum > div.lettering2 {
	width: 200px;
}
.section_information_thum > div.lettering2 img {
	width: 100%;
	height: auto;
}
.section_information_thum > div.lettering2 img[src*="noimage.png"] {
	width: auto;
	max-width: 100%;
	display: block;
	margin: 0px auto;
}

.section_information_thum > div.lettering3 {
	padding-left: 20px;
}
.section_information_thum > div.lettering3 span {
	display: block;
}

/********** 8 サイド **********/

/* サイドバー */
#sidebar1 > div:last-child,
#sidebar2 > div:last-child {
	/* margin-bottom: 0 !important; */
}
#sidebar1 img,
#sidebar2 img {
	max-width: 100% !important;
	height: auto !important;
}

/* サイドメニュー */
.side_box {
	background: #f5e9b3;
	margin: 0px 0px 10px;
	padding: 0px;
}
.side_box_ttl h2 {
	font-size: 1.8rem;
	font-weight: bold;
	margin: 0px;
	padding: 15px;
}

.side_box_list > ul {
	margin: 0px 0px 20px 20px;
	padding: 10px 15px;
/* 	list-style: none; */
}
.side_box_list ul li {
	margin: 0px 0px 10px 0px;
	padding: 0px;
}
.side_box_list ul li:before {
}
.side_box_list > ul > li > ul {
	margin: 0px 0px 0px 20px;
	padding: 10px 15px;
}

.side_box_txt {
	padding: 0px 15px 15px;
}
.side_box_txt p {
	margin: 0px 0px 10px;
}
.side_box_txt p:last-child {
	margin-bottom: 0px;
}

/* レコメンド */
#sidebar_recommend {
	margin: 0px 0px 10px;
	background: #f5f5f5;
	border-radius: 10px;
	overflow: hidden;
}
#sidebar_recommend h2 {
	margin: 0px;
	padding: 15px;
	padding-left: 60px;
	font-size: 1.6rem;
	line-height: 1.125em;
	font-weight: bold;
	background: url(/img/common/title_recommend.png) no-repeat left 20px center #d2dbaa;
	color: #000000;
}
#sidebar_recommend ul {
	margin: 0px;
	padding: 10px 15px;
	list-style: none;
}
#sidebar_recommend ul li {
	margin: 0px;
	padding: 8px 0px 8px 20px;
	background: url(/img/common/icon_list_recommend.png) no-repeat left 0.8em;
}

/* 「見つからないときは」「よくある質問」バナー */
#common_banner_link {
	margin: 0px 0px 10px;
}
#common_banner_link ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
#common_banner_link ul li {
	margin-bottom: 10px;
}
#common_banner_link ul li:last-child {
	margin-bottom: 0px;
}
#common_banner_link ul li a {
	display: block;
}
#common_banner_link ul li a:hover {
}

/********** 9 メイン **********/

/* メイン */
#mymainback {
	padding-top: 30px;
	padding-bottom: 30px;
}

/********** 10 各ページ **********/

/* 印刷用アイコン */
#content_header {
	margin: 25px 0px;
	text-align: right;
}

#content_header > span {
	display: inline-block;
	vertical-align: middle;
	margin-left: 1em;
	text-align: left;
	font-size: 1.5rem;
	line-height: 1em;
}
#print_mode_link,
#print_mode_link_large {
	padding-left: 20px;
	background: url(/img/common/icon_print.png) no-repeat left center;
}
#content_header .sns_button_wrap{
	margin-top: 10px;
}

/* カレンダー登録・SNSボタン */
#content_footer {
	clear: both;
	margin: 30px 0px 0px;
}
#content_footer div[id^="calendar_button_"] {
	display: inline-block;
	vertical-align: middle;
	margin: 0px 20px 20px 0px;
}
#content_footer div[id^="calendar_button_"]:before {
	content: url(/img/common/icon_add_calendar.png);
	display: inline-block;
	vertical-align: middle;
	margin-right: 10px;
}

.sns_button_wrap {
	text-align: right;
}
.sns_button_wrap > iframe,
.sns_button_wrap > div {
	display: inline-block;
	vertical-align: top;
}

/* PDF・WMPリンク */
.pdf_download,
.wmplayer_download {
	clear: both;
	margin: 30px 0px 0px;
	width: 100%;
	display: table;
}
.pdf_download .pdf_img,
.wmplayer_download .wmplayer_img {
	display: table-cell;
	vertical-align: top;
	width: 158px;
	margin: 0px;
	padding: 0px;
}
.pdf_download .pdf_img img,
.wmplayer_download .wmplayer_img img {
	width: 100%;
	height: auto;
}

.tenpu_txt {
	display: table-cell;
	vertical-align: top;
	margin: 0px;
	padding: 0px 0px 0px 20px;
	font-size: 1.3rem;
	line-height: 1.5;
}
.tenpu_txt br {
	display: none;
}

/* サイトマップ */

/* 大分類（見出し） */
div[id^="main_header_life3_"] {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: nowrap;
		flex-wrap: nowrap;
	-webkit-box-pack: justify;
		-ms-flex-pack: justify;
			justify-content: space-between;
	width: 100%;
	min-height: 150px;
	background-color: #f0f5cd;
	margin: 0px 0px 30px;
	padding: 0px;
	position: relative;
	-webkit-box-align: center;
		-ms-flex-align: center;
			align-items: center;
}

div[id^="main_header_life3_"] h1 {
	/* width: 100%; */
	margin: 0px;
	padding: 0px 20px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	font-size: 3.2rem;
	font-weight: bold;
	line-height: 1.4;
}

div[id^="main_header_life3_"] img {
	margin-right: 20px;
	max-width: 410px;
	height: auto;
}

/* 大分類（ライフイベント） */
#lifestage {
	margin-bottom: 30px;
}
#lifestage h2 {
	margin: 0px;
	padding: 0px 20px 20px;
	font-size: 2.2rem;
	font-weight: bold;
}
#lifestage ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	-webkit-box-pack: justify;
		-ms-flex-pack: justify;
			justify-content: space-between;
}
#lifestage ul li {
	width: 130px;
	max-width: 12%;
}
#lifestage ul li a {
	display: block;
	background-color: #cccccc;
	background-repeat: no-repeat;
	background-position: center 20px;
	text-align: center;
	padding: 80px 10px 10px;
}
#lifestage ul li#lifestage1 a {
	background-image: url(/img/lifestage/lifestage1_b.png);
}
#lifestage ul li#lifestage2 a {
	background-image: url(/img/lifestage/lifestage2_b.png);
}
#lifestage ul li#lifestage3 a {
	background-image: url(/img/lifestage/lifestage3_b.png);
}
#lifestage ul li#lifestage4 a {
	background-image: url(/img/lifestage/lifestage4_b.png);
}
#lifestage ul li#lifestage5 a {
	background-image: url(/img/lifestage/lifestage5_b.png);
}
#lifestage ul li#lifestage6 a {
	background-image: url(/img/lifestage/lifestage6_b.png);
}
#lifestage ul li#lifestage7 a {
	background-image: url(/img/lifestage/lifestage7_b.png);
}
#lifestage ul li#lifestage8 a {
	background-image: url(/img/lifestage/lifestage8_b.png);
}

/* 分類 */
.life3box .life2box {
	margin-bottom: 40px;
}
.life3box .life2box:last-child {
	margin-bottom: 0px;
}

.life3box .life1box li {
	margin-bottom: 5px;
}
.life3box .life1box li > span {
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	-webkit-box-pack: justify;
		-ms-flex-pack: justify;
			justify-content: space-between;
	-webkit-box-align: start;
		-ms-flex-align: start;
			align-items: flex-start;
	width: 100%;
}
.life3box .life1box li > span > span{
	display: block;
/*	width: 60%*/
}
.life3box .life1box li > span > a{
	display: block;
/*	max-width: 40%;*/
	text-align: right;
	margin-left: auto;
}

/* 関連情報 */
#kanren_info .kanren_box{
	margin: 0 0 5px;
}
#kanren_info .kanren_box:last-child{
	margin-bottom: 0;
}

#kanren_info {
	background: #efefed;
	margin: 0px 0px 10px;
	padding: 0 20px 20px;
}
#kanren_info h2 {
	font-size: 1.8rem;
	font-weight: bold;
	margin: 0px;
	padding: 15px;
	padding-left: 30px;
	background: url(/img/common/icon_kanren_title.png) no-repeat left center;
}
#kanren_info h3 {
	background: #d3dbaa;
	font-size: 1.6rem;
	font-weight: bold;
	margin: 0px;
	padding: 0px;
}
#kanren_info h3 button{
	display: block;
	border: none;
	background: none;
	color: currentColor;
	font-weight: bold;
	margin: 0;
	padding: 10px 15px;
	width: 100%;
	text-align: left;
	background: url(/img/common/icon_open.png) no-repeat right 20px center;
}

#kanren_info .acc_open h3 button{
	background-image: url(/img/common/icon_close.png);
}

#kanren_info .kanren_list{
	display: none;
}

#kanren_info .acc_open ~ .kanren_list{
	display: block;
}

.kanren_box ul {
	margin: 0px;
	padding: 0px 0px 0px 20px;
}
.kanren_box ul li {
	margin: 10px 0px 20px;
	padding: 0px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
}

.kanren_box div.link_ichiran {
	margin-top: 0px;
	padding: 0px 15px 15px;
}

/* サブカテゴリ */
.lifesub_cat_list .lifesub_list ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	list-style: none;
	margin: 0;
	padding: 0;
}
.lifesub_cat_list .lifesub_list ul li{
	width: 50%;
}
#main_body .lifesub_cat_list h2,
#main_body .lifesub_cat_list h3 {
	margin-bottom: 10px;
}

.life_cat_list_ttl {
	padding: 0.6em 20px;
	background: #f5f5f5;
	border: none;
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.4;
}

.editbox{
	padding: 20px;
	background: #efefed;
	margin: 0px 0px 10px;
}

/* 組織 */
#soshiki_hyouji ul {
	margin: 20px 0px;
	padding: 0px;
	list-style: none;
	text-align: center;
}
#soshiki_hyouji ul li {
	display: inline-block;
	vertical-align: middle;
	margin: 5px 10px 5px 0px;
	padding-right: 15px;
	border-right: 1px solid #666666;
	line-height: 1.4;
}
#soshiki_hyouji ul li:last-child {
	border-right: none;
	margin-right: 0px;
	padding-right: 0px;
}

#freespace_bu {
	margin: 30px 0px;
}
#freespace_bu p {
	margin: 0px 0px 1em;
}
#freespace_bu p:last-child {
	margin-bottom: 0px;
}

.kakuka_info_box {
	margin-bottom: 30px;
}
.kakuka_contact_box > div {
	margin-bottom: 0.5em;
}
.kakuka_contact_box > div:last-child {
	margin-bottom: 0px;
}

.kakuka_tel_list ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
.kakuka_tel_list ul li span {
	margin-left: 0.5em;
}
.kakuka_tel_list ul li span:before {
	content: '(';
}
.kakuka_tel_list ul li span:after {
	content: ')';
}
.kakuka_tel_list ul li span:empty:before,
.kakuka_tel_list ul li span:empty:after {
	display: none;
}

#soshiki_pr_image {
	margin: 30px 0px;
}
#soshiki_pr_image img {
	max-width: 100%;
	height: auto;
}

#freespace_ka {
	margin: 30px 0px;
}
#freespace_ka p {
	margin: 0px 0px 1em;
}
#freespace_ka p:last-child {
	margin-bottom: 0px;
}

#freespace2_ka {
	margin: 0px 0px 10px;
}
#freespace2_ka p {
	margin: 0px 0px 10px;
}
#freespace2_ka p:last-child {
	margin-bottom: 0px;
}

.kakuka_view {
	max-width: 300px;
	margin: 0px auto;
}
.kakuka_view img {
	width: 100%;
	height: auto;
}

.soshiki_kakuka .side_box_txt > div {
	margin-bottom: 0.5em;
}
.soshiki_kakuka .side_box_txt > div:last-child {
	margin-bottom: 0px;
}

/* 改ページ */
.page_num {
	margin: 30px 0px 0px;
	font-size: 1.8rem;
}
.page_num_ttl {
	font-size: 1.6rem;
}

/* ウェブブック */
#book_list_wrap {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	-webkit-box-pack: start;
		-ms-flex-pack: start;
			justify-content: flex-start;
	-webkit-box-align: stretch;
		-ms-flex-align: stretch;
			align-items: stretch;
}
.book_list_box {
	width: calc(50% - 15px);
	margin: 0px 30px 20px 0px;
}
.book_list_box:nth-child(2n) {
	margin-right: 0px;
}

#main_body .book_list_box h3 {
	margin-top: 0px;
}
.book_list_box .book_info {
	width: 100%;
	display: table;
}
.book_list_box .book_info > div {
	display: table-cell;
	vertical-align: top;
}
.book_list_box .book_info > div.book_thumb_img {
	width: 66px;
	padding-right: 15px;
}
.book_list_box .book_info > div.book_thumb_img img {
	width: 100%;
	height: auto;
}

/* アンケート */
#main_body table.tbl_ques {
	width: 100%;
	margin: 20px 0px 0px;
	border-width: 2px;
}
#main_body table.tbl_ques th {
	text-align: center;
}
#main_body table.tbl_ques th.title {
	width: 60%;
}
#main_body table.tbl_ques th.date {
	width: 15%;
}
#main_body table.tbl_ques th.date2 {
	width: 15%;
}
#main_body table.tbl_ques th.button {
	width: 10%
}
#main_body table.tbl_ques td.t_center {
	text-align: center;
}
#main_body table.tbl_ques td input,
.question #main_body table.tbl_ques td input {
	display: block;
	width: 100%;
	border: none;
	background: #e6e6e6;
	color: #000000;
	font-size: 1.4rem;
	line-height: 2rem;
	margin: 0px;
	padding: 5px 0px;
	text-align: center;
}

div.q2 br {
	display: none;
}

.question_detail #main_body fieldset {
	border: none;
	margin: 0px;
	padding: 0px;
}
.question_detail #main_body fieldset legend {
	display: block;
	width: 100%;
	margin: 0px;
	padding: 0px;
}

.question_detail #main_body input[type="text"] {
	font-size: 1.6rem;
	max-width: 100%;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.question_detail #main_body textarea {
	font-size: 1.6rem;
	width: 100%;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.question_detail #main_body select {
	font-size: 1.6rem;
}

.question #main_body input[type="submit"],
.question #main_body input[type="button"] {
	display: inline-block;
	width: 23%;
	border: none;
	background: #e6e6e6;
	color: #000000;
	line-height: 2rem;
	margin: 5px;
	padding: 10px 0px;
	text-align: center;
}

#hyouka_area_submit,
.question_detail #main_body form p[align="left"] {
	margin-top: 20px;
	text-align: center;
}

/* アンケート結果グラフ */
#main_body img[src="img/graph.gif"] {
	height: 20px !important;
	vertical-align: middle;
}

/* お問い合わせフォーム */
#mail_form_message,
#cookie_err_message {
	margin: 1em 0px;
	color: #cc0000;
}

#main_body table#mail_form_tbl {
	width: 100%;
	border-width: 2px;
}
#main_body table#mail_form_tbl th {
	width: 25%;
}
#main_body table#mail_form_tbl td {
	width: 75%;
}
#main_body table#mail_form_tbl td input[type="text"] {
	font-size: 1.6rem;
	width: 100%;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
#main_body table#mail_form_tbl td textarea {
	font-size: 1.6rem;
	width: 100%;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

#mail_form_btn_wrap {
	margin: 20px 0px 0px;
	text-align: center;
}
#mail_form_btn_wrap input[type="submit"] {
	display: inline-block;
	width: 23%;
	border: none;
	background: #e6e6e6;
	color: #000000;
	line-height: 2rem;
	margin: 5px;
	padding: 10px 0px;
	text-align: center;
}

/* googleカスタム検索結果 */
#main_body #cse_search_result table {
	border: none;
	margin: 0px;
}
#main_body #cse_search_result td {
	border: none;
}

.gsc-results .gsc-cursor-box .gsc-cursor-page {
	display: inline-block !important;
	vertical-align: middle;
	margin-bottom: 5px;
	padding: 10px 15px;
	border: 1px solid #cccccc;
	font-size: 1.6rem;
}
.gsc-results .gsc-cursor-box .gsc-cursor-current-page {
	background: #f5f5f5;
}

/* Googlemap */
.gglmap {
	position: relative;
	padding-top: 30px;
	padding-bottom: 56.25%;
	height: 0px;
	overflow: hidden;
}
.gglmap iframe,
.gglmap object,
.gglmap embed {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
}

/* 地図でさがす */
#shisetsu_list_txt {
	border: 1px solid #cccccc;
	border-bottom: none;
}
#shisetsu_list_txt p {
	margin: 0px;
	padding: 20px;
}

#shisetsu_list_link {
	border: 1px solid #cccccc;
	border-bottom: none;
}
#shisetsu_list_link ul {
	margin: 0px;
	padding: 10px 20px;
	list-style: none;
}
#shisetsu_list_link ul li {
	display: inline-block;
	vertical-align: top;
	margin: 5px 20px 5px 0px;
}

#shisetsu_map {
	border: 1px solid #cccccc;
}
#map_canvas {
	width: 100%;
	height: 500px;
}

#map_canvas_detail {
	width: 100%;
	height: 400px;
}

.shisetsu_detail_box {
	margin-bottom: 20px;
}

/* 重要なお知らせ */
#detail_side_important {
	border: 1px solid #cc0000;
	margin: 0px 0px 10px;
	color: #cc0000;
}
#detail_side_important h2 {
	margin: 0px;
	padding: 25px 0px;
	padding-left: 60px;
	font-size: 1.6rem;
	font-weight: bold;
	background: url(/img/common/icon_important.png) no-repeat left 20px center transparent;
}
#detail_side_important ul {
	margin: 0px;
	padding: 0px 20px 10px;
	list-style: none;
}
#detail_side_important ul li {
	padding: 8px 0px;
}
#detail_side_important ul li a {
	color: #cc0000;
}
#detail_side_important ul li > span {
	display: block;
}

/*関連ページバナー追加*/
.banner_chusho {
	margin: 90px 0px 0px;
	-webkit-box-ordinal-group: 13;
	-ms-flex-order: 12;
	order: 12;
	width: 100%;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
}
.banner_chusho a {
	display: inline-block;
	margin: 0px 10px 10px 0px;
}
.banner_chusho img {
	max-width: 100%;
	height: auto;
	vertical-align: top;
}
.banner_chusho a img {
	opacity: 1;
	transition: opacity 0.3s ease;
}
.banner_chusho a img:hover {
	opacity: 0.85;
}

/* タブレット */
@media screen and (min-width: 671px) and (max-width: 1079px) {

	/* コンテナ */
	#container {
		padding-top: 0px !important;
	}

	/* ヘッダ */
	#header {
	/*	position: relative;*/
	}

	#spm_wrap {
		display: block;
		position: absolute;
		top: 15px;
		right: 10px;
		z-index: 200;
	}
	#spm_wrap a,
	#spm_wrap button {
		display: inline-block;
		vertical-align: middle;
		width: 75px;
		height: 60px;
		margin: 0px 0px 0px 10px;
		padding: 0px;
		border: none;
		background-color: #fff;
		background-repeat: no-repeat;
		background-position: center center;
		background-size: 75px 60px;
		color: #000;
		text-align: left;
		text-indent: -9999em;
		overflow: hidden;
	}
	#spm_wrap a#spm_bosai {
		background-image: url(/img/sp/btn_spm_bosai.png);
	}
	#spm_wrap button#spm_menu {
		background-image: url(/img/sp/btn_spm_menu.png);
	}
	#spm_wrap button#spm_search {
		background-image: url(/img/sp/btn_spm_search.png);
	}
	.spm_menu_open #spm_wrap button#spm_menu,
	.spm_search_open #spm_wrap button#spm_search {
		background-image: url(/img/sp/btn_spm_close.png);
	}

	#header2 {
		width: auto;
		/* min-height: 80px; */
		max-width: none;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		-webkit-box-pack: start;
		-ms-flex-pack: start;
		justify-content: flex-start;
	}

	#he_left {
		position: static;
		/* width: 180px; */
		margin: 0px;
		padding: 0 10px;
	}
	#he_left a.link_honbun {
		display: none;
	}
	#he_left #logo a,
	#he_left h1#logo {
		width: 150px;
		height: 60px;
		overflow: hidden;
	}
	#he_left #logo a img,
	#he_left h1#logo img {
		width: 100%;
		height: auto;
		margin-top: -26px;
	}

	#he_right {
		display: none;
		margin: 0px;
		padding: 10px;
		width: 100%;
		text-align: center;
		-webkit-box-sizing: border-box;
				box-sizing: border-box;
		background: #f0f0ee;
	}
	.spm_menu_open #he_right {
		display: block;
		margin-top: 15px;
	}
	ul#header_link{
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
			flex-wrap: wrap;
		-webkit-box-pack: center;
			-ms-flex-pack: center;
				justify-content: center;
		-webkit-box-align: stretch;
			-ms-flex-align: stretch;
				align-items: stretch;
	}
	ul#header_link > li {
		display: inline-block;
		vertical-align: top;
		width: calc(20% - 10px);
		margin: 5px 5px;
	}
	ul#header_link > li > a {
		background: #dddddd;
	}

	ul#header_link {
		position: relative;
	}
	#hl_func {
		position: static;
	}

	#acc_func_box.func_menu_open{
		top: 40px;
		left: auto;
		right: 0;
		width: 100%;
	}
	#acc_func_box ul{
		width: auto;
		padding-right: 40%;
	}

	ul#header_link > li#keep_page_wrap {
		display: inline-block;
		vertical-align: top;
	}
	#ktp_viewsw {
		display: block;
		width: 100%;
		margin: 0;
		padding: 8px 13px;
		border: none;
		background: #dddddd;
		font-size: 1.2rem;
		line-height: 1em;
		color: #333;
		text-decoration: none;
		border-radius: 5px;
		-webkit-box-sizing: border-box;
				box-sizing: border-box;
	}
	#ktp_viewsw.open,
	#ktp_viewsw:hover,
	#ktp_viewsw:focus {
		background: #76a32e;
		color: #000000;
	}
	.header_fixed li#keep_page_wrap {
		position: static;
	}
	#keep_page.open,
	.header_fixed .open#keep_page {
		display: block;
		position: absolute;
		top: 40px;
		right: auto;
		left: 0px;
		z-index: 100;
		background: #76a32e;
		-webkit-box-shadow: 0px 3px 10px -2px rgba(0, 0, 0, 0.5);
		box-shadow: 0px 3px 10px -2px rgba(0, 0, 0, 0.5);
		border-radius: 5px;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		margin: 0px;
		padding: 10px;
		color: #000000;
		width: 100%;
	}

	#ktp_list_wrap2 {
		padding: 10px;
	}
	#ktp_list_wrap2 > button.btn_func{
		width: 47%;
		padding: 10px 0;
		font-size: 1.2rem;
		font-weight: bold;
	}
	#ktp_list_wrap2 > button br{
		display: none;
	}
	ul#ktp_item_list{
		text-align: left;
	}

	#kpt_all_close.button_close {
		top: 10px;
		right: 10px;
	}

	/* グローバルナビ */
	#top_search {
		display: none;
	}
	.spm_menu_open #top_search {
		display: block;
	}

	ul#gnav {
		display: block;
		width: auto;
		padding: 0px;
	}
	ul#gnav li {
		display: block;
		margin: 0px 0px 20px;
		padding: 0px;
	}

	ul#gnav li a {
		font-size: 1.6rem;
		padding: 10px 15px;
		text-align: left;
	}
	ul#gnav li#gnav1{
		display: none;
	}
	ul#gnav > li > a,
	ul#gnav > li > button,
	ul#gnav > li#gnav3 > button{
		display: block;
		width: 100%;
		background-color: #557624;
		color: #ffffff;
		background-position: left 10px center;
		text-align: left;
		padding: 20px 20px 20px 50px;
		height: auto;
		background-size: auto 25px;
	}
	ul#gnav > li > button,
	ul#gnav > li#gnav3 > button{
		pointer-events: none;
		font-size: 1.6rem;
	}
	#life_menu,
	#mokuteki_menu{
		position: static;
		outline: none;
		display: block;
	}
	#life_menu ul,
	#mokuteki_menu ul{
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
			flex-wrap: wrap;
		-webkit-box-pack: start;
			-ms-flex-pack: start;
				justify-content: flex-start;
		-webkit-box-align: stretch;
			-ms-flex-align: stretch;
				align-items: stretch;
		margin: 10px 0 0;
	}
	#life_menu ul li,
	#mokuteki_menu ul li{
		display: block;
		border: none;
		width: 50%;
		height: auto;
		border-bottom: 1px solid rgba(255,255,255,0.5);
		margin: 0;
		padding: 0;
	}
	#life_menu ul li a,
	#mokuteki_menu ul li a{
		display: block;
		font-size: 1.4rem;
		white-space: normal;
	}
	#life_menu ul li:nth-child(odd) a,
	#mokuteki_menu ul li:nth-child(odd) a{
		border-right: 1px solid #ffffff;
	}
	#life_menu .button_close,
	#mokuteki_menu .button_close{
		display: none;
	}

	/* 検索 */
	#top_search_keyword{
		display: none;
		margin: 0px;
		padding: 10px;
		width: 100%;
		text-align: center;
		-webkit-box-sizing: border-box;
				box-sizing: border-box;
	}
	.spm_search_open #top_search_keyword {
		margin-top: 15px;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: nowrap;
			flex-wrap: nowrap;
		-webkit-box-pack: justify;
			-ms-flex-pack: justify;
				justify-content: space-between;
		text-align: left;
	}

	#cse-search-box {
		display: inline-block;
		vertical-align: top;
		width: calc(100% - 320px);
	}

	#tmp_query {
		font-size: 1.4rem;
		display: inline-block;
		vertical-align: top;
		width: calc(100% - 70px) !important;
	}
	#submit {
		font-size: 1.4rem;
	}

	.submit_wrap {
		display: inline-block;
		vertical-align: top;
		width: 70px;
	}

	#top_search_page_id {
		display: inline-block;
		vertical-align: top;
		width: 300px;
	}
	#top_search_page_id_ttl {
		text-align: left;
		margin: 10px 0;
	}
	button#search_page_id_title {
		pointer-events: none;
		color: #333;
		font-weight: normal;
		margin: 0px;
		padding: 0px;
		font-size: 1.4rem;
		line-height: 1em;
	}
	button#search_page_id_title:after {
		display: none;
	}
	#search_open_page_id_detail {
		position: static;
		width: auto;
		margin: 0px;
		padding: 0px;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
			flex-wrap: wrap;
		-webkit-box-pack: justify;
			-ms-flex-pack: justify;
				justify-content: space-between;
	}
	label[for="open_page_id"],
	#search_open_page_id_detail .button_close {
		display: none;
	}
	input#open_page_id {
		display: inline-block;
		vertical-align: top;
		width: calc(100% - 70px);
		height: 3.5rem;
		-webkit-box-sizing: border-box;
				box-sizing: border-box;
	}
	input#open_page_id_submit {
		padding: 0px;
		font-size: 1.4rem;
	}

	/* フッタ */
	#copyright p {
		padding-right: 100px;
		text-align: left;
	}

}/* end */
@media screen and (max-width : 1079px) {

	/* 各ページ */
	div[id^="main_header_life3_"] {
		height: 150px;
	}
	div[id^="main_header_life3_"] img {
		max-width: 360px;
	}

	#life_menu_left {
		width: 70%;
		padding-right: 20px;
	}
	#life_menu_right {
		width: 30%;
	}

	#soshiki_pr_image img {
		max-height: 150px;
	}

	/* アンケート */
	#main_body table.tbl_ques th.title {
		width: 55%;
	}
	#main_body table.tbl_ques th.button {
		width: 15%;
	}

}
/* タブレット ここまで */