@charset "UTF-8";
/*
	* Bootstrap 単独ページに掛かる関するカスタムCSS

	@media screen and (max-width: 1499.98px) {}
	@media (max-width: 991.98px) {}
	@media print {}
	@media screen and (max-width: 767px) {}
 
	xxl-1500over(min-1500)
	xl-1500(max-1499) 左右余白15pxを含む（1470）
	lg-992(max-991)
	md-768(max-767)
	sm-576(max-575)
 
	-------------------

*/

/* Bootstrapスライドに関わるCSS */
	#myCarousel{
		width: 100%;
	}
	.cus-mv{
		position: relative;
	}
	.cus-mv-slide-normal{
		overflow: hidden;
		position: relative;
		margin: 0;
		width: 100%;
		height: 100vh; /* 画像高さを指定 */
	}
	.cus-mv-slide-normal img{
		width: 100%;
		height: 100%;
		object-fit: cover;
	}

	.carousel-indicators {/* ドット（インジケーター）を右端に縦で表示したい場合こちら */
		right: 30px;
		left: auto;
		bottom: auto;
		top: 50%;
		transform: translateY(-50%);
		flex-direction: column; 
		margin: 0;
		width: auto;
	}
	.carousel-indicators button {
		position: relative;
		width: 10px !important;
		height: 10px !important;
		border-radius: 50%;
		background-color: #fff;
		border: none;
		margin: 0 !important;
		opacity: 0.5;
	}
	.carousel-indicators .active::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		width: 18px;
		height: 18px;
		background-color: #fff;
		opacity: 0.5;
		border-radius: 50%;
		z-index: -1;
	}

	.carousel-control-prev,
	.carousel-control-next {/* 左右の矢印ボタンを画像の上に重ねて中央に配置 */
		width: 5%;    /* ボタンの反応範囲 */
		z-index: 10;
	}

	.mv-midashi{
		position: absolute;
		bottom: 24%;
		left: 2%;
		display: flex;
		flex-direction: column-reverse;
		z-index: 3;
		
		transition: all 0.5s 0s ease;
	}
	.mv-midashi .en{
		background: linear-gradient(to right, #33c4f8, #0478c6);
		margin-bottom: 40px;
		font-family: 'Arial Black', sans-serif;
		font-weight: 900 !important;
		font-style: normal;
		font-size: 70px;
		line-height: 1;
		-webkit-background-clip: text;
		background-clip: text;
		color: transparent;
		filter: drop-shadow(4px 4px 0 rgba(255, 255, 255, 0.8));
	}
	.mv-midashi .main{
		font-size: 40px;
		color: white;
		letter-spacing: 0.08em;
		transition: all 0.5s 0s ease;
	}
	.mv-midashi .main .text01,
	.mv-midashi .main .text02{
		position: relative;
		display: inline-block;
		padding: 10px 15px 10px 10px;
		overflow: hidden;
		background-color: transparent;
	}
	.mv-midashi .main .text01{
		margin-bottom: 2px;
	}
	.mv-midashi .main .text01 span,
	.mv-midashi .main .text02 span{
		display: inline-block;
		position: relative;
		z-index: 2;
		clip-path: polygon(0 0, 0 0, 0 100%, 0% 100%);
		animation: mvTextWipeIn 0.6s forwards ease-out;
	}
	.mv-midashi .main .text01 span{
		animation-delay: 0.4s;
	}
	.mv-midashi .main .text02 span{
		animation-delay: 1.8s;
	}
	.mv-midashi .main .text01::before,
	.mv-midashi .main .text02::before{
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		z-index: 1; /* 【重要】文字の後ろ、コンテナの枠内に配置 */
		width: 100%;
		height: 100%;
		background-color: rgba(57, 153, 218, 0.8);
		transform-origin: left center;
		transform: scaleX(0);
		animation: mvBgExtend 0.6s forwards cubic-bezier(0.25, 1, 0.5, 1);
	}
	.mv-midashi .main .text01::before{
		animation-delay: 0.2s;
	}
	.mv-midashi .main .text02::before{
		animation-delay: 1.6s;
	}
	@keyframes mvBgExtend {
		0% {
			transform: scaleX(0);
		}
		100% {
			transform: scaleX(1);
		}
	}
	@keyframes mvTextWipeIn {
		0% {
			clip-path: polygon(0 0, 0 0, 0 100%, 0% 100%);
		}
		100% {
			clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%); /* 全開にする */
		}
	}

	.cus-mv .mv-arrow{
		position: absolute;
		bottom: 30px;
		right: 2%;
		z-index: 3;
		width: 22px;
		animation: bounce 3s infinite;
	}
	@keyframes bounce {
		0%, 20%, 50%, 80%, 100% {
			transform: translateY(0);
		}
		40% {
			transform: translateY(-15px);
		}
		60% {
			transform: translateY(-7px);
		}
	}
	@media screen and (max-width: 1499.98px) {
		.mv-midashi .en{
			margin-bottom: 40px;
			font-size: 4.6vw;
		}
		.mv-midashi .main{
			font-size: 3vw;
		}
	}
	@media (max-width: 991.98px) {
		.mv-midashi .en{
			margin-bottom: 40px;
			font-size: 5vw;
			filter: drop-shadow(3px 3px 0 rgba(255, 255, 255, 0.8));
		}
		.mv-midashi .main{
			font-size: 3.6vw;
		}
	}
	@media print {
		.cus-mv-slide-normal{
			height: 320px; /* 画像高さを指定 */
		}
		.mv-midashi .en{
			margin-bottom: 40px;
			font-size: 5vw;
			filter: drop-shadow(3px 3px 0 rgba(255, 255, 255, 0.8));
		}
		.mv-midashi .main{
			font-size: 3.6vw;
		}
		.mv-midashi .main .text01,
		.mv-midashi .main .text02 {
			background-color: rgba(57, 153, 218, 0.8) !important;
		}
		.mv-midashi .main .text01 span,
		.mv-midashi .main .text02 span {
			color: #ffffff !important;
			clip-path: none !important;
			animation: none !important;
		}
		.mv-midashi .main .text01::before,
		.mv-midashi .main .text02::before {
			display: none !important;
		}
	}
	@media screen and (max-width: 767px) {
		.cus-mv-slide-normal{
			height: 86vh; /* 画像高さを指定 */
		}
		.mv-midashi .en{
			margin-bottom: 30px;
			font-size: 28px;
			filter: drop-shadow(2px 2px 0 rgba(255, 255, 255, 0.8));
		}
		.mv-midashi .main{
			font-size: 18px;
		}
	}

