@charset "utf-8";
/* ------------------------------
 リンク
------------------------------ */
.cms_link a,
a.cms_link {
	display: inline-block;
	color: #004097;
	font-weight: 500;
	text-decoration: none;
}
.cms_link a:not([target="_blank"])::after,
a.cms_link:not([target="_blank"])::after {
	content: "";
	display: inline-block;
	width: 6px;
	height: 6px;
	margin: 0 0 3px .3em;
	border: 0;
	border-top: solid 2px #004097;
	border-right: solid 2px #004097;
	transform: rotate(45deg);
	vertical-align: middle;
}
.cms_link a[target="_blank"]::after,
a.cms_link[target="_blank"]::after {
	content: "";
	display: inline-block;
	width: 12px;
	height: 12px;
	margin-left: .3em;
	background: url(/shared/img/icon_blank_s.svg) no-repeat 0 0 / cover;
}
.cms_link a:hover,
a.cms_link:hover {
	text-decoration: underline;
}
.cms_link + .cms_link {
	margin-top: 10px;
}
.linkBlockLower .cms_link + .cms_link,
.pageLink .cms_link + .cms_link,
.btnBox .cms_link + .cms_link,
.flexBox.div2 .cms_link + .cms_link {
	margin-top: 0;
}
/* 資料 */
a.cms_pdf,
.cms_pdf a,
a.cms_doc,
.cms_doc a,
a.cms_xls,
.cms_xls a,
a.cms_ppt,
.cms_ppt a {
	display: inline-block;
	font-weight: 500;
}
/* PDF */
a.cms_pdf::after,
.cms_pdf a::after {
	content: "";
	display: inline-block;
	width: 24px;
	height: 30px;
	margin-left: .5em;
	background: url(/shared/img/icon_pdf.svg) no-repeat 0 0 / cover;
	vertical-align: top;
}
.cms_pdf + .cms_pdf,
.cms_pdf + .cms_doc,
.cms_doc + .cms_pdf {
	margin-top: 10px;
}
.btnBox .cms_pdf + .cms_pdf {
	margin-top: 0;
}
/* Word */
a.cms_doc::after,
.cms_doc a::after {
	content: "";
	display: inline-block;
	width: 24px;
	height: 30px;
	margin-left: .5em;
	background: url(/shared/img/icon_doc.svg) no-repeat 0 0 / cover;
	vertical-align: top;
}
/* Excel */
a.cms_xls::after,
.cms_xls a::after {
	content: "";
	display: inline-block;
	width: 24px;
	height: 30px;
	margin-left: .5em;
	background: url(/shared/img/icon_xls.svg) no-repeat 0 0 / cover;
	vertical-align: top;
}
/* PPT */
a.cms_ppt::after,
.cms_ppt a::after {
	content: "";
	display: inline-block;
	width: 24px;
	height: 30px;
	margin-left: .5em;
	background: url(/shared/img/icon_ppt.svg) no-repeat 0 0 / cover;
	vertical-align: top;
}
/* _blank */
.cms_pdf a.cms_blank,
.cms_doc a.cms_blank,
.cms_xls a.cms_blank,
.cms_ppt a.cms_blank {
	background: none;
}
.cms_inner_blank::after,
.cms_blank::after,
.cms_menu_blank::after {
	content: "";
	display: inline-block;
	position: static;
	width: 12px;
	height: 12px;
	margin-left: .3em;
	border: none;
	background: url(/shared/img/icon_blank_s.svg) no-repeat 0 0 / cover;
	transform: none;
}
@media print, screen and (min-width: 768px) {
	a.cms_link:hover,
	.cms_link a:hover,
	a.cms_pdf:hover,
	.cms_pdf a:hover,
	a.cms_doc:hover,
	.cms_doc a:hover,
	a.cms_xls:hover,
	.cms_xls a:hover,
	a.cms_ppt:hover,
	.cms_ppt a:hover {
		text-decoration: underline;
	}
}

/* ----------------------------------------------
	■回り込み
------------------------------------------------- */
* + .cms_cf,
.cms_block:after,
.cms_clear_before {
	display: block;
	clear: both;
	content: '';
}
.cms_cf:after {
	display: block;
	clear: both;
	content: '';
}
.cms_clear {
	clear: both;
}
.cms_clear_block {
	font-size: 0 !important;
	line-height: 0 !important;
	clear: both !important;
	width: 0 !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
}

