@charset "utf-8";
@import url("./parts-header-footer.css");

/* var() 関数 */
:root {

	/* コンテンツ幅 */
	--content-width: 1200px;
	/* sidebar1の幅 */
	--sidebar1-width: 300px;
	/* sidebar2の幅 */
	--sidebar2-width: 300px;

	/* #mymainbackの上下余白 */
	--mymainback-margin-top: 30px;
	--mymainback-margin-bottom: 60px;
	/* コンテンツの上下余白 */
	--content-margin-normal: 40px;
	--content-margin-narrow: 30px;
	--content-margin-wide: 60px;

	/* フォントサイズ / 行間 / 文字間 */
	--fontsize-main-base: 62.5%;
	--fontsize-main: 1.6rem;
	--lineheight-main: 1.75;
	--letterspacing-main: 0em;
	/* 通常より一段階小さいフォントサイズ（一覧をみるボタンなど） */
	--fontsize-main-small: 1.5rem;
	/* 本文（ #main ） */
	--fontsize-detail: 1.8rem;
	--lineheight-detail: 1.75;
	--letterspacing-detail: 0.05em;
	/* 見出し */
	--lineheight-detail-midashi: 1.5;
	--letterspacing-detail-midashi: 0.1em;

	/* フォントファミリー */
	--fontfamily-normal: "Noto Sans JP", "Noto Sans", sans-serif, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	/* 見出し / 太字 */
	--fontfamily-bold: "Noto Sans JP", "Noto Sans", sans-serif, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;

	/* 基本文字色 */
	--text-color: #333333;

	/* a:link のリンク色 */
	--textlink-link: #0d59b7;
	/* a:visited のリンク色 */
	--textlink-visited: #222;
	/* a:active のリンク色 */
	--textlink-active: #cc0000;
	/* a:hoder / a:focus のリンク色 */
	--textlink-hover: #000000;

	/* ボタン（一覧をみる / アンケート送信 / お問い合わせ送信） */
	--btn-background: #e6e6e6;
	--btn-border: none;
	--btn-borderradius: 0;
	--btn-boxshadow: none;
	--btn-color: #333333;
	--btn-textdecoration: none;
	/* hover / focus */
	--btn-hover-background: #e6e6e6;
	--btn-hover-border: none;
	--btn-hover-borderradius: 0;
	--btn-hover-boxshadow: none;
	--btn-hover-color: #333333;
	--btn-hover-textdecoration: underline;

	/* 表の枠線の色 */
	--table-bordercolor: #333333;
	/* 表の見出し背景色 */
	--table-th-background: #f6f6f6;
	--table-th-color: #333333;

	/* パンくず背景 */
	--pankuzu-background: #f6f6f6;
	--pankuzu-color: #333333;
	/* 現在地・足あとアイコン */
	--pankuzu-midashi-border: none;
	--pankuzu-midashi-borderradius: 0;
	--pankuzu-midashi-background: #333333;
	--pankuzu-midashi-color: #ffffff;

	/* 大分類見出し背景 */
	--lifetitle-background: #f6f6f6;
	--lifetitle-color: #333333;

	/* サブサイト共通ヘッダ背景（画像なし） */
	--siteheader-background: #f6f6f6;
	--siteheader-color: #333333;
	/* サブサイト共通ヘッダ背景（画像あり / スマートフォン表示時） */
	--siteheader-img-background: #333333;
	--siteheader-img-color: #ffffff;

	/* サブサイト共通フッタ背景 */
	--sitefooter-background: #f6f6f6;
	--sitefooter-color: #333333;

}
/* var() 関数 ここまで */


/* ===== 1 基本設定 ===== */

/* フォント */
body,
button,
input[type="button"],
input[type="submit"],
input[type="text"],
textarea,
select {
	font-family: var(--fontfamily-normal, sans-serif);
	font-size: var(--fontsize-main, 1.6rem);
	line-height: var(--lineheight-main, 1.5);
	letter-spacing: var(--letterspacing-main, 0em);
	overflow-wrap: break-word;
}

#main {
	font-size: var(--fontsize-detail, 1.8rem);
	line-height: var(--lineheight-detail, 1.75);
	letter-spacing: var(--letterspacing-detail, 0.05em);
}

h1, h2, h3, h4, h5, h6, strong,
.kakuka_info_ttl,
.life_cat_list_ttl,
.subsite_menu_ttl,
.site_name,
#main_body table.tbl_ques caption,
#main_body table#mail_form_tbl caption {
	font-family: var(--fontfamily-bold, sans-serif);
	line-height: var(--lineheight-detail-midashi, 1.5);
	letter-spacing: var(--letterspacing-detail-midashi, 0.1em);
	font-weight: bold;
}

/* JavaScript挿入箇所のフォントファミリー（webフォント使用時） */
/*
#pankuzu_wrap, #footstep_wrap, #keep_page, #count_down_area,
#important_noticest_area, #important_noticest_area h2,
#osusume_contents_area, #osusume_contents_area h2,
#recommend_tag, #recommend_tag h2,
#ai_recommend_tag, #ai_recommend_tag h2 {
	font-family: Arial, 'BIZ UDPGothic', Meiryo, メイリオ, Osaka, sans-serif;
}
*/

em {
	font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Arial, 'BIZ UDPGothic', Osaka, 'MS PGothic', sans-serif;
}

.mincho {
	font-family: 'Hiragino Mincho Pro', 'HiraMinProN-W3', 'ヒラギノ明朝 Pro W3', Century, 'BIZ UDPMincho', '游明朝', 'Yu Mincho', '游明朝体', 'YuMincho', serif;
}

/* 文字色 */
body {
	color: var(--text-color, #333333);
}

/* リンク */
a:link {
	color: var(--textlink-link, #0d59b7);
	text-decoration: underline;
}
a:visited {
	color: #222;
	text-decoration: underline;
}
a:active {
	color: var(--textlink-active, #cc0000);
	text-decoration: none;
}
a:hover, a:focus {
	color: var(--textlink-hover, #000000);
	text-decoration: none;
}

a img {
	border: none;
	-webkit-transition: opacity 0.5s;
	-o-transition: opacity 0.5s;
	transition: opacity 0.5s;
}
a:hover img, a:focus img {
	opacity: 0.75;
}

/* 見出し */
#main_header {
	margin-bottom: var(--content-margin-narrow, 30px);
}
#main_header h1 {
	margin: 0px;
	padding: 26px 30px;
	background: #e6e6e6;
	font-size: 3.2rem;
}

#main_body :where(h2,h3,h4,h5,h6),
.kakuka_info_ttl,
.life_cat_list_ttl {
	clear: both;
	margin: 1em 0px;
}
.life_cat_list_ttl {
	margin: 0px;
}

#main_body h2 {
	padding: 21px 30px 20px;
	background: #e6e6e6;
	font-size: 2.6rem;
}

#main_body h3,
.kakuka_info_ttl,
.life_cat_list_ttl {
	padding: 17px 30px;
	background: #e6e6e6;
	font-size: 2.4rem;
}

#main_body h4 {
	padding: 14px 30px 13px;
	background: #e6e6e6;
	font-size: 2.2rem;
}

#main_body h5 {
	padding: 10px 30px;
	background: #e6e6e6;
	font-size: 2.0rem;
}

#main_body h6 {
	padding: 7px 30px 6px;
	background: #e6e6e6;
	font-size: 1.8rem;
}

/* テーブル */
#main_body table {
	border-color: var(--table-bordercolor, #333333);
	border-collapse: collapse;
	border-style: solid;
	border-width: 2px; /* CMSver5以降は管理画面で枠線の太さを変更することができない（機能が削除された）ためCSSで指定 */
	margin: 0px 0px 1em;
	max-width: 100%;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}
#main_body th {
	background: var(--table-th-background, #f6f6f6);
	color: var(--table-th-color, #333333);
	border-color: var(--table-bordercolor, #333333);
	border-collapse: collapse;
	border-style: solid;
	border-width: 1px;
	padding: 0.5em;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}
#main_body td {
	border-color: var(--table-bordercolor, #333333);
	border-collapse: collapse;
	border-style: solid;
	border-width: 1px;
	padding: 0.5em;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}
/* テーブル内のpタグのマージンを0にする */
#main_body table p {
	margin: 0px 0px 1em;
}
#main_body table p:last-child {
	margin: 0px;
}

/* 見出しとテーブルの設定は「 editor-public-page 」にも適用すること */

/* ===== 2 ヘッダ / フッタ ===== */

/* 「 parts-header-footer 」 参照 */

/* ===== 3 パンくず / 足あと ===== */

/* パンくず・足あと */
#pankuzu_wrap {
	background: var(--pankuzu-background, #f6f6f6);
	color: var(--pankuzu-color, #333333);
	font-size: var(--fontsize-main-small, 1.5rem);
	padding: 20px 0px 10px;
}
#pankuzu_wrap > div {
	width: var(--content-width, 1080px);
	margin: 0px auto 10px;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}