/* area02 */
	.cus-home-area02{
		background-image: url("../img/home/area02-bg.jpg");
		background-position: center center;
		background-size: cover;
		background-attachment: fixed; 
		padding: 120px 0;
	}

	.cus-home-area02-col{
    background: linear-gradient(to right, rgba(231, 249, 255, 0.8), rgba(138, 193, 229, 0.8));
		box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
		padding: 40px 0 80px 0;
		margin: 0 auto;
		width: 960px;
	}

	.cus-home-area02-col .col-bt{
		margin: 0 auto !important;
	}
	@media screen and (max-width: 1499.98px) {
		.cus-home-area02{
			padding: 100px 0;
		}
	
		.cus-home-area02-col{
			padding: 30px 0 60px 0;
			width: 940px;
		}
	}
	@media (max-width: 991.98px) {
		.cus-home-area02{
			padding: 80px 0;
		}
	
		.cus-home-area02-col{
			padding: 20px 0 40px 0;
			width: 94%;
		}
	}
	@media print {
		.cus-home-area02{
			background-attachment: scroll;
			padding: 60px 0;
		}

		.cus-home-area02-col{
			padding: 15px 0 20px 0;
			width: 94%;
		}
	}
	@media (max-width: 767px) {
		.cus-home-area02{
			background-attachment: scroll; 
			padding: 60px 0;
    }
    .cus-home-area02-col{
			padding: 15px 15px 20px 15px;
			width: 94%;
    }
	}


