@charset "utf-8";

/* ------------------------------
 リンク
------------------------------ */
.cms_text a,
a.cms_inner_blank,
.cms_inner_blank a {
	font-weight: 600;
	display: inline;
	color: #218734;
	text-decoration: underline;
	background-color: transparent;
}
.cms_link:not(:last-child),
.cms_pdf:not(:last-child),
.cms_doc:not(:last-child),
.cms_xls:not(:last-child) {
	margin-bottom: 3px;
}
a.cms_link,
.cms_link a {
	font-size: 1.8rem;
	font-weight: 600;
	color: #333;
	text-decoration: none;
}
p.cms_link:not(.btn) a {
	font-size: 1.8rem;
	color: #333;
	text-decoration: none;
}
.red a.cms_link,
.cms_link.red a {
	color: #CC4625;
}
a.cms_pdf,
.cms_pdf a,
a.cms_doc,
.cms_doc a,
a.cms_xl,
.cms_xls a,
.cms_text a.cms_pdf,
.cms_text .cms_pdf a,
.cms_text a.cms_doc,
.cms_text .cms_doc a,
.cms_text a.cms_xl,
.cms_text .cms_xls a {
	color: #333;
	font-weight: 400;
	padding-left: 1.6em;
	text-indent: -1.6em;
	display: inline-block;
	text-decoration: underline;
}
a.cms_link::after,
.cms_link:not(.btn) a::after {
	content: "";
	display: inline-block;
	width: 28px;
	height: 28px;
	background: #218734 url(../img/arrow_right_w_s.svg) no-repeat center / 10px auto;
    vertical-align: middle;
	border-radius: 100%;
	margin: 0 0 0.2em 3px;
}
a.cms_link[href^="tel:"]::after {
	content: none;
}
.btn a.cms_link::after {
	border-radius: 0;
}
.red a.cms_link::after,
.cms_link.red:not(.btn) a::after {
	background-color: #CC4625;
}
/* PDF */
a.cms_pdf::before,
.cms_pdf a::before {
	content: "";
	display: inline-block;
	width: 20px;
	height: 22px;
	background: url(../img/icon_pdf.png) no-repeat center / cover;
    vertical-align: middle;
	margin: 0 5px 0.2em 0;
}
/* Word */
a.cms_doc::before,
.cms_doc a::before {
	content: "";
	display: inline-block;
	width: 20px;
	height: 22px;
	background: url(../img/icon_doc.png) no-repeat center / cover;
    vertical-align: middle;
	margin: 0 5px 0.2em 0;
}
/* Excel */
a.cms_xls::before,
.cms_xls a::before {
	content: "";
	display: inline-block;
	width: 20px;
	height: 22px;
	background: url(../img/icon_xls.png) no-repeat center / cover;
    vertical-align: middle;
	margin: 0 5px 0.2em 0;
}
/* PPT */
/*
a.cms_ppt,
.cms_ppt a {
	display: inline-block;
	padding-left: 25px;
	background: url(../img/icon_ppt.png) no-repeat 0 2px / 20px 25px;
	color: #000;
}
.cms_pdf a.cms_blank,
.cms_doc a.cms_blank,
.cms_xls a.cms_blank,
.cms_ppt a.cms_blank {
	background: none;
}
*/
/* target="_blank" */
a.cms_inner_blank::after,
.cms_inner_blank a::after,
.header a[target="_blank"]::after,
.footerTop .footerMenu ul li a[target="_blank"]::after,
.localnavi ul li a[target="_blank"]::after {
	content: "";
	display: inline-block;
	width: 14px;
    height: 14px;
	background: url(../img/icon_blank.svg) no-repeat center / cover;
    vertical-align: middle;
	margin: 0 0 3px 5px;
}
a.cms_inner_blank::after,
.cms_inner_blank a::after {
	margin: 0 5px 3px;
}
.cms_link:not(.btn) a.cms_blank::after {
	width: 28px;
	height: 28px;
	background: #218734 url(../img/icon_blank_w_s.svg) no-repeat center / 12px auto;
}
/* リストアイコン */
.cms_link.list a::after {
	background: url(../img/icon_list_c.svg) no-repeat center / cover;
}
/* ページ内リンク */
.pl:not(.btn) a.cms_link::after,
.cms_link:not(.btn).pl a::after {
	background: #218734 url(../img/arrow_right_w_s.svg) no-repeat center / 10px auto;
	transform: rotate(90deg);
}
/* ブランクリンク */
a.cms_link[target="_blank"]::after,
.cms_link:not(.btn) a[target="_blank"]::after {
	width: 28px;
	height: 28px;
	background: #218734 url(../img/icon_blank_w_s.svg) no-repeat center / 12px auto;
}
/* ダウンロードアイコン */
.cms_link.dl a::before,
.cms_pdf.dl a::before,
.cms_doc.dl a::before,
.cms_xls.dl a::before {
	content: none !important;
}
.cms_link.dl:not(.btn) a::after,
.cms_pdf.dl:not(.btn) a::after,
.cms_doc.dl:not(.btn) a::after,
.cms_xls.dl:not(.btn) a::after {
	content: "";
	display: inline-block;
	width: 28px;
	height: 28px;
	background: #218734 url(../img/icon_dl_w_s.svg) no-repeat center top 6px / 13px auto;
	vertical-align: middle;
	margin: 0 0 0.2em 3px;
}
@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;
	}
}
/* ------------------------------
 リンク（SP）
------------------------------ */
@media screen and (max-width: 767px) {
	a.cms_link:not([href^="tel:"]),
	.cms_link a,
	a.cms_pdf,
	.cms_pdf a,
	a.cms_doc,
	.cms_doc a,
	a.cms_xl,
	.cms_xls a {
		font-size: 1.7rem;
	}
	a.cms_link::after,
	.cms_link a::after {
		width: 28px;
		height: 28px;
	}
	/* target="_blank" */
	.cms_link:not(.btn) a.cms_blank::after {
		width: 28px;
		height: 28px;
	}
	/* ダウンロードアイコン */
	.cms_link.dl a::after,
	.cms_pdf.dl a::after,
	.cms_doc.dl a::after,
	.cms_xls.dl a::after {
		width: 28px;
		height: 28px;
	}
}

