@charset "utf-8";

#recruit {
	margin: -90px 0 0;
}

/*h1エリア*/
@media screen and (max-width: 768px) {
	#recruit {
		margin: 0;
	}
	.titlebox{
		text-align: center;
	}
	
	.contents {
		margin: 0;
	}
}

/* -----------------------------------------------------------
	mv
-------------------------------------------------------------- */
.mv{
	width: 100%;
	height: 690px;
	/*background: url("../img/recruit-mv.jpg") no-repeat center top / cover;*/
	position: relative;
	overflow: hidden;
}
/*h1エリア*/
#recruit .mv .h1-area {
	position: absolute;
	top: 10px;
	right: 20px;
	left: auto;
	color: #fff;
}
.mv h1{
	color: #fff;
} 
.mv .page-title{
	/*margin: 260px 0 20px;*/
	margin: 100px 0 20px;
}
.mv .page-title .title-en{
	font-size: 5.5rem;
}
.mv .page-title .title-jp{
	font-size: 2.0rem;
}

.mv .mv-title-jp{
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	color: #fff;
	line-height: 2;
	font-size: 9rem;
	font-weight: 700;
	font-family: var(--jp-serif);
	width: 100%;
	text-align: center;
	text-shadow: 3px 3px 10px #444;
}
/*.mv .mv-title-jp span{
	display: inline-block;
	background-color: rgba(13,190,179,0.8);
	padding: 0 .15em;
	margin: .15em 0;
	font-size: 4.0rem;
	font-weight: 500;
}*/

.mv .img{
	position: absolute;
	z-index: -1;
}
.mv .img img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.mv .img.img01{
	left: 0;
	top: 0;
	width: 65%;
	height: 405px;
	/*border-right: 5px #fff solid;
	border-bottom: 5px #fff solid;*/
}
.mv .img.img02{
	right: 0;
	top: 0;
	width: 35%;
	height: 285px;
	/*border-bottom: 5px #fff solid;*/
}
.mv .img.img03{
	left: 0;
	bottom: 0;
	width: 40%;
	height: 285px;
}
.mv .img.img04{
	right: 0;
	bottom: 0;
	width: 60%;
	height: 405px;
	/*border-left: 5px #fff solid;*/
}
/*.mv .bg-img{
	width: 100%;
	height: 345px;
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden;
	z-index: -1;
}
.mv .bg-img.style02{
	width: 100%;
	height: 345px;
	position: absolute;
	top: 345px;
	left: 0;
	overflow: hidden;
	z-index: -1;
}
.mv .bg-img img{
	width: 100%;
	height: 345px;
	object-fit: cover;
	object-position: center;
}

.mv .bg-img.style02 img{
	width: 100%;
	height: 345px;
	object-fit: cover;
	object-position: center;
}*/
.mv .bg-img,
.mv .bg-img.style02{
	display: none;
}
@media screen and (max-width: 768px) {
	.mv{
		height: 470px;
		background: url("../img/recruit-mv-sp.jpg") no-repeat center top / cover;
		border-radius: 0 0 100px 0;
		margin: 0 0 20px;
	}
	/*h1エリア*/
	.mv .h1-area {
		top: 5px;
		right: 5px;
		color: transparent;
		background-color: transparent;
		margin: 0;
	}
	#recruit .mv .h1-area {
		top: -50px;
	}
	
	.mv h1{
		color: #fff;
	} 
	.mv .page-title{
		margin: 80px 0 0 20px;
	}
	.mv .page-title .titlebox{
		text-align: left;
	}
	.mv .page-title .title-en{
		font-size: 3.8rem;
	}
	.mv .page-title .title-jp{
		font-size: 1.7rem;
	}
	.mv .mv-title-jp{
		/*margin: 0 0 0 20px;*/
		font-size: 3.6rem;
		line-height: 1.4;
	}
	.mv .mv-title-jp span{
		font-size: 2.3rem;
	}
	/*.mv .bg-img{
		width: 100%;
		height: 314px;
		position: absolute;
		top: 0;
		left: 0;
		overflow: hidden;
		z-index: -1;
	}
	.mv .bg-img.style02{
		width: 100%;
		height: 157px;
		position: absolute;
		top: 314px;
		left: 0;
		overflow: hidden;
		z-index: -1;
	}
	.mv .bg-img img{
		width: 100%;
		height: 314px;
		object-fit: cover;
		object-position: center;
	}

	.mv .bg-img.style02 img{
		width: 100%;
		height: 157px;
		object-fit: cover;
		object-position: center;
	}*/
	.mv .bg-img,
	.mv .bg-img.style02{
		display: none;
	}
}


