@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;
}
#spm_wrap {
	display: none;
}
.sp_button {
	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: sans-serif;
}
em {
	font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Osaka, 'MS PGothic', sans-serif;
}

.mincho {
	font-family: serif;
}

/* リンク */
a:link {
	color: #333;
	text-decoration: underline;
}
a:visited {
	color: #333;
	text-decoration: underline;
}
a:active {
	color: #333;
	text-decoration: underline;
}
a:hover {
	color: #333;
	text-decoration: none;
}

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: #DFDFDF;
	border-collapse: collapse;
	border-style: solid;
	border-width: 1px;
	margin: 0px 0px 10px;
	max-width: 100%;
}
#main_body th {
	background: #F1F2E3;
	border-color: #BCC7BF;
	border-collapse: collapse;
	border-style: solid;
	border-width: 1px;
	padding: 0.5em;
}
#main_body td {
	border-color: #BCC7BF;
	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: 0;
}

/* 見出し */
#main_header {
	margin-bottom: 10px;
}
#main_header h1 {
	margin: 0px;
	padding: 0.9em 20px 0.7em 30px;
	font-size: 3rem;
	/*font-weight: normal;*/
	line-height: 1.4;
	background-color: #FCF9E8;
	background-image:url(/img/common/bk_h1.png);
	background-repeat:no-repeat;
	background-position:left;
}

#main_body h2 {
	clear: both;
	margin: 20px 0px;
	padding: 0.7em 20px 0.6em 20px;
	border-bottom: 2px solid #F1A992;
	border-top: 2px solid #F1A992;
	border-left: 10px solid #F1A992;
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.4;
}

#main_body h3 {
	clear: both;
	margin: 20px 0px;
	padding: 0.6em 30px;
	background: #fff;
	border: 2px dotted #F1A992;
	font-size: 1.7rem;
	font-weight: bold;
	line-height: 1.4;
border-radius: 10px;
}


#main_body h4 {
	clear: both;
	margin: 20px 0px;
	padding: 0.5em 30px;
	border-bottom: 2px solid #F1A992;
	font-size: 1.5rem;
	font-weight: bold;
	line-height: 1.4;
}


#main_body h5 {
	clear: both;
	margin: 20px 0px;
	padding: 0 20px;
	background: transparent;
	border: none;
	border-left: 10px solid #F1A992;
	font-size: 1.5rem;
	font-weight: bold;
	line-height: 1.2;
}

#main_body h6 {
	clear: both;
	margin: 20px 0px;
	padding: 0 30px;
	background: transparent;
	border: none;
	font-size: 1.5rem;
	font-weight: bold;
	line-height: 1.2;
}

/********** 3 ヘッダ **********/

/* ヘッダ */
#header {
	font-size: 1.5rem;
}

#header2 {
	width: 98%;
	max-width: 1100px;
	min-height: 90px;
	margin: 0px auto;
	position: relative;
}

#he_left {
	width: 300px;
	position: absolute;
	top: 15px;
	left: 0px;
	z-index: 1;
}
#he_left #logo {
	margin: 0px;
}
#he_left #logo a {
	display: block;
}
#he_left #logo img {
	max-width: 100%;
	width: 100%;
	height: auto;
}

#he_right {
	margin-left: 300px;
	padding: 10px 0px 10px 0px;
	text-align: right;
}

ul#header_link {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
ul#header_link > li {
	display: inline-block;
	vertical-align: middle;
	margin: 0px 0px 0px 15px;
	text-align: left;
	font-size: 1.3rem;
}

ul#header_link > li + li{
	border-left: 1px solid #777;
}

ul#header_link > li > a {
	display: block;
	background-color: transparent;
	background-repeat: no-repeat;
	background-position: left center;
	line-height: 1rem;
	padding: 5px 0px 5px 15px;
}


/* アクセシビリティ機能 */
#hl_func {
	position: relative;
}

ul#acc_func_box {
	display: none;
	position: absolute;
	top: 100%;
	right: 0px;
	z-index: 100;
	background: #ffffff;
	-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);
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	min-width: 100%;
	margin: 0px;
	padding: 15px 10px;
	list-style: none;
	text-align: center;
}
ul#acc_func_box.func_menu_open {
	display: block;
}
ul#acc_func_box li {
	display: block;
	margin-bottom: 15px;
}

