@charset "utf-8";
/* ===============================================================
 common contents
=============================================================== */

body #eNomixBannerInner {
	visibility: hidden !important;
}

body.has-chat #popup_bnr {
	display: none;
}

body.show-chat #eNomixBannerInner {
	visibility: visible !important;
}

#wrapper {
	min-width: 1040px;
	box-sizing: border-box;
}

#wrapper * {
	box-sizing: inherit;
}

#main {
	display: block;
	padding-top: 150px;
}

#main_wrap {
	float: left;
	width: 720px;
}

.conts_in {
	width: 1000px;
	margin: auto;
}

.lead_area {
	margin-bottom: 40px;
}

.section {
	margin-bottom: 80px;
}

.section_in {
	margin-bottom: 50px;
}

.section_in .section_in {
	margin-bottom: 30px;
}

.section:last-child,
.section_in:last-child,
.section_in .section_in:last-child {
	margin-bottom: 0;
}

#wrapper.popup_content {
	min-width: 760px;
}

.popup_content #main {
	padding-top: 0;
}

.popup_content .conts_in {
	width: 760px;
}

.popup_content #footer .sp_acc_wrap,
.popup_content #footer #page_top,
.popup_content #footer .info_btn_list {
	display: none;
}

.popup_content #footer {
	border-top: 0;
	margin-top: 60px;
}

.popup_content #footer .site_menu {
	margin-top: 0;
}

.chat-frame {
	position: fixed;
	bottom: 5px;
	right: 20px;
	max-width: 50vw;
	z-index: 300;
	display: none;
}

.chat-frame img {
	max-width: 100%;
	width: 240px;
	filter: drop-shadow(1px 2px 3px rgba(0, 0, 0, .5));
}

.chat-frame.chat-frame-show {
	display: inline-block;
}

.chat-frame a {
	width: 100%;
	height: 100%;
	display: inline-block;
	cursor: pointer;
	position: relative;
}

.chat-frame a:hover {
	top: -2px;
}

.chat-frame .chat-banner-close {
	display: inline-block;
	position: absolute;
	width: 10%;
	height: 20%;
	max-width: 15px;
	max-height: 15px;
	top: -2%;
	right: -2%;
	line-height: 1;
	cursor: pointer;
	background-color: #616161;
	border-radius: 100%;
	border: solid 6px #616161;
	box-sizing: content-box !important;
}

.chat-frame .chat-banner-close::before,
.chat-frame .chat-banner-close::after {
	content: "";
	width: 2px;
	height: 100%;
	position: absolute;
	top: 1px;
	display: inline-block;
	background-color: #ffffff;
	transform-origin: center center;
}

.chat-frame .chat-banner-close::before {
	transform: rotate(45deg) translateX(-50%);
	left: calc(50% + 1px);
}

.chat-frame .chat-banner-close::after {
	transform: rotate(-45deg) translateX(50%);
	right: calc(50% - 1px);
}


@media print, screen and (min-width: 768px) {
	.sp_only {
		display: none !important;
	}

	#wrapper {
		position: static !important;
		margin: auto;
	}

	.chat-frame {
		right: 80px;
		bottom: 20px;
	}

	.chat-frame.fixed {
		bottom: 0;
	}

	.chat-frame .chat-banner-close {
		right: 1%;
	}

}

@media screen and (max-width: 767px) {
	.pc_only {
		display: none !important;
	}

	body {
		font-size: 14px;
	}

	#wrapper {
		min-width: 100%;
		left: 0;
		right: 0;
	}

	#main {
		padding-top: 60px;
	}

	#main_wrap {
		float: none;
		width: 100%;
	}

	.conts_in {
		width: 100%;
	}

	.sp_conts_in {
		width: 92%;
		margin: auto;
	}

	.lead_area {
		margin-bottom: 30px;
	}

	.section {
		margin-bottom: 40px;
	}

	.section_in {
		margin-bottom: 30px;
	}

	.section_in .section_in {
		margin-bottom: 20px;
	}

	#wrapper.popup_content {
		min-width: 1px;
	}

	.popup_content .conts_in {
		width: 100%;
	}
}

.op:hover {
	opacity: 0.7;
}

/* ===============================================================
 title
=============================================================== */
.ttl_main_wrap {
	background-color: #4d4d4d;
	padding: 13px 0 14px;
	margin-bottom: 50px;
}

.ttl_main_wrap .ttl_main {
	color: #fff;
	font-size: 30px;
	line-height: 1.3;
}

.ttl_bg_wrap {
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	height: 370px;
	position: relative;
	margin-bottom: 100px;
}

.ttl_bg_wrap.bg_a {
	background-image: url(/supply/images/index_mv.jpg);
}

.ttl_bg_wrap.bg_b {
	background-image: url(/technology/images/index_mv.jpg);
}

.ttl_bg_wrap.bg_c {
	background-image: url(/consignment/images/index_mv.jpg);
}

.ttl_bg_wrap.bg_d {
	background-image: url(/application/images/index_mv.jpg);
}

.ttl_bg_wrap.bg_e {
	background-image: url(/corporate/images/index_mv.jpg);
}

.ttl_bg_wrap.bg_f {
	background-image: url(/teiden-info/images/index_mv.jpg);
}

.ttl_bg_wrap.bg_h {
	background-image: url(/denkiyoho/images/index_mv.jpg);
}

.ttl_bg_wrap.bg_i {
	background-image: url(/faq/images/index_mv.jpg);
}

.ttl_bg_wrap.bg_j {
	background-image: url(/inquiry/images/index_mv.jpg);
}

.ttl_bg_wrap.bg_k {
	background-image: url(/others/images/index_mv.jpg);
}

.ttl_bg_wrap .ttl_main_bg {
	position: absolute;
	background-color: rgba(0, 0, 0, 0.4);
	left: 0;
	bottom: 0;
	width: 100%;
	padding: 20px 0;
}

.ttl_bg_wrap .ttl_main {
	color: #fff;
	font-size: 36px;
	line-height: 1.3;
}

.ttl_bdr_l {
	font-weight: bold;
	font-size: 22px;
	line-height: 1.3;
	border-left: 4px solid #e60012;
	padding: 6px 0 6px 18px;
	margin-bottom: 35px;
}

.ttl_bdr_l_box {
	display: flex;
	align-items: center;
	margin-bottom: 35px;
}

.ttl_bdr_l_box .ttl_bdr_l {
	margin-bottom: 0;
}

.ttl_bdr_l_box .btn_red {
	margin-left: 30px;
}

.ttl_bdr_b {
	font-weight: bold;
	font-size: 20px;
	line-height: 1.3;
	border-bottom: 1px solid #4d4d4d;
	padding: 0 0 15px;
	margin-bottom: 20px;
}

.ttl_bold {
	font-weight: bold;
	font-size: 20px;
	line-height: 1.3;
	margin-bottom: 15px;
}