/* 採用について */
	.cus-recruit-area01-col01{
		position: relative;
	}
	.cus-recruit-area01-col01 .col01-arrow{
		position: absolute;
		bottom: 25px;
		left: 70px;
		background: linear-gradient(to right, #077dc9, #32c3f7);
		padding: 15px 60px 15px 15px;
		margin: 0;
		font-size: 24px;
		color: white;
    clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
        0% 0%, 
        calc(100% - 40px) 0%, 
        100% 50%, 
        calc(100% - 40px) 100%, 
        0% 100%
    );
		z-index: 3;
	}

	.cus-recruit-area01-photo{
		position: relative;
		padding-right: 30px;
		width: 100%;
		height: 405px;
		z-index: 3;
	}
	.cus-recruit-area01-photo::before{
		content: '';
		position: absolute;
		top: 40px;
		left: 0px;
		width: 100%;
		height: 100%;
		background-color: #32c3f7;
		clip-path: polygon(
			0% 0px,
			100% 0%,
			calc(100% - 40px) calc(100% - 40px),
			0px calc(100% - 40px)
    );
		z-index: -1;
	}
	.cus-recruit-area01-photo .img{
		display: block;
		width: 100%;
		height: 405px;
		clip-path: polygon(
			0% 40px,
			100% 0%,
			100% calc(100% - 40px),
			0% 100%
    );
	}
	.cus-recruit-area01-photo .img img{
		width: 100%;
		height: 100%;
		object-fit: cover;
		font-family: 'object-fit: cover;';
	}

	.cus-recruit-area01-text{
		position: relative;
		background-color: #077dc9;
		padding: 60px;
		margin-left: 20px;
		height: auto;
		min-height: 360px;
		z-index: 1;
		clip-path: polygon(
			60px 0%, 
			100% 0%, 
			100% calc(100% - 60px), 
			calc(100% - 60px) 100%, 
			0% 100%, 
			0% 60px
		);
	}
	.cus-recruit-area01-text::before{
		content: '';
		position: absolute;
		top: 2px;
		left: 2px;
		right: 2px;
		bottom: 2px;
		background-color: #e5f8ff; 
		z-index: -1;
		clip-path: polygon(
			60px 0%, 
			100% 0%, 
			100% calc(100% - 60px), 
			calc(100% - 60px) 100%, 
			0% 100%, 
			0% 60px
		);
	}

	.cus-recruit-area01-text .text-title{
		border-bottom: #32c3f7 dashed 2px;
	}
	.cus-recruit-area01-text .text-title .inner{
		position: relative;
		top: 2px;
		display: inline-block;
		background: linear-gradient(to right, #077dc9, #32c3f7);
		padding: 12px 15px;
		font-size: 18px;
		font-weight: 600;
		color: white;
	}
	@media screen and (max-width: 1499.98px) {
		.cus-recruit-area01-col01 .col01-arrow{
			bottom: 30px;
			left: 60px;
			padding: 13px 50px 13px 15px;
			font-size: 20px;
			clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
					0% 0%, 
					calc(100% - 30px) 0%, 
					100% 50%, 
					calc(100% - 30px) 100%, 
					0% 100%
			);
		}
	
		.cus-recruit-area01-photo{
			padding-right: 26px;
			height: 405px;
		}
		.cus-recruit-area01-photo::before{
			top: 35px;
			background-color: #32c3f7;
			clip-path: polygon(
				0% 0px,
				100% 0%,
				calc(100% - 40px) calc(100% - 40px),
				0px calc(100% - 40px)
			);
		}
		.cus-recruit-area01-photo .img{
			height: 405px;
			clip-path: polygon(
				0% 35px,
				100% 0%,
				100% calc(100% - 35px),
				0% 100%
			);
		}
	
		.cus-recruit-area01-text{
			padding: 50px 40px;
			margin-left: 15px;
			min-height: 360px;
			clip-path: polygon(
				50px 0%, 
				100% 0%, 
				100% calc(100% - 50px), 
				calc(100% - 50px) 100%, 
				0% 100%, 
				0% 50px
			);
		}
		.cus-recruit-area01-text::before{
			clip-path: polygon(
				50px 0%, 
				100% 0%, 
				100% calc(100% - 50px), 
				calc(100% - 50px) 100%, 
				0% 100%, 
				0% 50px
			);
		}

		.cus-recruit-area01-text .text-title .inner{
			padding: 10px 12px;
			font-size: 17px;
		}
	}
	@media (max-width: 991.98px) {
		.cus-recruit-area01-col01 .col01-arrow{
			bottom: 34px;
			left: 40px;
			padding: 10px 35px 10px 10px;
			font-size: 18px;
			clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
					0% 0%, 
					calc(100% - 20px) 0%, 
					100% 50%, 
					calc(100% - 20px) 100%, 
					0% 100%
			);
		}
	
		.cus-recruit-area01-photo{
			padding-right: 20px;
			height: 340px;
		}
		.cus-recruit-area01-photo::before{
			top: 30px;
			background-color: #32c3f7;
			clip-path: polygon(
				0% 0px,
				100% 0%,
				calc(100% - 34px) calc(100% - 34px),
				0px calc(100% - 34px)
			);
		}
		.cus-recruit-area01-photo .img{
			height: 340px;
			clip-path: polygon(
				0% 30px,
				100% 0%,
				100% calc(100% - 30px),
				0% 100%
			);
		}
	
		.cus-recruit-area01-text{
			padding: 30px;
			margin-left: 15px;
			min-height: 300px;
			clip-path: polygon(
				40px 0%, 
				100% 0%, 
				100% calc(100% - 40px), 
				calc(100% - 40px) 100%, 
				0% 100%, 
				0% 40px
			);
		}
		.cus-recruit-area01-text::before{
			clip-path: polygon(
				40px 0%, 
				100% 0%, 
				100% calc(100% - 40px), 
				calc(100% - 40px) 100%, 
				0% 100%, 
				0% 40px
			);
		}

		.cus-recruit-area01-text .text-title .inner{
			padding: 10px 12px;
			font-size: 16px;
		}
	}
	@media print {
		.cus-recruit-area01-col01 .col01-arrow{
			bottom: 40px;
			left: 25px;
			padding: 10px 35px 10px 10px;
			font-size: 16px;
			clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
					0% 0%, 
					calc(100% - 15px) 0%, 
					100% 50%, 
					calc(100% - 15px) 100%, 
					0% 100%
			);
		}
	
		.cus-recruit-area01-photo{
			padding-right: 15px;
			height: 340px;
		}
		.cus-recruit-area01-photo::before{
			top: 30px;
			background-color: #32c3f7;
			clip-path: polygon(
				0% 0px,
				100% 0%,
				calc(100% - 30px) calc(100% - 30px),
				0px calc(100% - 30px)
			);
		}
		.cus-recruit-area01-photo .img{
			height: 340px;
			clip-path: polygon(
				0% 25px,
				100% 0%,
				100% calc(100% - 25px),
				0% 100%
			);
		}
	
		.cus-recruit-area01-text{
			padding: 30px;
			margin-left: 15px;
			min-height: 300px;
			clip-path: polygon(
				30px 0%, 
				100% 0%, 
				100% calc(100% - 30px), 
				calc(100% - 30px) 100%, 
				0% 100%, 
				0% 30px
			);
		}
		.cus-recruit-area01-text::before{
			clip-path: polygon(
				30px 0%, 
				100% 0%, 
				100% calc(100% - 30px), 
				calc(100% - 30px) 100%, 
				0% 100%, 
				0% 30px
			);
		}

		.cus-recruit-area01-text .text-title .inner{
			padding: 8px 10px;
			font-size: 14px;
		}
	}
	@media screen and (max-width: 767px) {
		.cus-recruit-area01-col01 .col01-arrow{
			bottom: -20px;
			left: 3%;
			padding: 10px 30px 10px 10px;
			font-size: 16px;
			clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
					0% 0%, 
					calc(100% - 15px) 0%, 
					100% 50%, 
					calc(100% - 15px) 100%, 
					0% 100%
			);
		}
	
		.cus-recruit-area01-photo{
			padding-right: 20px;
			height: 56vw;
		}
		.cus-recruit-area01-photo::before{
			top: 20px;
			background-color: #32c3f7;
			clip-path: polygon(
				15px 0px,
				100% 0%,
				calc(100% - 30px) calc(100% - 30px),
				0px calc(100% - 30px)
			);
		}
		.cus-recruit-area01-photo .img{
			height: 56vw;
			clip-path: polygon(
				0% 30px,
				100% 0%,
				100% calc(100% - 25px),
				0% 100%
			);
		}
	
		.cus-recruit-area01-text{
			padding: 15px 25px 25px 25px;
			margin-left: 0px;
			min-height: 100px;
			clip-path: polygon(
				25px 0%, 
				100% 0%, 
				100% calc(100% - 25px), 
				calc(100% - 25px) 100%, 
				0% 100%, 
				0% 25px
			);
		}
		.cus-recruit-area01-text::before{
			clip-path: polygon(
				25px 0%, 
				100% 0%, 
				100% calc(100% - 25px), 
				calc(100% - 25px) 100%, 
				0% 100%, 
				0% 25px
			);
		}

		.cus-recruit-area01-text .text-title .inner{
			padding: 8px 10px;
			font-size: 16px;
		}
	}