#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: inline-block;
	vertical-align: middle;
	margin: 0px 5px 0px 0px;
	padding: 6px 0px;
	font-weight: bold;
	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: 1px solid #cccccc;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border-radius: 3px;
	color: #000000;
	text-decoration: none;
	padding: 5px 7px;
}
#acc_func_box dl dd a#moji_large {
	font-size: 1.6rem;
	font-weight: bold;
}
#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;
}

#func_menu_close {
	border: none;
	background: #e6e6e6;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border-radius: 3px;
	font-size: 1.4rem;
	margin: 0px;
	padding: 0px 20px;
	height: 3rem;
}


/* 分類でさがすとGoogleカスタム検索の横並び */
#ib-box{
	padding-top: 5px;
	display: flex;
	justify-content:flex-end;
	align-items: center;
}

#ib-box div:first-child{
	margin-right: 10px;
	padding: 4px 10px 4px 10px;
	border: 1px solid #ccc;
	border-radius: 5px;
	font-size: 1.3rem;
  }


/* Googleカスタム検索 */
#top_search_keyword form {
	border: 1px solid #ccc;
	border-radius: 5px;
	width:270px;
}

#cse-search-box {
	display: inline-block;
}
#tmp_query {
	/*width: 150px !important;*/
	width: calc( 100% - 40px );
	margin: 0;
	padding:5px;
	border: 0px solid #00ff00 !important;
	font-size: 1.4rem;
	border-radius: 5px 0 0 5px;

}
#tmp_query:focus { 
	/* 	background-image: none !important; */
	outline: none !important;
}

#submit {
	display: inline-block;
	vertical-align: middle;
	width: 40px;
	margin: 0;
	padding: 5px;
	background: url(/img/icon_search.png) no-repeat center center #fff;
	border: none;
	cursor: pointer;
	text-align: left;
	text-indent: -9999em;
	line-height: 1.5rem;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	border-radius: 0 5px 5px 0;
}
#submit:hover {
	border-radius: 0 5px 5px 0;
}


/* グローバルナビ */
#top_search {
	background: #F1A992;
	position: static;
	top: -30px;
	transition: all 0.3s ease 0s;
	width: 100%;
}

ul#gnav {
	margin: 0px auto;
	padding: 0px;
	list-style: none;
	width: 100%;
	max-width: 1100px;
	display: table;
	table-layout: fixed;
}
ul#gnav li {
	display: table-cell;
	vertical-align: middle;
	position:relative;
}
ul#gnav li a {
    display: block;
    height: 100%;
    width: 100%;
	
	color: #000000;
	font-size: 1.4rem;
	font-weight: bold;
	text-decoration: none;
	text-align: center;
	line-height: 2.5rem;
	padding: 15px 10px;
    border-left:1px solid #fff;
}
ul#gnav li:last-child a {border-right:1px solid #fff;}


ul#gnav li a:hover{
    background-color: rgba( 255, 255, 255, 0.45 );
	text-decoration:underline;
}

#gnav5 span, #gnav6 span{
  position: absolute;
  top: 50%;
  right: 0;
  bottom: 0;
  left: 0;
  font-size: 1.1rem;
  font-weight: lighter;
}

.gnav_sub {
	display:none;
	position:absolute;
	padding:0;
	margin:0px;
	top:40px;
	left:0;
	left: calc(( 220px - 100% ) / -2 );
	width: 220px;
	z-index: 9;
}

ul#gnav > li:hover div {
	display:block;
}

.gnav_sub ul{
	list-style-type:none;
	border: 5px solid #f1a992;
	background: #fff;
	border-radius: 10px;
	margin-top: 20px;
	padding: 0;
}

ul#gnav > li:hover ul li {
	display:block;
}
ul#gnav > li:hover ul li a {
	font-weight: lighter;
	text-align: left;
	line-height: 2rem;
	padding: 10px 10px;
    border-left:0px;
	border-bottom: 1px solid #F1A992;
}



/* グローバルナビ（スクロール発動の時に使用） */
#top_search.m_fixed {
	left: 0;
	position: fixed;
	top: 0;
	z-index: 299;
}


/* グローバルナビの横にある縦長バナー */
#sitelink {
	position: fixed;
	z-index: 10;
	/*top: 87px;*/