.ttl_bold_s {
	font-weight: bold;
	font-size: 18px;
	line-height: 1.3;
	margin-bottom: 10px;
}

.ttl_list_btn {
	background-color: #f2f2f2;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	padding: 15px;
	font-size: 20px;
	line-height: 1.3;
}

@media screen and (max-width: 767px) {
	.ttl_main_wrap {
		padding: 14px 4%;
		margin-bottom: 30px;
	}

	.ttl_main_wrap .ttl_main {
		font-size: 20px;
	}

	.ttl_bg_wrap {
		height: 230px;
		margin-bottom: 40px;
	}

	.ttl_bg_wrap .ttl_main_bg {
		position: absolute;
		background-color: rgba(0, 0, 0, 0.4);
		right: 0;
		top: 0;
		padding: 0;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
	}

	.ttl_bg_wrap .ttl_main {
		font-size: 22px;
		padding: 0 4%;
	}

	.ttl_bdr_l {
		font-size: 18px;
		padding: 5px 0 5px 15px;
		margin-bottom: 25px;
	}

	.ttl_bdr_b {
		font-size: 18px;
		padding: 0 0 10px;
	}

	.ttl_bold {
		font-size: 17px;
	}

	.ttl_bold_s {
		font-size: 16px;
	}

	.ttl_bdr_l_box {
		justify-content: space-between;
	}

	.ttl_bdr_l_box .btn_red {
		margin-left: 10px;
	}
}

/* ===============================================================
 links
=============================================================== */
.link_def {
	text-decoration: underline;
}

.link_red {
	color: #e60012;
	text-decoration: underline;
}

.link_def:hover,
.link_red:hover {
	text-decoration: none;
}

.link_arw_r,
.link_arw_l,
.link_arw_d,
.link_blank,
.link_popup,
.link_download,
.link_pdf,
.link_word,
.link_excel,
.link_ppt,
.link_csv {
	text-decoration: underline;
}

.link_arw_r:hover,
.link_arw_l:hover,
.link_arw_d:hover,
.link_blank:hover,
.link_popup:hover,
.link_download:hover,
.link_pdf:hover,
.link_word:hover,
.link_excel:hover,
.link_ppt:hover,
.link_csv:hover {
	text-decoration: none;
}

.link_arw_l {
	display: inline-block;
	position: relative;
	padding-left: 15px;
}

.link_arw_r:after,
.btn_wh_r:after,
.btn_red_r:after,
.btn_gry_r:after,
.btn_red_bdr_r:after,
.link_arw_l:before,
.link_arw_d:after,
.link_box_block .link_btn:after,
.anchor_wrap .anchor a:after {
	content: "";
	display: inline-block;
	vertical-align: middle;
	width: 7px;
	height: 7px;
	border-top: 1px solid #e60012;
	border-right: 1px solid #e60012;
}

.link_arw_r:after,
.link_arw_d:after,
.btn_wh_r:after,
.btn_gry_r:after,
.btn_red_r:after,
.btn_red_bdr_r:after,
.link_box_block .link_btn:after {
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	margin: -2px 0 0 10px;
}

.link_arw_l:before {
	position: absolute;
	display: block;
	top: 9px;
	left: 2px;
	-webkit-transform: rotate(-135deg);
	transform: rotate(-135deg);
}

.link_arw_d:after {
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
	margin-top: -5px;
}

.btn_red_bdr_r.link_blank,
.btn_red_bdr_r.link_pdf {
	text-decoration: none;
}

.btn_red_bdr_r.link_pdf,
.btn_red_bdr_r.link_pdf.dispB {
	padding-right: 65px;
}

.btn_red_bdr_r.link_blank:after,
.btn_red_bdr_r.link_pdf:after {
	-webkit-transform: rotate(0);
	transform: rotate(0);
	border: 0;
	margin-top: -6px;
}

.btn_red_bdr_r.link_pdf:after {
	height: auto;
	margin-top: -9px;
}

.link_blank:after,
.link_popup:after,
.link_download:after {
	content: "";
	display: inline-block;
	vertical-align: middle;
	width: 12px;
	height: 12px;
	background-repeat: no-repeat;
	background-size: contain;
	margin: -1px 0 0 10px;
}

.link_blank:after {
	background-image: url(/common/images/icon/icon_blank_red.svg);
	width: 14px;
	height: 11px;
}

.link_popup:after {
	background-image: url(/common/images/icon/icon_popup_red.svg);
}

.link_download:after {
	background-image: url(/common/images/icon/icon_download_red.svg);
	width: 15px;
	height: 13px;
}

.link_pdf:after,
.link_word:after,
.link_excel:after,
.link_ppt:after,
.link_csv:after {
	display: inline-block;
	vertical-align: middle;
	width: 36px;
	color: #fff;
	line-height: 1;
	font-size: 10px;
	border-radius: 2px;
	margin: -1px 8px 0 8px;
	text-align: center;
	padding: 3px 0;
	text-indent: 0;
}

.link_pdf:after {
	content: "PDF";
	background-color: #f91d0a;
}

.link_word:after {
	content: "Word";
	background-color: #2a5599;
}

.link_excel:after {
	content: "Excel";
	background-color: #156c39;
}

.link_ppt:after {
	content: "PPT";
	background-color: #b7472a;
}

.link_csv:after {
	content: "CSV";
	background-color: #156c39;
}

.btn_wh_r,
.btn_red_r,
.btn_gry_r,
.btn_red_bdr_r,
.btn_red {
	position: relative;
	background: #fff;
	border-radius: 4px;
	color: #333;
	font-weight: bold;
	display: inline-block;
	cursor: pointer;
	padding: 10px 50px 12px 40px;
}

.btn_wh_r.spDispB, .btn_wh_r.dispB,
.btn_red_r.spDispB, .btn_red_r.dispB,
.btn_gry_r.spDispB, .btn_gry_r.dispB,
.btn_red_bdr_r.spDispB, .btn_red_bdr_r.dispB {
	padding-left: 10px;
	padding-right: 26px;
}

.btn_wh_r:hover,
.btn_red_r:hover,
.btn_gry_r:hover,
.btn_red_bdr_r:hover,
.btn_red:hover {
	opacity: 0.7;
}

.btn_red_r,
.btn_red {
	background: #e60012;
	color: #fff !important;
}

.btn_red {
	padding: 10px 40px 12px;
}

.btn_gry_r {
	background: #777;
	color: #fff !important;
}

.btn_gry_r.not_active {
	background: #ccc;
	pointer-events: none;
}

.btn_red_bdr_r {
	background: #fff;
	color: #e60012;
	border: 1px solid #e60012;
}

.btn_wh_r:after,
.btn_red_r:after,
.btn_gry_r:after,
.btn_red_bdr_r:after,
.link_box_block .link_btn:after {
	display: block;
	position: absolute;
	right: 15px;
	top: 50%;
	margin-top: -3px;
}

