@charset "UTF-8";

header #nav_menu > ul > li:nth-child(3) > a::before{
	background: var(--mClr2);
}

/*-----------------------------------

	headline

-----------------------------------*/
#headline {
	background-image: url(../img/sustainability/headline_bg.jpg);
}
#headline h1::before {
	content: "SUSTAINABILITY";
}
/*-----------------------------------

	common

-----------------------------------*/
.sustainability {
	padding-bottom: 100px;
}
.sustainability h2 {
	width: 95vw;
	margin: 0 calc(600px - 47.5vw) 60px !important;
	padding: 55px calc(47.5vw - 600px);
	color: #FFF;
	font: 700 1.8rem/1 var(--fJa);
	position: relative;
	border-radius: 30px 30px 0 0;
}
.sustainability h2::before {
	display: block;
	font: 700 5rem/1 var(--fEn);
	margin-bottom: 30px;
}
.sustainability h2::after {
	content: "";
	width: 22px;
	height: 2px;
	background: var(--mClr3);
	position: absolute;
	top: 115px;
	left: calc(47.5vw - 600px);
}
.sustainability .text > *:not(:last-child) {
	margin-bottom: 50px;
}
.sustainability .text .text_inner > *:not(:last-child) {
	margin-bottom: 20px;
}
.sustainability h3 {
	font: 700 2.4rem/1 var(--fJa);
	border-left: 6px solid var(--mClr1);
	padding: 8px 20px;
}
.sustainability .copy {
	font: 700 1.8rem/1.67 var(--fJa);
	padding-left: 33px;
	position: relative;
}
.sustainability .copy::before {
	content: "";
	width: 21px;
	height: 1px;
	background: var(--mClr1);
	position: absolute;
	top: 13px;
	left: 0;
}
.sustainability .text p {
	line-height: 2;
	letter-spacing: 0.03em;
	white-space: pre-line;
	font-size: 17px;
}
.sustainability ul.list {
	background: #F4F9F8;
	padding: 30px 25px;
}
.sustainability ul.list > li {
	line-height: 2;
	letter-spacing: 0.03em;
	padding-left: 22px;
	background: url(../img/sustainability/icon_list_arrow.svg) no-repeat left 6px/11px;
}
.sustainability ul.list > li > ul > li {
	padding-left: 14px;
	position: relative;
}
.sustainability ul.list > li > ul > li::before {
	content: "";
	width: 10px;
	height: 1px;
	background: var(--mClr1);
	position: absolute;
	top: 13px;
	left: 0;
}
.sustainability figure img {
	display: block;
	margin-bottom: 10px;
}
.sustainability figure figcaption {
	text-align: center;
	line-height: 1.9;
}
@media screen and (max-width: 1340px) {
	.sustainability h2 {
		margin: 0 -2.5vw 60px !important;
		padding: 55px 2.5vw;
	}
	.sustainability h2::after {
		left: 2.5vw;
	}
}
@media screen and (max-width: 640px) {
	.sustainability {
		padding-bottom: 50px;
	}
	.sustainability h2 {
		margin: 0 -2.5vw 30px !important;
		padding: 30px 2.5vw;
		font-size: 1.4rem;
		border-radius: 15px 15px 0 0;
	}
	.sustainability h2::before {
		font-size: 2.8rem;
		margin-bottom: 15px;
	}
	.sustainability h2::after {
		width: 18px;
		height: 1px;
		top: 63px;
	}
	.sustainability .text > *:not(:last-child) {
		margin-bottom: 25px;
	}
	.sustainability .text .text_inner > *:not(:last-child) {
		margin-bottom: 10px;
	}
	.sustainability h3 {
		font-size: 1.6rem;
		border-left: 4px solid var(--mClr1);
		padding: 5px 15px;
	}
	.sustainability .copy {
		font-size: 1.4rem;
		padding-left: 22px;
	}
	.sustainability .copy::before {
		width: 15px;
		top: 10px;
	}
	.sustainability .text p {
		font-size: 15px;
	}
	.sustainability ul.list {
		padding: 15px;
	}
	.sustainability ul.list > li {
		padding-left: 16px;
		background: url(../img/sustainability/icon_list_arrow.svg) no-repeat left 7px/9px;
	}
	.sustainability figure img {
		margin-bottom: 5px;
	}
}
/*-----------------------------------

	intro_block

-----------------------------------*/
#intro_block .contents_inner {
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
}
#intro_block .text {
	width: 49.5%;
}
#intro_block .text .mCopy {
	font: 700 2.6rem/1.92 var(--fJa);
}
#intro_block .text .mCopy span {
	color: var(--mClr1);
}
#intro_block .image {
	width: 46.4%;
}
@media screen and (max-width: 840px) {
	#intro_block .contents_inner {
		flex-direction: column;
		gap: 50px;
	}
	#intro_block .text {
		width: 100%;
	}
	#intro_block .image {
		width: 100%;
	}
}
@media screen and (max-width: 640px) {
	#intro_block .contents_inner {
		gap: 25px;
	}
	#intro_block .text .mCopy {
		font-size: 1.8rem;
	}
}
/*-----------------------------------

	safety_block

-----------------------------------*/
#safety_block .contents_inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#safety_block h2 {
	background: url(../img/sustainability/safety_hlbg.jpg) center center/cover;
}
#safety_block h2::before {
	content: "For Safety & Quality";
}
#safety_block .text {
	width: 50%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
