@charset "utf-8";

/* 代表あいさつ */
#message_Area {
	padding: 0 0 80px;
}

#message_Area .flex {
	gap: 50px;
}

#message_Area .flex>div {
	width: calc(100% - (400px + 50px));
}

#message_Area .flex>figure {
	max-width: 400px;
	width: 100%;
}

#message_Area .txt {
	color: #323232;
}

#message_Area figcaption {
	margin-top: 10px;
	font-size: 12px;
	text-align: center;
}

#message_Area figcaption em {
	font-size: 18px;
	font-family: 'Times New Roman', Times, serif;
	font-style: normal;
}

/* 企業理念 */
#policy_Area {
	position: relative;
	padding: 80px 0;
	overflow: hidden;
}

#policy_Area .bg_Img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: .2;
	z-index: -1;
}

#policy_Area .bg_Img::before {
	display: block;
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: #052e54;
	mix-blend-mode: difference;
	z-index: 0;
}

#policy_Area .bg_Img>img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top;
}

#policy_Block01 {
	flex-direction: row-reverse;
	justify-content: center;
	gap: 100px;
	padding: 0 0 40px;
}

#policy_Block01>article {
	flex-direction: row-reverse;
	justify-content: center;
}

#policy_Block01 h4,
#policy_Block01 p {
	font-size: min(4.5vw, 24px);
	font-family: 'Yu Mincho Light', 'YuMincho', 'Yu Mincho', '游明朝体', 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', sans-serif;
	writing-mode: vertical-rl;
	letter-spacing: 0.5em;
	line-height: 1.8;
}

#policy_Block01 h4 {
	padding: 2em 0 0 0.5em;
}

#policy_Block01 .motto p {
	text-indent: -3em;
	padding-top: 3em;
	line-height: 1.2;
	box-sizing: border-box;
}

#policy_Block01 .motto p:not(:first-child) {
	margin-left: 1em;
}

#policy_Block02 {
	position: relative;
	width: fit-content;
	margin: 0 auto;
	padding: 40px 5em;
	background-color: rgba(255, 255, 255, .5);
	box-sizing: border-box;
	z-index: 1;
}

#policy_Block02>article {
	width: fit-content;
	margin: 0 auto;
	padding: 30px;
	box-sizing: border-box;
}

#policy_Block02>article h4,
#policy_Block02>article p {
	font-size: min(4.5vw, 22px);
	letter-spacing: 0.1em;
}

#policy_Block02>article p:not(:first-child) {
	margin-top: 1em;
}

#policy_Block03 {
	padding: 80px 0 0;
	background-color: #fff;
}

.copy {
	width: 80%;
	margin: 0 auto 50px;
}

#policy_Block03 .flex {
	justify-content: center;
	align-items: flex-start;
	gap: 50px;
}

#policy_Block03 .flex>div {
	width: calc((100% - 100px) / 3);
	box-sizing: border-box;
	text-align: center;
	cursor: pointer;
}

#policy_Block03 .flex>div figure {
	width: auto;
	height: 45px;
	margin: 0 auto 20px;
}

#policy_Block03 .flex>div figure img {
	width: auto;
	height: 100%;
}

#policy_Block03 .flex>div p {
	color: #323232;
	font-size: 16px;
	line-height: 2;
}

#policy_Block03 .flex>div p .blue {
	color: #0073BB;
	font-weight: 600;
}


#policy_Block03 .flex>div:hover figure {
	animation: poyopoyo 2s ease-out infinite;
}

@keyframes poyopoyo {

	0%,
	40%,
	60%,
	80% {
		transform: scale(1.0);
	}

	50%,
	70% {
		transform: scale(0.95);
	}
}

@media (max-width:900px) {

	/* 代表あいさつ */
	#message_Area {
		padding: 80px 0;
	}

	#message_Area .flex {
		flex-direction: column;
		flex-wrap: wrap;
		gap: 30px;
	}

	#message_Area .flex>div {
		width: 100%;
	}

	#message_Area .flex>figure {
		max-width: 100%;
		width: 100%;
	}

	/* 企業理念 */
	#policy_Block01 {
		flex-direction: column;
		gap: 50px;
	}

	#policy_Block02 {
		width: 90%;
		padding: 10px;
	}

	#policy_Block02 p {
		text-indent: -2.1em;
		padding-left: 2.1em;
		line-height: 1.5;
	}

	.copy {
		width: 90%;
	}

	#policy_Block03 .flex {
		flex-direction: column;
		flex-wrap: wrap;
		gap: 50px;
	}

	#policy_Block03 .flex>div {
		width: 100%;
	}

	#policy_Block03 .flex>div figure {
		height: 30px;
		margin: 0 auto 10px;
		animation: poyopoyo 2s ease-out infinite;
	}

	#policy_Block03 .flex>div:hover figure {
		animation: none;
	}
}