.btn_red_r:after,
.btn_gry_r:after,
.link_box_block .link_btn:after {
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
}

.btn_red.btn_out:after{
	content: "";
	background:url(/common/images/icon/icon_blank_white.svg) no-repeat center center;
	display: inline-block;
	width:14px;
	height: 11px;
}

.link_box_block .link_btn.link_out:after {
	border:none;
	content:url(/common/images/icon/icon_blank_red.svg);
	object-fit:contain;
	width:14px;
	height:11px;
	transform: translateY(calc(-11px / 2));
	filter: grayscale(1) brightness(100);
	margin-top: 0;
}

.clm_in .btn_wh_r {
	display: table;
	width: 100%;
	height: 80px;
	padding: 0 10px;
}

.clm_in .btn_wh_r .btn_in {
	display: table-cell;
	vertical-align: middle;
	padding: 0 30px 0 15px;
}

.btn_update {
	padding: 5px 35px 5px 10px;
}

.btn_update:after {
	display: none;
}

.btn_update:before {
	content: "";
	position: absolute;
	top: 50%;
	right: 10px;
	width: 14px;
	height: 14px;
	margin-top: -7px;
	background: url(/common/images/icon/icon_update_red.svg) no-repeat;
	background-size: contain;
}

/*枠付きリンク 主にl2 l3 top*/
.link_box_block {
	border: 1px solid #ccc;
}

.link_box_block .link_btn {
	background-color: #666;
	color: #fff;
	height: 75px;
	display: table;
	width: 100.2%;
	padding: 0 30px 0 15px;
	font-size: 18px;
	font-weight: bold;
	line-height: 1.3;
	position: relative;
}

.link_box_block .link_btn:hover {
	opacity: 0.7;
}

.link_box_block .link_btn.nolink:after {
	display: none;
}

.link_box_block .link_btn.nolink {
	pointer-events: none;
}

.link_box_block .link_btn .link_in {
	display: table-cell;
	vertical-align: middle;
}

.link_box_block .box_cont {
	display: table;
	width: 100%;
	padding: 15px;
	table-layout: fixed;
}

.link_box_block .box_cont .img_box,
.link_box_block .box_cont .txt_box {
	display: table-cell;
	vertical-align: top;
}

.link_box_block .box_cont .img_box {
	width: 220px;
	padding-right: 20px;
}

#main_wrap .link_box_block .box_cont .img_box {
	width: 140px;
}

.link_box_wrapper {
	margin-top: -20px;
	justify-content: space-between;
	margin-left: -4%;
}

.link_box_wrapper>li {
	margin-top: 20px;
	padding-left: 4%;
}

.link_box_in {
	display: flex;
	flex-wrap: wrap;
	height: 100%;
	justify-content: space-around;
}


@media screen and (max-width: 767px) {
	.link_box_block .link_btn {
		height: auto;
		padding: 12px 30px 12px 15px;
		font-size: 15px;
		display: block;
		width: 100%;
	}

	.link_box_block .link_btn .link_in {
		display: block;
	}

	.link_box_block .box_cont {
		padding: 10px;
	}

	.link_box_block .box_cont .img_box {
		width: 45%;
		padding-right: 10px;
	}

	#main_wrap .link_box_block .box_cont .img_box {
		width: 45%;
	}

	.btn_wh_r,
	.btn_red_r,
	.btn_gry_r,
	.btn_red_bdr_r {
		padding: 10px 35px 12px 25px;
	}

	.btn_red {
		padding: 10px 12px 12px;
		white-space: nowrap;
	}

	.btn_update {
		padding: 5px 35px 5px 10px;
	}
}

/*anchor*/
.anchor_wrap {
	font-size: 0;
	margin-bottom: 30px;
}

.anchor_wrap .anchor {
	display: inline-block;
	margin: 0 10px 10px 0;
}

.anchor_wrap .anchor:last-child {
	margin-right: 0;
}

.anchor_wrap .anchor a {
	display: block;
	padding: 5px 15px;
	font-size: 16px;
	background-color: #f2f2f2;
}

.anchor_wrap .anchor a:after {
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
	margin: -6px 0 0 10px;
}

@media screen and (max-width: 767px) {
	.anchor_wrap .anchor a {
		padding: 7px 10px;
		font-size: 14px;
	}
}

.popup_content #bt_close {
	padding: 6px 35px 6px 20px;
	margin-top: 30px;
}

.popup_content #bt_close:after,
.popup_content #bt_close:before {
	content: "";
	position: absolute;
	top: 18px;
	right: 13px;
	background-color: #fff;
	z-index: 999;
	box-sizing: border-box;
	width: 15px;
	height: 2px;
	border: 0;
	margin: 0;
}

.popup_content #bt_close:before {
	transform: rotate(45deg);
}

.popup_content #bt_close:after {
	transform: rotate(-45deg);
}

/* ===============================================================
 list_btn
=============================================================== */
.list_btn:after {
	content: "";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}

.list_btn .list {
	width: 48%;
	float: left;
	margin: 0 4% 0 0;
	height: 70px;
	display: table;
	position: relative;
}

.list_btn .list:nth-child(2n) {
	margin-right: 0;
}

.list_btn .list:nth-child(2n+1) {
	clear: both
}

.list_btn .list .btn {
	padding: 0 30px 0 5px;
	line-height: 1.3;
	border-bottom: 1px solid #ccc;
	display: table-cell;
	vertical-align: middle;
}

.list_btn .list .btn.bdt {
	border-top: 1px solid #ccc;
}