.pankuzu,
#footstep {
	position: relative;
	padding-left: 7rem;
}
.pankuzu .icon_current {
	display: none;
}
.pankuzu:first-child .icon_current,
#footstep_ttl {
	display: block;
	width: 5rem;
	height: auto;
	min-height: 2rem;
	border: var(--pankuzu-midashi-border, none);
	border-radius: var(--pankuzu-midashi-borderradius, 0);
	background: var(--pankuzu-midashi-background, #333333);
	color: var(--pankuzu-midashi-color, #ffffff);
	font-size: 1.3rem;
	line-height: 1.6rem;
	padding: 0.2rem 0px;
	text-align: center;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	position: absolute;
	top: 2px;
	left: 0px;
}

#clear_footstep {
	width: 24px;
	height: 24px;
	border-radius: 100%;
	border: 2px solid var(--pankuzu-background, #f6f6f6);
	background: url("../../img/common/icon_clear.png") no-repeat center center #333333;
	background-size: 10px 10px;
	color: #ffffff;
}

/* ===== 4 メイン ===== */

/* メイン */
#mymainback {
	padding-top: var(--mymainback-margin-top, 30px);
	padding-bottom: var(--mymainback-margin-bottom, 60px);
}

/* コンテンツヘッダ */
#content_header {
	margin: 0px 0px 20px;
	text-align: right;
	font-size: var(--fontsize-main-small, 1.5rem);
}
#content_header > span {
	display: inline-block;
	margin-left: 2em;
}

/* コンテンツフッタ */
#content_footer {
	clear: both;
}

/* 印刷 */
#print_mode_link,
#print_mode_link_large {
	display: inline-block;
	background: url("../../img/common/icon_print.png") no-repeat left center transparent;
	padding-left: 20px;
}

/* SDGsアイコン */
.d-flex.f-wrap-wrap,
.sdgs-icons {
	margin: 0px 0px 20px;
	text-align: left;
}
.d-flex.f-wrap-wrap > *,
.sdgs-icons > * {
	display: inline-block;
	vertical-align: top;
	margin: 0px 5px 5px 0px;
	width: 100px;
}

.d-flex.f-wrap-wrap img,
.sdgs-icons img {
	width: 100px;
	height: auto;
	vertical-align: top;
}
.d-flex.f-wrap-wrap > * img,
.sdgs-icons > * img {
	display: block;
	margin: 0px;
	width: 100%;
	height: auto;
}

/* カレンダー登録 */
#calendar_button_google,
#calendar_button_yahoo {
	display: inline-block;
	vertical-align: top;
	margin: var(--content-margin-normal, 40px) 30px 0px 0px;
}
#calendar_button_google a,
#calendar_button_yahoo a {
	display: inline-block;
	font-size: var(--fontsize-main-small, 1.5rem);
	line-height: 2rem;
	padding: 5px 0px 5px 35px;
	background: url("../../img/common/icon_calendar.png") no-repeat left center transparent;
}

/* SNSボタン */
.sns_button_wrap {
	margin-top: var(--content-margin-normal, 40px);
	line-height: 1em;
}
.sns_button_wrap > div {
	display: inline-block;
	vertical-align: top;
}

/* PDF・WMPリンク */
.pdf_download,
.wmplayer_download {
	clear: both;
	margin: var(--content-margin-normal, 40px) 0px 0px;
	width: 100%;
	display: table;
}
.pdf_download .pdf_img,
.wmplayer_download .wmplayer_img {
	display: table-cell;
	vertical-align: middle;
	width: 158px;
	margin: 0px;
	padding: 0px;
}
.wmplayer_download .wmplayer_img {
	width: 88px;
}
.pdf_download .pdf_img img,
.wmplayer_download .wmplayer_img img {
	width: 100%;
	height: auto;
	vertical-align: top;
}

.tenpu_txt {
	display: table-cell;
	vertical-align: middle;
	margin: 0px;
	padding: 2px 0px 2px 10px;
	font-size: 1.3rem;
	line-height: 1.4;
	letter-spacing: 0em;
}

/* 評価エリア */
#hyouka_area_box {
	clear: both;
	margin: var(--content-margin-normal, 40px) 0px 0px;
	padding: 30px;
	background: #f6f6f6;
}

#hyouka_area_box h2,
#main_body #hyouka_area_box h2 {
	margin: 0px 0px 15px;
	padding: 0px;
	border: none;
	border-radius: 0;
	background: none;
	color: inherit;
	font-size: 2rem;
}
#main_body #hyouka_area_box h2::before,
#main_body #hyouka_area_box h2::after {
	display: none;
}
#main_body #hyouka_area_box hr.cf {
	margin: 0px;
}

#hyouka_area_box .hyouka_box_detail {
	border-bottom: 1px solid #d9d9d9;
	margin-bottom: 15px;
	padding-bottom: 15px;
	font-size: var(--fontsize-main-small, 1.5rem);
}
#hyouka_area_box .hyouka_box_detail:last-child {
	border-bottom: none;
	margin-bottom: 0px;
}
#hyouka_area_box .hyouka_box_detail fieldset {
	border: none;
	margin: 0px;
	padding: 0px;
}
#hyouka_area_box .hyouka_box_detail fieldset legend {
	margin: 0px 0px 5px;
	padding: 0px;
	width: 100%;
}
#hyouka_area_box .hyouka_box_detail fieldset span {
	display: inline-block;
	vertical-align: top;
	margin: 0px 4em 0px 0px;
}
#hyouka_area_box .hyouka_box_detail fieldset span:first-of-type {
	min-width: 11em;
}
.font_size_changed #hyouka_area_box .hyouka_box_detail fieldset span:first-of-type {
	min-width: auto;
}
#hyouka_area_box .hyouka_box_detail fieldset span input {
	margin: 3px 4px 5px 5px;
	vertical-align: middle;
}

#hyouka_area_submit,
div[class*="confirm_quest_hankyou"] #hyouka_area_submit {
	margin-top: 10px;
}
#hyouka_area_submit input {
	display: inline-block;
	border: none;
	border-radius: 0;
	background: #ffffff;
	color: #333333;
	margin: 0px;
	padding: 10px;
	font-size: var(--fontsize-main-small, 1.5rem);
	line-height: 2rem;
	text-decoration: none;
	text-align: center;
	width: 260px;
	max-width: 90%;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}
#hyouka_area_submit input:hover,
#hyouka_area_submit input:focus {
	text-decoration: underline;
}

/* 評価エリア（確認ページ） */
div[class*="confirm_quest_hankyou"] #hyouka_area_box {
	margin: 0px;
	padding: 0px;
	background: none;
	border: none;
	border-radius: 0px;
	-webkit-box-shadow: none;
	        box-shadow: none;
}

/* お問い合わせ先 */
#section_footer {
	clear: both;
	margin: var(--content-margin-normal, 40px) 0px 0px;
	padding: 30px;
	background: #f6f6f6;
}

#section_footer h2,
#main_body #section_footer h2 {
	margin: 0px 0px 15px;
	padding: 0px;
	border: none;
	border-radius: 0;
	background: none;
	color: inherit;
	font-size: 2rem;
}
#main_body #section_footer h2::before,
#main_body #section_footer h2::after {
	display: none;
}
#main_body #section_footer hr.cf {
	margin: 0px;
}

#section_footer_detail span {
	display: inline-block;
	vertical-align: top;
	margin-right: 1em;
}
#section_footer_detail span[class*="sf_name"] {
	margin-bottom: 10px;
}

/* おすすめコンテンツ */
#osusume_contents_area {
	clear: both;
}
#osusume_contents_area .second_osusume {
	margin: var(--content-margin-normal, 40px) 0px 0px;
	padding: 30px 16px 10px;
	background: #f6f6f6;
}
#osusume_contents_area .second_osusume h2,
#osusume_contents_area .second_osusume_ttl {
	margin: 0px 14px 20px;
	padding: 0px 0px 0px 25px;
	border: none;
	border-radius: 0;
	background: url("../../img/common/icon_osusume.png") no-repeat left center transparent;
	color: inherit;
	font-size: 2rem;
}
#osusume_contents_area .second_osusume 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: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
}
#osusume_contents_area .second_osusume ul li {
	display: inline-block;
	vertical-align: top;
	width: 200px;
	margin: 0px 18px 20px;
}
#osusume_contents_area .second_osusume ul li div > span {
	display: block;
}
#osusume_contents_area .second_osusume ul li div > span.osusume_img {
	margin-bottom: 10px;
}
#osusume_contents_area .second_osusume ul li div > span.osusume_img img {
	width: 100%;
	height: auto;
	vertical-align: top;
}

/* ===== 5 サイド ===== */

/* サイドバー */
#sidebar1 > div,
#sidebar2 > div {
	margin-bottom: 20px;
}
#sidebar1 > div:last-child,
#sidebar2 > div:last-child,
#sidebar1 > div:empty,
#sidebar2 > div:empty {
	margin-bottom: 0px !important;
}

#sidebar1 img,
#sidebar2 img {
	max-width: 100%;
	height: auto;
	vertical-align: top;
}

/* 重要なお知らせ */
#important_noticest_area .second_important {
	background: #fdf2f2;
	padding: 30px 20px;
}
#important_noticest_area .second_important a {
	color: #cc0000;
}

#important_noticest_area .second_important h2,
#important_noticest_area .second_important_ttl {
	margin: 0px 0px 15px;
	padding: 0px;
	color: #cc0000;
	font-size: 2rem;
	text-align: center;
}

#important_noticest_area .second_important ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
#important_noticest_area .second_important ul li {
	margin: 0px 0px 15px;
}
#important_noticest_area .second_important ul li:last-child {
	margin-bottom: 0px;
}
#important_noticest_area .second_important ul li > span {
	display: block;
}

#important_noticest_area .second_important .link_box {
	margin-top: 20px;
	text-align: right;
}
#important_noticest_area .second_important .link_box > span {
	display: block;
	margin-top: 5px;
}
#important_noticest_area .second_important .link_box > span a {
	font-size: var(--fontsize-main-small, 1.5rem);
}

