@charset "utf-8";

/* ------------------------------
 リンク
------------------------------ */
/* PDF・ワード・パワーポイント・エクセル */
a.cms_pdf,
.cms_pdf a,
a.cms_doc,
.cms_doc a,
a.cms_ppt,
.cms_ppt a,
a.cms_xls,
.cms_xls a {
	display: inline-block;
	color: #000;
	font-size: 1.8rem;
	font-weight: bold;
}
a.cms_pdf::after,
.cms_pdf a::after,
a.cms_doc::after,
.cms_doc a::after,
a.cms_ppt::after,
.cms_ppt a::after,
a.cms_xls::after,
.cms_xls a::after {
	content: "";
	display: inline-block;
	width: 25px;
	height: 25px;
	margin: 0 0 3px 6px;
	border-radius: 50%;
	background: #00a0e9 url(../img/icon_download.svg) no-repeat 7px 7px / 11px 10px;
	vertical-align: middle;
}
.cms_pdf a.cms_blank,
.cms_doc a.cms_blank,
.cms_ppt a.cms_blank,
.cms_xls a.cms_blank {
	background: none;
}
/* リンク */
.cms_link a {
	display: inline-block;
	/* color: #000; */
	font-size: 1.8rem;
	font-weight: bold;
}
.cms_block .cms_link:not(.btn) a:not([target="_blank"])::after {
	content: "";
	display: inline-block;
	width: 30px;
	height: 30px;
	margin: 0 0 3px 6px;
	border-radius: 50%;
	background: #1f1f1f url(../img/icon_arrow_link_sp.svg) no-repeat 10px 11px / 12px 6px;
	vertical-align: middle;
}
.cms_block .cms_link:not(.btn) a[target="_blank"]::after {
	content: "";
	display: inline-block;
	width: 30px;
	height: 30px;
	margin: 0 0 3px 6px;
	border-radius: 50%;
	background: #1f1f1f url(../img/icon_blank_small.svg) no-repeat 10px 8px / 12px 12px;
	vertical-align: middle;
}
.cms_link + .cms_link,
.cms_pdf + .cms_pdf,
.cms_doc + .cms_doc,
.cms_ppt + .cms_ppt,
.cms_xls + .cms_xls,
.cms_link + .cms_pdf {
	margin-top: 10px;
}
.cms_link.btn + .cms_link.btn {
	margin-top: 20px;
}
.linkBlockLower .cms_link + .cms_link,
.pageLink .cms_link + .cms_link,
.btnBox .cms_link + .cms_link,
.flexBox.div2 .cms_link + .cms_link {
	margin-top: 0;
}
@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: none;
	}
}

/* ----------------------------------------------
	■回り込み
------------------------------------------------- */
* + .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;
}
.cms_block:last-child,
.cms_text:last-child,
.cms_image:last-child {
	margin-bottom: 0 !important;
}
.cms_image {
	margin-bottom: 70px;
}
.cms_image.cms_fl,
.cms_image.cms_fr  {
	text-align: left;
}
.cms_text {
	margin-bottom: 70px;
}
.cms_text.b1 {
	margin-bottom: 1.75em;
}
.cms_fl {
	float: left;
}
.cms_fr {
	float: right;
}
.cms_caption_t {
	margin-bottom: 20px;
}
.cms_caption_b {
	margin-top: 10px;
	position: relative;
	padding-left: 15px;
}
.cms_caption_t::before,
.cms_caption_b::before {
	content: "";
	display: inline-block;
	position: absolute;
	top: 10%;
	left: 0;
	width: 5px;
	height: 80%;
	background-color: #00a0e9;
}
.fl + .fr,
.cms_fl + .cms_fr,
.cms_fl + .fr,
.fl + .cms_fr {
	margin-left: 0;
}
.cms_cf + .cms_cf {
	margin-top: -.75em;
}

/* ----------------------------------------------
 ■配置
------------------------------------------------- */
.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 #c4cbd4;
}

/* ----------------------------------------------
 ■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_link a {
		font-size: 1.6rem;
	}
	.cms_block .cms_link:not(.btn) a:not([target="_blank"])::after {
		width: 26px;
		height: 26px;
		margin: 0 0 3px 6px;
		background: #1f1f1f url(../img/icon_arrow_link_sp.svg) no-repeat 8px 9px / 12px 6px;
	}
	.cms_block {
		margin-bottom: 70px;
	}
	.cms_image {
		margin-bottom: 40px;
	}
	.cms_text {
		margin-bottom: 40px;
	}
	.cms_fl {
		float: none !important;
		margin-bottom: 40px;
	}
	.cms_fr {
		float: none !important;
		margin-bottom: 40px;
	}
	#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;
	}
}