.list_btn .list .btn:after {
	content: "";
	display: block;
	width: 7px;
	height: 7px;
	border-top: 1px solid #e60012;
	border-right: 1px solid #e60012;
	position: absolute;
	right: 15px;
	top: 50%;
	margin-top: -3px;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.list_btn .list .btn.link_out::before{
	display:none;
}
.list_btn .list .btn.link_out::after {
	content: url(/common/images/icon/icon_blank_red.svg);
	width: 14px;
	height: 11px;
	border: none;
	transform: translateY(calc(-11px/2));
	object-fit: contain;
	margin-top: 0;
	line-height: 1;
}
@media screen and (max-width: 767px) {
	.list_btn .list {
		width: 100%;
		float: none;
		margin: 0;
		height: auto;
		display: block;
	}

	.list_btn .list .btn {
		display: block;
		padding: 12px 30px 12px 10px;
	}

	.list_btn .list:nth-child(2) .btn.bdt {
		border-top: 0;
	}

}

/* ===============================================================
 box
=============================================================== */
.box_bg_gry,
.box_bg_pnk {
	padding: 15px;
}

.box_bg_gry, .bg_gry {
	background-color: #f2f2f2;
}

.box_bg_pnk, .bg_pnk {
	background-color: #ffe0e0;
}

.box_bdr_gry .box_ttl,
.box_bdr_pnk .box_ttl {
	font-size: 18px;
	line-height: 1.3;
	font-weight: bold;
	padding: 8px 15px 10px 15px;
}

.box_bdr_gry .box_in,
.box_bdr_pnk .box_in {
	padding: 15px 15px;
}

.box_bdr_red .box_in {
	padding: 1em 2em;
}

.box_bdr_gry {
	border: 1px solid #ccc;
}

.box_bdr_gry .box_ttl {
	background-color: #ccc;
}

.box_bdr_pnk {
	border: 1px solid #ffe0e0;
}

.box_bdr_pnk .box_ttl {
	background-color: #ffe0e0;
}

.box_bdr_red {
	border: solid 1px #e60012;
}

.kiyaku_box {
	border: 1px solid #ccc;
	padding: 15px 15px;
	max-height: 300px;
	overflow-y: auto;
}

.acrobat_box {
	margin-top: 80px;
	font-size: 14px;
}

.acrobat_box .clm_in:first-child {
	width: 77%;
	margin-right: 0;
}

.acrobat_box .clm_in:last-child {
	width: 21%;
	float: right;
	padding-top: 5px;
}

.btm_excursion {
	margin-top: 80px;
}

.section+.btm_excursion {
	margin-top: 0;
}

@media screen and (max-width: 767px) {
	.btm_excursion {
		margin-top: 40px;
	}
}

/* ===============================================================
 clms
 .clm2.sp1 ： PC 2 → SP 1
 .clm2 ： PC2 → SP2

 .clm3.sp1 ： PC 3 → SP 1
 .clm3.sp2 ： PC 3 → SP 2
 .clm3 ： PC 3 → SP 3

 .clm4.sp1 ： PC 4 → SP 1
 .clm4.sp2 ： PC 4 → SP 2
 .clm4： PC 4 → SP 4
=============================================================== */
.clm2:after,
.clm3:after,
.clm4:after {
	content: "";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}

.clm2>.clm_in,
.clm3>.clm_in,
.clm4>.clm_in {
	float: left;
}

.clm2 .clm_in .img_box img,
.clm3 .clm_in .img_box img,
.clm4 .clm_in .img_box img {
	display: block;
	width: 100%;
	height: auto;
}

.clm1 .clm_in {
	width: 100%;
	margin-top: 15px;
}

.clm2 .clm_in .img_box img {
	display: block;
}

.clm2>.clm_in {
	width: 48%;
	margin-top: 20px;
	margin-right: 4%;
}

.clm2.sp_img_btm>.clm_in {
	margin-right: 0;
}

.clm2.sp_img_btm>.clm_in:first-child {
	float: right;
}

.clm3>.clm_in {
	width: 31%;
	margin: 20px 3% 0 0;
}

.clm4>.clm_in {
	width: 23.5%;
	margin: 20px 2% 0 0;
}

/*flow*/
.clm2.flow_wrap>.clm_in,
.clm3.flow_wrap>.clm_in,
.clm4.flow_wrap>.clm_in {
	position: relative;
}

.clm2.flow_wrap>.clm_in:after,
.clm3.flow_wrap>.clm_in:after,
.clm4.flow_wrap>.clm_in:after {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
}

.clm2.flow_wrap .clm_in:nth-child(2n):after,
.clm3.flow_wrap .clm_in:nth-child(3n):after,
.clm4.flow_wrap .clm_in:nth-child(4n):after {
	display: none;
}

.clm2.flow_wrap>.clm_in {
	width: 47%;
	margin-right: 6%;
}

.clm2.flow_wrap>.clm_in:after {
	border-left: 18px solid #ccc;
	border-top: 30px solid transparent;
	border-bottom: 30px solid transparent;
	margin-top: -30px;
	left: 104%;
}

.clm3.flow_wrap>.clm_in {
	width: 30%;
	margin-right: 5%;
}

.clm3.flow_wrap>.clm_in:after {
	border-left: 16px solid #ccc;
	border-top: 26px solid transparent;
	border-bottom: 26px solid transparent;
	margin-top: -26px;
	left: 106%;
}

.clm4.flow_wrap>.clm_in {
	width: 22%;
	margin-right: 4%;
}

.clm4.flow_wrap>.clm_in:after {
	border-left: 14px solid #ccc;
	border-top: 20px solid transparent;
	border-bottom: 20px solid transparent;
	margin-top: -20px;
	left: 105%;
}

.clm2>.clm_in:nth-child(2n+1),
.clm3>.clm_in:nth-child(3n+1),
.clm4>.clm_in:nth-child(4n+1) {
	clear: both;
}

.clm2>.clm_in:nth-child(2n),
.clm3>.clm_in:nth-child(3n),
.clm4>.clm_in:nth-child(4n) {
	margin-right: 0;
}

.clm1>.clm_in:first-child,
.clm2>.clm_in:nth-child(-n+2),
.clm3>.clm_in:nth-child(-n+3),
.clm4>.clm_in:nth-child(-n+4) {
	margin-top: 0;
}

.clm2 .clm_in .radius img,
.clm3 .clm_in .radius img,
.clm4 .clm_in .radius img {
	display: block;
}

.clm2 .clm_in .radius,
.clm3 .clm_in .radius,
.clm4 .clm_in .radius {
	border-radius: 8px;
	overflow: hidden;
}

.clm2 .clm_in .img_box,
.clm3 .clm_in .img_box,
.clm4 .clm_in .img_box {
	margin-bottom: 15px;
}

.clm2 .clm_in .txt_box+.img_box,
.clm3 .clm_in .txt_box+.img_box,
.clm4 .clm_in .txt_box+.img_box {
	margin-bottom: 0;
	margin-top: 15px;
}

.clm2 .clm_in .txt_box,
.clm3 .clm_in .txt_box,
.clm4 .clm_in .txt_box {
	line-height: 1.4;
}

.clm2 .clm_in.w38p {
	width: 38%;
}

.clm2 .clm_in.w58p {
	width: 58%;
}

.clm2 .clm_in.w18p {
	width: 18%;
}

.clm2 .clm_in.w78p {
	width: 78%;
}

.clm2 .clm_in.w30p {
	width: 30%;
}

.clm2 .clm_in.w66p {
	width: 66%;
}



@media screen and (max-width: 767px) {

	.clm2.sp1>.clm_in,
	.clm2.sp1>.clm_in:nth-child(2n),
	.clm2.sp1>.clm_in:nth-child(-n+2),
	.clm3.sp1>.clm_in,
	.clm3.sp1>.clm_in:nth-child(3n),
	.clm3.sp1>.clm_in:nth-child(-n+3),
	.clm4.sp1>.clm_in,
	.clm4.sp1>.clm_in:nth-child(4n),
	.clm4.sp1>.clm_in:nth-child(-n+4) {
		float: none;
		width: 100%;
		margin-top: 20px;
	}

	.clm4.sp2>.clm_in,
	.clm4.sp2>.clm_in:nth-child(4n),
	.clm4.sp2>.clm_in:nth-child(-n+4),
	.clm3.sp2>.clm_in,
	.clm3.sp2>.clm_in:nth-child(3n),
	.clm3.sp2>.clm_in:nth-child(-n+3) {
		width: 48%;
		margin-right: 4%;
		margin-top: 4%;
	}

	.clm3.sp2>.clm_in:nth-child(3n+1),
	.clm4.sp2>.clm_in:nth-child(4n+1) {
		clear: none;
	}

	.clm3.sp2>.clm_in:nth-child(2n+1),
	.clm4.sp2>.clm_in:nth-child(2n+1) {
		clear: both;
	}

	.clm3.sp2>.clm_in:nth-child(2n),
	.clm4.sp2>.clm_in:nth-child(2n) {
		margin-right: 0;
	}

	.clm2.sp1>.clm_in:first-child,
	.clm3.sp1>.clm_in:first-child,
	.clm4.sp1>.clm_in:first-child,
	.clm3.sp2>.clm_in:nth-child(-n+2),
	.clm4.sp2>.clm_in:nth-child(-n+2) {
		margin-top: 0;
	}

	.clm2 .clm_in .img_box,
	.clm3 .clm_in .img_box,
	.clm4 .clm_in .img_box {
		margin-bottom: 8px;
	}

	.spw50p {
		width: 50%;
	}

	/*flow*/
	.flow_wrap.sp1>.clm_in {
		padding-bottom: 30px;
	}

	.flow_wrap.sp1>.clm_in:last-child {
		padding-bottom: 0;
	}

	.flow_wrap.sp1>.clm_in:after {
		top: auto;
		bottom: -30px;
		left: 50%;
		border-left: 24px solid transparent;
		border-top: 18px solid #ccc;
		border-right: 24px solid transparent;
		margin: 0 0 0 -24px;
	}

	.flow_wrap.sp1>.clm_in:last-child:after {
		display: none;
	}
}

/* ===============================================================
 table
=============================================================== */
.table_normal {
	width: 100%;
	table-layout: fixed;
	background-color: #fff;
}

.table_normal th,
.table_normal td {
	text-align: left;
	padding: 12px;
	border: 1px solid #ccc;
	vertical-align: top;
	word-break: break-word;
}

.table_normal th {
	background-color: #f2f2f2;
}

.th_dgry th {
	background-color: #4d4d4d;
	color: #fff;
}

@media screen and (max-width: 767px) {

	.table_normal th,
	.table_normal td {
		padding: 10px;
	}

	.swipe .table_normal {
		width: 600px;
	}

	.table_normal.sp_block,
	.table_normal.sp_block tbody,
	.table_normal.sp_block tr,
	.table_normal.sp_block th,
	.table_normal.sp_block td {
		display: block;
		border: 0;
	}

	.table_normal.sp_block th,
	.table_normal.sp_block td {
		width: 100% !important;
	}

	.table_normal.sp_block tr {
		border: 1px solid #ccc;
		border-bottom: 0;
	}

	.table_normal.sp_block tr:last-child {
		border-bottom: 1px solid #ccc;
	}

	.table_normal.sp_block td {
		border-top: 1px solid #ccc;
	}
}

/* ===============================================================
 parts
=============================================================== */
.annotation {
	font-size: 14px;
}

.reset-indent {
	text-indent: 0;
}

.indent1 {
	text-indent: -1em;
	padding-left: 1em;
}

.indent2 {
	text-indent: -1.7em;
	padding-left: 1.7em;
}

.indent3 {
	text-indent: -3em;
	padding-left: 3em;
}

.indent0 {
	text-indent: 0;
}

.text_mb {
	margin-bottom: 15px;
}

.text_red,
.text_red a{
	color: #e60012;
}

.text_blue,
.text_blue a{
	color: #00a0e9;
}

.gloss_list .word {
	font-weight: bold;
}

.gloss_list .dtl {
	margin-bottom: 10px
}

.gloss_list .dtl:last-child {
	margin-bottom: 0;
}

.date_list .dtl {
	padding-bottom: 10px;
	margin-bottom: 10px;
	border-bottom: 1px solid #ccc;
}

.date_list .dtl:last-child {
	margin-bottom: 0;
}

.img_pd {
	background-color: #fff;
	padding: 15px;
}

.flexCenter {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: center;
}

/* ===============================================================
 list
=============================================================== */
.list_dot .list {
	margin-bottom: 5px;
	padding-left: 11px;
	text-indent: -11px;
}

.list_dot .list:before {
	content: "";
	background-color: #aaa;
	width: 6px;
	height: 6px;
	border-radius: 3px;
	display: inline-block;
	vertical-align: middle;
	margin: -3px 5px 0 0;
}

.list_num .list {
	margin-bottom: 5px;
	padding-left: 28px;
	text-indent: -28px;
}

.list_num .indent1 {
	text-indent: -1em;
	padding-left: 1em;
}

.list_num .num {
	color: #e60012;
	padding-right: 3px;
	font-size: 18px;
}

/* ===============================================================
 swipe_wrap
=============================================================== */
.swipe_wrap .swipe_annotation {
	display: none;
}

@media screen and (max-width: 767px) {
	.swipe_wrap .swipe {
		padding: 15px 10px 10px;
		overflow-y: hidden;
		overflow-x: auto;
		position: relative;
	}

	.swipe_wrap .img_box .swipe img {
		margin-right: 10px;
		max-width: 700px;
		height: auto;
	}

	.swipe_wrap .swipe_annotation {
		font-size: 12px;
		display: block;
		text-align: center;
		line-height: 1;
		position: relative;
		top: 0;
		left: 0;
		background: #ccc;
	}

	.swipe_wrap .swipe_annotation span {
		background-color: #fff;
		padding: 0 15px;
		position: relative;
		z-index: 1;
	}

	.acc_in .swipe_wrap .swipe_annotation span {
		background-color: #efefef;
	}

	.swipe_wrap .swipe_annotation::before,
	.swipe_wrap .swipe_annotation::after {
		display: block;
		content: '';
		width: 0;
		height: 0;
		border-style: solid;
		position: absolute;
		top: -4px;
		z-index: 1;
	}

	.swipe_wrap .swipe_annotation::before {
		border-width: 10px 12px 10px 0;
		border-color: #fff #ccc #fff #fff;
		left: 0;
	}

	.acc_in .swipe_wrap .swipe_annotation::before {
		border-color: #efefef #ccc #efefef #efefef;
	}

	.swipe_wrap .swipe_annotation::after {
		border-width: 10px 0 10px 12px;
		border-color: #fff #fff #fff #ccc;
		right: 0;
	}

	.acc_in .swipe_wrap .swipe_annotation::after {
		border-color: #efefef #efefef #efefef #ccc;
	}
}

/* ===============================================================
 input
=============================================================== */
.input_nml,
.slct_nml,
.textarea_nml {
	border: 1px solid #ccc;
	padding: 8px 15px;
	font-size: 16px;
	-webkit-appearance: none;
	appearance: none;
	outline: none;
	box-shadow: none;
	display: inline-block;
}

.slct_nml {
	padding-right: 30px;
	background: url(/common/images/arw_d_blk.png) no-repeat right 12px center;
	background-size: 12px auto;
}

select::-ms-expand {
	display: none;
}

/* ==========================================================================
   tab
========================================================================== */
.tab_area .btn_tab {
	width: 49%;
	height: 60px;
	float: left;
	display: table;
	margin-right: 2%;
	font-weight: bold;
	text-align: center;
	line-height: 1.3;
	position: relative;
	color: #b3b3b3;
}

.tab_area .btn_tab:last-child {
	margin-right: 0;
}

.tab_area .btn_tab .btn {
	border-radius: 10px 10px 0 0;
	display: table-cell;
	vertical-align: middle;
	padding: 0 3%;
	font-size: 20px;
	cursor: pointer;
	background-color: #e6e6e6;
}

.tab_switch_css input {
	display: none;
}

/*cssで切り替えタブ*/
.tab_switch_css .tab_cont {
	display: none;
}

.tab_switch_css .tab1:checked~.tab_area .btn_tab1 .btn,
.tab_switch_css .tab2:checked~.tab_area .btn_tab2 .btn,
.tab_switch_css .tab3:checked~.tab_area .btn_tab3 .btn,
.tab_switch_nml .active .btn {
	background-color: #ffd9d9;
	color: #333;
}

.tab_switch_css .tab1:checked~.tab_cont1,
.tab_switch_css .tab2:checked~.tab_cont2,
.tab_switch_css .tab3:checked~.tab_cont3 {
	display: block;
}

.tab_cont.bdr {
	border: 1px solid #e0e0e0;
	padding: 30px 20px;
}

@media screen and (max-width: 767px) {
	.tab_area .btn_tab {
		height: 50px;
	}

	.tab_area .btn_tab .btn {
		font-size: 16px;
	}

	.tab_cont.bdr {
		border: 1px solid #e0e0e0;
		padding: 20px 4%;
	}
}

/* ===============================================================
 accorion
=============================================================== */
/* ----------info_btn_list----------- */
.acc_area {
	border-bottom: 1px solid #ccc;
}

.ttl_acc_area {}

.acc_btn {
	display: block;
	position: relative;
	color: #333;
	padding: 20px 50px 20px 15px;
	font-weight: bold;
}

.acc_btn:after {
	content: "";
	display: inline-block;
	vertical-align: middle;
	width: 22px;
	height: 22px;
	background-image: url(/common/images/icon/icon_plus_red.svg);
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 15px;
	margin-top: -10px;
}

.acc_btn.open:after {
	background-image: url(/common/images/icon/icon_minus_red.svg);
}

.ttl_acc_btn {
	padding-right: 40px;
	cursor: pointer;
	position: relative;
}

.ttl_acc_btn:hover {
	color: #e60012;
}

.ttl_bdr_l.ttl_acc_btn {
	margin-bottom: 0;
}

.ttl_acc_btn:after {
	content: "";
	display: inline-block;
	vertical-align: middle;
	width: 22px;
	height: 22px;
	background-image: url(/common/images/icon/icon_plus_red.svg);
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 15px;
	margin-top: -10px;
}

.ttl_acc_btn.open:after {
	background-image: url(/common/images/icon/icon_minus_red.svg);
}

.acc_in {
	display: none;
	padding: 20px 15px 20px;
	background-color: #f2f2f2;
}

.ttl_acc_in {
	margin-top: 35px;
	padding: 20px 15px 20px;
	background-color: #f2f2f2;
	display: none;
}

.sp_acc_btn {
	display: block;
	font-weight: bold;
	margin-bottom: 10px;
}

/* ----------faq_box----------- */
.faq_box .acc_btn {
	padding: 20px 50px 20px 50px;
}

.faq_box .acc_btn:before,
.faq_box .q_btn:before {
	content: "Q.";
	color: #e60012;
	position: absolute;
	top: 12px;
	left: 15px;
	font-size: 24px;
}

.faq_box .acc_in {
	padding: 20px 15px 20px 50px;
	position: relative;
}

.faq_box .acc_in:before {
	content: "A.";
	position: absolute;
	top: 12px;
	left: 15px;
	font-size: 24px;
	font-weight: bold;
}

/* ---------- accordion css animation --------------*/
.css_acc_in {
	display: block;
	padding: 0;
	overflow: hidden;
	max-height: 0;
	transition: max-height 0.2s;
	border: none;
}

.css_acc_open {
	transition: max-height 1s;
	max-height: 300vh;
}

.css_acc_inner {
	padding: 20px 15px 20px;
}

@media screen and (min-width: 768px) {
	.sp_acc_btn {
		font-size: 18px;
		pointer-events: none;
	}
}

@media screen and (max-width: 767px) {

	/* ----------sp_acc_btn----------- */
	.acc_btn {
		padding: 12px 30px 12px 10px;
	}

	.acc_in,
	.sp_acc_in {
		padding: 15px 10px 15px;
		background-color: #f2f2f2;
	}

	.ttl_acc_in {
		margin-top: 25px;
		padding: 15px 10px 15px;
	}

	.css_acc_in {
		padding: 0;
	}

	.sp_acc_area {
		border-bottom: 1px solid #ccc;
	}

	.sp_acc_btn {
		position: relative;
		padding: 12px 25px 12px 10px;
		margin-bottom: 0;
	}

	.acc_btn:after,
	.ttl_acc_btn:after,
	.sp_acc_btn:after {
		content: "";
		display: inline-block;
		vertical-align: middle;
		width: 16px;
		height: 16px;
		background-image: url(/common/images/icon/icon_plus_red.svg);
		background-repeat: no-repeat;
		background-size: contain;
		margin: -8px 0 0 0;
		position: absolute;
		top: 50%;
		right: 4%;
	}

	.fslink:after {
		display: block;
		position: absolute;
		right: 15px;
		top: 50%;
		margin-top: -3px;
		transform: rotate(45deg);
		margin: -2px 0 0 10px;
		content: "";
		display: inline-block;
		vertical-align: middle;
		width: 7px;
		height: 7px;
		border-top: 1px solid #e60012;
		border-right: 1px solid #e60012;
	}

	.acc_btn.open:after,
	.ttl_acc_btn.open:after,
	.sp_acc_btn.open:after {
		background-image: url(/common/images/icon/icon_minus_red.svg);
	}

	.sp_acc_in {
		display: none;
	}

	.faq_box .acc_btn {
		padding: 12px 40px 12px 40px;
	}

	.faq_box .acc_in {
		padding: 15px 10px 15px 40px;
	}

	.faq_box .acc_btn:before,
	.faq_box .acc_in:before {
		top: 8px;
		left: 10px;
		font-size: 20px;
	}
}

/* ===============================================================
 video
=============================================================== */
.video_wrap {
	position: relative;
	width: 600px;
	height: 450px;
	margin: auto;
}

.video_wrap.video_slim {
	height: 338px;
}

.video_wrap iframe {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
}

@media screen and (max-width: 767px) {
	.video_wrap {
		width: 100%;
		height: 1px;
		padding-bottom: 74.5%;
	}

	.video_wrap.video_slim {
		height: 1px;
		padding-bottom: 56.6%;
	}
}

/* ===============================================================
 search_wrap
=============================================================== */
.search_wrap {
	font-size: 0;
}

.search_wrap .input_txt {
	display: inline-block;
	border: 1px solid #ccc;
	border-right: 0;
	padding: 13px 15px;
	font-size: 15px;
	width: 170px;
}

.search_wrap .btn_search {
	display: inline-block;
	width: 50px;
	height: 50px;
	background: #4d4d4d url(/common/images/icon/icon_search_wh.png) no-repeat center;
	background-size: 24px auto;
	padding: 10px;
	font-size: 0;
}

@media screen and (max-width: 767px) {
	.search_wrap .input_txt {
		font-size: 16px;
		width: 85%;
	}

	.search_wrap .btn_search {
		width: 15%;
	}
}

/* ===============================================================
 contact_wrap
=============================================================== */
.contact_wrap .ttl_box,
.contact_wrap .cont_box {
	line-height: 1.4;
}

.contact_wrap .ttl_box {
	background-color: #4d4d4d;
	color: #fff;
	padding: 8px 15px 10px 15px;
	font-size: 18px;
}

.contact_wrap .cont_box {
	padding: 15px;
	border: 1px solid #ccc;
	border-top: 0;
}

.contact_wrap .cont_box .ttl_bdr {
	font-size: 18px;
	font-weight: bold;
	background-color: #f2f2f2;
	padding: 5px 10px;
	margin-bottom: 15px;
}

.contact_wrap .cont_box .tel_contact {
	margin-top: 30px;
}

.contact_wrap .cont_box .name {
	display: inline-block;
	font-size: 14px;
	border: 1px solid #ccc;
	padding: 6px 10px;
	margin-right: 20px;
	vertical-align: middle;
}

.contact_wrap .cont_box .tel {
	vertical-align: middle;
	display: inline-block;
	font-size: 32px;
	font-weight: bold;
}

.contact_wrap [data-ruby] {
	position: relative;
}

.contact_wrap [data-ruby]::before {
	content: attr(data-ruby);
	position: absolute;
	top: -7px;
	left: 0;
	right: 0;
	margin: auto;
	text-align: center;
	font-size: 12px;
}

.contact_wrap .cont_box .tel .sub {
	font-size: 26px;
}

.contact_wrap .cont_box .tel .dtl {
	font-size: 22px;
}

.contact_wrap .cont_box .hour {
	font-weight: bold;
	font-size: 14px;
	margin: 10px 0 5px;
}

@media screen and (min-width: 768px) {
	.contact_wrap .cont_box .tel {
		pointer-events: none;
	}
}

@media screen and (max-width: 767px) {

	.contact_wrap,
	.contact_wrap .ttl_box,
	.contact_wrap .cont_box {
		display: block;
	}

	.contact_wrap .ttl_box {
		font-size: 16px;
	}

	.contact_wrap .cont_box {
		border: 1px solid #ccc;
		border-top: 0;
		padding: 10px 10px 15px;
	}

	.contact_wrap .cont_box .ttl_bdr {
		font-size: 16px;
		margin-bottom: 10px;
	}

	.contact_wrap .cont_box .tel {
		font-size: 20px;
	}

	.contact_wrap [data-ruby]::before {
		font-size: 10px;
	}

	.contact_wrap .cont_box .tel .sub {
		font-size: 14px;
	}

	.contact_wrap .cont_box .tel .dtl {
		font-size: 13px;
	}

	.contact_wrap .cont_box .name {
		display: inline-block;
		font-size: 14px;
		border: 1px solid #ccc;
		padding: 3px 10px;
		margin: 0 0 10px;
	}
}

/* ===============================================================
 breadcrumbs
=============================================================== */
.breadcrumbs {
	width: 1000px;
	margin: 15px auto;
}

.breadcrumbs li {
	display: inline-block;
	vertical-align: middle;
	margin: 0 5px 0 0;
}

.breadcrumbs li:after {
	content: "";
	display: inline-block;
	vertical-align: middle;
	width: 6px;
	height: 6px;
	border-top: 1px solid #010101;
	border-right: 1px solid #010101;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	margin: 0 0 0 3px;
}

.breadcrumbs a,
.breadcrumbs .ct {
	font-size: 14px;
	color: #010101;
	display: inline-block;
}

.breadcrumbs a:hover {
	color: #e60012;
}

.breadcrumbs li:last-child:after {
	display: none;
}

.breadcrumbs li:last-child a {
	pointer-events: none;
}

@media screen and (max-width: 767px) {
	.breadcrumbs {
		display: none;
	}
}

/* ===============================================================
 related_links
=============================================================== */
#related_links {
	margin-top: 80px;
}