/* カウントダウン */
#count_down_area .count_down_box {
	background: #f6f6f6;
	margin: 0px 0px 15px;
	padding: 20px;
	position: relative;
}
#count_down_area .count_down_box:last-child {
	margin-bottom: 0px;
}

#count_down_area .count_down_box2 {
	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: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
}
#count_down_area .count_down_box2 > span {
	display: inline-block;
	vertical-align: top;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}

#count_down_area .count_down_box2 > span.count_img {
	width: 100px;
}
#count_down_area .count_down_box2 > span.count_img > span {
	display: block;
}
#count_down_area .count_down_box2 > span.count_img > span img {
	width: 100%;
	height: auto;
	vertical-align: top;
}

#count_down_area .count_down_box2 > span.count_txt {
	width: calc(100% - 120px);
}
#count_down_area .count_down_box2 > span.count_txt:only-child {
	width: 100%;
}
#count_down_area .count_down_box2 > span.count_txt > span {
	display: block;
}
#count_down_area .count_down_box2 > span.count_txt > span.count_comment {
	margin-top: 10px;
	font-size: 1.4rem;
}
#count_down_area .count_down_box2 > span.count_txt > span.count_day {
	margin-top: 10px;
	color: #cc0000;
	font-weight: bold;
	text-align: right;
}
#count_down_area .count_down_box2 > span.count_txt > span.count_day span {
	font-size: 3rem;
	line-height: 1;
	margin-left: 0.5em;
	margin-right: 0.25em;
}

/* カウントダウン クリアボタン */
#count_down_area .count_down_clear {
	display: block;
	width: 24px;
	height: 24px;
	margin: 0px;
	padding: 0px;
	border: 2px solid #ffffff;
	background: url("../../img/common/icon_clear.png") no-repeat center center #333333;
	background-size: 10px 10px;
	border-radius: 100%;
	color: #ffffff;
	line-height: 1em;
	text-align: left;
	text-indent: -9999em;
	overflow: hidden;
	cursor: pointer;
	position: absolute;
	top: 0px;
	right: 0px;
}
/* カウントダウン クリアボタンを使用しない */
#count_down_area .count_down_clear {
	display: none;
}

/* レコメンド・AIレコメンド */
#sidebar_recommend,
#sidebar_ai_recommend {
	background: #f6f6f6;
}

#recommend_title,
#ai_recommend_title {
	background: #e6e6e6;
	text-align: center;
	padding: 10px 5px;
}
#recommend_title h2,
#ai_recommend_title h2 {
	display: inline-block;
	text-align: left;
	font-size: 1.6rem;
	margin: 0px;
	padding: 6px 0px 6px 40px;
}
#recommend_title h2 {
	background: url("../../img/common/icon_recommend.png") no-repeat left center transparent;
	color: inherit;
}
#ai_recommend_title h2 {
	background: url("../../img/common/icon_ai_recommend.png") no-repeat left center transparent;
	color: inherit;
}
#recommend_title h2 span,
#ai_recommend_title h2 span {
	display: block;
}

#sidebar_recommend ul,
#sidebar_ai_recommend ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
#sidebar_recommend ul li,
#sidebar_ai_recommend ul li {
	display: block;
	border-top: 1px solid #ffffff;
	padding: 15px 20px;
}

/* 関連リンク */
#kanren_link h2 {
	background: #e6e6e6;
	margin: 0px;
	padding: 18px 20px;
	font-size: 1.8rem;
	text-align: center;
}
#kanren_link ul {
	margin: 0px;
	padding: 20px 0px 20px 20px;
}
#kanren_link ul li {
	margin-bottom: 15px;
}
#kanren_link ul li:last-child {
	margin-bottom: 0px;
}

/* 「見つからないときは」「よくある質問」バナー */
.common_banner_link ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
.common_banner_link *[class*="common_banner_"] {
	margin-bottom: 15px;
}
.common_banner_link *[class*="common_banner_"]:last-child {
	margin-bottom: 0px;
}
.common_banner_link a {
	display: block;
	background: #e6e6e6;
	color: #333333;
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 2rem;
	letter-spacing: 0.1em;
	padding: 15px 5px;
	text-align: center;
}
.common_banner_link a span {
	display: inline-block;
	padding: 10px 0px 10px 40px;
}
.common_banner_link .common_banner_mitsukaranai a span {
	background: url("../../img/common/icon_mitsukaranai.png") no-repeat left center transparent;
	color: inherit;
}
.common_banner_link .common_banner_faq a span {
	background: url("../../img/common/icon_faq.png") no-repeat left center transparent;
	color: inherit;
}
.common_banner_link a:hover,
.common_banner_link a:focus,
.common_banner_link a:hover span,
.common_banner_link a:focus span {
	text-decoration: underline;
}
/* 「見つからないときは」「よくある質問」バナー（1カラム） */
@media screen and (min-width: 1081px) {
	#main .common_banner_link,
	#main .common_banner_link ul {
		margin: var(--content-margin-normal, 40px) 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 {
		margin: 0px;
		width: 100%;
	}
	#main .common_banner_link *[class*="common_banner_"] {
		display: inline-block;
		vertical-align: top;
		width: calc(50% - 15px);
		margin: 0px;
	}
}
/* 「見つからないときは」「よくある質問」バナー（1カラム） ここまで */

/* 関連情報 */
#kanren_info {
	background: #f6f6f6;
	padding: 20px 20px 10px;
	text-align: center;
}
#kanren_info h2 {
	display: inline-block;
	background: url("../../img/common/icon_kanren.png") no-repeat left center transparent;
	font-size: 1.8rem;
	margin: 0px;
	padding: 10px 20px 10px 35px;
}

/*
#kanren_info .kanren_box {
	padding: 15px 0px;
	text-align: left;
}
#kanren_info .kanren_box h3 {
	margin: 0px 0px 15px;
	padding: 10px 20px;
	background: #ffffff;
	font-size: 1.6rem;
	text-align: center;
}
#kanren_info .kanren_box ul {
	margin: 0px;
	padding: 5px 0px 5px 20px;
}
#kanren_info .kanren_box ul li {
	margin-bottom: 10px;
}
*/
#kanren_info .kanren_box ul li:last-child {
	margin-bottom: 0px;
}

#kanren_info div.link_ichiran {
	margin: 15px 15px 0px;
	padding: 0px;
	text-align: center;
}
#kanren_info div.link_ichiran a {
	display: block;
}

/* サイドメニュー */
/*
.side_box {
	background: #f6f6f6;
}
*/

.side_box_ttl h2 {
	background: #e6e6e6;
	margin: 0px;
	padding: 18px 20px;
	font-size: 1.8rem;
	text-align: center;
}

.side_box_txt {
	padding: 20px;
}
.side_box_txt p {
	margin: 0px 0px 1em;
}
.side_box_txt p:last-child {
	margin-bottom: 0px;
}
.side_box_txt > div {
	margin: 0px 0px 1em;
}
.side_box_txt > div:last-child {
	margin-bottom: 0px;
}

.side_box_list ul {
	margin: 0px;
	padding: 20px 20px 20px 40px;
}
.side_box_list ul li {
	margin: 0px 0px 15px;
}
.side_box_list ul li:last-child {
	margin-bottom: 0px;
}
.side_box_list ul li ul {
	padding: 10px 0px 0px 20px;
}
.side_box_list ul li ul li {
	margin-bottom: 5px;
}
.side_box_list ul li ul li:last-child {
	margin-bottom: 0px;
}

/* サブサイト大小メニュー */
.subsite_menu {
	background: #f6f6f6;
	margin: 0px 0px 20px;
}
.subsite_menu:last-child {
	margin-bottom: 0px;
}

.subsite_menu_ttl {
	background: #e6e6e6;
	margin: 0px;
	padding: 18px 20px;
	font-size: 1.8rem;
	text-align: center;
}
.subsite_menu_ttl a {
	color: inherit;
}

.subsite_menu_list ul {
	margin: 0px;
	padding: 20px 20px 20px 40px;
}
.subsite_menu_list ul li {
	margin: 0px 0px 15px;
}
.subsite_menu_list ul li:last-child {
	margin-bottom: 0px;
}

.subsite_menu_list div.link_ichiran {
	margin: 0px;
	padding: 0px 35px 25px;
	text-align: center;
}
.subsite_menu_list div.link_ichiran a {
	display: block;
}

/* サブサイト大小メニュー（開閉） */
.subsite_menu summary:only-child {
	display: block;
	list-style-type: none;
	pointer-events: none;
	cursor: auto;
}
.subsite_menu summary:only-child::-webkit-details-marker {
	display: none;
}
.subsite_menu summary:only-child a {
	pointer-events: auto;
}
/* サブサイト大小メニュー（開閉）（PCは開閉しない） */
@media screen and (min-width: 1081px) {
	.subsite_menu summary {
		display: block;
		list-style-type: none;
		pointer-events: none;
		cursor: auto;
	}
	.subsite_menu summary::-webkit-details-marker {
		display: none;
	}
	.subsite_menu summary a {
		pointer-events: auto;
	}
}
/* サブサイト大小メニュー（開閉）（PCは開閉しない） ここまで */

/* 自由編集項目 */
.free_box {
	display: flow-root;
}
.free_box p {
	margin: 0px 0px 1em;
}
.free_box p:last-child {
	margin-bottom: 0px;
}
.free_box img {
	max-width: 100%;
	height: auto !important;
	vertical-align: top;
}

