@charset "UTF-8";

/* ---------------------------------------
  RECRUIT-KEYWORD
-----------------------------------------*/

@media screen and (min-width: 768px) {
	#pagettl {
		background-image: url(../img/recruit/pagettl_pc.jpg);
	}
}

@media screen and (max-width: 767px) {
	#pagettl {
		background-image: url(../img/recruit/pagettl_sp.jpg);
	}
}


/* pickup
--------------------------------*/
#sec_mv {
	padding: 60px 0 65px;
}

#sec_mv::before {
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background: url(../img/recruit/keyword/mv_bg_pc.png) repeat-x center / 2380px auto;
}

#sec_mv .wrap {
	width: 946px;
}

#sec_mv .secttl {
	margin-bottom: 20px;
}

#sec_mv .secttl span.en {
	color: #00a0e9;
}

#sec_mv .secttl span.en::before,
#sec_mv .secttl span.en::after {
	background-color: #00a0e9;
}

#sec_mv .lead {
	font-weight: 500;
	font-size: 2rem;
	line-height: 1.9;
	letter-spacing: 0.075em;
	text-align: justify;
}

@media screen and (max-width: 767px) {
	#sec_mv {
		padding: 15.6rem 0 10rem;
	}

	#sec_mv::before {
		background: url(../img/recruit/keyword/mv_bg_sp.png) repeat-x center / cover;
	}

	#sec_mv .wrap {
		width: 84%;
	}

	#sec_mv .secttl {
		margin-bottom: 5rem;
	}

	#sec_mv .lead {
		font-size: 3rem;
	}
}


/* keyword
--------------------------------*/
#sec_keyword {
	padding: 90px 0;
	background-color: #00a0e9;
	background-image: url(../img/recruit/keyword/keyword_bg_pc.png);
	background-repeat: no-repeat;
	background-size: 2706px auto;
	background-position: center top;
}

#sec_keyword .box {
	padding: 50px 50px 42px;
	background-color: #fff;
	border-radius: 20px;
}

#sec_keyword .box {
	margin-top: 24px;
}

#sec_keyword .wrap > :first-of-type {
	margin-top: 0;
}

#sec_keyword .box .txtwrap {
	width: 486px;
}

#sec_keyword .box .ttlwrap {
	display: flex;
	align-items: center;
	margin-bottom: 25px;
}

#sec_keyword .box .ttlwrap .num {
	flex: 0 0 auto;
	text-align: center;
	color: #00a0e9;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1;
	letter-spacing: 0.05em;
}

#sec_keyword .box .ttlwrap .num span {
	display: block;
	font-size: 8.2rem;
	line-height: 1;
	letter-spacing: 0.1em;
}

#sec_keyword .box .ttlwrap .ttl {
	color: #00a0e9;
	font-weight: 700;
	font-size: 2.8rem;
	line-height: 1.5;
	letter-spacing: 0.15em;
	margin-left: 1.2em;
}

#sec_keyword .box .ttlwrap .ttl.ls {
	letter-spacing: -0.01em;
}

#sec_keyword .box .ttlwrap .ttl .ttlbg {
	position: relative;
	display: inline-block;
	line-height: 1.25;
	animation-name: bgextendAnimeBase;
	animation-duration: 1s;
	animation-fill-mode: forwards;
	position: relative;
	opacity: 0;
}

@keyframes bgextendAnimeBase {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

#sec_keyword .box.is-show .ttlwrap .ttl .ttlbg > span {
	position: relative;
	display: inline-block;
	animation-name: bgextendAnimeSecond;
	animation-duration: 1s;
	animation-delay: 0.6s;
	animation-fill-mode: forwards;
	opacity: 0;
	-webkit-backface-visibility: hidden;
	backface-visibilsity: hidden;
	overflow: hidden;
	transform: translate3d(0, 0, 0);
	will-change: opacity;
}

@keyframes bgextendAnimeSecond {
	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}
}

#sec_keyword .box .ttlwrap .ttl .ttlbg::before {
	will-change: width;
}

#sec_keyword .box.is-show .ttlwrap .ttl .ttlbg::before {
	animation-name: bgLRextendAnime;
	animation-duration: 1s;
	animation-fill-mode: forwards;
	content: "";
	width: 100%;
	height: 80%;
	background-color: #00a0e9;
	position: absolute;
	left: 0;
	top: 10%;
	-webkit-backface-visibility: hidden;
	backface-visibilsity: hidden;
	overflow: hidden;
}