#related_links .ttl_related {
	border-bottom: 2px solid #d9d9d9;
	font-size: 26px;
	font-weight: bold;
	position: relative;
	line-height: 1.3;
	padding-bottom: 15px;
	margin-bottom: 40px;
}

#related_links .ttl_related:after {
	content: "";
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 4em;
	height: 2px;
	background-color: #e60012;
}

.link_related {
	border: 1px solid #ccc;
	border-radius: 8px;
	overflow: hidden;
	display: table;
	width: 100%;
	table-layout: fixed;
}

.link_related .img_box,
.link_related .txt_box {
	display: table-cell;
	vertical-align: top;
}

.link_related .img_box {
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	width: 190px;
}

.link_related .txt_box {
	padding: 20px;
	height: 125px;
	position: relative;
}

.link_related .txt_box:after {
	content: "";
	width: 30px;
	height: 30px;
	background-color: #e60012;
	display: block;
	position: absolute;
	right: -15px;
	bottom: -15px;
	transform: rotate(-45deg);
}

.link_related .txt_box .ttl {
	font-weight: bold;
	margin-bottom: 5px;
}

.link_related .txt_box .txt {
	font-size: 14px;
}

@media screen and (max-width: 767px) {
	#related_links {
		margin-top: 50px;
	}

	#related_links .ttl_related {
		font-size: 18px;
		margin-bottom: 20px;
		padding-bottom: 10px;
	}

	.link_related .img_box {
		display: none;
	}

	.link_related .txt_box {
		vertical-align: middle;
	}

	.link_related .txt_box {
		padding: 0 15px;
		height: 90px;
	}
}

