@charset "utf-8";

/*
===== company_index ===========================*/

footer {
	background: #F1E2B0;
}

/* .c-headline_01
--------------------*/
#company_index .c-headline_01 .bg {
	background: url(/assets/company/img/index_bg_main.jpg) no-repeat 50% 100%;
	background-size: cover;
}

@media (max-width: 768px) {
	#company_index .c-headline_01 .bg {
		background: url(/assets/company/img/index_bg_main_sp.jpg) no-repeat 50% 100%;
		background-size: cover;
	}
}

/* p-philosophy
--------------------*/
#company_index .p-philosophy {
	margin: 64px 0 0;
}

#company_index .p-philosophy .wrap {
	position: relative;
	margin: 56px 0 0;
	padding-right: calc(50% + 44px);
}

#company_index .p-philosophy .wrap:nth-of-type(2n) {
	padding-right: 0;
	padding-left: calc(50% + 44px);
}

#company_index .p-philosophy .wrap h3 {
	display: flex;
	align-items: center;
	width: fit-content;
	height: 56px;
	padding: 0 20px;
	background: #000000;
	border-radius: 10px;
	color: #ffffff;
	font-size: 20px;
	font-weight: 700;
}

#company_index .p-philosophy .wrap dl {
	padding: 32px 0 0 24px;
}

#company_index .p-philosophy .wrap dt {
	font-size: 36px;
	font-weight: 700;
	line-height: 1.5;
}

#company_index .p-philosophy .wrap:nth-of-type(2n) dt {
	white-space: nowrap;
}

#company_index .p-philosophy .wrap dd {
	max-width: 504px;
	margin: 16px 0 0;
	font-size: 20px;
	font-weight: 700;
	line-height: 2;
}

#company_index .p-philosophy .wrap p {
	margin: 40px 28px 0 24px;
	padding: 24px;
	border: 1px solid rgba(0,0,0,0.3);
	border-radius: 10px;
	font-size: 16px;
	line-height: 2;
}

#company_index .p-philosophy .wrap figure {
	position: absolute;
	top: 0;
	left: 50%;
	width: 50vw;
	border-radius: 20px 0 0 20px;
	overflow: hidden;
}

#company_index .p-philosophy .wrap:nth-of-type(2n) figure {
	left: inherit;
	right: 50%;
	border-radius: 0 20px 20px 0;
}

@media (max-width: 1264px) {
	#company_index .p-philosophy .wrap:nth-of-type(2n) dt {
		white-space: wrap;
	}
}

@media (max-width: 1024px) {
	#company_index .p-philosophy .wrap,
	#company_index .p-philosophy .wrap:nth-of-type(2n) {
		padding: 0;
	}

	#company_index .p-philosophy .wrap figure {
		position: static;
		width: 72%;
		margin: 0 -32px 40px auto;
	}

	#company_index .p-philosophy .wrap:nth-of-type(2n) figure {
		margin: 0 0 40px -32px;
	}
}

@media (max-width: 768px) {
	#company_index .p-philosophy {
		margin: 32px 0 0;
	}

	#company_index .p-philosophy .wrap {
		margin: 32px 0 0;
	}

	#company_index .p-philosophy .wrap + .wrap {
		margin: 80px 0 0;
	}

	#company_index .p-philosophy .wrap h3 {
		height: 42px;
		padding: 0 16px;
		font-size: 16px;;
	}

	#company_index .p-philosophy .wrap dl {
		padding: 24px 0 0;
	}

	#company_index .p-philosophy .wrap dt {
		font-size: 28px;
		line-height: calc(38 / 28);
	}

	#company_index .p-philosophy .wrap:nth-of-type(2n) dt {
		white-space: wrap;
	}

	#company_index .p-philosophy .wrap dd {
		margin: 16px 0 0;
		font-size: 18px;
		line-height: 1.8;
	}

	#company_index .p-philosophy .wrap p {
		margin: 24px 0 0;
		padding: 20px;
	}

	#company_index .p-philosophy .wrap figure {
		position: static;
		width: calc(100% + (calc((20 / 335) * 100%)));
		margin: 0 calc((20 / 335) * -100%) 32px 0;
	}

	#company_index .p-philosophy .wrap:nth-of-type(2n) figure {
		margin: 0 0 32px calc((20 / 335) * -100%);
	}
}

/* p-profile
--------------------*/
#company_index .p-profile {
	margin: 64px 0 0;
	padding: 64px 0 108px;
	background: #F1E2B0;
}

#company_index .p-profile .wrap {
	max-width: 1000px;
	margin: 42px auto 0;
}

#company_index .p-profile .wrap > dl {
	display: flex;
	gap: 24px;
	border-bottom: 1px solid #A99E7B;
}

#company_index .p-profile .wrap > dl:last-of-type {
	border-bottom: none;
}

#company_index .p-profile .wrap > dl > dt {
	width: calc((256 / 1000) * 100%);
	padding: 24px 0;
}

#company_index .p-profile .wrap > dl > dd {
	flex: 1;
	padding: 24px 0;
}

#company_index .p-profile .wrap > dl > dd dl + dl {
	margin: 24px 0 0;
}

@media (max-width: 768px) {
	#company_index .p-profile {
		margin: 56px 0 0;
		padding: 32px 0 56px;
	}

	#company_index .p-profile .wrap {
		margin: 16px 0 0;
	}

	#company_index .p-profile .wrap > dl {
		display: block;
	}

	#company_index .p-profile .wrap > dl > dt {
		width: 100%;
		padding: 24px 0 0;
	}

	#company_index .p-profile .wrap > dl > dd {
		padding: 16px 0 24px;
	}

	#company_index .p-profile .wrap > dl > dd dl + dl {
		margin: 16px 0 0;
	}
}