/* area02 */
	.cus-recruit-area02-col01{
		display: flex;
		justify-content: center;
		align-items: center;
	}
	.cus-recruit-area02-col01 .col01-link{
		position: relative;
		display: block;
		width: 33.333%;
	}

	.cus-recruit-area02-col01 .col01-link .link-main{
		position: absolute;
		top: 0px;
		left: 0px;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		text-align: center;
		padding: 0 30px;
		width: 100%;
		height: 100%;
		z-index: 6;
	}
	.cus-recruit-area02-col01 .col01-link .link-main .link-title{
		position: absolute;
		top: 50%;
		color: white;
		transform: translateY(-50%) scale(1);
		transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1), top 0.6s cubic-bezier(0.25, 1, 0.5, 1);
	}
	.cus-recruit-area02-col01 .col01-link .link-main .link-title .en{
		position: relative;
		padding: 0 30px;
		font-family: 'Arial Black', sans-serif;
		font-weight: 900 !important;
		font-style: normal;
		font-size: 32px;
	}
	.cus-recruit-area02-col01 .col01-link .link-main .link-title .en::before{
		content: '';
		position: absolute;
		top: 0px;
		left: 0px;
		border: white solid 1px;
		width: 100%;
		height: 100%;
	}
	.cus-recruit-area02-col01 .col01-link .link-main .link-title .en::after{
		content: '';
		position: absolute;
		top: 5px;
		left: 5px;
		border: white solid 1px;
		width: 100%;
		height: 100%;
		opacity: 0.6;
	}
	.cus-recruit-area02-col01 .col01-link .link-main .link-title .number{
		font-family: 'Arial Black', sans-serif;
		font-weight: 900 !important;
		font-style: normal;
		font-size: 60px;
		line-height: 1.4;
	}
	.cus-recruit-area02-col01 .col01-link .link-main .link-text{
		position: relative;
		top: 60px;
		color: white;
		text-align: left;
		transform: translateY(40px);
		transition: opacity 0.6s ease, transform 0.6s ease;
		opacity: 0;
		pointer-events: none;
	}
	.cus-recruit-area02-col01 .col01-link .link-main .link-text .main{
		margin-bottom: 10px;
		font-size: 24px;
		font-weight: 600;
	}
	.cus-recruit-area02-col01 .col01-link:hover .link-main .link-title{
		top: 20%;
	}
	.cus-recruit-area02-col01 .col01-link:hover .link-main .link-text{
		transform: translateY(0);
		pointer-events: auto;
		transition-delay: 0.15s;
		opacity: 1;
	}

	.cus-recruit-area02-col01 .col01-link .link-photo{
		position: relative;
		background-color: #077dc9;
		margin: 0;
		width: 100%;
		height: 600px;
		transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1), background-color 0.6s ease;
	}
	.cus-recruit-area02-col01 .col01-link .link-photo img{
		width: 100%;
		height: 600px;
		object-fit: cover;
		font-family: 'object-fit: cover;';
		opacity: 0.4;
	}
	.cus-recruit-area02-col01 .col01-link:hover .link-photo{
		transform: scale(1.05);
		transition: 0.7s all;
		background-color: #222222;
		z-index: 3;
	}
	@media screen and (max-width: 1499.98px) {
		.cus-recruit-area02-col01 .col01-link .link-main{
			padding: 0 20px;
		}
		.cus-recruit-area02-col01 .col01-link .link-main .link-title .en{
			padding: 0 25px;
			font-size: 28px;
		}
		.cus-recruit-area02-col01 .col01-link .link-main .link-title .number{
			font-size: 52px;
		}
		.cus-recruit-area02-col01 .col01-link .link-main .link-text .main{
			font-size: 21px;
		}
	
		.cus-recruit-area02-col01 .col01-link .link-photo{
			height: 520px;
		}
		.cus-recruit-area02-col01 .col01-link .link-photo img{
			height: 520px;
		}
	}
	@media (max-width: 991.98px) {
		.cus-recruit-area02-col01 .col01-link .link-main{
			padding: 0 15px;
		}
		.cus-recruit-area02-col01 .col01-link .link-main .link-title .en{
			padding: 0 20px;
			font-size: 24px;
		}
		.cus-recruit-area02-col01 .col01-link .link-main .link-title .number{
			font-size: 46px;
		}
		.cus-recruit-area02-col01 .col01-link .link-main .link-text .main{
			font-size: 19px;
		}
	
		.cus-recruit-area02-col01 .col01-link .link-photo{
			height: 480px;
		}
		.cus-recruit-area02-col01 .col01-link .link-photo img{
			height: 480px;
		}
	}
	@media print {
		.cus-recruit-area02-col01 .col01-link .link-main{
			padding: 0 15px;
		}
		.cus-recruit-area02-col01 .col01-link .link-main .link-title .en{
			padding: 0 20px;
			font-size: 24px;
		}
		.cus-recruit-area02-col01 .col01-link .link-main .link-title .number{
			font-size: 46px;
		}
		.cus-recruit-area02-col01 .col01-link .link-main .link-text .main{
			font-size: 19px;
		}
	
		.cus-recruit-area02-col01 .col01-link .link-photo{
			height: 510px;
		}
		.cus-recruit-area02-col01 .col01-link .link-photo img{
			height: 510px;
		}

		.cus-recruit-area02-col01 .col01-link .link-main .link-title{/* 印刷時表示 */
			top: 20%;
		}
		.cus-recruit-area02-col01 .col01-link .link-main .link-text{/* 印刷時表示 */
			transform: translateY(0);
			pointer-events: auto;
			transition-delay: 0.15s;
			opacity: 1;
		}
		.cus-recruit-area02-col01 .col01-link .link-photo{/* 印刷時表示 */
			background-color: #222222;
		}
	}
	@media screen and (max-width: 767px) {
		.cus-recruit-area02-col01{
			display: block;
		}
		.cus-recruit-area02-col01 .col01-link{
			width: auto;
		}
		.cus-recruit-area02-col01 .col01-link .link-main{
			padding: 0 15px;
		}
		.cus-recruit-area02-col01 .col01-link .link-main .link-title .en{
			padding: 0 20px;
			font-size: 24px;
		}
		.cus-recruit-area02-col01 .col01-link .link-main .link-title .number{
			font-size: 46px;
		}
		.cus-recruit-area02-col01 .col01-link .link-main .link-text .main{
			font-size: 19px;
		}
	
		.cus-recruit-area02-col01 .col01-link .link-photo{
			height: 380px;
		}
		.cus-recruit-area02-col01 .col01-link .link-photo img{
			height: 380px;
		}

		.cus-recruit-area02-col01 .col01-link .link-main .link-title{/* スマホ時表示 */
			top: 20%;
		}
		.cus-recruit-area02-col01 .col01-link .link-main .link-text{/* スマホ時表示 */
			transform: translateY(0);
			pointer-events: auto;
			transition-delay: 0.15s;
			opacity: 1;
		}
		.cus-recruit-area02-col01 .col01-link .link-photo{/* スマホ時表示 */
			background-color: #222222;
		}
	}

