/* 
 recruit
----------------------------------------------------------- */
body {
	/*--- ▼ゴシック ---*/
	font-family:"Noto Sans JP", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
h1,h2,h3,h4,h5,h6{
	line-height: 1.5;
}
.recruit #sub_fv {
	background-image: url('../images/recruit_fv.jpg');
}
.recruit_read .inner{
	padding-bottom: clamp(70px, 8.3vw, 160px);
	width: min(90%,1200px);
}
.recruit_read{
	background-color: #fff;
}
.recruit_read h2{
	font-size: clamp(60px, 5.7vw, 110px);
	font-weight: 700;
	font-family: 'Jost', sans-serif;
	line-height: 1.1;
	margin-bottom: clamp(20px, 5.7vw, 110px);
	animation: AnimationTitle 5s ease infinite;
	background: linear-gradient(to right, #0B3620, #1DA155, #0E483E);
	background-size: 200% 100%;
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	text-align: left;
}
@keyframes AnimationTitle {
	0% {
		background-position: 0% 50%;
	}
	50% {
		background-position: 100% 50%;
	}
	100% {
		background-position: 0% 50%;
	}
}
.recruit_read p{
	font-weight: 700;
	font-size: clamp(21px, 1.7vw, 33px);
}
.recruit_read p span{
	display: block;
}
.recruit_personnel {
	margin-top: calc(clamp(20px, 1.6vw, 30px) * -1);
	border-radius: clamp(20px, 1.6vw, 30px);
	background-image: url('../images/recruit_personnel_bg.jpg');
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	box-shadow: 0px -4px 10px 0px rgba(0, 0, 0, 0.05);
}
.recruit_personnel ol{
	display: grid;
	gap: clamp(20px, 1.6vw, 30px);
	grid-template-columns: repeat(3, 1fr);
	margin-bottom: clamp(40px, 4.1vw, 80px);
}
.recruit_personnel ol li{
	padding: clamp(20px, 2vw, 40px) clamp(25px, 2.6vw, 50px);
	border-radius: 5px;
	background-color: rgba(255,255,255,0.12);
	-webkit-backdrop-filter: brightness(1.1) blur(15px);
	backdrop-filter: brightness(1.1) blur(15px);
}
.recruit_personnel ol li > span{
	display: block;
	position: relative;
	line-height: 1;
	color: #B2B2B2;
	font-family: 'Jost', sans-serif;
	font-weight: 500;
	margin-bottom: clamp(10px, 1vw, 20px);
	font-size: clamp(30px, 3.1vw, 60px);
}
.recruit_personnel ol li > span::before{
	content: "";
	position: absolute;
	left: calc(clamp(25px, 2.6vw, 50px) * -1);
	top: 50%;
	transform: translateY(-50%);
	height: 1px;
	width: clamp(20px, 2vw, 40px);
	background-color: #B2B2B2;
}
.recruit_personnel ol li h3{
	font-size: var(--fontsize-25);
	color: var(--main-color);
	font-weight: 700;
	margin-bottom: 5px;
}
.recruit_personnel ol li h3 span{
	color: var(--font-color);
}
.recruit_personnel p.tac{
	font-size: var(--fontsize-20);
	font-weight: 500;
}
.recruit_attractiveness::before{
	content: "";
	display: block;
	position: fixed;
	top: 5%;
	left: 5%;
	z-index: -10;
	width: clamp(330px, 40.9vw, 785px);
	height: clamp(330px, 40.9vw, 785px);
	background-image: url('../images/recruit_attractiveness_bglogo.svg');
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
}
.recruit_attractiveness::after{
	content: "";
	display: block;
	position: fixed;
	top: 5%;
	left: 5%;
	z-index: -10;
	width: clamp(330px, 40.9vw, 785px);
	height: clamp(330px, 40.9vw, 785px);
	background-image: url('../images/recruit_attractiveness_bgtxt.svg');
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	animation: rotateForever 60s linear infinite;
}
@keyframes rotateForever {
	0% { transform: rotate(0deg); }
	100% { transform: rotate(360deg); }
}
.recruit_attractiveness .txt{
	display: flex;
	justify-content: flex-end;
	flex-wrap: wrap;
	margin-bottom: clamp(40px, 4.9vw, 95px);
}
.recruit_attractiveness .txt h3{
	color: var(--main-color);
	font-weight: 500;
	font-size: clamp(28px, 2.2vw, 42px);
	margin-right: 5%;
	line-height: 1.5;
}
.recruit_attractiveness .txt p{
	font-size: var(--fontsize-20);
}
.recruit_attractiveness .bg_box{
	background-color: rgba(240,236,233,0.4);
	border-radius: 5px;
	padding: clamp(30px, 6.8vw, 130px) clamp(20px, 6vw, 115px);
	-webkit-backdrop-filter: brightness(0.98) blur(5px);
	backdrop-filter: brightness(0.98) blur(5px);
}
.recruit_h2{
	color: #474141;
	font-size: clamp(23px, 1.7vw, 33px);
}
.recruit_h2 span{
	font-size: var(--fontsize-18);
	color: var(--main-color);
	display: block;
	font-family: 'Jost', sans-serif;
	letter-spacing: 0.1em;
}
.recruit_attractiveness .ttl{
	display: flex;
	flex-wrap: wrap;
	margin-bottom: clamp(30px, 3.4vw, 65px);
}
.recruit_attractiveness .recruit_h2{
	margin-right: clamp(40px, 4.9vw, 95px);
}
.recruit_attractiveness ol{
	margin-bottom: clamp(25px, 2.6vw, 50px);
}
.recruit_attractiveness ol li:not(:last-child){
	margin-bottom: clamp(30px, 3.4vw, 65px);
}
.recruit_attractiveness ol li{
	position: relative;
}
.recruit_attractiveness ol li .img{
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: clamp(170px, 15.6vw, 300px);
}
.recruit_attractiveness ol li:nth-child(even) .img{
	left: auto;
	right: 0;
}
.recruit_attractiveness ol li .img img{
	width: 100%;
	height: auto;
}
.recruit_attractiveness ol li .white_box{
	background-color: #fff;
	border-radius: 5px;
	padding: clamp(25px, 2.6vw, 50px) clamp(25px, 4.9vw, 95px) clamp(25px, 2.6vw, 50px) clamp(80px, 6.8vw, 130px);
	width: 85.5%;
	margin-left: auto;
}
.recruit_attractiveness ol li:nth-child(even) .white_box{
	margin-right: auto;
	margin-left: 0;
	padding: clamp(25px, 2.6vw, 50px) clamp(80px, 6.8vw, 130px) clamp(25px, 2.6vw, 50px) clamp(25px, 4.9vw, 95px);
}
.recruit_attractiveness ol li .white_box > span{
	color: var(--main-color);
	font-size: var(--fontsize-18);
	font-family: 'Jost', sans-serif;
	letter-spacing: 0.1em;
}
.recruit_attractiveness ol li .white_box > .sub_txt{
	color: var(--main-color);
	font-size: var(--fontsize-15);
}
.recruit_attractiveness ol li h3{
	color: var(--main-color);
	font-size: var(--fontsize-25);
	font-weight: 500;
}
.recruit_attractiveness ol li .txt_wrap{
	margin-top: clamp(10px, 0.8vw, 15px);
	margin-left: clamp(15px, 1vw, 20px);
	border-left: 1px solid #DAD2CA;
	padding: clamp(10px, 1vw, 20px) 0 clamp(10px, 1vw, 20px) clamp(20px, 2vw, 40px);
}
.recruit_attractiveness ol li .bg_box{
	padding: 20px clamp(20px, 2vw, 40px);
	margin: clamp(10px, 1vw, 20px) 0;
}
.recruit_attractiveness ol li .bg_box h4{
	color: var(--main-color);
	text-align: center;
	font-size: var(--fontsize-18);
	margin-bottom: clamp(10px, 1vw, 20px);
}
.recruit_attractiveness ol li .bg_box p span{
	display: inline-block;
	padding: 2px 10px;
	background-color: var(--main-color);
	color: #fff;
	font-size: var(--fontsize-15);
	margin-right: 10px;
}
.recruit_attractiveness ol li .bg_box p:first-of-type{
	margin-bottom: clamp(8px, 0.73vw, 14px);
}
.movie_ttl{
	padding: clamp(20px, 2.3vw, 45px) 0;
	text-align: center;
	margin-bottom: 4px;
	color: var(--main-color);
	font-size: var(--fontsize-20);
	background-image: url('../images/movie_ttl_bg.png');
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	font-weight: 500;
}
.movie_box{
	width: min(100%,800px);
	margin-inline: auto;
}
.recruit_imgbox{
	width: 90%;
	margin-left: auto;
	height: clamp(200px, 31.2vw, 600px);
	background-image: url('../images/recruit_imgbox.jpg');
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	border-radius: 5px 0 0 5px;
	z-index: 1;
	position: relative;
}
.recruit_data{
	margin-top: calc(clamp(100px, 15.6vw, 300px) * -1);
	background: linear-gradient(to right, #2C744B 50%, #67AD86);
}
.recruit_data .inner{
	padding-top: clamp(100px, 15.6vw, 300px);
	z-index: 2;
	position: relative;
	color: #fff;
}
.recruit_data .recruit_h2{
	padding: clamp(15px, 1.6vw, 30px) clamp(50px, 4.7vw, 90px) clamp(15px, 1.3vw, 25px) 0;
	border-radius: 0 5px 0 0;
	background: linear-gradient(to right top, #2C744B 65%, #67AD86);
	width: fit-content;
	color: #fff;
	margin-top: calc(clamp(30px, 3.4vw, 65px) * -1);
	margin-bottom: clamp(40px, 4.1vw, 80px);
}
.recruit_data .recruit_h2 span{
	color: #fff;
}
.recruit_data ul{
	display: grid;
	gap: 4px;
	grid-template-columns: repeat(3, 1fr);
}
.recruit_data ul li{
	padding: clamp(15px, 1.6vw, 30px) clamp(20px, 2vw, 40px);
	background-color: rgba(255,255,255,0.2);
	border-radius: 5px;
	position: relative;
	transition: transform 0.5s;
}
.recruit_data ul li:hover {
	transition: transform 0.5s;
	animation: card 0.5s ease-in forwards;
}
@keyframes card {
	to {
		transform: rotateY(360deg);
	}
}
.recruit_data ul li > span{
	display: inline-block;
	padding: 4px 15px;
	background-color: #FFF;
	border-radius: 3px;
	color: #01622C;
}
.recruit_data ul li > p{
	text-align: right;
	font-size: var(--fontsize-18);
}
.recruit_data ul li > p span{
	font-size: clamp(60px, 5.2vw, 100px);
	line-height: 1;
	font-weight: 500;
}
.recruit_data ul li > p span > span{
	font-size: clamp(25px, 2.6vw, 50px);
}
.recruit_data ul li > p > small{
	font-size: var(--fontsize-16);
	display: block;
}
.recruit_data ul li > p span > small{
	text-align: center;
	display: block;
	width: fit-content;
	font-size: var(--fontsize-16);
	margin: 0 auto;
}
.recruit_data ul li:nth-child(4) > p {
	display: flex;
	justify-content: flex-end;
	align-items: flex-end;
}
.recruit_data ul li > img{
	width: clamp(40px, 3.9vw, 75px);
	height: auto;
	position: absolute;
	left: clamp(20px, 2vw, 40px);
	bottom: clamp(15px, 1.6vw, 30px);
}
.recruit_benefits{
	background-color: #FFFFFF;
}
.recruit_benefits .inner{
	padding-bottom: clamp(70px, 8.3vw, 160px);
}
.recruit_benefits ul{
	display: grid;
	gap: 4px;
	grid-template-columns: repeat(4, 1fr);
}
.recruit_benefits ul li{
	position: relative;
	padding: clamp(20px, 2vw, 40px);
	border: 1px solid #D9D9D9;
	border-radius: 5px;
}
.recruit_benefits ul li::before{
	content: "";
	position: absolute;
	left: 50%;
	top: 0;
	transform: translateX(-50%);
	height: 4px;
	width: clamp(40px, 2.6vw, 50px);
	background-color: var(--main-color);
}
.recruit_benefits ul li img{
	width: clamp(45px, 3.1vw, 60px);
	height: auto;
	margin: 0 auto clamp(15px, 1.3vw, 25px);
}
.recruit_benefits ul li h3{
	color: var(--main-color);
	font-size: var(--fontsize-18);
	font-weight: 500;
	margin-bottom: 10px;
}
.recruit_benefits ul li p{
	color: #555;
	font-size: var(--fontsize-15);
}
.recruit_careers {
	margin-top: calc(clamp(20px, 1.6vw, 30px) * -1);
	border-radius: clamp(20px, 1.6vw, 30px);
	background-color: #F0ECE9;
	box-shadow: 0px -4px 10px 0px rgba(0, 0, 0, 0.05);
}
.hyo {
	overflow-x: auto;
}
.hyo dl {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.hyo dl:not(:last-of-type) {
	margin-bottom: clamp(10px, 1vw, 20px);
}
.hyo dl dt {
	width: clamp(120px, 9.1vw, 175px);
	padding: clamp(10px, 1vw, 20px) 0;
}
.hyo dl dd {
	width: calc(100% - clamp(120px, 9.1vw, 175px));
	padding: clamp(10px, 1vw, 20px) clamp(10px, 2vw, 40px);
	background-color: #F7F6F5;
	border-radius: 5px;
}
.fix_flex .side h3{
	font-weight: 500;
}
.recruit_link{
	display: block;
	margin-top: clamp(40px, 5.2vw, 100px);
	padding: clamp(20px, 3.9vw, 75px);
	border-radius: 5px;
	background-image: url('../images/recruit_personnel_bg.jpg');
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	box-shadow: 0px 2px 10px 0px rgba(0, 0, 0, 0.1);
	transition: all ease 0.5s;
}
.recruit_link:hover{
	opacity: 0.7;
}
.recruit_link i{
	margin-left: 10px;
}
.recruit_link p{
	text-align: center;
	width: fit-content;
	font-weight: 500;
	letter-spacing: 0.065em;
	font-size: var(--fontsize-25);
	position: relative;
	line-height: 1.3;
	margin: 0 auto;
}
.recruit_link p::before{
	content: "";
	width: 10px;
	height: 10px;
	background-color: #009944;
	border-radius: 5px;
	position: absolute;
	left: -10px;
	top: -10px;
}
.recruit_event{
	width: 100%;
	position: relative;
	z-index: 0;
	overflow: hidden;
}
.recruit_event_bg {
	display:flex;
	position:absolute;
	left: 0;
	top: 49%;
	transform: translateY(-50%);
	z-index: -1;
	height: 60%;
	width: 100%;
}
.recruit_event_bg li {
	animation:img-loop 400s linear 0s infinite;
}
.recruit_event_bg li:nth-child(2) {
	animation:img-loop2 400s linear -200s infinite;
}
.recruit_event_bg li img{
	height: 100%;
	width: auto;
	max-width: none;
}
@keyframes img-loop {
	0% {
		transform:translateX(100%)
	}
	to {
		transform:translateX(-100%)
	}
}
@keyframes img-loop2 {
	0% {
		transform:translateX(0)
	}
	to {
		transform:translateX(-200%)
	}
}
.recruit_event .inner{
	padding-bottom: clamp(70px, 8.3vw, 160px);
}
.recruit_event .box{
	width: clamp(250px, 27.6vw, 530px);
	padding: clamp(30px, 6.8vw, 130px) clamp(20px, 4.9vw, 95px);
	background-image: url('../images/recruit_event_bg.png');
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	border-radius: 5px;
	box-shadow: 0px 2px 10px 0px rgba(0, 0, 0, 0.1);
}
.recruit_event .box p{
	font-size: clamp(16px, 1.3vw, 25px);
	font-weight: 500;
}
.recruit_effort{
	margin-top: calc(clamp(20px, 1.6vw, 30px) * -1);
	border-radius: clamp(20px, 1.6vw, 30px) clamp(20px, 1.6vw, 30px) 0 0;
	background-color: #F0ECE9;
	box-shadow: 0px -4px 10px 0px rgba(0, 0, 0, 0.05);
}
.recruit_effort .inner{
	width: min(90%,1200px);
	padding-bottom: clamp(70px, 8.3vw, 160px);
}
.recruit_inspection{
	margin-top: calc(clamp(20px, 1.6vw, 30px) * -1);
	border-radius: clamp(20px, 1.6vw, 30px) clamp(20px, 1.6vw, 30px) 0 0;
	box-shadow: 0px -4px 10px 0px rgba(0, 0, 0, 0.05);
	background-color: #FFFFFF;
	background-image: url('../images/recruit_inspection_bg.png');
	background-size: clamp(300px, 46vw, 885px) auto;
	background-position: top right;
	background-repeat: no-repeat;
	overflow: hidden;
}
.recruit_inspection h3{
	letter-spacing: 0.065em;
}
.recruit_inspection ul li:not(:last-child){
	margin-bottom: clamp(40px, 4.9vw, 95px);
}
.recruit_inspection ul li{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: flex-start;
}
.recruit_inspection ul li:nth-child(odd){
	flex-direction: row-reverse;
}
.recruit_inspection ul li .txt{
	width: 50%;
}
.recruit_inspection ul li .img{
	width: 45vw;
	overflow: hidden;
}
.recruit_inspection ul li .img img{
	width: 100%;
	height: auto;
}
.recruit_inspection ul li:nth-child(odd) .img{
	border-radius: 0 5px 5px 0;
	margin-left: calc(50% - 50vw);
}
.recruit_inspection ul li:nth-child(even) .img{
	border-radius: 5px 0 0 5px;
	margin-right: calc(50% - 50vw);
}
@media screen and (max-width: 1100px) {
	.recruit_personnel ol{
		grid-template-columns: repeat(2, 1fr);
	}
	.recruit_attractiveness .txt{
		justify-content: space-between;
	}
	.recruit_attractiveness .txt h3{
		margin-right: 0;
		margin-bottom: 25px;
	}
	.recruit_attractiveness .txt p{
		width: calc(95% - 140px);
	}
	.recruit_attractiveness .ttl{
		display: block;
	}
	.recruit_attractiveness .recruit_h2{
		margin-right: 0;
		margin-bottom: 20px;
	}
	.recruit_data ul{
		grid-template-columns: repeat(2, 1fr);
	}
	.recruit_benefits ul{
		grid-template-columns: repeat(3, 1fr);
	}
}
@media screen and (max-width: 820px) {
	.recruit_attractiveness ol li .img{
		display: none;
	}
	.recruit_attractiveness ol li .white_box{
		width: 100%;
		padding: 25px !important;
	}
	.recruit_data ul li:nth-child(6) > img{
		bottom: 40px;
	}
	.recruit_benefits ul{
		grid-template-columns: repeat(2, 1fr);
	}
	.recruit_inspection ul li .txt{
		width: 100%;
		margin-bottom: 25px;
	}
	.recruit_inspection ul li .img{
		width: 95vw;
	}
}
@media screen and (max-width: 640px) {
	.recruit_personnel ol{
		grid-template-columns: repeat(1, 1fr);
	}
	.recruit_personnel p.tac{
		text-align: justify !important;
	}
	.recruit_attractiveness .txt h3{
		width: 100%;
	}
	.recruit_attractiveness .txt p{
		width: 100%;
	}
	.recruit_attractiveness ol li .txt_wrap{
		margin: 0;
		padding: 0;
		border-left: none;
	}
	.recruit_attractiveness ol li .bg_box p span{
		margin-bottom: 3px;
	}
	.recruit_data ul{
		grid-template-columns: repeat(1, 1fr);
	}
	.recruit_benefits ul{
		grid-template-columns: repeat(1, 1fr);
	}
	.hyo dl dt {
		width: 100%;
		padding-top: 0;
	}
	.hyo dl dd {
		width: 100%;
	}
}