bottom: 90px;
	right: 10px;
	cursor: pointer;
}
#sitelink img {width: 100px;}


#clear_sitelink {
	position:absolute;
	top:0;
	right:0px;
	display: inline-block;
	vertical-align: top;
	width: 18px;
	height: 18px;
	border: none;
	background: url(/img/common/link_deletion.png) no-repeat center center;
	border-radius: 100%;
	line-height: 1;
	text-align: left;
	text-indent: -9999em;
	overflow: hidden;
	cursor: pointer;
}





/********** 4 パンくず **********/

/* パンくず */
#pankuzu_wrap {
	background: #f4f4f4;
	padding: 18px 0px 8px;
	font-size: 1.4rem;
}
#pankuzu_wrap > div {
	width: 1080px;
	margin: 0px auto 10px;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}

.pankuzu {
	position: relative;
	padding-left: 6rem;
	font-size: 1.3rem;
}
.pankuzu .icon_current {
	display: none;
}
.pankuzu:first-child .icon_current {
	display: block;
	width: 5rem;
	height: 2rem;
	background: #fff;
	font-size: 1.2rem;
	line-height: 1.2rem;
	padding: 0.3rem 0px;
	text-align: center;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	position: absolute;
	top: 2px;
	left: 0px;
	border-radius: 30px;
	border: 1px solid #ccc;
}

/********** 5 フッタ **********/

/* フッタ */
#footer {
    max-width: 1110px;
    padding: 30px 15px 10px 15px;
    margin-left: auto;
    margin-right: auto;
}

#footer_navi {
	border-top:solid 2px #CCC;
	border-bottom:solid 2px #CCC;
}
ul.footer_navi_g {
	width: 100%;
	padding: 0 15px 0 15px;
	list-style: none;
	text-align: center;
	margin:0.7rem;
}
ul.footer_navi_g li {
	display: inline-block;
	vertical-align: middle;
	padding: 0px 15px 0px 15px;
	line-height: 2rem;
	font-size: 1.3rem;
	margin: 0;
}

ul.footer_navi_g li + li{
	border-left: 1px solid #777;
}





#author_info {
}
#author_box {
	padding-top: 15px;
	font-size: 1.3rem;
}
#author_box p {
	margin: 0px;
	line-height: 1.6;
}
#author_box p.f_author {
	font-weight: bold;
}
#author_box p span {
	display: inline-block;
	margin-right: 1em;
}


#copyright p {
	width: 100%;
	background-color: #F1A992;
	margin: 0px;
	padding: 1rem;
	text-align: center;
	font-size: 1.1rem;
}

@media screen and (max-width: 670px) {
	ul.footer_navi_g {
		padding: 0 5px 0 0px;
	}
	ul.footer_navi_g li {
		font-size: 1.4rem;
	}
}





/*ページトップへ*/
#footer_link_pagetop {
	display: block;
	/*width: 90px;*/
	position: fixed;
	right: 10px;
	bottom: -140px;
	z-index: 70;
	-webkit-transition: bottom 0.5s ease-in-out;
	-o-transition: bottom 0.5s ease-in-out;
	transition: bottom 0.5s ease-in-out;
}
#footer_link_pagetop.fixed {
	bottom: 10px;
}
#footer_link_pagetop a {
	display: block;
}
#footer_link_pagetop img {
	max-width: 100%;
	height: auto;
}





/* おすすめ情報（回遊ボタン） */
#osusume_banner {
	position: fixed;
	left: 10px;
	bottom: 10px;
	z-index: 90;
}
#osusume_banner_box {
	width: auto;
	display: table;
}

#osusume_banner_ttl {
	display: table-cell;
	vertical-align: bottom;
	width: 100px;
}
#osusume_banner_ttl a {
	display: block;
	color: #000000;
	font-size: 1.5rem;
	font-weight: bold;
	line-height: 2rem;
	text-align: center;
	text-decoration: none;
	background: #cccccc;
	padding: 30px 0px;
}

#osusume_banner_list {
	display: none;
	vertical-align: bottom;
	background: #cccccc;
	padding: 10px;
	max-width: calc(100vw - 140px);
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-border-radius: 0px 10px 10px 0px;
	-moz-border-radius: 0px 10px 10px 0px;
	border-radius: 0px 10px 10px 0px;
}
#osusume_banner.open #osusume_banner_list {
	display: table-cell;
}

