@charset "utf-8";
/*------------------------------------------------------------
	sustainability-materiality-process
------------------------------------------------------------*/
#page-path {
	margin-bottom: 66px;
}
#main .headline06 {
	margin-bottom: 48px;
}
#main .border-box {
	border: 2px solid #576B89;
}
#main .step-box:not(:last-of-type)::before {
	position: absolute;
	left: 50%;
	margin-left: -40px;
	bottom: -32px;
	width: 80px;
	height: 30px;
	content: "";
	background: url("../images/sustainability-materiality-process/arrow01.png");
	background-size: 100%;
}
#main .step-box:not(:last-of-type) {
	margin-bottom: 60px;
	position: relative;
}
#main h4 {
	margin-bottom: 42px;
	display: flex;
	color: #FFF;
	flex-wrap: wrap;
	font-size: 2.2rem;
	font-weight: 500;
	align-items: center;
	justify-content: space-between;
	background-color: #576B89;
}
#main h4 .num {
	padding: 8px 0 11px;
	width: 158px;
	display: block;
	color: #FFF;
	font-size: 2.4rem;
	font-weight: 500;
	text-align: center;
	box-sizing: border-box;
	background-color: #2D466C;
}
#main h4 .ttl {
	padding-bottom: 2px;
	width: calc(100% - 198px);
	display: block;
	box-sizing: border-box;
}
#main .step-box .sub-box {
	padding: 0 38px 45px 78px;
}
#main .step-box .sub-box p {
	max-width: 723px;
}
#main .img-box .pho-box {
	order: 1;
}
#main .img-box .txt-box {
	margin-top: 38px;
	width: 445px;
}
#main .real-box {
	margin: 90px 0 62px !important;
	padding-bottom: 48px;
}
#main .real-box:not(:last-of-type)::before {
	background-image: url("../images/sustainability-materiality-process/arrow02.png");
}
#main .real-box h4 .num {
	min-height: 57px;
}
#main .real-box .top-text {
	margin-bottom: 44px;
	text-align: center;
}
#main .real-box .text-ul li {
	margin-right: 50px;
	width: 260px;
}
#main .real-box .text-ul li:nth-child(3n) {
	margin-right: 0;
}
#main .real-box .text-ul .ttl {
	margin-bottom: 16px;
	padding: 24px 0 28px;
	border-radius: 4px;
	text-align: center;
	color: #FFF;
	font-size: 2.2rem;
	font-weight: 700;
	line-height: 1.25;
}
#main .real-box .text-ul .ttl span {
	padding: 1px 0;
	margin: 0 auto 8px;
	width: 157px;
	display: block;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 1.5;
	text-align: center;
	box-sizing: border-box;
	border: 1px solid #FFF;
}
#main .real-box .text-ul dl {
	margin-bottom: 24px;
}
#main .real-box .text-ul .com-btn01 a {
	width: auto;
	background-position: right 9px center;
}
#main .step-box:last-of-type {
	margin-bottom: 100px;
}
@media all and (max-width: 896px) {	
	#main .headline06 {
		margin-bottom: 30px;
	}
	#main .border-box {
		border: 2px solid #576B89;
	}
	#main .step-box:not(:last-of-type) {
		margin-bottom: 40px;
	}
	#main h4 {
		margin-bottom: 20px;
		padding-bottom: 10px;
		display: block;
		text-align: center;
		font-size: 1.6rem;
	}
	#main h4 .num {
		margin-bottom: 7px;
		width: auto;
		min-height: inherit !important;
		font-size: 1.4rem;
	}
	#main h4 .ttl {
		padding-bottom: 2px;
		width: auto;
	}
	#main .step-box .sub-box {
		padding: 0 20px 25px;
	}
	#main .step-box .sub-box p {
		max-width: inherit;
	}
	#main .img-box {
		display: block;
	}
	#main .img-box .pho-box {
		text-align: center;
	}
	#main .img-box .txt-box {
		margin-top: 15px;
		width: auto;
	}
	#main .real-box {
		margin: 90px 0 62px !important;
		padding-bottom: 48px;
	}
	#main .real-box .top-text {
		margin-bottom: 30px;
		text-align: left;
	}
	#main .real-box .text-ul {
		margin-top: 0;
		display: block;
	}
	#main .real-box .text-ul li {
		margin: 0 0 30px;
		width: auto;
	}
	#main .real-box .text-ul li:last-child {
		margin-bottom: 0;
	}
	#main .real-box .text-ul .ttl {
		font-size: 1.8rem;
	}
	#main .step-box:last-of-type {
		margin-bottom: 50px;
	}
}