/* ===== 6 リスト ===== */

/* リスト（横並び） */
.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;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
}
.navigation ul li,
.navigation > div {
	display: inline-block;
	vertical-align: top;
	margin: 0px 1em 1em 0px;
	padding-right: 1em;
	border-right: 1px solid;
	line-height: 1.25;
}
.navigation ul li:last-child,
.navigation > div:last-child {
	margin-right: 0px;
	padding-right: 0px;
	border-right: none;
}

/* リスト（一覧） */
.info_list ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
.info_list ul li {
	margin: 0px 0px 15px;
}
.info_list ul li:last-child {
	margin-bottom: 0px;
}

/* リスト（日付） */
.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: calc(11em + 10px);
}

/* リスト（日付 / 文字拡大時） */
.font_size_changed .info_list.info_list_date ul li,
.font_size_changed .info_list.info_list_date ul li > span {
	display: block;
}
.font_size_changed .info_list.info_list_date ul li > span.article_date {
	width: auto;
}

/* リスト（担当課） */
.article_section:has(span:empty) {
	display: none;
}

/* リスト（サムネイル） */
.list_pack {
	width: 100%;
	display: table;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}

.list_pack .article_txt {
	display: table-cell;
	vertical-align: top;
}
.list_pack .article_txt .article_date {
	display: block;
}
.list_pack .article_txt .article_title {
	display: block;
}

.list_pack .article_img {
	display: table-cell;
	vertical-align: top;
	width: 200px;
	padding-right: 20px;
}
.list_pack .article_img span {
	display: block;
	height: 150px;
	overflow: hidden;
	background: #f6f6f6;
}
.list_pack .article_img span:empty {
	height: 150px;
	background: url("../../img/common/noimage.png") no-repeat center center #f6f6f6;
	background-size: contain;
}
.list_pack .article_img span img {
	width: 100%;
	height: 100%;
	-o-object-fit: contain;
	   object-fit: contain;
}

/* リスト（一覧リンク） */
div.link_ichiran {
	margin: 30px 0px 20px;
	padding: 0px;
	text-align: right;
}
div.link_ichiran a {
	display: inline-block;
	background: var(--btn-background, #e6e6e6);
	border: var(--btn-border, none);
	border-radius: var(--btn-borderradius, 0);
	-webkit-box-shadow: var(--btn-boxshadow, none);
	        box-shadow: var(--btn-boxshadow, none);
	color: var(--btn-color, #333333);
	text-decoration: var(--btn-textdecoration, none);
	font-size: var(--fontsize-main-small, 1.5rem);
	line-height: 2rem;
	padding: 10px 20px;
	text-align: center;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}
div.link_ichiran a:hover,
div.link_ichiran a:focus {
	background: var(--btn-hover-background, #e6e6e6);
	border: var(--btn-hover-border, none);
	border-radius: var(--btn-hover-borderradius, 0);
	-webkit-box-shadow: var(--btn-hover-boxshadow, none);
	        box-shadow: var(--btn-hover-boxshadow, none);
	color: var(--btn-hover-color, #333333);
	text-decoration: var(--btn-hover-textdecoration, underline);
}

#main div.link_ichiran a {
	min-width: 260px;
}

/* ===== 7 新着情報 ===== */

/* 新着情報 */
.section_information {
	background: #f6f6f6;
	margin: var(--content-margin-normal, 40px) 0px;
	padding: 30px;
}
.section_information h2 {
	margin: 0px;
	padding: 0px;
	border: none;
	border-radius: 0;
	background: none;
	font-size: 2.4rem;
}

.section_information p.no_data {
	margin: 0px;
	padding: 20px 0px;
}

.section_information_list img.icon_new {
	vertical-align: middle;
	margin-left: 0.5em;
}

.section_information_list ul {
	margin: 0px;
	padding: 20px 0px;
	list-style: none;
}
.section_information_list ul li {
	width: 100%;
	display: table;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	margin: 0px 0px 15px;
}
.section_information_list ul li:last-child {
	margin-bottom: 0px;
}
.section_information_list ul li > span {
	display: table-cell;
	vertical-align: top;
}
.section_information_list ul li > span.article_date {
	width: calc(11em + 10px);
}

/* 新着情報（文字拡大時） */
.font_size_changed .section_information_list ul li,
.font_size_changed .section_information_list ul li > span {
	display: block;
}
.font_size_changed .section_information_list ul li > span.article_date {
	width: auto;
}

/* 新着情報（一覧 / RSS） */
.section_information_list div.link_box {
	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: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	padding: 10px 0px;
}
.section_information_list div.link_box span {
	display: inline-block;
	vertical-align: top;
	margin: 10px 10px 0px;
	width: 260px;
	max-width: calc(100% - 20px);
}
.section_information_list div.link_box span a {
	display: block;
	border: none;
	border-radius: 0;
	background: #ffffff;
	color: #333333;
	font-size: var(--fontsize-main-small, 1.5rem);
	line-height: 2rem;
	text-decoration: none;
	margin: 0px;
	padding: 10px 20px;
	text-align: center;
}
.section_information_list div.link_box span a:hover,
.section_information_list div.link_box span a:focus {
	text-decoration: underline;
}

/* 新着情報（サムネイル） */
.section_information_thum {
	width: 100%;
	display: table;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	margin: 20px 0px 0px;
}
.section_information_thum > div {
	display: table-cell;
	vertical-align: top;
}
.section_information_thum > div.lettering2 {
	width: 200px;
	padding-right: 20px;
}
.section_information_thum > div.lettering2 img {
	width: 100%;
	height: auto;
	vertical-align: top;
}
.section_information_thum > div.lettering3 .lettering_a > span {
	display: block;
}

/* 新着情報2 */
.section_information2 {
	margin: var(--content-margin-normal, 40px) 0px;
}
.section_information2 h2 {
	margin: 0px 0px 15px;
	padding: 0px;
	border: none;
	border-radius: 0;
	background: none;
	color: inherit;
	font-size: 2.4rem;
}

/* ===== 8 バナー ===== */

/* バナー広告 */
#footer_banner {
	clear: both;
	width: var(--content-width, 1080px);
	margin: 0px auto var(--mymainback-margin-bottom, 60px);
}
#footer_banner 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;
}
#footer_banner ul.banner_list li {
	display: inline-block;
	vertical-align: top;
	width: 200px;
	margin: 0px 20px 0px 0px;
}
#footer_banner ul.banner_list li:nth-child(5n) {
	margin-right: 0px;
}
#footer_banner ul.banner_list li:nth-child(n+6) {
	margin-top: 20px;
}
#footer_banner ul.banner_list li img {
	width: 100%;
	height: auto;
	vertical-align: top;
}

.banner_text {
	display: block;
	padding: 10px;
	text-align: left;
}
.banner_text span {
	display: block;
}
.banner_text span:nth-child(2n) {
	font-size: var(--fontsize-main-small, 1.5rem);
}

/* ===== 9 各ページ ===== */

/* サイトマップ */
#sitemap_list_wrap > div {
	margin-bottom: var(--content-margin-wide, 60px);
}
#sitemap_list_wrap > div > div {
	margin-bottom: var(--content-margin-normal, 40px);
}
#sitemap_list_wrap > div:last-child,
#sitemap_list_wrap > div > div:last-child {
	margin-bottom: 0px;
}

/* 分類でさがす */
div[class*="life_index"] #main_body > div {
	margin-bottom: var(--content-margin-normal, 40px);
}
div[class*="life_index"] #main_body > div:last-child {
	margin-bottom: 0px;
}

/* 大分類（見出し） */
div[id^="main_header_life3_"] {
	display: block;
	width: 100%;
	height: 200px;
	background-color: var(--lifetitle-background, #f6f6f6);
	background-repeat: no-repeat;
	background-position: right center;
	background-size: cover;
	color: var(--lifetitle-color, #333333);
	margin: 0px 0px var(--content-margin-narrow, 30px);
	padding: 0px;
	position: relative;
}
/*
div#main_header_life3_1 { background-image: url("../../img/life/life3_1_title.jpg"); }
div#main_header_life3_2 { background-image: url("../../img/life/life3_2_title.jpg"); }
div#main_header_life3_3 { background-image: url("../../img/life/life3_3_title.jpg"); }
div#main_header_life3_4 { background-image: url("../../img/life/life3_4_title.jpg"); }

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;
	text-shadow: 0px 0px 3px #ffffff, 0px 0px 3px #ffffff, 0px 0px 3px #ffffff, 0px 0px 3px #ffffff, 0px 0px 3px #ffffff,
		0px 0px 3px #ffffff, 0px 0px 3px #ffffff, 0px 0px 3px #ffffff, 0px 0px 3px #ffffff, 0px 0px 3px #ffffff,
		0px 0px 3px #ffffff, 0px 0px 3px #ffffff, 0px 0px 3px #ffffff, 0px 0px 3px #ffffff, 0px 0px 3px #ffffff;
	position: absolute;
	top: 50%;
	left: 0px;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	z-index: 1;
}
*/
/* 大分類（ライフイベント） */
.list_lifestage {
	margin: var(--content-margin-wide, 60px) 0px;
}
.list_lifestage h2 {
	margin: 0px 0px 20px;
	padding: 0px;
	border: none;
	background: none;
	font-size: 2rem;
}
.list_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: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: stretch;
	    -ms-flex-align: stretch;
	        align-items: stretch;
}
.list_lifestage ul li {
	width: 121px;
	margin: 0px 16px 0px 0px;
}
.list_lifestage ul li:nth-child(8n) {
	margin-right: 0px;
}
.list_lifestage ul li:nth-child(n+9) {
	margin-top: 16px;
}
.list_lifestage ul li a {
	display: block;
	border: none;
	border-radius: 0;
	background-color: #f6f6f6;
	background-repeat: no-repeat;
	background-position: center 20px;
	font-size: 1.6rem;
	line-height: 2rem;
	text-align: center;
	padding: 80px 10px 20px;
	height: 100%;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}
.list_lifestage ul li.lifestage01 a {
	background-image: url("../../img/lifestage/lifestage1_b.png");
}
.list_lifestage ul li.lifestage02 a {
	background-image: url("../../img/lifestage/lifestage2_b.png");
}
.list_lifestage ul li.lifestage03 a {
	background-image: url("../../img/lifestage/lifestage3_b.png");
}
.list_lifestage ul li.lifestage04 a {
	background-image: url("../../img/lifestage/lifestage4_b.png");
}
.list_lifestage ul li.lifestage05 a {
	background-image: url("../../img/lifestage/lifestage5_b.png");
}
.list_lifestage ul li.lifestage06 a {
	background-image: url("../../img/lifestage/lifestage6_b.png");
}
.list_lifestage ul li.lifestage07 a {
	background-image: url("../../img/lifestage/lifestage7_b.png");
}
.list_lifestage ul li.lifestage08 a {
	background-image: url("../../img/lifestage/lifestage8_b.png");
}

/* 分類 */
div[class*="life"] #content_header {
	display: none !important; /* ページIDを非表示 */
}