#osusume_banner_list_box {
	background: #ffffff;
	-webkit-border-radius: 0px 5px 5px 0px;
	-moz-border-radius: 0px 5px 5px 0px;
	border-radius: 0px 5px 5px 0px;
	padding: 5px;
	position: relative;
}
#osusume_banner_list_box ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
#osusume_banner_list_box ul li {
	display: inline-block;
	vertical-align: top;
	width: 200px;
	height: 60px;
	margin: 5px;
}
#osusume_banner_list_box ul li img {
	width: 100%;
	height: auto;
}

#osusume_banner_close {
	display: block;
	width: 22px;
	height: 22px;
	margin: 0px;
	padding: 0px;
	border: none;
	background: url(/img/common/icon_keep_clear.png) no-repeat center center #333333;
	background-size: 10px 10px;
	color: #ffffff;
	line-height: 1;
	-webkit-border-radius: 100%;
	-moz-border-radius: 100%;
	border-radius: 100%;
	cursor: pointer;
	text-align: left;
	text-indent: -9999em;
	overflow: hidden;
	position: absolute;
	top: -10px;
	right: -10px;
}

/********** 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;
	-webkit-box-align: start;
		-ms-flex-align: start;
		align-items: flex-start;
}
ul.banner_list li {
	display: inline-block;
	vertical-align: top;
	width: 290px;
}
ul.banner_list li img {
	width: 100%;
	height: auto;
}

.banner_text {
	display: block;
	padding: 10px;
	text-align: left;
}
.banner_text span {
	display: block;
}
.banner_text span:nth-child(2n) {
	font-size: 1.4rem;
}

/* バナー広告（フッタ） */
#footer_banner {
	clear: both;
	width: 1080px;
	margin: 0px auto 50px;
}




/********** 7 リスト **********/

/* リスト（横並び） */
.navigation,
.navigation ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
}
.navigation ul li,
.navigation > div {
	display: inline-block;
	vertical-align: middle;
	margin: 0px 15px 15px 0px;
	padding-right: 15px;
	border-right: 1px solid;
	line-height: 1.3;
}
.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 {
	display: block;
	margin: 0px;
	padding: 8px 0px;
}

.info_list ul li {
	margin: 0px;
	padding: 18px 0px 17px;
	border-bottom: 1px dashed #ccc;
}
.info_list ul li:last-child {
	border-bottom: none;
}





/* リスト（日付） */
.info_list.info_list_date ul li {
	width: 100%;
	display: table;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}
.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: 13em;
	font-weight: bold;
	opacity:0.8;
	font-size: 1.3rem;
}

/* リスト（担当課） */
.article_section:before {
	content: '（';
}
.article_section:after {
	content: '）';
}
.article_section:empty:before,
.article_section:empty:after {
	display: none;
}

/* リスト（サムネイル） */
.list_pack {
	width: 100%;
	display: table;
}

.list_pack .article_img {
	display: table-cell;
	vertical-align: top;
	width: 200px;
	padding-right: 20px;
}
.list_pack .article_img span {
	display: block;
}
.list_pack .article_img span:empty {
	height: 120px;
	background: url(/img/common/noimage.png) no-repeat center center #eee;
	background-size: contain;
}
.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 {
	display: block;
}
.list_pack .article_txt .article_title {
	display: block;
}

/* リスト（一覧リンク） */
div.link_ichiran {
	margin-top: 20px;
	text-align: right;
}
div.link_ichiran a {
	display: inline-block;
	background: #f6f6f6;
	border-radius: 6px;
	color: #333;
	font-size: 1.4rem;
	line-height: 2rem;
	padding: 11px 20px 9px;
	text-align: center;
}

#main div.link_ichiran a {
	min-width: 220px;
}

/* リスト（newアイコン） */
img.icon_new {
	vertical-align: top;
	margin-top: 0.2em;
	margin-left: 10px;
}

/* リスト（人権センターのカテゴリ別アイコン） */
.icon_category {
	display: inline-block;
	margin-right: 1rem;
	max-width: 170px;
	width: 100%;
	background: #F1A992;
	border: 1px solid #F1A992;
	font-size: 1rem;
	line-height: 1rem;
	padding: 0.5rem 0.5rem 0.4rem 0.5rem;
	text-align: center;
	border-radius: 5px;
	/*
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	position: absolute;
	top: 2px;
	left: 0px;
	border: 1px solid #ccc;
	*/
}
#slick-tit .icon_category, #topics_pr_list .icon_category {
	display: block;
}
#slick-tit .icon_category {
	margin-bottom:10px;
}