@keyframes bgLRextendAnime {
	0% {
		left: 0;
		width: 0;
	}

	50% {
		left: 0;
		width: 100%;
	}

	51% {
		left: 0;
		width: 100%;
	}

	100% {
		left: 100%;
		width: 0;
	}
}


#sec_keyword .box .imgwrap {
	width: 438px;
}

#sec_keyword .box .img {
	border-radius: 20px;
	overflow: hidden;
}

#sec_keyword .box .imgwrap.flex .img {
	width: 215px;
	border-radius: 10px;
}

#sec_keyword .box .imgwrap.flex .img._full {
	width: 100%;
	border-radius: 0;
}

#sec_keyword .box .imgwrap.flex .img._full img {
	width: 100%;
}

#sec_keyword .box .imgwrap.flex .img:nth-child(n + 3) {
	margin-top: 8px;
}

#sec_keyword .box .txt {
	text-align: justify;
	letter-spacing: 0.05em;
}

#sec_keyword .box .img + .txt {
	margin-top: 30px;
}

#sec_keyword .btnwrap {
	margin-top: 100px;
}

#sec_keyword .btnwrap .btn {
	margin-top: 0;
}

#sec_keyword .btnwrap .btn a {
	min-width: 344px;
	height: 90px;
}
#sec_keyword .box._06 .img {
	border-radius: 0!important;
}

#sec_keyword .box._10 .img:nth-child(n + 2) {
	margin-top: 8px;
}

@media screen and (min-width: 768px) {

	#sec_keyword .boxwrap.col2 .box {
		width: 538px;
	}

	#sec_keyword .boxwrap.col3 .box {
		width: 350px;
	}

	#sec_keyword .boxwrap.col3 .box .ttlwrap {
		display: block;
		text-align: center;
		margin-bottom: 15px;
	}

	#sec_keyword .boxwrap .box .ttlwrap .ttl {
		margin-left: 1em;
	}

	#sec_keyword .boxwrap.col3 .box .ttlwrap .ttl {
		min-height: 3em;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		margin-top: .754em;
		margin-left: 0;
	}

	#sec_keyword .boxwrap.col3 .box .img {
		border-radius: 10px;
	}

	#sec_keyword .btnwrap .btn a::before {
		background-color: #007de9;
	}
}

@media screen and (max-width: 767px) {
	#sec_keyword {
		padding: 10rem 0 15rem;
		background-color: #00a0e9;
		background-image: url(../img/recruit/keyword/keyword_bg_sp.png);
		background-size: 100%;
		background-repeat: repeat-y;
	}

	#sec_keyword .box {
		padding: 6rem 5rem 4rem;
		border-radius: 3rem;
	}

	#sec_keyword .box {
		margin-top: 6rem;
	}

	#sec_keyword .box .txtwrap {
		width: 100%;
	}

	#sec_keyword .box .ttlwrap {
		margin-bottom: 3.8rem;
	}

	#sec_keyword .box .ttlwrap .num {
		font-size: 2.4rem;
	}

	#sec_keyword .box .ttlwrap .num span {
		font-size: 12.3rem;
		letter-spacing: 0.05em;
	}

	#sec_keyword .box .ttlwrap .ttl {
		font-size: 4.2rem;
		margin-left: .75em;
		white-space: nowrap;
		margin-bottom: -.2em;
	}

	#sec_keyword .box .imgwrap {
		width: 100%;
	}

	#sec_keyword .box .img {
		border-radius: 2rem;
	}

	#sec_keyword .box .imgwrap.flex .img {
		width: 26rem;
		border-radius: 1rem;
	}

	#sec_keyword .box .imgwrap.flex .img:nth-child(n + 3) {
		margin-top: 1rem;
	}

	#sec_keyword .box .txt {
		line-height: 1.85;
	}

	#sec_keyword .box .img + .txt {
		margin-top: 3.5rem;
	}

	#sec_keyword .box .inner.flex .txtwrap {
		display: contents;
	}

	#sec_keyword .box .inner.flex .txtwrap .ttl {
		order: 1;
	}

	#sec_keyword .box .inner.flex .txtwrap .txt {
		order: 3;
		margin-top: 3.5rem;
	}

	#sec_keyword .box .inner.flex .imgwrap {
		order: 2;
	}

	#sec_keyword .btnwrap {
		width: 51.6rem;
		margin: 15rem auto 0;

	}

	#sec_keyword .btnwrap .btn + .btn {
		margin-top: 3.5rem;
	}

	#sec_keyword .btnwrap .btn a {
		min-width: inherit;
		width: 100%;
		height: 13.5rem;
	}
	
	#sec_keyword .box._10 .img:nth-child(n + 2) {
		margin-top: 1rem;
	}
}