/* ===============================================================
 popup_bnr
=============================================================== */
#popup_bnr {
	position: fixed;
	width: 500px;
	bottom: -200px;
	right: 95px;
	z-index: 999;
	transition: all 0.6s;
	background-color: #fff;
	border-radius: 8px;
}

#popup_bnr.show {
	bottom: 15px;
}

#popup_bnr a,
#popup_bnr img {
	display: block;
}

#popup_bnr img {
	width: 100%;
	height: auto;
}

#popup_bnr .btn_close {
	position: absolute;
	top: -10px;
	right: -10px;
	width: 40px;
	z-index: 1000;
}

@media screen and (max-width: 767px) {
	#popup_bnr {
		width: auto;
		bottom: -200px;
		right: 15px;
		left: 15px;
	}

	#popup_bnr.show {
		bottom: 10px;
	}
}

.whole_page_information {
	background-color: #e70012;
	color: #fff;
	padding: 170px 0 20px;
}

.whole_page_information+#main {
	padding-top: 0 !important;
}

.emg-loaded .whole_page_information {
	display: none;
}

.whole_page_information .ttl {
	font-size: 18px;
	float: left;
	line-height: 40px;
}

.whole_page_information .ttl:before {
	content: "";
	display: inline-block;
	vertical-align: middle;
	width: 22px;
	height: 22px;
	background: url(/common/images/icon/icon_caution_wh.svg) no-repeat;
	background-size: contain;
	margin: -2px 10px 0 0;
}

