@charset "UTF-8";
/*-----------------------------------

	service_block

-----------------------------------*/
#service_block {
	padding: 117px 0 120px;
}
#service_block .service_tab {
	gap: 20px 0;
	margin-bottom: 120px;
}
#service_block .service_tab a {
	font-size: 18px;
	font-weight: 700;
	color: #FFFFFF;
	background: #47A448;
	width: calc((100% - 40px) / 2);
	padding: 42px 100px 42px 130px;
	border-radius: 5px;
	position: relative;
}
#service_block .service_tab a::before,
#service_block .service_tab a::after {
	content: '';
	display: block;
	margin: auto;
	position: absolute;
	top: 0;
	bottom: 0;
	z-index: 1;
}
#service_block .service_tab a::before {
	width: 50px;
	height: 40px;
	left: 40px;
}
#service_block .service_tab a.consult::before {
	background: url(../img/service/icon_consult.svg) no-repeat center / contain;
}
#service_block .service_tab a.seminar::before {
	background: url(../img/service/icon_seminar.svg) no-repeat center / contain;
}
#service_block .service_tab a::after {
	content: '';
	display: block;
	background: url(../img/common/icon_arwlong_rt_wh.svg) no-repeat center / contain;
	width: 21px;
	height: 7px;
	margin: auto;
	position: absolute;
	right: 40px;
	transform: rotate(90deg);
	z-index: 2;
}
#service_block #consult {
	margin-bottom: 120px;
}
#service_block h3 {
	font-size: 38px;
	font-weight: 700;
	line-height: 1.45;
	padding: 7px 0 15px 100px;
	border-bottom: 5px solid #CCCCBC;
	margin-bottom: 25px;
	position: relative;
}
#service_block h3::before,
#service_block h3::after {
	content: '';
	display: block;
	margin: auto;
	position: absolute;
}
#service_block h3::before {
	background: #47A448;
	width: 80px;
	height: calc(100% + 5px);
	border-top-left-radius: 5px;
	border-top-right-radius: 5px;
	top: 0;
	left: 0;
	z-index: 1;
}
#service_block h3::after {
	width: 40px;
	height: 32px;
	top: 24px;
	left: 20px;
	z-index: 2;
}
#service_block #consult h3::after {
	background: url(../img/service/icon_consult.svg) no-repeat center / contain;
}
#service_block #seminar h3::after {
	background: url(../img/service/icon_seminar.svg) no-repeat center / contain;
}
#service_block h4 {
	font-size: 26px;
	font-weight: 700;
	line-height: 1.423;
	background: #F3F3EB;
	padding: 14.5px 24px 18.5px 44px;
	border-radius: 5px;
	margin-bottom: 26px;
	position: relative;
}
#service_block h4::before {
	content: '';
	display: block;
	background: #F38200;
	width: 4px;
	height: 30px;
	margin: auto;
	position: absolute;
	top: 19px;
	left: 20px;
	z-index: 1;
}
#service_block p {
	font-size: 18px;
}
#service_block .intro_txt {
	font-size: 20px;
	font-weight: 500;
	margin-bottom: 54px;
}
#service_block .intro_txt .clr {
	color: #F38200;
}
#service_block ul {
	width: max-content;
	max-width: 100%;
	padding: 28px 30px 24px;
	border: 1px solid #CCCCBC;
	border-radius: 10px;
	margin: 15px 0 16px;
}
#service_block li {
	font-size: 18px;
	font-weight: 500;
	padding-left: 18px;
	position: relative;
}
#service_block li::before {
	content: '';
	display: block;
	background: #F38200;
	width: 8px;
	height: 8px;
	border-radius: 50vw;
	margin: auto;
	position: absolute;
	top: 15px;
	left: 0;
	z-index: 1;
}
#service_block .service_box {
	margin-bottom: 45px;
}
#service_block .last_box {
	margin-bottom: 55px;
}
#service_block .faq_wrapper {
	background: #F3F3EB;
	padding: 40px;
	border-radius: 20px;
}
#service_block .faq_wrapper h5 {
	font-size: 27px;
	font-weight: 700;
	line-height: 1.45;
	text-align: center;
	padding-bottom: 14px;
	margin-bottom: 30px;
	position: relative;
}
#service_block .faq_wrapper h5::after {
	content: '';
	display: block;
	background: #F38200;
	width: 30px;
	height: 4px;
	margin: auto;
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
}
#service_block .faq_box {
	background: #ffffff;
	border-radius: 5px;
}
#service_block .faq_box:not(:last-of-type) {
	margin-bottom: 20px;
}
#service_block .faq_box .faq_ttl,
#service_block .faq_box .faq_contents_ttl {
	font-size: 18px;
	font-weight: 500;
}
#service_block .faq_box .faq_ttl {
	padding: 35px 110px 35px 30px;
	position: relative;
	cursor: pointer;
	transition: 0.3s;
}
#service_block .faq_box .faq_ttl:hover {
	background: #FAFAF6;
}
#service_block .faq_box .faq_ttl::before {
	content: '';
	display: block;
	background: #333333;
	width: 50px;
	height: 50px;
	border-radius: 50vw;
	margin: auto;
	position: absolute;
	top: 30px;
	right: 30px;
	z-index: 1;
}
#service_block .faq_box .faq_ttl::after {
	content: '';
	display: block;
	background: url(../img/common/icon_arwlong_rt_wh.svg) no-repeat center / contain;
	width: 21px;
	height: 7px;
	margin: auto;
	position: absolute;
	top: 51px;
	right: 43px;
	transform: rotate(90deg);
	z-index: 2;
}
#service_block .faq_box .faq_ttl.active::after {
	right: 46px;
	transform: rotate(-90deg);
}
#service_block .faq_box .faq_contents_ttl {
	margin-bottom: 6px;
}
#service_block .faq_box .faq_ttl span,
#service_block .faq_box .faq_contents_ttl span {
	font-size: 20px;
	font-weight: 600;
	padding-right: 11px;
}
#service_block .faq_box .faq_ttl span {
	color: #47A448;
}
#service_block .faq_box .faq_contents_ttl span {
	color: #F38200;
}
#service_block .faq_box .faq_contents {
	padding: 24px 0 25px;
	border-top: 2px dotted #CCCCBC;
	margin: 0 30px;
}
#service_block .faq_box:not(:first-of-type) .faq_contents {
	display: none;
}
#service_block .faq_box .faq_contents_details {
	padding-left: 30px;
}
@media screen and (max-width: 1100px) {
	#service_block .service_tab a {
		width: 100%;
	}
}
@media screen and (max-width: 640px) {
	#service_block {
		padding: 45px 0 60px;
	}
	#service_block .service_tab {
		margin-bottom: 50px;
	}
	#service_block .service_tab a {
		font-size: 15px;
		padding: 20px 100px 20px 75px;
	}
	#service_block .service_tab a::before {
		width: 40px;
		height: 30px;
		left: 15px;
	}
	#service_block .service_tab a::after {
		width: 15px;
		height: 5px;
		right: 30px;
	}
	#service_block #consult {
		margin-bottom: 50px;
	}
	#service_block h3 {
		font-size: 20px;
		padding: 7px 0 9px 70px;
		border-width: 3px;
		margin-bottom: 20px;
	}
	#service_block h3::before {
		width: 55px;
		height: calc(100% + 3px);
	}
	#service_block h3::after {
		width: 30px;
		height: 22px;
		top: 14px;
    	left: 14px;
	}
	#service_block h4 {
		font-size: 18px;
		padding: 9px 24px 9px 34px;
		margin-bottom: 20px;
	}
	#service_block h4::before {
		width: 3px;
		height: 20px;
		top: 12px;
		left: 15px;
	}
	#service_block p {
		font-size: 14px;
	}
	#service_block .intro_txt {
		font-size: 16px;
		margin-bottom: 28px;
	}
	#service_block ul {
		padding: 18px 15px 14px;
	}
	#service_block li {
		font-size: 15px;
		padding-left: 15px;
	}
	#service_block li::before {
		width: 6px;
		height: 6px;
		top: 11px;
	}
	#service_block .service_box {
		margin-bottom: 35px;
	}
	#service_block .last_box {
		margin-bottom: 45px;
	}
	#service_block .faq_wrapper {
		padding: 20px 15px;
		border-radius: 10px;
	}
	#service_block .faq_wrapper h5 {
		font-size: 18px;
	}
	#service_block .faq_wrapper h5::after {
		height: 3px;
	}
	#service_block .faq_box:not(:last-of-type) {
		margin-bottom: 15px;
	}
	#service_block .faq_box .faq_ttl,
	#service_block .faq_box .faq_contents_ttl {
		font-size: 15px;
	}
	#service_block .faq_box .faq_ttl {
		text-indent: -21px;
		padding: 15px 60px 15px 36px;
	}
	#service_block .faq_box .faq_ttl span,
	#service_block .faq_box .faq_contents_ttl span {
		font-size: 16px;
		padding-right: 5px;
	}
	#service_block .faq_box .faq_ttl::before {
		width: 35px;
		height: 35px;
		top: 12px;
		right: 15px;
	}
	#service_block .faq_box .faq_ttl::after {
		width: 13px;
		height: 4px;
		top: 28px;
		right: 26px;
	}
	#service_block .faq_box .faq_ttl.active::after {
		top: 28px;
		right: 27px;
	}
	#service_block .faq_box .faq_contents {
		padding: 14px 0 15px;
		margin: 0 15px;
	}
	#service_block .faq_box .faq_contents_details {
		padding-left: 20px;
	}
}