#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 0px 0px;
}
.life_cat_list:nth-child(2n) {
	margin-right: 0px;
}
.life_cat_list:nth-child(n+3) {
	margin-top: 30px;
}

#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カラム */
div[class*="life_list3"] .life_cat_list,
div[class*="life_list3"] .life_cat_list:nth-child(2n),
div[class*="life_list3"] .life_cat_list:nth-child(n+3) {
	width: 340px;
	margin: 0px 30px 0px 0px;
}
div[class*="life_list3"] .life_cat_list:nth-child(3n) {
	margin-right: 0px;
}
div[class*="life_list3"] .life_cat_list:nth-child(n+4) {
	margin-top: 30px;
}

/* 小分類 */
div[class*="life_list1"] #main_body > div {
	margin-bottom: var(--content-margin-normal, 40px);
}
div[class*="life_list1"] #main_body > div:last-child {
	margin-bottom: 0px;
}

/* サブカテゴリ */
#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 {
	display: inline-block;
	vertical-align: top;
	width: calc(50% - 15px);
	margin: 0px 30px 0px 0px;
}
.lifesub_cat_list:nth-child(2n) {
	margin-right: 0px;
}
.lifesub_cat_list:nth-child(n+3) {
	margin-top: 30px;
}

#main_body .lifesub_cat_list h2,
#main_body .lifesub_cat_list h3 {
	margin-top: 0px;
}

.lifesub_cat_list .info_list.info_list_date ul li {
	display: block;
}
.lifesub_cat_list .info_list.info_list_date ul li > span {
	display: block;
}
.lifesub_cat_list .info_list.info_list_date ul li > span.article_date {
	width: auto;
}

/* サブカテゴリ小 */
div[class*="kanren1"] .info_list ul li:last-child {
	margin-bottom: 15px;
}

/* 組織 */
div[class*="soshiki"] #content_header {
	display: none !important; /* ページIDを非表示 */
}

div[class*="soshiki_index"] #main_body > div {
	margin-bottom: var(--content-margin-normal, 40px);
}
div[class*="soshiki_index"] #main_body > div:last-child {
	margin-bottom: 0px;
}

#soshiki_hyouji,
div[class*="soshiki_index"] #main_body > div#soshiki_hyouji {
	margin: 30px 0px 15px;
}
#soshiki_hyouji 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: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
}
#soshiki_hyouji ul li {
	display: inline-block;
	vertical-align: top;
	margin: 0px 1em 15px 0px;
	padding-right: 1em;
	border-right: 1px solid;
	line-height: 1.25;
	font-size: var(--fontsize-main-small, 1.5rem);
}
#soshiki_hyouji ul li:last-child {
	margin-right: 0px;
	padding-right: 0px;
	border-right: none;
}

/* 部局 */
#freespace_bu,
#main_body div#freespace_bu {
	margin: var(--content-margin-narrow, 30px) 0px;
}
#freespace_bu p {
	margin: 0px 0px 1em;
}
#freespace_bu p:last-child {
	margin-bottom: 0px;
}

.kakuka_info_box {
	margin-bottom: var(--content-margin-normal, 40px);
}
.kakuka_contact_box > div:not(.kakuka_info_ttl) {
	margin-bottom: 0.5em;
}
.kakuka_contact_box > div:not(.kakuka_info_ttl):last-child {
	margin-bottom: 0px;
}

.kakuka_tel_list .grpname:has(span:empty) {
	display: none;
}

div[class*="soshiki_kakubu"] #main_body > div {
	margin-bottom: var(--content-margin-normal, 40px);
}
div[class*="soshiki_kakubu"] #main_body > div:last-child {
	margin-bottom: 0px;
}

/* 課室 */
#soshiki_pr_image {
	margin: var(--content-margin-narrow, 30px) 0px;
}
#soshiki_pr_image img {
	width: auto;
	max-width: 100%;
	height: auto;
	vertical-align: top;
}

#freespace_ka,
#main_body div#freespace_ka {
	margin: var(--content-margin-narrow, 30px) 0px;
}
#freespace_ka p {
	margin: 0px 0px 1em;
}
#freespace_ka p:last-child {
	margin-bottom: 0px;
}

#freespace2_ka p {
	margin: 0px 0px 1em;
}
#freespace2_ka p:last-child {
	margin-bottom: 0px;
}

.kakuka_view,
.side_box_txt > div.kakuka_view {
	max-width: 300px;
	margin-left: auto;
	margin-right: auto;
}
.kakuka_view img {
	width: 100%;
	height: auto;
	vertical-align: top;
}

.kakuka_contact_wrap .grpname_box {
	border-top: 1px solid;
	padding-top: 1em;
	margin-top: 1em;
}

.midashi_ka_detail {
	margin-bottom: var(--content-margin-normal, 40px);
}
.midashi_ka_detail:last-child {
	margin-bottom: 0px;
}

/* 新着情報 */
div[class*="soshiki_news"] img.icon_new {
	vertical-align: middle;
	margin-left: 0.5em;
}

/* 改ページ */
.page_num {
	margin: var(--content-margin-normal, 40px) 0px 0px;
	font-size: 1.8rem;
	letter-spacing: 0.2em;
}
.page_num_ttl {
	font-size: 1.6rem;
}
.page_num_view {
	font-size: 1.6rem;
	margin-top: 10px;
	letter-spacing: 0em;
}

/* ウェブブック */
#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 {
	display: inline-block;
	vertical-align: top;
	width: calc(50% - 15px);
	margin: 0px 30px 0px 0px;
}
.book_list_box:nth-child(2n) {
	margin-right: 0px;
}
.book_list_box:nth-child(n+3) {
	margin-top: 30px;
}

#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: 20px;
}
.book_list_box .book_info > div.book_thumb_img img {
	width: 100%;
	height: auto;
	vertical-align: top;
}

/* アンケート */
#main_body table.tbl_ques {
	width: 100%;
	margin: 0px;
	border-width: 2px;
}
#main_body table.tbl_ques caption {
	text-align: left;
}
#main_body table.tbl_ques th {
	font-weight: bold;
	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;
}
div[class*="question"] #main_body table.tbl_ques td input {
	display: block;
	margin: 0px;
	padding: 10px;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	width: 100%;
	max-width: none;
	min-width: auto;
}

div.q2 br {
	display: none;
}

div[class*="question_detail"] #main_body fieldset {
	border: none;
	margin: 0px 0px var(--content-margin-normal, 40px);
	padding: 0px;
}
div[class*="question_detail"] #main_body fieldset legend {
	display: block;
	width: 100%;
	margin: 0px;
	padding: 0px;
}
div[class*="question_detail"] #main_body fieldset label {
	margin-right: 1em;
}
div[class*="question_detail"] #main_body select {
	height: 2em;
}
div[class*="question_detail"] #main_body input[type="text"] {
	max-width: 100%;
	height: 2em;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	border: 1px solid #666666;
}
div[class*="question_detail"] #main_body textarea {
	width: 100%;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	border: 1px solid #666666;
}
div[class*="question_detail"] #main_body img {
	max-width: 100%;
	height: auto !important;
	vertical-align: top;
}
div[class*="question_detail"] #main_body form > img {
	margin-top: 1em;
	margin-bottom: 1em;
}
div[class*="question_detail"] #main_body div.detail_free > *:first-child {
	margin-top: 0px !important;
}
div[class*="question_detail"] #main_body div.detail_free > *:last-child {
	margin-bottom: 0px !important;
}

div[class*="confirm_quest_hankyou"] #hyouka_area_submit,
div[class*="question_detail"] #main_body form p[align="left"],
div[class*="question_detail"] #main_body form p[style="text-align:left;"] {
	text-align: center;
	margin: var(--content-margin-wide, 60px) 0px 0px;
	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: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
}