/* リスト（新着情報） */
.section_information {
	margin-top: 30px;
	margin-bottom: 30px;
		border: 5px solid #F2A389;
}

.section_information h2,
#main_body .section_information h2 {
	clear: both;
	margin: 0px;
	padding: 15px 10px 12px 25px;
	border: 0px;
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.4;
}

.section_information p.no_data {
	margin: 0px;
	padding: 20px 0px;
}

.section_information_list {
	padding: 0px 25px 20px;
}

.section_information_list ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
.section_information_list ul li {
	width: 100%;
	display: table;
	margin: 0px;
	padding: 18px 0px 17px;
	border-bottom: 1px dashed #ccc;
}
.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 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	justify-content: flex-end;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
	padding-top: 10px;
}
.section_information_list div.link_box span {
	display: inline-block;
	vertical-align: middle;
	margin: 5px 10px 0px 0px;
}
.section_information_list div.link_box span a {
	display: inline-block;
	background: url(/img/common/icon_link_ichiran.png) no-repeat right 5px top 50%;
	font-size: 1.5rem;
	line-height: 2rem;
	padding: 7px 30px 5px 20px;
}
.section_information_list div.link_box span a:hover {
	text-decoration: none;
}

/* リスト（新着情報サムネイル） */
.section_information_thum {
	width: 100%;
	display: table;
	padding: 20px 0px;
	border-bottom: 1px solid #d2d1c7;
}
.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.lettering3 {
	padding-left: 20px;
}
.section_information_thum > div.lettering3 span {
	display: block;
}

/********** 8 サイド **********/

/* サイドバー */
#sidebar1 > div,
#sidebar2 > div {
	margin-bottom: 10px;
}
#sidebar1 > div:last-child,
#sidebar2 > div:last-child {
	margin-bottom: 0px !important;
}

#sidebar1 img,
#sidebar2 img {
	max-width: 100%;
	height: auto;
}

/* サイドメニュー */
.side_box {
	background: #f5f5f5;
	margin: 0px 0px 10px;
	padding: 0px;
}
.side_box_ttl h2 {
	background: #e6e6e6;
	font-size: 1.7rem;
	font-weight: bold;
	margin: 0px;
	padding: 15px;
}

.side_box_list ul {
	margin: 0px;
	padding: 10px 15px;
	list-style: none;
}
.side_box_list ul li {
	margin: 0px;
	padding: 3px 0px 3px 20px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
}
.side_box_list ul li:before {
	content: '';
	width: 0px;
	height: 0px;
	border: 5px solid transparent;
	border-right-width: 0px;
	border-left-width: 8px;
	border-left-color: #666666;
	position: absolute;
	top: 0.6em;
	left: 0px;
}
.side_box_list ul li ul {
	padding: 0px;
}

.side_box_txt {
	padding: 15px;
}
.side_box_txt p {
	margin: 0px 0px 10px;
}
.side_box_txt p:last-child {
	margin-bottom: 0px;
}

/* レコメンド */
#sidebar_recommend {
	background-color: #DFF2FA;
	border-radius: 10px;
	padding: 30px;
	margin-bottom: 10px;
}
#sidebar_recommend h2 {
	margin: 0px;
	padding: 0px 0px 20px 0px;
	font-size: 1.7rem;
	font-weight: bold;
	border-bottom: 1px dashed #707070;
	text-align: center;
	line-height: 1.4;
}


#sidebar_recommend ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
#sidebar_recommend ul li {
	margin: 0px;
	padding: 8px 0px 8px 0px;
}

/* 「見つからないときは」「よくある質問」バナー */
#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;
	background: #F3F3F3;
	color: #333;
	font-size: 1.7rem;
	font-weight: bold;
	line-height: 1.4;
	padding: 10px 20px;
	border-radius: 10px;
	border: 1px solid #ccc;
}
#common_banner_link ul li a span {
	display: inline-block;
	padding: 13px 0px 12px 40px;
}
#common_banner_link ul li#common_banner_mitsukaranai a span {
	background: url(/img/common/icon_mitsukaranai.png) no-repeat left center;
}
#common_banner_link ul li#common_banner_faq a span {
	background: url(/img/common/icon_faq.png) no-repeat left center;
}
#common_banner_link ul li a:hover span {
	text-decoration: underline;
}