/* -----------------------------------------------------------
	news
-------------------------------------------------------------- */
.news-area {
	padding: 0;
	margin: 0 auto;
}
.news-area .news-box_inner{
	display: flex;
	justify-content: space-between;
    margin: 10px auto 0;
}
.news-area .news-box{
	display: flex;
	justify-content: space-between;
	position: relative;
    margin: 0 0 10px 0;
}
.news-area .news-title {
	font-size: 3rem;
	font-weight: 700;
	font-family: var(--en-font);
    color: var(--recruit-main);
}
.news-area .news-list {
	width: 1000px;
	list-style-type: none;
	padding: 0 0 0 60px;
}
.news-area .news-list a{
	display: flex;
	width: 100%;
	box-sizing: border-box;
	align-items: center;
    margin: 0 0 10px;
}

.news-area .news-de_title {
	flex: 1;
	font-weight: 400;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.news-area .cate{
	display: inline-block;
	color: #333;
	font-size: 1.2rem;
	line-height: 1;
	text-align: center;
	padding: 3px 15px 6px;
	border: 1px solid #707070;
	margin: 0 30px;
    background: #fff;
	min-width: 80px;
}

.news-area .news-more{
	right: 0;
}
.news-area .news-more > a{
}
.news-area .news-more > a::before{
	display: inline-block;
	content: "\f105";
	font-weight: 700;
	font-family: "Font Awesome 5 Free";
	padding: 0 8px 0 0;
}

.news-area .news-right a {
    width: 330px;
    padding: 40px 30px 40px 120px;
    background: url("../img/top-product01.png") no-repeat 15px 15px;
}

.news-area .news-right a .txt{
    font-weight: 400;
}

@media screen and (max-width: 768px){
	.news-area {
		padding: 20px 20px 0;
	}
	.news-area .news-box{
		display: block;
		position: relative;
		margin-bottom: 50px;
        padding: 0;
	}
	.news-area .news-box_inner{
		display: block;
        margin: 20px 0 0;
	}
	.news-area .news-title {
		font-size: 2.6rem;
		margin: 0;
	}
	.news-area .news-list {
		width: 100%;
        padding: 0;
	}
	.news-area .news-list li{
		margin: 15px 0 0;
	}
	.news-area .news-list li:nth-child(n+3){
		display: none;
	}
	.news-area .news-list a{
		flex-wrap: wrap;
	}
	.news-area .news-de_title {
		flex: auto;
		flex-shrink: 0;
		width: 100%;
		margin: 10px 0 0;
	}
	.news-area .cate{
		margin: 0 0 0 10px;
	}
	.news-area .news-more{
		position: absolute;
		top: 0;
		right: 0;
	}
}

/* -----------------------------------------------------------
	intro-area
-------------------------------------------------------------- */
.intro-area{
	margin: 100px 0 0;
	padding: 0 0 168px;
	position: relative;
}
.intro-area .inner{
	display: flex;
}
.intro-area .txt-area{
	width: 600px;
	margin: 0 80px 0 0;
}
.intro-area .img-circle{
	width: 520px;
	height: 520px;
	border-radius: 50%;
	position: relative;
}
.intro-area .circle-wrap{
	content: "";
	display: block;
	width: 520px;
	height: 520px;
	position: absolute;
	top: 0;
	left: 0;
	-webkit-transform-origin: 50% 50%;
	        transform-origin: 50% 50%;
	-webkit-animation: loading05 5s cubic-bezier(.58,.17,.67,.83) infinite;
	        animation: loading05 5s cubic-bezier(.58,.17,.67,.83) infinite;
}
.intro-area .circle {
	content: "";
	display: block;
	width: 16px;
	height: 16px;
	border-radius: 50%;
	position: absolute;
	top: -9px;
	left: 0;
	right: 0;
	margin: 0 auto;
	background: var(--recruit-main);
}
@-webkit-keyframes loading05 {
	0% {
		-webkit-transform: rotate(0deg);
		transform: rotate(0deg);
	}
	100% {
		-webkit-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}
@keyframes loading05 {
	0% {
		-webkit-transform: rotate(0deg);
		transform: rotate(0deg);
	}
	100% {
		-webkit-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}
/*.intro-area .img{
	border-radius: 50%;
	overflow: hidden;
}*/
.intro-area .video{
	border-radius: 50%;
	overflow: hidden;
	width: 520px;
	height: 520px;
	flex-shrink: 0;
	position: relative;
}
.intro-area .video video{
	width: auto;
	height: 100%;
	position: absolute;
	top: 0;
	bottom: 0;
	/*left: -180px;*/
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
}
.intro-area .text-slide{
	width: 100%;
	height: 183px;
	position: absolute;
	bottom: 45px;
	right: 0;
	background: url("../img/text-slide-rec.png") repeat-x top left / auto 183px;
	animation: bg-slider 35s linear infinite;
	overflow: hidden;
	z-index: -1;
}
@keyframes bg-slider {
	from {
        background-position: 0 0;
    }
    to {
        background-position: -3672px 0;
    } /* 3672pxとは使用した背景画像の長さ */
}

@media screen and (max-width: 768px) {
	.intro-area{
		margin: 110px 0 50px;
		padding: 0;
		position: relative;
	}
	.intro-area .inner{
		flex-direction: column;
	}
	.intro-area .txt-area{
		width: 100%;
		margin: 0;
	}
	.intro-area .txt-area .catch{
		width: 50%;
	}/*
	.intro-area .img{
		position: absolute;
		top: -80px;
		left: 50%;
		width: 200px;
	}*/
	.intro-area .img-circle{
		position: absolute;
		top: -80px;
		left: 50%;
		width: 200px;
		height: 200px;
	}
	.intro-area .circle-wrap{
		width: 200px;
		height: 200px;
		-webkit-animation: loading05 3s cubic-bezier(.58,.17,.67,.83) infinite;
				animation: loading05 3s cubic-bezier(.58,.17,.67,.83) infinite;
	}
	.intro-area .circle {
		width: 12px;
		height: 12px;
		top: -6px;
		left: 0;
		right: 0;
		margin: 0 auto;
		background: var(--recruit-main);
	}
	/*.intro-area .img{
		border-radius: 50%;
		overflow: hidden;
	}*/
	.intro-area .video{
		width: 200px;
		height: 200px;
		/*position: absolute;
		top: 116px;
		left: 57%;*/
	}
	.intro-area .video video{
		top: 0;
		bottom: 0;
		/*left: -80px;*/
	}
	.intro-area .text-slide{
		height: 80px;
		position: absolute;
		top: -80px;
		bottom: auto;
		right: 0;
		background: url("../img/text-slide-rec.png") repeat-x top left / auto 80px;
		animation: bg-slider 60s linear infinite;
		overflow: hidden;
		z-index: -1;
	}
	@keyframes bg-slider {
		from {
			background-position: 0 0;
		}
		to {
			background-position: -3672px 0;
		} /* 3672pxとは使用した背景画像の長さ */
	}
	
}



/* -----------------------------------------------------------
	message-area
-------------------------------------------------------------- */
.message-area{
	position: relative;
}
.message-area::before{
	content: "";
	display: block;
	width: 100%;
	max-width: calc(1000px + (100% - 1000px)/2);
	height: 100%;
	background-color: var(--bg-green);
	border-radius: 200px 0 0 200px;
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}
.message-area .inner{
	display: flex;
	position: relative;
	padding: 100px 0 85px;
}
.message-area .img-area{
	width: 534px;
	/*height: 740px;*/
	flex-shrink: 0;
	position: relative;
	top: 0;
	left: -50px;
}
.message-area .img-area .img{
	/*border-radius: 30px;
	overflow: hidden;*/
	position: absolute;
	top: 0;
	left: 70px;
}
.message-area .img-area .img img{
	border-radius: 30px;
	overflow: hidden;
}
/*.message-area .img-area .img.style02{
	top: auto;
	bottom: 0;
	left: 0;
}
.message-area .img-area .img.style02 img{
	border:5px solid #fff;
}*/

.message-area .img-area .img.style02{
	top: -120px;
	left: 1020px;
}
.message-area .img-area .img.style02 img{
	width: 240px;
	transform: rotate(10deg);
}

.message-area .txt-wrap{
	margin: 0 0 0 20px;
}

@media screen and (max-width: 768px) {
	.message-area{
		position: relative;
	}
	.message-area::before{
		width: 100%;
		height: 100%;
		border-radius: 80px 0 0 80px;
	}
	.message-area .inner{
		flex-direction: column;
		padding: 50px 0;
	}
	.message-area .img-area{
		width: 100%;
		height: auto;
		position: sticky;
	}
	.message-area .img-area .img{
		/*border-radius: 0 20px 20px 0;
		overflow: hidden;*/
		width: calc(100% - 40px);
		height: 205px;
		position: absolute;
		top: 0;
		left: 0;
	}
	.message-area .img-area .img img{
		border-radius: 0 20px 20px 0;
		max-width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: center;
	}
	.message-area .img-area .img.style02{
		/*border: 3px solid #fff;
		border-radius: 20px;*/
		width: calc(50% - 30px);
		min-width: 152px;
		height: 132px;
		top: 155px;
		bottom: auto;
		left: auto;
		right: 15px;
	}
	.message-area .img-area .img.style02 img{
		border: 3px solid #fff;
		border-radius: 20px;
	}
	.message-area .txt-wrap{
		margin: 0;
		width: 100%;
	}
	.message-area .txt-wrap .wrap20{
		padding: 220px 20px 0;
	}
}

/* -----------------------------------------------------------
	about-area
-------------------------------------------------------------- */
.about-area{
	margin: 100px 0 0;
	padding: 100px 0 100px;
	background: url("../img/recruit-top--about-bg.jpg") no-repeat center bottom / cover;
	color: #fff;
}

@media screen and (max-width: 768px) {
	.about-area{
		margin: 50px 0 0;
		padding: 50px 0;
		background: linear-gradient(to bottom , rgba(0,0,0,0.3), rgba(0,0,0,0.3)) , url("../img/recruit-top--about-bg.jpg") no-repeat 78% bottom / cover;
		text-align: center;
	}
	.about-area .catch{
		text-align: center;
	}
	.about-area .button{
		margin: 30px auto 0;
	}
}

/* -----------------------------------------------------------
	work-area
-------------------------------------------------------------- */
.work-area{
	margin: 120px 0 0;
	position: relative;
}
.work-area::before{
	content: "";
	display: block;
	width: calc(100% - (100% - 1200px)/2 - 852px);
	height: 412px;
	background: url("../img/recruit-work-img01.jpg") no-repeat center top/ cover;
	border-radius: 0 30px 30px 0;
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
	transition: all .6s ease;
	transform: translateX(-10%);
	opacity: 0;
}
.is-show.work-area::before{
	transform: translateX(0);
	opacity: 1;
}
.work-area .inner{
	position: relative;
}
.work-area .inner::before{
	content: "";
	display: block;
	width: 299px;
	height: 189px;
	background: url("../img/recruit-work-img02.jpg") no-repeat center/ cover;
	border-radius: 30px;
	overflow: hidden;
	position: absolute;
	top: 375px;
	left: 0;
}
.work-area .inner::after{
	content: "";
	display: block;
	width: calc(100vw - (100vw - 1200px)/2 - 981px);
	max-width: 380px;
	height: 300px;
	background: url("../img/recruit-work-img03.jpg") no-repeat center/ cover;
	border-radius: 30px;
	overflow: hidden;
	position: absolute;
	top: 100px;
	left: 918px;
	transition: all .6s ease;
	transform: translateX(10%);
	opacity: 0;
}
.is-show.work-area .inner::after{
	transform: translateX(0);
	opacity: 1;
}
.work-area .txt-wrap{
	width: 440px;
	padding: 50px 0;
	margin: 0 0 0 438px;
}

@media screen and (max-width: 768px) {
	.work-area{
		margin: 50px 0 0;
		padding: 0 0 330px;
		text-align: center;
	}
	.work-area::before{
		content: "";
		display: block;
		width: 100%;
		height: 180px;
		background: url("../img/recruit-work-img01.jpg") no-repeat center top -12px / cover;
		border-radius: 0 30px 0 0;
		top: auto;
		left: 0;
		bottom: 100px;
	}
	.work-area .inner{
		position: relative;
	}
	.work-area .inner::before{
		content: "";
		display: block;
		width: calc(50vw + 37px);
		height: 120px;
		background: url("../img/recruit-work-img02.jpg") no-repeat center/ cover;
		border-radius: 0 0 0 30px;
		position: absolute;
		top: auto;
		left: 0;
		bottom: -340px;
	}
	.work-area .inner::after{
		content: "";
		display: block;
		width: calc(50vw - 37px);
		max-width: none;
		height: 120px;
		background: url("../img/recruit-work-img03.jpg") no-repeat right bottom / cover;
		border-radius: 0;
		overflow: hidden;
		position: absolute;
		top: auto;
		left: auto;
		bottom: -340px;
		right: 0;
	}
	.work-area .txt-wrap{
		width: 100%;
		padding: 0;
		margin: 0;
	}
	.work-area .catch{
		text-align: center;
	}
	.work-area .button{
		margin: 30px auto 0;
	}

}


/* -----------------------------------------------------------
	interview-area
-------------------------------------------------------------- */
.interview-area{
	margin: 150px 0 0;
	padding: 100px 0;
	position: relative;
}
.interview-area::before{
	content: "";
	display: block;
	width: 100%;
	max-width: calc(1300px + (100% - 1300px)/2 + 80px);
	height: 100%;
	background-color: var(--bg-green);
	border-radius: 0 150px 150px 0;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}
.interview-area .recruit-list{
	display: flex;
	flex-wrap: wrap;
	gap: 40px;
	margin: 50px 0 0;
}
.interview-area .recruit-list li{
	background-color: #fff;
	border-radius: 30px;
}
.interview-area .recruit-list li a{
	display: block;
	position: relative;
	border-radius: 30px;
	box-shadow: 7px 7px 30px -10px rgba(0,0,0,0.1);
}
.interview-area .recruit-list li{
	width: calc((100% - 40px)/ 2); 
}
.interview-area .recruit-list li .img{
	border-radius: 30px 30px 0 0;
	overflow: hidden;
	position: relative;
}
.interview-area .recruit-list li .img::after{
	content: "";
	display: block;
	width: 100%;
	height: 58px;
	background: linear-gradient(to bottom , rgba(255,255,255,0) 0% , rgba(255,255,255,0.7) 60%, rgba(255,255,255,1) 100%);
	position: absolute;
	bottom: 0;
	left: 0;
}
.interview-area .recruit-list li .titlebox{
	padding: 0 30px;
  	margin: -40px 0 20px;
}
.interview-area .recruit-list li .titlebox .title-en{
	font-size: 5.0rem;
}
.interview-area .recruit-list li .titlebox .title-jp{
	color: var(--recruit-main);
}
.interview-area .recruit-list li .catch{
	padding: 0 30px 40px;
	font-size: 2.0rem;
	line-height: 1.5;
	margin: 0;
}
.interview-area .recruit-list li .arrow-g{
	display: block;
	width: 40px;
	height: 8px;
	position: absolute;
	right: 20px;
	bottom: 30px;
	transition: 0.5s;
	background: url("../img/arrow-g.svg") no-repeat center / contain;
}
.interview-area .recruit-list li a:hover .arrow-g{
	right: 10px;
}
.interview-area .button.rec{
	text-align: center;
}


@media screen and (max-width: 768px) {
	.interview-area{
		margin: -50px 0 0;
		padding: 100px 0 50px;
	}
	.interview-area::before{
		width: 100%;
		max-width: calc(1300px + (100% - 1300px)/2 + 80px);
		border-radius: 0 80px 80px 0;
	}
	.interview-area .recruit-list{
		flex-direction: column;
		gap: 20px;
		margin: 30px 0 0;
	}
	.interview-area .recruit-list li{
		background-color: #fff;
		border-radius: 30px;
	}
	.interview-area .recruit-list li a{
		border-radius: 30px;
	}
	.interview-area .recruit-list li{
		width: 100%; 
	}
	.interview-area .recruit-list li .img{
		border-radius: 30px 30px 0 0;
		overflow: hidden;
		position: relative;
	}
	.interview-area .recruit-list li .img img{
	}
	.interview-area .recruit-list li .img::after{
		content: "";
		display: block;
		width: 100%;
		height: 58px;
		background: linear-gradient(to bottom , rgba(255,255,255,0) 0% , rgba(255,255,255,0.7) 60%, rgba(255,255,255,1) 100%);
		position: absolute;
		bottom: 0;
		left: 0;
	}
	.interview-area .recruit-list li .titlebox{
		padding: 0 30px;
		margin: -20px 0 10px;
		text-align: left;
	}
	.interview-area .recruit-list li .titlebox .title-en{
		font-size: 3.0rem;
	}
	.interview-area .recruit-list li .titlebox .title-jp{
		color: var(--recruit-main);
		font-size: 1.5rem;
	}
	.interview-area .recruit-list li .catch{
		padding: 0 30px 30px;
		font-size: 1.4rem;
		line-height: 1.5;
		margin: 0;
	}
	.interview-area .recruit-list li .arrow-g{
		bottom: 20px;
	}
	.interview-area .button{
		margin: 30px auto 0;
	}
	
}

/* -----------------------------------------------------------
	environment-area
-------------------------------------------------------------- */
.environment-area{
	margin: 150px auto;
}
.environment-area .inner{
	position: relative;
}
.environment-area .inner::before{
	content: "";
	display: block;
	width: 937px;
	height: 937px;
	background: url("../img/bg-circle-green.png") no-repeat center / 100%;
	position: absolute;
	top: -90px;
	right: -468px;
	z-index: -1;
}
.environment-area .txt-wrap{
	width: 420px;
	margin: 0 0 0 50px;
}
.environment-area .txt-wrap .catch,
.environment-area .txt-wrap .txt{
	text-shadow: 1px 1px 0 #FFF, -1px -1px 0 #FFF, -1px 1px 0 #FFF, 1px -1px 0 #FFF, 0px 1px 0 #FFF, 0-1px 0 #FFF, -1px 0 0 #FFF, 1px 0 0 #FFF;
}
.environment-area .img-slide{
	width: 850px;
	height: 488px;
	position: absolute;
	top: -30px;
	right: -50px;
	background: url("../img/recruit-top-environment-slide.png") repeat-x top left / auto 488px;
	animation: bg-slider2 30s linear infinite;
	overflow: hidden;
	z-index: -1;
}

@keyframes bg-slider2 {
	from {
        background-position: 0 0;
    }
    to {
        background-position: -2142px 0;
    } /* 1193pxとは使用した背景画像の長さ */
}
@media screen and (max-width: 768px) {
	.environment-area{
		margin: 120px auto 50px;
	}
	.environment-area .inner{
		position: relative;
	}
	.environment-area .inner::before{
		content: "";
		display: block;
		width: 621px;
		height: 621px;
		background: url("../img/bg-circle-green.png") no-repeat center / 100%;
		position: absolute;
		top: -160px;
		right: -50px;
		z-index: -1;
	}
	.environment-area .txt-wrap{
		width: 100%;
		margin: 0;
		padding: 0 20px;
		color: #fff;
	}
	.environment-area .titlebox .title-en,
	.environment-area .titlebox .title-jp{
		color: #fff;
		text-shadow: 0px 0px 6px rgba(0,0,0,0.16);
	}
	.environment-area .txt-wrap .catch{
		font-size: 2.2rem;
		text-align: center;
		text-shadow: 0px 0px 6px rgba(0,0,0,0.16);
	}
	.environment-area .txt-wrap .txt{
		text-shadow: none;
	}
	.environment-area .img-slide{
		width: 100%;
		height: 253px;
		position: absolute;
		top: -70px;
		right: 0;
		background: url("../img/recruit-top-environment-slide.png") repeat-x top left / auto 253px;
		animation: bg-slider2 30s linear infinite;
		overflow: hidden;
		z-index: -1;
	}

	@keyframes bg-slider2 {
		from {
			background-position: 0 0;
		}
		to {
			background-position: -1111px 0;
		} /* 1193pxとは使用した背景画像の長さ */
	}
	.environment-area .button{
		margin: 30px auto 0;
	}
}


/* -----------------------------------------------------------
	positions-area
-------------------------------------------------------------- */
.positions-area {
	position: relative;
}
.positions-area::before {
	content: "";
	display: block;
	width: 937px;
	height: 937px;
	background: url("../img/bg-circle-green.png") no-repeat center / 100%;
	position: absolute;
	top: -400px;
	left: -468px;
	z-index: -1;
}
.positions-area a{
	display: flex;
	width: 100%;
	border-radius: 30px;
	box-shadow: 0px 3px 10px rgba(0,0,0,0.16);
	position: relative;
}
.positions-area a .img{
	flex-shrink: 0;
	border-radius: 30px 0 0 30px;
	overflow: hidden;
}
.positions-area a .txt-wrap{
	display: flex;
	flex-direction: column;
	justify-content: center;
	margin: 0 0 0 60px;
}
.positions-area a .titlebox{
	margin: 0 0 20px;
}
.positions-area a .catch{
	font-size: 2.0rem;
	margin: 0;
}
.positions-area a span{
	display: block;
	width: 40px;
	height: 8px;
	position: absolute;
	right: 30px;
	bottom: 30px;
	transition: 0.5s;
	background: url("../img/arrow-g.svg") no-repeat center / contain;
}
.positions-area a:hover span{
	right: 20px;
}

@media screen and (max-width: 768px) {
	.positions-area {
		position: relative;
		padding: 0 20px;
	}
	.positions-area::before {
		content: "";
		display: block;
		width: 500px;
		height: 500px;
		background: url("../img/bg-circle-green.png") no-repeat center / 100%;
		position: absolute;
		top: -120px;
		left: 20px;
		z-index: -1;
	}
	.positions-area a{
		background: #fff;
		display: flex;
		width: 100%;
		height: 100px;
		border-radius: 20px;
		box-shadow: 0px 3px 10px rgba(0,0,0,0.16);
		position: relative;
	}
	.positions-area a .img{
		width: 100px;
		height: 100px;
		border-radius: 20px 0 0 20px;
	}
	.positions-area a .img img{
		width: auto;
		height: 100%;
		object-fit: cover;
		object-position: center;
	}
	.positions-area a .txt-wrap{
		justify-content: center;
    	align-items: flex-start;
		margin: 0 0 0 20px;
	}
	.positions-area a .titlebox{
		margin: 0;
		text-align: left;
	}
	.positions-area a .title-en{
		font-size: 3.0rem;
	}
	.positions-area a .catch{
		font-size: 1.4rem;
	}
	.positions-area a span{
		display: block;
		width: 40px;
		height: 8px;
		position: absolute;
		right: 10px;
		bottom: 15px;
		transition: 0.5s;
		background: url("../img/arrow-g.svg") no-repeat center / contain;
	}
	.positions-area a:hover span{
		right: 20px;
	}
	
}