div[class*="question"] #main_body input[type="submit"],
div[class*="question"] #main_body input[type="button"] {
	display: inline-block;
	background: var(--btn-background, #e6e6e6);
	border: var(--btn-border, none);
	border-radius: var(--btn-borderradius, 0);
	-webkit-box-shadow: var(--btn-boxshadow, none);
	        box-shadow: var(--btn-boxshadow, none);
	color: var(--btn-color, #333333);
	text-decoration: var(--btn-textdecoration, none);
	font-size: var(--fontsize-main-small, 1.5rem);
	line-height: 2rem;
	margin: 0px 10px;
	padding: 15px 20px;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	width: 260px;
	max-width: calc(50% - 20px);
}
div[class*="question"] #main_body input[type="submit"]:hover,
div[class*="question"] #main_body input[type="button"]:hover,
div[class*="question"] #main_body input[type="submit"]:focus,
div[class*="question"] #main_body input[type="button"]:focus {
	background: var(--btn-hover-background, #e6e6e6);
	border: var(--btn-hover-border, none);
	border-radius: var(--btn-hover-borderradius, 0);
	-webkit-box-shadow: var(--btn-hover-boxshadow, none);
	        box-shadow: var(--btn-hover-boxshadow, none);
	color: var(--btn-hover-color, #333333);
	text-decoration: var(--btn-hover-textdecoration, underline);
}

/* アンケート結果グラフ */
#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%;
	margin: 0px;
	border-width: 2px;
}
#main_body table#mail_form_tbl caption {
	text-align: left;
}
#main_body table#mail_form_tbl th {
	width: 25%;
	text-align: left;
}
#main_body table#mail_form_tbl td {
	width: 75%;
}
#main_body table#mail_form_tbl td input[type="text"] {
	width: 100%;
	height: 2em;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	border: 1px solid #666666;
}
#main_body table#mail_form_tbl td input[type="text"]#mail_to,
#main_body table#mail_form_tbl td input[type="text"]#mail_to2 {
	width: 80%;
}
#main_body table#mail_form_tbl td textarea {
	width: 100%;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	border: 1px solid #666666;
}
#main_body table#mail_form_tbl td fieldset {
	border: none;
	margin: 0px;
	padding: 0px;
}

#mail_form_btn_wrap {
	text-align: center;
	margin: var(--content-margin-wide, 60px) 0px 0px;
	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: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
}
#mail_form_btn_wrap input[type="submit"] {
	display: inline-block;
	background: var(--btn-background, #e6e6e6);
	border: var(--btn-border, none);
	border-radius: var(--btn-borderradius, 0);
	-webkit-box-shadow: var(--btn-boxshadow, none);
	        box-shadow: var(--btn-boxshadow, none);
	color: var(--btn-color, #333333);
	text-decoration: var(--btn-textdecoration, none);
	font-size: var(--fontsize-main-small, 1.5rem);
	line-height: 2rem;
	margin: 0px 10px;
	padding: 15px 20px;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	width: 260px;
	max-width: calc(50% - 20px);
}
#mail_form_btn_wrap input[type="submit"]:hover,
#mail_form_btn_wrap input[type="submit"]:focus {
	background: var(--btn-hover-background, #e6e6e6);
	border: var(--btn-hover-border, none);
	border-radius: var(--btn-hover-borderradius, 0);
	-webkit-box-shadow: var(--btn-hover-boxshadow, none);
	        box-shadow: var(--btn-hover-boxshadow, none);
	color: var(--btn-hover-color, #333333);
	text-decoration: var(--btn-hover-textdecoration, underline);
}

#mail_form_btn_wrap p {
	width: 100%;
	margin: 1em 0px;
	font-size: var(--fontsize-main-small, 1.5rem);
}

/* googleカスタム検索結果 */
#main_body #cse_search_result table,
#main_body #cse_search_result table td,
#main_body .gsc-control-cse table,
#main_body .gsc-control-cse table td {
	border: none;
	margin: 0px;
}

.gsc-results .gsc-cursor-box .gsc-cursor-page {
	display: inline-block !important;
	vertical-align: top;
	margin: 0px 0px 5px;
	padding: 10px 15px;
	border: 1px solid #cccccc !important;
	background: #ffffff !important;
	color: #0066cc !important;
	font-size: 1.6rem;
}
.gsc-results .gsc-cursor-box .gsc-cursor-current-page {
	background: #f5f5f5 !important;
	color: #333333 !important;
}

/* 地図でさがす */
#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: 20px 20px 10px;
	list-style: none;
}
#shisetsu_list_link ul li {
	display: inline-block;
	vertical-align: top;
	margin: 0px 20px 10px 0px;
}

#shisetsu_map {
	border: 1px solid #cccccc;
}
#map_canvas {
	width: 100%;
	height: 500px;
}
#main_body #map_canvas table,
#main_body #map_canvas th,
#main_body #map_canvas td {
	margin: 0px;
	padding: 0px;
	border: none;
}

#map_canvas_detail {
	width: 100%;
	height: 400px;
}

#shisetsu_detail_wrap .shisetsu_detail_box {
	margin-bottom: 20px;
}

/* FAQ */
div[class*="faq_index"] .side_box_ttl h2 {
	font-size: 1.6rem;
}


/* ==================================================
タブレット
================================================== */
@media screen and (max-width: 1080px) {

}
/* ==================================================
タブレット ここまで
================================================== */




:root {
    --content-width: 100%;
    --fontsize-detail: 1.6rem;
}
#main{
    font-size: var(--fontsize-detail, 1.6rem);
    padding: 0 15px;
    width: calc(100% - 30px);
}
#main.main_l{
	padding-right: 0;
    width: calc(100% - var(--sidebar2-width, 300px) - 15px);
}
a:hover img, a:focus img {
    opacity: 1;
}	
#sp_page_index_link_wrap {
    display: none;
}
#pankuzu_wrap{
	background: none;
    width: calc(100% - 30px);
    padding: 20px 15px 10px;
    max-width: 1200px;
	margin: 0 auto;
}
#pankuzu_wrap > div{
	display: flex;
    gap: 0.5em 1em;
    padding-left: 0;
    margin: 0;
    flex-wrap: wrap;
    display: block;
    padding-left: calc(6em + 34px);
    position: relative;
}
#pankuzu_wrap .pankuzu_list{
	display: flex;
    flex-wrap: wrap;
    gap: 0.5em 1em;
    padding-left: 0;
}
#pankuzu_wrap .pankuzu_mark{
	color: #0077C0;
    display: inline-block;
    margin: 0 0.5em;
}
#pankuzu_wrap .pankuzu_class{
    display: inline;
}
#pankuzu_wrap a{
	color: #222;
}
.pankuzu:first-child .icon_current, #footstep_ttl{
    display: flex;
    width: auto;
    font-size: 1.6rem;
    position: initial;
    padding: 0 10px;
    background: #ECF5FC;
    color: #222;
    border-radius: 6px;
    align-items: center;
    display: inline-block;
    width: calc(6em + 20px);
    position: absolute;
    height: auto;
    line-height: 1.6;
}
#mymainback{
    align-items: flex-start;
}
#main_header h1{
	background: #0077C0;
	color: #fff;
	border-radius: 8px;
	font-size: 2.4rem;
    display: flex;
    gap: 16px;
    padding: 26px 18px;
}
#main_header h1:before{
	content: "";
	display: block;
	width: 5px;
    min-width: 5px;
	height: 1em;
	background: #fff;
	border-radius: 100px;
    margin-top: 0.25em;
}
.category_h1,
div[id^="main_header_life3_"]{
    background: #0077C0;
    color: #fff;
    margin: 0 0 1em;
    font-size: 4.0rem;
    font-weight: normal;
    padding: 1.2em 15px;
    margin-top: 30px;
    height: auto;
    width: calc(100% - 30px);
    margin-bottom: 0;
}
div[id^="main_header_life3_"] h1{
    margin: 0 auto;
    padding: 0 15px;
    width: calc(100% - 30px);
    max-width: 1200px;
}
.category_h1 span,
div[id^="main_header_life3_"] span{
	width: 100%;
	max-width: 1230px;
	margin: 0 auto;
    display: flex;
    text-shadow: none;
    font-size: 4.0rem;
    font-weight: normal;
}
#main_body a:link{
	color: #222;
}
#main_body  .text_r{
	text-align: right;
    margin-bottom: 30px;
}
#main_body h2{
	background: #ECF5FC;
	font-size: 2.2rem;
	border-radius: 8px;
    display: flex;
    gap: 16px;
    padding: 16px 12px;
    margin-top: 2.5em;
}
#main_body h2:before{
	content: "";
	display: block;
	width: 20px;
    min-width: 20px;
	height: 3px;
	background: #0077C0;
	border-radius: 100px;
    margin-top: 0.75em;
}
#main_header{
    margin-bottom: 1em;
}
#main_body h3, .kakuka_info_ttl, .life_cat_list_ttl{
    font-size: 1.8rem;
    background: none;
    border-bottom: 3px solid #D9D9D9;
    padding: 0 0 6px;
    position: relative;
    margin-top: 1.5em;
}
#main_body h3:after, .kakuka_info_ttl:after, .life_cat_list_ttl:after{
    position: absolute;
    content: " ";
    display: block;
    border-bottom: solid 3px #0077C0;
    bottom: -3px;
    width: 15%;
    left: 0;
}
#main_body h4{
	background: #e6e6e6;
    font-size: 1.8rem;
	padding: 14px 20px 13px;
}
#main_body h5{
	background: none;
    font-size: 1.8rem;
	padding: 0;
}
#main_body h6{
    background: none;
    border-bottom: 2px dashed #cdcdcd;
    font-size: 1.6rem;
    padding: 7px 0 6px;
}
#main_body > *:first-child,
#main_body #sp_headline_0 + h2,
#main_body #toc1 + h2{
    margin-top: 1em;
}
#main_body ul{
	padding: 0;
	list-style: none;
    margin: 1.2em 0;
}
#main_body ul li{
	padding-left: 18px;
	position: relative;
}
#main_body ul li + li{
    margin-top: 16px;
}
#main_body ul li:before{
    content: "";
    width: 8px;
    height: 8px;
    display: block;
    background: #0077C0;
    border-radius: 100%;
    position: absolute;
    left: 0;
    top: 0.7em;
}
#main_body .list_ccc ul li:before{
	content:none;
}
#main_body ul.furusato_btnList li + li{
    margin-top: 0;
}
#main_body ul.furusato_btnList li:before{
	content:none;
}
#main_body ul li a{
	color:#222;
	text-decoration: underline;
}
#main_body ul li a:hover{
	text-decoration: none;
}
#main_body .list_ccc ul{
	padding: 0;
	margin: 0;
	list-style: none;
}
#main_body .list_ccc ul li{
    display: flex;
    padding: 20px;
    border-bottom: 1px solid #cdcdcd;
    margin-bottom: 0;
}
#main_body .list_ccc ul li:first-child{
	padding-top: 0;
}
#main_body .list_ccc ul li .span_a,
#main_a .list_ccc ul li .article_date{
	color: #0077C0;
	font-weight: bold;
    width: 14em;
    min-width: 14em;
}
#main_body .list_ccc ul li a,
.list_type_a_list_box .list_ccc ul li .article_title a{
	color:#222;
	text-decoration: underline;
}
#main_body .list_ccc ul li a:hover,
.list_type_a_list_box .list_ccc ul li .article_title a:hover{
	text-decoration: none;
}
#main_body .nodot_list li{
    display: inline-block;
    vertical-align: top;
    margin: 0px 1em 1em 0px;
    padding-left: 0;
    padding-right: 1em;
    border-right: 1px solid;
    line-height: unset;
}
#main_body .nodot_list li:last-child{
    margin-right: 0px;
    padding-right: 0px;
    border-right: none;
}
#main_body .nodot_list li:before{
content: none;
}
#main_body table{
    width: 100%;
    border: 1px solid #d9d9d9;
    font-size: 1.6rem;
}
#main_body table caption{
	background: #0077C0;
	text-align: center;
	color: #fff;
    padding: 6px 10px;
}
#main_body table th{
    background: #ecf5fc;
    border: 1px solid #d9d9d9;
}
#main_body table td{
	background: #fff;
    border: 1px solid #d9d9d9;
}