.whole_page_information .btn {
	float: right;
}

.whole_page_information .btn .btn_red_bdr_r {
	background-color: transparent;
	border: 1px solid #fff;
	color: #fff;
	padding-top: 6px;
	padding-bottom: 6px;
}

.whole_page_information .btn .btn_red_bdr_r:after {
	-webkit-transform: rotate(0);
	transform: rotate(0);
	border: 0;
	background-image: url(/common/images/icon/icon_popup_wh.svg);
	background-repeat: no-repeat;
	width: 12px;
	height: 12px;
	background-size: contain;
	margin: -6px 0 0 10px;
}

@media screen and (max-width: 767px) {
	.whole_page_information {
		padding: 70px 0 10px;
	}

	.whole_page_information .ttl {
		font-size: 15px;
		float: left;
		line-height: 1.3;
		width: 54%;
		padding-left: 22px;
		position: relative;
	}

	.whole_page_information .ttl:before {
		width: 16px;
		height: 16px;
		margin: 0;
		position: absolute;
		top: 2px;
		left: 0;
	}

	.whole_page_information .btn {
		float: right;
		width: 46%;
	}

	.whole_page_information .btn .btn_red_bdr_r {
		padding: 6px 15px 8px 8px;
		display: block;
	}

	.whole_page_information .btn .btn_red_bdr_r:after {
		right: 8px;
	}
}