/* ----------------------------------------------
	■マージン
------------------------------------------------- */
.cms_block {
	margin-bottom: 120px;
	margin-left: auto;
	margin-right: auto;
}
.mainContents .cms_block {
	margin-bottom: 80px;
}
.cms_block:last-child,
.mainContents .cms_block:last-child,
.cms_text:last-child,
.cms_image:last-child {
	margin-bottom: 0 !important;
}
.cms_image {
	margin-bottom: 40px;
}
.cms_image.cms_fl,
.cms_image.cms_fr  {
	text-align: left;
}
.cms_text {
	margin-bottom: 40px;
}
.cms_fl {
	/* margin-right: 24px; */
	float: left;
}
.cms_fr {
	/* margin-left: 24px; */
	float: right;
}
.cms_caption_t {
	margin-bottom: 10px;
}
.cms_caption_b {
	margin-top: 10px;
}
.fl + .fr,
.cms_fl + .cms_fr,
.cms_fl + .fr,
.fl + .cms_fr {
	margin-left: 0;
}
.cms_cf + .cms_cf {
	margin-top: -.75em;
}
/* .cms_text p + p {
	margin-top: .875em;
} */

/* ----------------------------------------------
 ■配置
------------------------------------------------- */
.cms_center {
	text-align: center;
}
.cms_left {
	text-align: left;
}
.cms_right {
	text-align: right;
}
.cms_center .cms_caption_t,
.tal .cms_caption_t,
.cms_center .cms_caption_b,
.tal .cms_caption_b {
	text-align: left;
}
.tac .cms_caption_t,
.tac .cms_caption_b {
	text-align: center !important;
}
.tar .cms_caption_t,
.tar .cms_caption_b {
	text-align: right !important;
}

/* ----------------------------------------------
 ■ボーダー
------------------------------------------------- */
img.cms_border {
	border: solid 1px #b5b5b6;
}

/* ----------------------------------------------
 ■PDFダウンロード
------------------------------------------------- */
.adobebox {
	padding: 25px 28px;
	border: solid 1px #dcdcdc;
}
.adobebox .tleft {
	overflow: hidden;
}
.adobebox .imgright {
	float: right;
	width: 115px;
	margin-left: 10px;
}

/* -------------------------------------------
 ■now loading
---------------------------------------------- */
#now_loading {
	z-index: 9998;
	width: 60px;
	height: 60px;
	padding: 10px;
	padding: 10px;
	opacity: .75;
	border-radius: 15px;
	background-color: #e0e0e0;
}
#now_loading img {
	width: 100%;
	height: 100%;
}

/* ------------------------------
 タブレット・スマホ用コード
------------------------------ */
@media screen and (max-width: 767px) {
	.cms_block,
	.mainContents .cms_block {
		margin-bottom: 55px;
	}
	.cms_image {
		margin-bottom: 25px;
		/* text-align: center; */
	}
	.cms_text {
		margin-bottom: 25px;
	}
	.cms_fl {
		float: none !important;
		margin-bottom: 25px;
		/* margin-right: 0; */
	}
	.cms_fr {
		float: none !important;
		margin-bottom: 25px;
		/* margin-left: 0; */
	}
	.cms_caption_t {
		margin-bottom: 5px;
		text-align: left;
	}
	.cms_caption_b {
		margin-top: 5px;
		text-align: left;
	}
	/* 新着情報 */
	.mainContents .cms_image.cms_fl,
	.mainContents .cms_image.cms_fr  {
		text-align: center !important;
	}
	#now_loading {
		width: 40px;
		height: 40px;
	}
}
@media screen and (max-width:640px) {
	#now_loading img {
		margin-left: 0 !important;
	}
	#now_loading {
		position: fixed;
		top: 50%;
		left: 50%;
		z-index: 9998;
		width: 75px;
		height: 75px;
		margin: 0 0 0 -13%;
		padding-top: 10px;
		padding-right: 7px;
		padding-left: 7px !important;
		opacity: .5;
		border-radius: 15px;
		background-color: #e0e0e0;
	}
}