#sidebar2 .sidebar1_box,
#sidebar2 .sidebar1_b{
	background: #0077C0;
    border-radius: 8px 8px 0 0;
    border: 1px solid #fff;
}
/*#kanren_info{
    padding: 0 10px 10px;
	background: none;
}*/
#sidebar2 .sidebar1_box,
#sidebar2 .sidebar1_b,
#sidebar2 .sidebar_border{
    padding: 0 10px 10px;
	background: #0077C0;
    border: 1px solid #fff;
}
#sidebar2 .subsite_menu{
    background: none;
    margin: 0;
}
#sidebar2 h2{
	background: none;
	color: #fff;
	font-size: 2.1rem;
    display: block;
    padding: 0;
    text-align: center;
    padding-top: 10px;
    margin-top: 0;
    margin-bottom: 0;
}
#sidebar2 .subsite_menu_list{
    margin-top: 10px;
}
#sidebar2 .sidebar1_b{
    color: #fff;
    font-size: 2.1rem;
    display: block;
    padding: 0;
    text-align: center;
    font-family: var(--fontfamily-bold, sans-serif);
    line-height: var(--lineheight-detail-midashi, 1.5);
    letter-spacing: var(--letterspacing-detail-midashi, 0.1em);
    font-weight: bold;
	margin: 0;
    padding: 0.83em 0;
}
#sidebar2 h3,
#sidebar1.soshiki_side h3{
	background: #ECF5FC;
	font-size: 1.6rem;
	display: flex;
    padding: 16px;
    gap: 10px;
    margin: 0;
    text-align: left;
}
#sidebar1.soshiki_side h3:before{
	content: "";
	background: #0077C0;
	width: 5px;
	height: 20px;
	display: block;
    margin-top: 0.2em;
}
#sidebar1.soshiki_side h3{
}
#sidebar2 ul,
#sidebar1.soshiki_side ul{
    margin: 0;
    background: #fff;
	text-align: left;
    padding: 16px;
    list-style: none;
}
#sidebar2 ul li{
    padding-left: 18px;
    margin-bottom: 20px;
    position: relative;
}
#sidebar2 ul li:last-child{
    margin-bottom: 0;
}
#sidebar2 ul li:before {
    content: "";
    width: 8px;
    height: 8px;
    display: block;
    background: #0077C0;
    border-radius: 100%;
    position: absolute;
    left: 0;
    top: 0.7em;
}
#sidebar2 ul li + li{
	margin-top: 0.3em;
}
#sidebar2 ul li a{
	color: #222;
}

#section_footer{
	background: #0077C0;
	border-radius: 8px 8px 0 0;
    padding: 20px 10px 10px;
    border: 1px solid #fff;
}
#section_footer_title{
    font-size: 2.0rem;
    color: #fff;
    margin-bottom: 20px;
}
#section_footer h2, #main_body #section_footer h2{
    color: #fff;
    font-weight: normal;
    font-size: 2.0rem;
    margin-bottom: 20px;
    margin-top: 0;
}
#section_footer_detail{
    background: #fff;
    padding: 20px;
}
#section_footer_name{
	background: #fff;
    padding: 20px 20px 0;
}
#section_footer_info{
	background: #fff;
    padding: 0 20px 20px;
}
#section_footer_info a{
	color:#222;
}

.system_box,
#hyouka_area_box{
    margin-top: 80px;
    padding: 0;
    background: none;
}
#hyouka_box_title,
#main_body #hyouka_area_box h2{
    background: #ECF5FC;
    font-size: 2.2rem;
    border-radius: 8px;
    display: flex;
    gap: 16px;
    padding: 16px 12px;
    margin-block: 1em;
}
#hyouka_box_title:before,
#main_body #hyouka_area_box h2:before{
    content: "";
    display: block;
    width: 20px;
    min-width: 20px;
    height: 3px;
    background: #0077C0;
    border-radius: 100px;
    margin-top: 0.75em;
}
.hyouka_box .hyouka_area_ans fieldset{
    border: none;
    padding: 0;
    margin: 0 0 1em;
}
.hyouka_box .hyouka_area_ans fieldset legend{
    font-weight: bold;
}
.hyouka_box input[type="submit"],
#hyouka_area_submit input,
div[class*="question"] #main_body input[type="submit"], div[class*="question"] #main_body input[type="button"]{
    border: 2px solid #9BBDD2;
    background: #ECF5FC;
    border-radius: 6px;
    padding: 4px 26px;
    margin-top: 1.5em;
    width: auto;
    line-height: 1.75;
}
div[class*="question"] #main_body input[type="button"]{
    border: 2px solid #d9d9d9;
    background: #ededed;
}

#main_header + .list_type_a_list_box{
	margin-top: 0;
}
.list_type_a_list_box{
    margin-top: 30px;
}
.list_type_a_title h2{
    background: #0077C0;
    font-size: 2.2rem;
    border-radius: 8px;
    display: flex;
    gap: 16px;
    padding: 16px 12px;
	color: #fff;
}
.list_type_a_title h2:before{
    content: "";
    display: block;
    width: 20px;
    min-width: 20px;
    height: 3px;
    background: #fff;
    border-radius: 100px;
    margin-top: 0.75em;
}
.list_type_a_list_box .list_ccc ul {
    padding: 0;
    margin: 0;
    list-style: none;
}
.list_type_a_list_box .list_ccc ul li{
    display: flex;
    padding: 20px;
    border-bottom: 1px solid #cdcdcd;
}
.list_type_a_list_box .list_ccc ul li:first-child{
	padding-top: 0;
}
.list_type_a_list_box .list_ccc ul li .span_aa {
    color: #0077C0;
    font-weight: bold;
    width: 14em;
    min-width: 14em;
}
.list_type_a_list_box .list_ccc ul li .span_b a{
	color: #222;
}
.list_type_a_list_box .text_d2,
#main_body .list_ccc .text_d3{
    display: flex;
    justify-content: flex-end;
    gap: 60px;
    margin-top: 30px;
}
#main_body .list_ccc .text_d3 a,
.list_type_a_list_box .text_d a,
.list_type_a_list_box .icon_rss a{
	color: #222;
}
#main_body .list_ccc .text_d3 a:after,
.list_type_a_list_box .text_d a:after,
.list_type_a_list_box .icon_rss a:after{
	content: "";
	width: 7px;
	height: 12px;
	display: inline-block;
    background: url("../../img/common/icon_arrow_blue.svg") no-repeat;
    margin-left: 10px;
}