/* 「見つからないときは」「よくある質問」バナー（1カラム） */
@media screen and (min-width: 671px) {
	#main #common_banner_link ul {
		margin: 30px 0px 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;
		-webkit-box-align: start;
		    -ms-flex-align: start;
		        align-items: flex-start;
	}
	#main #common_banner_link ul li {
		display: inline-block;
		vertical-align: top;
		width: calc(50% - 5px);
		margin: 0px;
	}
}
/* 「見つからないときは」「よくある質問」バナー（1カラム） ここまで */




/********** 9 メイン **********/

/* メイン */


/********** 10 各ページ **********/
.content_header_wrap{
	text-align: right;
}

#content_header {
	display: inline-block;
	vertical-align: top;
	margin-left: 1em;
	font-size: 1.3rem;
}

/* 印刷用アイコン */
#print_mode_link,
#print_mode_link_large {
	padding-left: 20px;
	padding-right: 10px;
	background: url(/img/common/icon_print.png) no-repeat left center;
}

/* カレンダー登録・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;
}

#sns_button_wrap  div[id^="sns_button_"] {
	display: inline-block;
	vertical-align: middle;
	margin: 0px 20px 0px 0px;
}
#sns_button_wrap  div[id^="sns_button_"] a {
	display: block;
	line-height: 1.5rem;
	background-color: transparent;
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 35px auto;
	padding: 10px 10px 10px 45px;
}
#sns_button_wrap  div#sns_button_facebook a {
	background-image: url(/img/common/sns/icon_sns_fb.png);
}
#sns_button_wrap  div#sns_button_twitter a {
	background-image: url(/img/common/sns/icon_sns_tw.png);
}
#sns_button_wrap  div#sns_button_line a {
	background-image: url(/img/common/sns/icon_sns_line.png);
	text-transform: uppercase;
}

/* 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;
}

/* サイトマップ */
/*
#sitemap_list_wrap {
	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;
}
#sitemap_list_wrap > div {
	width: calc(50% - 15px);
}
#main_body #sitemap_list_wrap > div h2 {
	margin-top: 0px;
}
*/

/* 大分類（見出し） */
div[id^="main_header_life3_"] {
	display: block;
	width: 100%;
	height: 200px;
	background: url(/img/common/bg_ttl_life.jpg) no-repeat  right center #F8F7EB;
	background-size: cover;
	margin: 0px 0px 30px;
	padding: 0px;
	position: relative;
}
div[id^="main_header_life3_"] h1 {
	display: block;
	width: 100%;
	margin: 0px;
	padding: 0px 30px;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	font-size: 3.2rem;
	font-weight: bold;
	line-height: 1.4;
	position: absolute;
	top: 50%;
	left: 0px;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}
/* 大分類（ライフイベント） */
#lifestage {
	margin-bottom: 30px;
}
#lifestage h2 {
	margin: 0px;
	padding: 0px 20px 20px;
	font-size: 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);
}

/* 分類 */
#life_cat_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;
}
.life_cat_list {
	display: inline-block;
	vertical-align: top;
	width: calc(50% - 15px);
	margin: 0px 30px 30px 0px;
}
.life_cat_list:nth-child(2n) {
	margin-right: 0px;
}

#main_body .life_cat_list h2,
#main_body .life_cat_list h3 {
	margin-top: 0px;
}

.life_cat_list .info_list.info_list_date ul li {
	display: block;
}
.life_cat_list .info_list.info_list_date ul li > span {
	display: block;
}
.life_cat_list .info_list.info_list_date ul li > span.article_date {
	width: auto;
}

.life_gaiyou {
	margin-bottom: 1em;
}

/* 分類（3カラム） */
.life_list3 .life_cat_list,
.life_list3 .life_cat_list:nth-child(2n) {
	width: 340px;
	margin: 0px 30px 30px 0px;
}
.life_list3 .life_cat_list:nth-child(3n) {
	margin-right: 0px;
}
.life_list3 #main_body .life_cat_list h2 {
	border: none;
	background: #F1A992;
	padding: 18px 20px 17px;
	font-size: 1.8rem;
	text-align: center;
}