/* area04 */
	.cus-recruit-area04-col{
		position: relative;
		height: 340px;
	}
	.cus-recruit-area04-col .col-arrow01{
		position: absolute;
		top: 0px;
		left: 0px;
    background: linear-gradient(to right, #e2f4fb, #9bd0eb);
    clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
        0% 0%, 
        calc(100% - 50px) 0%, 
        100% 50%, 
        calc(100% - 50px) 100%, 
        0% 100%, 
        50px 50%
    );
		padding: 20px 50px;
		width: 51%;
		height: 100%;
		z-index: 3;
	}
	.cus-recruit-area04-col .col-arrow02{
		position: absolute;
		top: 0px;
		left: 49%;
    background: linear-gradient(to right, #e2f4fb, #9bd0eb);
    clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
        0% 0%, 
        calc(100% - 50px) 0%, 
        100% 50%, 
        calc(100% - 50px) 100%, 
        0% 100%, 
        50px 50%
    );
		padding: 20px 50px;
		width: 51%;
		height: 100%;
		z-index: 2;
	}

	.cus-recruit-area04-title{
		position: relative;
		display: inline-block;
		padding: 0 40px 15px 2px;
		margin-bottom: 60px;
		font-size: 32px;
		font-weight: 600;
		line-height: 1.4;
	}
	.cus-recruit-area04-title::before{
		content: '';
		position: absolute;
		bottom: 0px;
		left: 0px;
		background-color: #0478c6;
		width: 100%;
		height: 1px;
	}

	.cus-recruit-area04-dial{
		display: flex;
		align-items: center;
		padding: 0 50px;
		gap: 20px;
	}
	.cus-recruit-area04-mail{
		display: flex;
		align-items: center;
		padding: 0 50px;
		gap: 20px;
	}
	.cus-recruit-area04-dial .ic,
	.cus-recruit-area04-mail .ic{
		position: relative;
		top: 5px;
		width: 80px;
	}
	.cus-recruit-area04-dial .ic .target-icon,
	.cus-recruit-area04-mail .ic .target-icon{
		fill: #005791;
	}
	.cus-recruit-area04-dial .main .phone-dial{
		font-family: 'Arial Black', sans-serif;
		font-weight: 900 !important;
		font-style: normal;
		font-size: 52px;
		letter-spacing: 0.08em;
		line-height: 1.4;
	}
	.cus-recruit-area04-dial .main .text02{
		padding-right: 10px;
		margin: 0;
		text-align: right;
	}

	.cus-recruit-area04-mail .mail{
		padding-top: 16px;
	}
	.cus-recruit-area04-mail .mail a{
		position: relative;
		font-family: 'Arial Black', sans-serif;
		font-weight: 900 !important;
		font-style: normal;
		font-size: 46px;
		color: initial;
		letter-spacing: 0.08em;
		line-height: 1.4;
		text-decoration: none;
	}
	.cus-recruit-area04-mail .mail a::before{
		content: '';
		position: absolute;
		bottom: 0px;
		right: -10%;
		background-image: url("../img/site/contact-mail-arrow.png");
		background-repeat: no-repeat;
		background-position: bottom right;
		width: 110%;
		height: 100%;
		transition: all 0.5s 0s ease;
	}
	.cus-recruit-area04-mail .mail a:hover::before{
		right: -20%;
		width: 120%;
		transition: all 0.5s 0s ease;
	}
	@media screen and (max-width: 1499.98px) {
		.cus-recruit-area04-col{
			height: 260px;
		}
		.cus-recruit-area04-col .col-arrow01{
			clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
					0% 0%, 
					calc(100% - 50px) 0%, 
					100% 50%, 
					calc(100% - 50px) 100%, 
					0% 100%, 
					50px 50%
			);
			padding: 20px 50px;
			width: 51%;
		}
		.cus-recruit-area04-col .col-arrow02{
			left: 49%;
			clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
					0% 0%, 
					calc(100% - 50px) 0%, 
					100% 50%, 
					calc(100% - 50px) 100%, 
					0% 100%, 
					50px 50%
			);
			padding: 20px 50px;
			width: 51%;
		}
	
		.cus-recruit-area04-title{
			padding: 0 30px 13px 2px;
			margin-bottom: 50px;
			font-size: 26px;
		}

		.cus-recruit-area04-dial{
			padding: 0 20px 0 40px;
			gap: 16px;
		}
		.cus-recruit-area04-mail{
			padding: 0 20px 0 40px;
			gap: 16px;

		}
		.cus-recruit-area04-dial .ic,
		.cus-recruit-area04-mail .ic{
			top: 5px;
			width: 50px;
		}
		.cus-recruit-area04-dial .ic svg,
		.cus-recruit-area04-mail .ic svg{
			width: 50px !important;
		}
		.cus-recruit-area04-dial .main .phone-dial{
			font-size: 3.1vw;
		}
		.cus-recruit-area04-dial .main .text02{
			padding-right: 6px;
		}
	
		.cus-recruit-area04-mail .mail{
			padding-top: 0px;
		}
		.cus-recruit-area04-mail .mail a{
			font-size: 3vw;
		}
	}
	@media (max-width: 991.98px) {
		.cus-recruit-area04-col{
			height: 220px;
		}
		.cus-recruit-area04-col .col-arrow01{
			clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
					0% 0%, 
					calc(100% - 40px) 0%, 
					100% 50%, 
					calc(100% - 40px) 100%, 
					0% 100%, 
					40px 50%
			);
			padding: 15px 40px;
			width: 51%;
		}
		.cus-recruit-area04-col .col-arrow02{
			left: 49%;
			clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
					0% 0%, 
					calc(100% - 40px) 0%, 
					100% 50%, 
					calc(100% - 40px) 100%, 
					0% 100%, 
					40px 50%
			);
			padding: 15px 40px;
			width: 51%;
		}
	
		.cus-recruit-area04-title{
			padding: 0 20px 10px 2px;
			margin-bottom: 40px;
			font-size: 21px;
		}

		.cus-recruit-area04-dial{
			padding: 0 10px 0 20px;
			gap: 12px;
		}
		.cus-recruit-area04-mail{
			padding: 0 10px 0 20px;
			gap: 12px;

		}
		.cus-recruit-area04-dial .ic,
		.cus-recruit-area04-mail .ic{
			top: 5px;
			width: 42px;
		}
		.cus-recruit-area04-dial .ic svg,
		.cus-recruit-area04-mail .ic svg{
			width: 42px !important;
		}
		.cus-recruit-area04-dial .main .phone-dial{
			font-size: 3.1vw;
		}
		.cus-recruit-area04-dial .main .text02{
			padding-right: 6px;
		}
	
		.cus-recruit-area04-mail .mail{
			padding-top: 0px;
		}
		.cus-recruit-area04-mail .mail a{
			font-size: 3vw;
		}
		.cus-recruit-area04-mail .mail a::before{
			background-size: auto 14px;
		}
	}
	@media print {
		.cus-recruit-area04-col{
			height: 200px;
		}
		.cus-recruit-area04-col .col-arrow01{
			clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
					0% 0%, 
					calc(100% - 34px) 0%, 
					100% 50%, 
					calc(100% - 34px) 100%, 
					0% 100%, 
					34px 50%
			);
			padding: 15px 30px;
			width: 51%;
		}
		.cus-recruit-area04-col .col-arrow02{
			left: 49%;
			clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
					0% 0%, 
					calc(100% - 34px) 0%, 
					100% 50%, 
					calc(100% - 34px) 100%, 
					0% 100%, 
					34px 50%
			);
			padding: 15px 30px;
			width: 51%;
		}
	
		.cus-recruit-area04-title{
			padding: 0 15px 10px 2px;
			margin-bottom: 30px;
			font-size: 18px;
		}

		.cus-recruit-area04-dial{
			padding: 0 0px 0 15px;
			gap: 10px;
		}
		.cus-recruit-area04-mail{
			padding: 0 0px 0 15px;
			gap: 10px;

		}
		.cus-recruit-area04-dial .ic,
		.cus-recruit-area04-mail .ic{
			top: 5px;
			width: 34px;
		}
		.cus-recruit-area04-dial .ic svg,
		.cus-recruit-area04-mail .ic svg{
			width: 34px !important;
		}
		.cus-recruit-area04-dial .main .phone-dial{
			font-size: 3.1vw;
		}
		.cus-recruit-area04-dial .main .text02{
			padding-right: 6px;
		}
	
		.cus-recruit-area04-mail .mail{
			padding-top: 0px;
		}
		.cus-recruit-area04-mail .mail a{
			font-size: 3vw;
		}
		.cus-recruit-area04-mail .mail a::before{
			background-size: auto 14px;
		}
	}
	@media screen and (max-width: 767px) {
		.cus-recruit-area04-col{
			display: block;
			height: auto;
		}
		.cus-recruit-area04-col .col-arrow01{
			position: static;
			clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
					0% 0%, 
					calc(100% - 26px) 0%, 
					100% 50%, 
					calc(100% - 26px) 100%, 
					0% 100%, 
					26px 50%
			);
			padding: 15px 30px;
			margin-bottom: 20px;
			width: auto;
		}
		.cus-recruit-area04-col .col-arrow02{
			position: static;
			clip-path: polygon( /* 要素を右向きの矢印型に切り抜く */
					0% 0%, 
					calc(100% - 26px) 0%, 
					100% 50%, 
					calc(100% - 26px) 100%, 
					0% 100%, 
					26px 50%
			);
			padding: 15px 30px;
			width: auto;
		}
	
		.cus-recruit-area04-title{
			padding: 0 15px 10px 2px;
			margin-bottom: 0px;
			font-size: 18px;
		}

		.cus-recruit-area04-dial{
			justify-content: center;
			padding: 0;
			gap: 10px;
		}
		.cus-recruit-area04-mail{
			justify-content: center;
			padding: 0;
			gap: 10px;

		}
		.cus-recruit-area04-dial .ic,
		.cus-recruit-area04-mail .ic{
			top: 5px;
			width: 34px;
		}
		.cus-recruit-area04-dial .ic svg,
		.cus-recruit-area04-mail .ic svg{
			width: 34px !important;
		}
		.cus-recruit-area04-dial .main .phone-dial{
			font-size: 22px;
		}
		.cus-recruit-area04-dial .main .text02{
			padding-right: 6px;
		}
	
		.cus-recruit-area04-mail .mail{
			padding-top: 0px;
		}
		.cus-recruit-area04-mail .mail a{
			font-size: 20px;
		}
		.cus-recruit-area04-mail .mail a::before{
			background-size: auto 14px;
		}
	}