#koukoku_side ul{
	margin: 0;
	padding: 0;
	display: flex;
	list-style: none;
    justify-content: space-between;
	gap: 25px;
}
#koukoku_side ul li{
    width: 50%;
}
#koukoku_side ul li a{
    background: #ECF5FC;
    display: flex;
    align-items: center;
    padding: 15px 25px;
    justify-content: space-between;
    color: #222;
    text-decoration: none;
    border: 1px solid #fff;
}
#koukoku_side ul li a:hover{
	text-decoration: underline;
}
#koukoku_side ul li span{
	font-size: 2.4rem;
    display: flex;
    gap: 16px;
    padding: 16px 12px;
    align-items: center;
}
#koukoku_side ul li span:before{
    content: "";
    display: block;
    width: 3px;
    min-width: 3px;
    height: 20px;
    background: #0077C0;
    border-radius: 100px;
}

#halfbox_wrap{
    display: flex;
    flex-wrap: wrap;
    gap: 50px 20px;
}
#halfbox_wrap .halfbox{
    width: calc((100% - 40px) / 3);
}
#halfbox_wrap .halfbox h3{
    background: #EFEFEF;
    border-radius: 8px;
    border: none;
    margin-top: 0;
    display: flex;
    align-items: center;
    padding: 12px 12px 12px 26px;
}
#halfbox_wrap .halfbox h3:after{
    top: 1em;
    position: absolute;
    content: " ";
    display: block;
    width: 2px;
    left: 12px;
    height: 1em;
    background: #0077C0;
    margin-top: -2px;
    bottom: initial;
}
#halfbox_wrap .halfbox .navigation ul{
	list-style: none;
    margin: 0;
}
#halfbox_wrap .halfbox .navigation ul li{
	list-style: none;
	padding-left: 0;
}
#halfbox_wrap .halfbox .navigation ul li + li{
    margin-top: 0;
}
#main_body #halfbox_wrap .halfbox .navigation ul li:before{
	content: none;
}
.detail_image_normal img{
	max-width: 100%;
}

#kanren_info{
    background: none;
    padding: 0;
}
#kanren_info .menu_list_c{
    margin-top: 10px;
}
#hyouka_area_box .hyouka_box_detail fieldset span:first-of-type{
    min-width: auto;
}

div#main_header_life3_2:before{
    background: #0077C0 url(../../img/common/icon_bunrui_kurashi.svg) no-repeat;
    background-size: 48px;
}
.side_box_list ul li {
	margin: 0px 0px 20px;
}
#sidebar1.soshiki_side{
    order: 12;
    padding-left: 15px;
    padding-right: 15px;
    width: calc(var(--sidebar2-width, 300px) - 45px);
}
#sidebar1.soshiki_side .side_box{
    padding: 0 10px 10px;
    background: #0077C0;
    border-radius: 8px 8px 0 0;
}
#sidebar1.soshiki_side .side_box_ttl h2{
    background: none;
    color: #fff;
    font-size: 2.1rem;
    display: block;
    padding: 0;
    text-align: center;
    padding-top: 0.83em;
    margin-top: 0;
}
#sidebar1.soshiki_side .side_box_list ul{
    margin: 0;
    background: #fff;
    text-align: left;
    padding: 16px;
    list-style: none;
    margin-top: 16px;
}
#sidebar1.soshiki_side .side_box_list h3 + ul{
    margin: 0;
}
#sidebar1.soshiki_side .side_box_list ul li{
    padding-left: 18px;
    position: relative;
}
#sidebar1.soshiki_side .side_box_list ul li:before{
    content: "";
    width: 8px;
    height: 8px;
    display: block;
    background: #0077C0;
    border-radius: 100%;
    position: absolute;
    left: 0;
    top: 0.7em;
}
#soshiki_hyouji ul li, div[class*="soshiki_index"] #main_body > div#soshiki_hyouji ul li{
    padding-left: 0;
}
#soshiki_hyouji ul li:before, div[class*="soshiki_index"] #main_body > div#soshiki_hyouji ul li:before{
content:none;
}
.pdf_download, .wmplayer_download{
display:none;
}
.section_information{
    margin-top: 40px;
    padding: 0;
    background: none;
}
.section_information h2{
    background: #0077C0;
    font-size: 2.2rem;
    border-radius: 8px;
    display: flex;
    gap: 16px;
    padding: 16px 12px;
    color: #fff;
    margin-block-start: 0.83em;
    margin-block-end: 0.83em;
}
.section_information h2:before{
    content: "";
    display: block;
    width: 20px;
    min-width: 20px;
    height: 3px;
    background: #fff;
    border-radius: 100px;
    margin-top: 0.75em;
}
.section_information_list_wrap ul{
    padding: 0;
    margin: 0;
    list-style: none;
}
.section_information_list_wrap ul li{
    display: flex;
    padding: 20px;
    border-bottom: 1px solid #cdcdcd;
    margin: 0;
}
.section_information_list_wrap ul li:first-child{
    padding-top: 0;
}
.section_information_list_wrap ul li .article_date{
    color: #0077C0;
    font-weight: bold;
    width: 14em;
    min-width: 14em;
}
.section_information_list_wrap ul li .article_title a{
    color: #222;
}
.section_information_list div.link_box{
    display: flex;
    justify-content: flex-end;
    gap: 60px;
    margin-top: 30px;
    padding: 0;
}
.section_information_list div.link_box span{
    margin: 0;
    width: auto;
    max-width: none;
}
.section_information_list div.link_box span a{
    line-height: initial;
    color: #222;
    padding: 0;
}
.section_information_list div.link_box a:after{
    content: "";
    width: 7px;
    height: 12px;
    display: inline-block;
    background: url(../../img/common/icon_arrow_blue.svg) no-repeat;
    margin-left: 10px;
}
.side_box_txt{
    background: #fff;
    text-align: left;
    padding: 16px;
    list-style: none;
    margin: 10px 0 0;
}
#kanren_info .kanren_box{
    margin: 10px 0 0;
}
#kanren_info div.link_ichiran,
.common_banner_link *[class*="common_banner_"]{
    display: none;
}
#main_body a span.externalicon{
    display: inline-block;
    line-height: 1;
    vertical-align: baseline;
    margin-left: 3px;
}
#main_body .info_list ul{
    padding: 0;
    margin: 0;
    list-style: none;
}
#main_body .info_list ul li{
    display: flex;
    padding: 20px;
    border-bottom: 1px solid #cdcdcd;
    margin-bottom: 0;
}
#main_body .info_list ul li + li{
    margin-top: 0;
}
#main_body .info_list ul li:before{
content:none;
}
#main_body .info_list ul li:first-child{
    padding-top: 0;
}
#main_body .info_list ul li .article_date{
    color: #0077C0;
    font-weight: bold;
    width: 14em;
    min-width: 14em;
}
#main_body .info_list ul li a{
    color: #222;
    text-decoration: underline;
}
.kakuka_contact_wrap .kakuka_grpname{
    color: #0077C0;
    font-weight: bold;
}
.kakuka_contact_wrap .kakuka_address a{
    color: #222;
}
.list_lifestage ul{
    background: #ECF5FC;
    padding: 20px;
    gap: 30px;
}
.list_lifestage ul li,
.list_lifestage ul li:nth-child(n+9){
    width: auto;
    margin: 0;
}
.list_lifestage ul li a{
    background-color: #fff;
    display: flex;
    flex-direction: column;
    background: #fff;
    align-items: center;
    padding: 19px;
    width: 130px;
    height: 110px;
    color: #222;
    text-decoration: none;
    box-sizing: unset;
}
#mail_form_btn_wrap input[type="submit"]{
    background: #2676be;
    color: #fff;
    border-radius: 8px;
    border: 2px solid #2676be;
}
#mail_form_btn_wrap input[type="submit"]:hover{
    border: 2px solid #2676be;
    border-radius: 8px;
    color: #222;
    background: #fff;
}
#section_footer_detail span{
    display: inline;
}
#subsite_h1{
    width: 100%;
    max-width: 1200px;
    margin: 20px auto 0;
    text-align: center;
    line-height: 1;
}
#subsite_h1 img{
    max-width: 100%;
}


.tdlife_contents{
    width: 100%;
    max-width: 880px;
    margin: 0 auto;
}
.tdlife_contents .tdlife_bg_top{
    width: calc(100% - 100px);
    display: flex;
    flex-wrap: wrap;
}
.tdlife_contents .tdlife_bg_top .tdlife_tit{
    width: 100%;
}
.tdlife_contents .tdlife_bg_top .tdlife_img01{
    float: none;
    margin: 20px 0 0;
    order: 3;
}
.tdlife_contents .tdlife_bg_top .tdlife_txt01{
    float: none;
    width: calc(100% - 380px);
}
.tdlife_contents .tdlife_bg_bottom{
    width: calc(100% - 100px);
    min-width: auto;
    display: flex;
}
.tdlife_contents .tdlife_appeal,
.tdlife_contents .tdlife_family{
    margin-top: 0;
    height: auto;
    float: none;
}
.subsite_menu_list div.link_ichiran{
    padding: 10px 0 0;
}
.subsite_menu_list div.link_ichiran a{
    background: #fff;
    border: 1px solid #fff;
    text-decoration: underline;
}
.subsite_menu_list div.link_ichiran a:hover{
    text-decoration: none;
}
.subs #hyouka_area_box{
    display: none;
}


#main_body .detail_free .navigation, #main_body .detail_free .navigation ul{
    display: block;
}
#main_body .detail_free .navigation ul li + li{
    margin-top: 0;
}
#main_body .detail_free .navigation ul li:before{
    top: 0.5em;
}

#main_body .detail_free :where(p,ul,ol) li + li{
    margin-top: 16px;
}