/* 分類（サムネイル） */
.life_list3_thum .life_cat_list,
.life_list2_thum .life_cat_list {
	width: 100%;
	margin-right: 0px;
}
/* 関連情報 */
#kanren_info {
	background: #f5f5f5;
	margin: 0px 0px 10px;
	padding: 0px;
}
#kanren_info h2 {
	background: #e6e6e6;
	font-size: 1.8rem;
	font-weight: bold;
	margin: 0px;
	padding: 15px;
}
#kanren_info h3 {
	background: #e6e6e6;
	font-size: 1.6rem;
	font-weight: normal;
	margin: 10px 15px 0px;
	padding: 10px 15px;
}

.kanren_box ul {
	margin: 0px;
	padding: 10px 15px;
	list-style: none;
}
.kanren_box ul li {
	margin: 0px;
	padding: 3px 0px 3px 20px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
}
.kanren_box ul li:before {
	content: '';
	width: 0px;
	height: 0px;
	border: 5px solid transparent;
	border-right-width: 0px;
	border-left-width: 8px;
	border-left-color: #666666;
	position: absolute;
	top: 0.6em;
	left: 0px;
}

.kanren_box div.link_ichiran {
	margin-top: 0px;
	padding: 0px 15px 15px;
}

/* サブカテゴリ */
#lifesub_cat_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;
}
.lifesub_cat_list {
	width: calc(50% - 15px);
	margin: 0px 30px 20px 0px;
}
.lifesub_cat_list:nth-child(2n) {
	margin-right: 0px;
}
#main_body .lifesub_cat_list h2,
#main_body .lifesub_cat_list h3 {
	margin-top: 0px;
}

.life_cat_list_ttl {
	padding: 0.6em 20px;
	background: #f5f5f5;
	border: none;
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.4;
}

/* 組織 */
#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;
}
#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;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.question_detail #main_body textarea {
	font-size: 1.6rem;
	width: 100%;
	-webkit-box-sizing: border-box;
	-moz-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: 0px 1% 0px 0px;
	padding: 10px 0px;
	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%;
}
#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;
	-moz-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;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

#mail_form_btn_wrap {
	margin: 20px 0px 0px;
}
#mail_form_btn_wrap input[type="submit"],
.questionnaire-detail #main_body input[type="submit"]{
	display: inline-block;
	width: 25%;
	border: none;
	background: #7ACEE7;
	color: #000000;
	line-height: 2rem;
	margin: 0px 1% 0px 0px;
	padding: 10px 0px;
	text-align: center;
	border-radius: 6px;
}




/* 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;
}

/* タブレット */
@media screen and (max-width : 1099px) {

	div[id^="main_header_life3_"] {
		height: 150px;
	}
/*
	#life_menu_left {
		width: 70%;
		padding-right: 20px;
	}
	#life_menu_right {
		width: 30%;
	}
*/
	#soshiki_pr_image img {
		max-height: 150px;
	}

	/* 分類 */
	.life_list3 .life_cat_list,
	.life_list3 .life_cat_list:nth-child(2n),
	.life_list3 .life_cat_list:nth-child(3n) {
		width: calc(50% - 15px);
		margin: 0px 30px 30px 0px;
	}
	.life_list3 .life_cat_list:nth-child(2n) {
		margin-right: 0px;
	}

	/* サブカテゴリ */
	.kanren_index .lifesub_cat_list,
	.kanren_index .lifesub_cat_list:nth-child(2n),
	.kanren_index .lifesub_cat_list:nth-child(3n) {
		width: calc(50% - 15px);
		margin: 0px 30px 30px 0px;
	}
	.life_list3 .life_cat_list:nth-child(2n) {
		margin-right: 0px;
	}

	/* アンケート */
	#main_body table.tbl_ques th.title {
		width: 50%;
	}
	#main_body table.tbl_ques th.date,
	#main_body table.tbl_ques th.date2 {
		width: 18%;
	}
	#main_body table.tbl_ques th.button {
		width: 14%;
	}

}
/* タブレット ここまで */


.info_list.info_list_date .article_title img {
	margin-right: 10px;
	vertical-align: middle;
}