@charset "utf-8";
/* ------------------------------
 リンク
------------------------------ */
.cms_block a,
a.cms_link, .cms_link a,
a.cms_inner_blank, .cms_inner_blank a,
a.cms_pdf, .cms_pdf a,
a.cms_doc, .cms_doc a {
    color: #f17361;
}
.cms_block a::before,
a.cms_link::before, .cms_link a::before,
a.cms_pdf::before, .cms_pdf a::before {
    content: "";
    display: inline-block;
    width: 21px;
    height: 21px;
	vertical-align: middle;
    background: url(../img/icon_link.svg) no-repeat;
	margin-right: 5px;
	margin-bottom: 4px;
}

/* pdfリンク */
a.cms_pdf,
.cms_pdf a {
	margin-left: 0;
    padding-left: 0;
	background: none;
}
a.cms_pdf::after, .cms_pdf a::after,
a[target="_blank"].cms_pdf::after,
.cms_pdf a[target="_blank"]::after {
	content: "";
    display: inline-block;
    width: 18px;
    height: 20px;
	vertical-align: middle;
	background: none;
    background: url(../img/icon_pdf.svg) no-repeat;
	margin-left: 5px;
	margin-bottom: 5px;
}
a.cms_pdf,
.cms_pdf a {
	display: block;
	text-indent: -26px;
	margin-left: 26px;
}
a.cms_pdf::before,
.cms_pdf a::before {
	margin-bottom: 3px;
}
.cms_pdf + .cms_pdf {
	margin-top: 25px;
}

.cms_pdf a.cms_blank ,
.cms_doc a.cms_blank ,
.cms_ppt a.cms_blank ,
.cms_xls a.cms_blank {
    background: none;
}

br + .cms_inner_blank.cms_link,
br + .cms_blank.cms_link {
	padding-left: 0;
}
br + .cms_inner_blank.cms_link:before,
br + .cms_blank.cms_link:before {
	display: 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: 80px;
	margin-left: auto;
	margin-right: auto;
}

.cms_block:last-child,
.cms_text:last-child,
.cms_image:last-child  {
	margin-bottom: 0;
}

.cms_image {
	margin-bottom: 40px;
}

.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 {
    margin-left: 0;
}
.cms_cf+
.cms_cf {
    margin-top: -.75em;
}

.cms_text p + p {
    margin-top: .8em;
}


/* ----------------------------------------------
	■配置
------------------------------------------------- */
.cms_center {
    text-align: center;
}
.cms_left {
    text-align: left;
}
.cms_right {
    text-align: right;
}

.cms_center .cms_caption_b,
.tal .cms_caption_b {
    text-align: left;
}
.tac .cms_caption_b {
    text-align: center !important;
}
.tar .cms_caption_b {
    text-align: right !important;
}


/* ----------------------------------------------
	■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: 40px;
		z-index: 2;
	}
	
	.cms_image {
		text-align: center;
		margin-bottom: 25px;
	}

	.cms_text {
		margin-bottom: 25px;
	}
	.cms_fl {
	    float: none !important;
	    margin-right: 0;
	    margin-bottom: 15px;
	}
	.cms_fr {
	    float: none !important;
	    margin-bottom: 15px;
	    margin-left: 0;
	}
	#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;
    }
}