/* ----------------------------------------------
	■回り込み
------------------------------------------------- */
* + .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: 100px;
	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: 40px;
}
.cms_text {
	margin-bottom: 40px;
}
.cms_fl {
	float: left;
}
.cms_fr {
	float: right;
}
.cms_caption_t,
.cms_caption_b {
	font-size: 1.6rem;
}
.cms_caption_t {
	margin-bottom: 10px;
}
.cms_caption_b {
	margin-top: 10px;
}
/* h2が最初にある場合上の空きを広げる */
.cms_image:has(h2:first-child) .cms_caption_b {
	margin-top: 40px;
}
.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 #C2C2C2;
}

/* ----------------------------------------------
 ■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 {
		margin-bottom: 60px;
	}
	.cms_image {
		text-align: center;
		margin-bottom: 30px;
	}
	.cms_image .cms_caption_t,
	.cms_image .cms_caption_b {
		text-align: left;
	}
	.cms_text {
		margin-bottom: 30px;
	}
	.cms_fl {
		float: none !important;
	}
	.cms_fr {
		float: none !important;
	}
	.cms_caption_t,
	.cms_caption_b {
		font-size: 1.5rem;
	}
	.cms_caption_t {
		margin-bottom: 5px;
	}
	.cms_caption_b {
		margin-top: 10px;
	}
	/* h2が最初にある場合上の空きを広げる */
	.cms_image:has(h2:first-child) .cms_caption_b {
		margin-top: 20px;
	}
	#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;
	}
}