#safety_block .image {
	width: 46.67%;
}
#safety_block .image .img01 {
	margin-bottom: 30px;
}
#safety_block .image .img01 img {
	border-radius: 20px;
}
#safety_block .image .img02 img {
	width: 202px;
	margin: 0 auto;
}
@media screen and (max-width: 840px) {
	#safety_block .text {
		width: 100%;
		margin-bottom: 50px;
	}
	#safety_block .image {
		width: 100%;
	}
}
@media screen and (max-width: 640px) {
	#safety_block .text {
		margin-bottom: 25px;
	}
	#safety_block .image .img01 {
		margin-bottom: 15px;
	}
	#safety_block .image .img01 img {
		border-radius: 10px;
	}
}
/*-----------------------------------

	environment_block

-----------------------------------*/
#environment_block .contents_inner > *:not(:last-child) {
	margin-bottom: 50px;
}
#environment_block h2 {
	background: url(../img/sustainability/environment_hlbg.jpg) center center/cover;
}
#environment_block h2::before {
	content: "For Environment";
}
#environment_block .image {
	display: flex;
	justify-content: center;
	align-items: end;
	gap: 40px;
}
#environment_block .image figure img {
	border-radius: 20px;
}
#environment_block .image .img01 img {
	width: 170px;
}
#environment_block .image .img02 img {
	width: 300px;
}
#environment_block .image .img03 img {
	width: 265px;
}
#environment_block .image .img04 img {
	width: 560px;
}
#environment_block .image .img05 img {
	width: 336px;
}
@media screen and (max-width: 640px) {
	#environment_block .contents_inner > *:not(:last-child) {
		margin-bottom: 25px;
	}
	#environment_block .image {
		flex-direction: column;
		align-items: center;
		gap: 20px;
	}
	#environment_block .image figure img {
		border-radius: 10px;
	}
}
/*-----------------------------------

	workers_block

-----------------------------------*/
#workers_block .contents_inner > *:not(:last-child) {
	margin-bottom: 50px;
}
#workers_block h2 {
	background: url(../img/sustainability/workers_hlbg.jpg) center center/cover;
}
#workers_block h2::before {
	content: "For Workers";
}
#workers_block .image {
	display: flex;
	justify-content: center;
	align-items: end;
	gap: 40px;
}
#workers_block .image figure img {
	border-radius: 20px;
	width: 560px;
	aspect-ratio: 28 / 17;
	object-fit: cover;
}
#workers_block .image .img04 img {
	object-fit: contain;
}
#workers_block a.link {
	padding: 20px 60px 20px 30px;
	border-radius: calc(1px/0);
	font-weight: 700;
	width: max-content;
	text-box: trim-both cap alphabetic;
	background: var(--sClr2) url(../img/sustainability/icon_link_arrow.svg) no-repeat calc(100% - 7px) center/38px;
	color: #FFF;
}
@media screen and (max-width: 640px) {
	#workers_block .contents_inner > *:not(:last-child) {
		margin-bottom: 25px;
	}
	#workers_block .image {
		flex-direction: column;
		align-items: center;
		gap: 20px;
	}
	#workers_block .image figure img {
		border-radius: 10px;
	}
}
/*-----------------------------------

	social_block

-----------------------------------*/
#social_block .contents_inner > *:not(:last-child) {
	margin-bottom: 50px;
}
#social_block h2 {
	background: url(../img/sustainability/social_hlbg.jpg) center center/cover;
}
#social_block h2::before {
	content: "For Social";
}
#social_block .inner {
	display: flex;
	justify-content: space-between;
}
#social_block .inner .text {
	width: 48.41%;
}
#social_block .inner .image {
	width: 46.67%;
}
#social_block .image {
	display: flex;
	justify-content: center;
	align-items: end;
	gap: 100px;
}
#social_block .image figure img {
	border-radius: 20px;
	width: 560px;
	aspect-ratio: 28 / 17;
	object-fit: cover;
}
#social_block .image .img03 img {
	width: 340px;
	aspect-ratio: 1.2 / 1;
}
#social_block .contents_inner > .text {
	text-align: center;
	padding: 50px 0;
	position: relative;
}
#social_block .contents_inner > .text::before,
#social_block .contents_inner > .text::after {
	content: "";
	width: 74px;
	height: 1px;
	background: var(--mClr1);
	position: absolute;
	left: calc(50% - 37px);
}
#social_block .contents_inner > .text::before {
	top: 0;
}
#social_block .contents_inner > .text::after {
	bottom: 0;
}
@media screen and (max-width: 840px) {
	#social_block .inner {
		flex-direction: column;
		gap: 50px;
	}
	#social_block .inner .text {
		width: 100%;
	}
	#social_block .inner .image {
		width: 100%;
	}
}
@media screen and (max-width: 640px) {
	#social_block .contents_inner > *:not(:last-child) {
		margin-bottom: 25px;
	}
	#social_block .inner {
		gap: 25px;
	}
	#social_block .image {
		flex-direction: column;
		align-items: center;
		gap: 20px;
	}
	#social_block .image figure img {
		border-radius: 10px;
	}
	#social_block .contents_inner > .text {
		padding: 25px 0;
	}
}