body.cmodalOpen {
	position: relative;
	max-height: 100vh;
	overflow-y: hidden;
}

body.cmodalOpen .cmodal-overlay {
	position: fixed;
	left: 0;
	top: 0;
	width: 100vw;
	height: 100vh;
	z-index: 10000;
	background: rgba(0, 0, 0, .5);
}

.cmodal-wrapper {
	display: none;
}

body.cmodalOpen .cmodal-wrapper {
	display: flex;
	position: absolute;
	top: 0;
	left: 0;
	align-items: center;
	justify-content: center;
	height: 100%;
	max-height: 100vh;
	width: 100%;
	z-index: 10001;
}

body.cmodalOpen .cmodal-frame {
	position: relative;
	width: min(80vw, 760px);
	height: min(max-content, 80%);
	background: #ffffff;
	border-radius: 5px;
	padding: 1em .2em;
}

body.cmodalOpen .cmodal-body {
	margin: 0 auto;
	padding: 1em 1em 5em;
	height: 100%;
	box-sizing: border-box;
	overflow: auto;
	position: relative;
}

.cmodal-frame .cmodal-close {
	position: absolute;
	right: -1.5em;
	top: -1.5em;
	width: 2.5em;
	height: 2.5em;
	background: #333333;
	border-radius: 100%;
	cursor: pointer;
}

.cmodal-frame .cmodal-close::before {
	content: "×";
	font-size: 1.5em;
	color: #ffffff;
}

.cmodal-body .dont-display-again {
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
}

.cmodal-body .dont-display-again input[type="checkbox"] {
	appearance: checkbox;
	margin-right: .5em;
}

.cmodal-body [for="dont-display-again"] {
	cursor: pointer;
}

.grid-banner-area {
	width: clamp(320px, 96%, 960px);
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.grid-banner-image-wrapper {
	text-align: center;
	margin-bottom: 1em;
}

.grid-banner-image-wrapper img {
	width: clamp(200px, 100%, 460px);
	max-width: 100%;
	object-fit: contain;
}

@media screen and (min-width:768px) {

	.grid-banner-area {
		width: min(100%, 960px);
		display: grid;
		grid-template-columns: max-content 1fr;
		align-items: center;
		justify-content: center;
		grid-template-rows: 2em 172.5px;
		margin: 0 auto;
		grid-gap: 10px;
	}

	#main_wrap .grid-banner-area {
		grid-template-columns: repeat(2, auto);
		grid-template-rows: auto 172.5px;
	}

	.main_wrap_only {
		display: none;
	}

	#main_wrap .main_wrap_only {
		display: inherit;
	}


	.grid-banner-label {
		grid-row: 1;
		text-align: center;
	}

	.grid-banner-image-wrapper {
		height: 100%;
		display: flex;
		grid-row: 2;
		width: 100%;
		overflow: hidden;
		justify-content: center;
	}

	#main_wrap .grid-banner-image-wrapper {
		max-width: 100%;
	}

	.grid-banner-image-wrapper img {
		height: 100%;
		object-fit: contain;
		width: auto;
	}
	#main_wrap .grid-banner-image-wrapper img{
		max-height: 135px;
	}

	.grid-banner-area .banner-item {
		grid-row: 2;
	}

	.grid-banner-image-wrapper:nth-of-type(odd) {
		grid-column: 1;
	}

	.grid-banner-image-wrapper:nth-of-type(even) {
		grid-column: -1;
	}

	.grid-banner-label:nth-of-type(odd) {
		grid-column: 1;
	}

	.grid-banner-label:nth-of-type(even) {
		grid-column: -1;
	}

}