@charset "utf-8";

/*-------------------------------------------------------------------
	index
-------------------------------------------------------------------*/
body{
	background: linear-gradient(90deg, #00c4ff, #0066c4);
}
/*-------------------------------------------------------------------
	mainVisual
-------------------------------------------------------------------*/
#mainVisual{
	width: 940px;
	position: relative;
	padding-top: 40px;
}
#mainVisual .ttl02{
	width: 500px;
	max-width: 100%;
	aspect-ratio: 590 / 123;
	position: absolute;
	top: 50px;
	left: -10%;
}
#mainVisual .mainVisualList{
	display: flex;
	margin-bottom: 40px;
}
#mainVisual .mainVisualListItem{
	position: relative;
}
#mainVisual .leftContainer{
	width: 43%;
	z-index: 1;
	margin-top: 35px;
}
#mainVisual .leftContainer .mvImg01{
	margin-bottom: 30px;
	margin-left: 5%;
	position: relative;
}
#mainVisual .leftContainer .mvImg01 img{
	max-width: 130%;
}
#mainVisual .leftContainer .recruitBtn,
#mainVisual .leftContainer .careerBtn{
	max-width: none;
}

#mainVisual .mainVisualListItem .mvText{
	font-size: 1.5rem;
	color: #fff;
	line-height: 2;
	margin-bottom: 45px;
	margin-left: 10%;
	position: relative;
	z-index: 1;
}
#mainVisual .recruitBtn.careerBtn{
	margin-bottom: 10px;
	background-color: #95eeff;
	color: #003399;
}

#mainVisual .rightContainer{
	width: 57%;
}
#mainVisual .rightContainer .mvImg02{
	max-width: 100%;
	position: relative;
	height: 100%;
}
#mainVisual .rightContainer .mvImg02 img{
	max-width: 126%;
	position: absolute;
	top: 0;
	left: -19%;
}
#mainVisual .OB_OGFlex{
	display: flex;
	align-items: center;
	background: #fff;
	padding: 20px;
	position: relative;
	z-index: 1;
}
#mainVisual .OB_OGFlex .OB_OGimg{
	min-width: 65px;
	width: fit-content;
	aspect-ratio: 1 / 1;
}
#mainVisual .OB_OGFlex .OB_OGttl{
	font-size: 2.2rem;
	font-weight: 500;
	line-height: 1;
	margin:0 20px;
	white-space: nowrap
}
#mainVisual .OB_OGFlex .OB_OGText{
	max-width: 58%;
	font-size: 1.3rem;
	margin-left: auto;
}
#mainVisual .fadeItem01,
#mainVisual .fadeItem02,
#mainVisual .fadeItem03{
	opacity: 0;
	transform: translateY(25px);
	transition: 1s;
}
#mainVisual .fadeIn{
	opacity: 1;
	transform: translateX(0);
}

/*-------------------------------------------------------------------
	firstCareer
-------------------------------------------------------------------*/
#firstCareer .firstCareerFlex{
	padding: 140px 0 180px;
	display: flex;
	background: url(../image/recruit/top/firstCareer_bg01_pc.png);
	background-repeat: no-repeat;
	background-position: top 50px left 0;
}
#firstCareer .firstCareerFlex .firstCareerText{
	color: #fff;
	margin-right: 10%;
	padding-left: 4%;
}
#firstCareer .firstCareerFlex .firstCareerText p{
	font-size: 2.5rem;
	line-height: 1;
	margin-bottom: 25px;
}
#firstCareer .firstCareerFlex .firstCareerText h3{
	font-size: 8.5rem;
	line-height: 1;
	margin-bottom: 80px;
}
#firstCareer .firstCareerFlex .firstCareerText dt{
	font-size: 3.3rem;
	line-height: 1.4;
	margin-bottom: 40px;
}
#firstCareer .firstCareerFlex .firstCareerText dd{
	line-height: 1.8;
}
#firstCareer .firstCareerImg{
	display: flex;
	align-items: center;
	transform: translateY(-25px);
}
#firstCareer .firstCareerFlex a{
	width: fit-content;
	display: block;
	opacity: 0;
	transition: opacity .5s;
}
#firstCareer .firstCareerImg a.fadeIn{
	opacity: 1;
}

#firstCareer .firstCareerFlex .leftItem a figure{
	width: fit-content;
	display: block;
}

#firstCareer .firstCareerFlex .rightItem{
	transform: translateX(-20px);
	margin-right: -20px;
}