/* 会社案内 */
	.cus-company-area01-text01{
		display: flex !important;
		margin: 0 !important;
	}

/* area02 */
	.cus-company-area02-photo{
		position: relative;
		padding-right: 30px;
		width: 100%;
		height: 500px;
		z-index: 3;
	}
	.cus-company-area02-photo::before{
		content: '';
		position: absolute;
		top: 40px;
		left: 0px;
		width: 100%;
		height: 100%;
		background-color: #32c3f7;
		clip-path: polygon(
			0% 0px,
			100% 0%,
			calc(100% - 40px) calc(100% - 40px),
			0px calc(100% - 40px)
    );
		z-index: -1;
	}
	.cus-company-area02-photo .img{
		display: block;
		width: 100%;
		height: 500px;
		clip-path: polygon(
			0% 40px,
			100% 0%,
			100% calc(100% - 40px),
			0% 100%
    );
	}
	.cus-company-area02-photo .img img{
		width: 100%;
		height: 100%;
		object-fit: cover;
		font-family: 'object-fit: cover;';
	}
	@media screen and (max-width: 1499.98px) {
		.cus-company-area02-photo{
			padding-right: 26px;
			height: 40vw;
		}
		.cus-company-area02-photo::before{
			top: 36px;
			clip-path: polygon(
				0% 0px,
				100% 0%,
				calc(100% - 36px) calc(100% - 36px),
				0px calc(100% - 36px)
			);
		}
		.cus-company-area02-photo .img{
			height: 40vw;
			clip-path: polygon(
				0% 36px,
				100% 0%,
				100% calc(100% - 36px),
				0% 100%
			);
		}
	}
	@media (max-width: 991.98px) {
		.cus-company-area02-photo{
			padding-right: 22px;
			height: 40vw;
		}
		.cus-company-area02-photo::before{
			top: 30px;
			clip-path: polygon(
				0% 0px,
				100% 0%,
				calc(100% - 30px) calc(100% - 30px),
				0px calc(100% - 30px)
			);
		}
		.cus-company-area02-photo .img{
			height: 40vw;
			clip-path: polygon(
				0% 30px,
				100% 0%,
				100% calc(100% - 30px),
				0% 100%
			);
		}
	}
	@media print {
		.cus-company-area02-photo{
			padding-right: 22px;
			height: 34vw;
		}
		.cus-company-area02-photo::before{
			top: 30px;
			clip-path: polygon(
				0% 0px,
				100% 0%,
				calc(100% - 30px) calc(100% - 30px),
				0px calc(100% - 30px)
			);
		}
		.cus-company-area02-photo .img{
			height: 34vw;
			clip-path: polygon(
				0% 30px,
				100% 0%,
				100% calc(100% - 30px),
				0% 100%
			);
		}
	}
	@media screen and (max-width: 767px) {
		.cus-company-area02-photo{
			padding-right: 20px;
			height: 62vw;
		}
		.cus-company-area02-photo::before{
			top: 24px;
			clip-path: polygon(
				0% 0px,
				100% 0%,
				calc(100% - 24px) calc(100% - 24px),
				0px calc(100% - 24px)
			);
		}
		.cus-company-area02-photo .img{
			height: 62vw;
			clip-path: polygon(
				0% 24px,
				100% 0%,
				100% calc(100% - 24px),
				0% 100%
			);
		}
	}