/*-------------------------------------------------------------------
	careerUp
-------------------------------------------------------------------*/
#careerUp{
	background: url(../image/recruit/top/careerup_bg01_pc.jpg);
	background-position: center;
	background-size: 100%;
	background-attachment: fixed;
	background-repeat: no-repeat;
	padding: 50px 0 85px;
	color: #fff;
}
#careerUp .careerUpContents{
	width: fit-content;
	padding-top: 50px;
	background: url(../image/recruit/top/careerup_dec02_pc.png);
	background-repeat: no-repeat;
	background-position: top center;
	background-size: auto 90%;
}
#careerUp dt,
#careerUp dd{
	display: flex;
	flex-flow: column;
	align-items: center;
}
#careerUp dt{
	margin-bottom: 40px;
}
#careerUp dt p{
	font-size: 2.5rem;
	line-height: 1;
	margin-bottom: 25px;
}
#careerUp dd p{
	line-height: 2;
	text-align: center;
	margin-bottom: 40px;
}
/*-------------------------------------------------------------------
	pickUp
-------------------------------------------------------------------*/
#pickUp{
	background: url(../image/recruit/top/pickup_bg01.png);
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	padding: 110px 0 220px;
	color: #fff;
}
#pickUp dt,
#pickUp dd{
	display: flex;
	flex-flow: column;
	align-items: center;
}
#pickUp dt{
	margin-bottom: 40px;
}
#pickUp dt h3{
	margin-bottom: 35px;
}

#pickUp dt h4{
	font-size: 4.8rem;
	font-weight: 400;
	line-height: 1;
	letter-spacing: 0.15em;
	text-align: center;
}
#pickUp dd p{
	line-height: 2;
	text-align: center;
	margin-bottom: 50px;
}
@media screen and (max-width: 1200px){
	#mainVisual .ttl02{
		left: 0;
	}

}

@media screen and (max-width: 1150px){
	#mainVisual::before{
		left: -2.5%;
	}
}

@media screen and (max-width: 1024px){

}

@media screen and (max-width: 768px){
	#mainVisual .leftContainer{
		width: 100%;
	}
	#mainVisual .ttl02{
		left: 50%;
		transform: translateX(-50%);
	}

	#mainVisual .leftContainer .mvImg01{
		margin-left: 0;
		margin-bottom: -30px;
	}
	#mainVisual .leftContainer .mvImg01 img{
		max-width: 100%;
	}
	#mainVisual .mainVisualList{
		margin-bottom: 55px;
	}
	#mainVisual .mainVisualListItem .mvText{
		margin-left: 0;
		text-align: center;
	}
	#mainVisual .recruitBtn{
		max-width: 100%;
		margin: 0 auto;
	}
	#mainVisual .OB_OGFlex{
		flex-wrap: wrap;
		padding: 20px 7%;
	}
	#mainVisual .OB_OGFlex .OB_OGimg{
		min-width:auto;
		aspect-ratio: auto;
	}
	#mainVisual .OB_OGFlex .OB_OGttl{
		margin: 0 0 0 20px;
	}
	#mainVisual .OB_OGFlex .OB_OGText{
		max-width: 100%;
		margin-top: 15px;
	}
	#mainVisual .leftContainer .recruitBtn,
	#mainVisual .leftContainer .careerBtn{
		max-width: 100%;
	}
	#firstCareer{
		background: url(../image/recruit/top/firstCareer_bg01_sp.png);
		background-size: 100%;
		background-repeat: no-repeat;
		background-position: top 70px left 0;
	}
	#firstCareer .firstCareerFlex{
		padding: 100px 0 0;
		flex-wrap: wrap;
		background: none;
	}
	#firstCareer .firstCareerFlex .firstCareerText{
		padding-left: 0;
		margin: 0 auto 25px;
		text-align: center;
	}
	#firstCareer .firstCareerFlex .firstCareerText h3{
		margin-bottom: 40px;
		max-height: 120px;
	}
	#firstCareer .firstCareerFlex .firstCareerText h3 img{
		max-height: 100px;
	}

	#firstCareer .firstCareerFlex .firstCareerText dt{
		margin-bottom: 15px;
	}
	#firstCareer .firstCareerImg{
		transform: translateY(0);
		margin-right: -20px;
		margin: 0 auto;
	}

	#careerUp{
		padding: 65px 0 0;
		background: none;
	}
	#careerUp .careerUpContents{
		padding-top: 35px;
		background: url(../image/recruit/top/careerup_dec02_sp.png);
		background-repeat: no-repeat;
		background-position: top center;
	}
	#careerUp h3 img{
		max-height: 40px;
	}
	#pickUp{
		background: none;
		position: relative;
		padding: 50px 0 90px;
	}
	#pickUp::before{
		content: "";
		display: block;
		width: 45%;
		aspect-ratio: 328 / 229;
		background: url(../image/recruit/top/pickup_bg02.png);
		background-size: cover;
		background-repeat: no-repeat;
		position: absolute;
		top: 0;
		left: 0;
	}
	#pickUp::after{
		content: "";
		display: block;
		width: 10%;
		min-width: 75px;
		aspect-ratio: 75 / 56;
		background: url(../image/recruit/top/pickup_bg03.png);
		background-size: cover;
		background-repeat: no-repeat;
		position: absolute;
		bottom: 0;
		right: 0;
	}

	#pickUp dt h4{
		font-size: 3.3rem;
		line-height: 1.4;
	}
	
}
@media screen and (max-width: 400px){
	#mainVisual .OB_OGFlex .OB_OGimg{
		display: flex;
		justify-content: center;
		align-items: center;
		width: calc(100% - 227px);
	}
	#mainVisual .OB_OGFlex .OB_OGttl{
		margin-left: 10px;
	}

	#careerUp{
	max-width: 100%;
}
}