/* お問い合わせ */
	.cus-contact-area01{
		position: relative;
		background-image: url("../img/contact/area01-bg01.jpg");
		background-size: cover;
		background-position: center center;
		padding: 120px 0;
	}
	.cus-contact-area01::before{
		content: '';
		position: absolute;
		top: 0px;
		left: 0px;
		background: linear-gradient(to right, #33c4f8, #0478c6);
		width: 100%;
		height: 100%;
		z-index: 0;
		opacity: 0.6;
	}

	.cus-contact-area01-title{
		position: relative;
		text-align: center;
		z-index: 3;
	}
	.cus-contact-area01-title .main{
		position: relative;
		display: inline-block;
		font-size: 32px;
		font-weight: 600;
		color: white;
		filter: drop-shadow(-3px 3px 4px rgba(0, 0, 0, 0.4));
	}
	.cus-contact-area01-title .main.main-bk{
		color: initial;
		filter: none;
	}
	.cus-contact-area01-title .main .inner{
		position: relative;
		display: inline-block;
	}
	.cus-contact-area01-title .main::before,
	.cus-contact-area01-title .main::after,
	.cus-contact-area01-title .main .inner::before,
	.cus-contact-area01-title .main .inner::after{
		content: '';
		position: absolute;
	}
	.cus-contact-area01-title .main::before{
		top: 0px;
		left: -80px;
		background: linear-gradient(to right, #33c4f8, #17a8db);
		width: 46px;
		height: 30px;
		transform: skewX(30deg);
		z-index: 3;
	}
	.cus-contact-area01-title .main::after{
		bottom: 0px;
		left: -64px;
		background: linear-gradient(to right, #0478c6, #005997);
		width: 46px;
		height: 30px;
		transform: skewX(30deg);
		z-index: 1;
	}
	.cus-contact-area01-title .main .inner::before{
		top: 0px;
		right: -64px;
		background: linear-gradient(to right, #33c4f8, #17a8db);
		width: 46px;
		height: 30px;
		transform: skewX(30deg);
		z-index: 3;
	}
	.cus-contact-area01-title .main .inner::after{
		bottom: 0px;
		right: -80px;
		background: linear-gradient(to right, #0478c6, #005997);
		width: 46px;
		height: 30px;
		transform: skewX(30deg);
		z-index: 1;
	}

	.cus-telephone{
		position: relative;
		z-index: 3;
		text-align: center;
	}
	.cus-telephone .telephone-box{
		display: inline-block;
		background-color: rgba(255, 255, 255, 0.8);
		padding: 50px 80px;
	}

	.cus-telephone .telephone-phone{
		font-family: 'Arial Black', sans-serif;
		font-weight: 900 !important;
		font-style: normal;
		font-size: 68px;
	}
	.cus-telephone .telephone-phone .ic01{
		position: relative;
		top: -2px;
		margin-right: 6px;
		width: 52px;
  	height: 52px;
  	fill: #0478c6;
	}
	
	.cus-telephone .telephone-text{
		display: flex;
		justify-content: space-between;
    align-items: center;
		padding-left: 90px;
	}
	.cus-telephone .telephone-text .text01,
	.cus-telephone .telephone-text .text02{
		font-size: 15px;
	}
	@media screen and (max-width: 1499.98px) {
		.cus-contact-area01-title .main{
			font-size: 27px;
		}
		.cus-contact-area01-title .main::before{
			left: -80px;
			width: 42px;
			height: 24px;
		}
		.cus-contact-area01-title .main::after{
			left: -64px;
			width: 42px;
			height: 24px;
		}
		.cus-contact-area01-title .main .inner::before{
			right: -64px;
			width: 42px;
			height: 24px;
		}
		.cus-contact-area01-title .main .inner::after{
			right: -80px;
			width: 42px;
			height: 24px;
		}

		.cus-telephone .telephone-phone{
			font-size: 56px;
		}
		.cus-telephone .telephone-phone .ic01{
			top: 0px;
			width: 46px;
			height: 46px;
		}
		.cus-telephone .telephone-text{
			padding-left: 76px;
		}
	}
	@media screen and (max-width: 991.98px) {
		.cus-contact-area01-title .main{
			font-size: 24px;
		}
		.cus-contact-area01-title .main::before{
			left: -76px;
			width: 36px;
			height: 20px;
		}
		.cus-contact-area01-title .main::after{
			left: -60px;
			width: 36px;
			height: 20px;
		}
		.cus-contact-area01-title .main .inner::before{
			right: -60px;
			width: 36px;
			height: 20px;
		}
		.cus-contact-area01-title .main .inner::after{
			right: -76px;
			width: 36px;
			height: 20px;
		}
		.cus-telephone .telephone-box{
			padding: 40px 60px;
		}
		.cus-telephone .telephone-phone{
			font-size: 50px;
		}
		.cus-telephone .telephone-phone .ic01{
			top: 0px;
			width: 42px;
			height: 42px;
		}
		.cus-telephone .telephone-text{
			padding-left: 4px;
		}
	}
	@media print {
		.cus-contact-area01-title .main{
			font-size: 24px;
		}
		.cus-contact-area01-title .main::before{
			left: -76px;
			width: 36px;
			height: 20px;
		}
		.cus-contact-area01-title .main::after{
			left: -60px;
			width: 36px;
			height: 20px;
		}
		.cus-contact-area01-title .main .inner::before{
			right: -60px;
			width: 36px;
			height: 20px;
		}
		.cus-contact-area01-title .main .inner::after{
			right: -76px;
			width: 36px;
			height: 20px;
		}

		.cus-telephone .telephone-box{
			padding: 30px 40px;
		}
		.cus-telephone .telephone-phone{
			font-size: 50px;
		}
		.cus-telephone .telephone-phone .ic01{
			top: 0px;
			width: 42px;
			height: 42px;
		}
		.cus-telephone .telephone-text{
			padding-left: 4px;
		}
	}
	@media screen and (max-width: 767px) {
		.cus-contact-area01-title .main{
			font-size: 22px;
		}
		.cus-contact-area01-title .main::before{
			top: 10px;
			left: -70px;
			width: 32px;
			height: 20px;
		}
		.cus-contact-area01-title .main::after{
			bottom: 10px;
			left: -54px;
			width: 32px;
			height: 20px;
		}
		.cus-contact-area01-title .main .inner::before{
			top: 10px;
			right: -54px;
			width: 32px;
			height: 20px;
		}
		.cus-contact-area01-title .main .inner::after{
			bottom: 10px;
			right: -70px;
			width: 32px;
			height: 20px;
		}

		.cus-telephone .telephone-box{
			padding: 30px 30px;
		}
		.cus-telephone .telephone-phone{
			font-size: 28px;
		}
		.cus-telephone .telephone-phone .ic01{
			top: 0px;
			width: 24px;
			height: 24px;
		}
		.cus-telephone .telephone-text{
			display: block;
			padding-left: 0px;
			text-align: center;
		}
		.cus-telephone .telephone-text .text01{
			margin-top: 10px;
		}
		.cus-telephone .telephone-text .text01,
		.cus-telephone .telephone-text .text02{
			display: block;
		}
	}

