@charset "utf-8";
/* CSS Document */
.contents{
	overflow: hidden;
}
.main-bg{
	position: relative;
	background: url("../images/nextchallenge/bg.jpg") no-repeat center center;
	background-size: cover;
	height: calc(100vh - 100px);
	margin-bottom: 85px;
}
.main-bg .tex-box{
	width: 100%;
	text-align: center;
	position: absolute;
    top: 50%;
    left: 0%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
.main-bg .tex-box .tex-img{
	width: 58%;
	max-width: 558px;
	margin-left: auto;
	margin-right: auto;
}
.main-bg .tex-box .tex-img img{
	display: block;
}
.main-bg .tex-box .ttl-tex{
	font-size: 42px;
	color: #fff;
}
.scroll{
	position: absolute;
	bottom: 30px;
	width: 10%;
	max-width: 10px;
	right:5%;
	opacity: 1;
	height: 50px;
		transition: 1.0s;
	-webkit-transition: 1.0s; /* Chrome、Safari用 */
	-moz-transition: 1.0s; /* Firefox用 */
	-o-transition: 1.0s; /* Opera用 */
		-moz-transition-delay:0s;
-webkit-transition-delay:0s;
-o-transition-delay:0s;
-ms-transition-delay:0s;
	/*display: flex;
	justify-content: space-between;
	align-items: flex-end;*/
}
.scroll .sc-img{
	position: absolute;
	left: 0;
	right: 0;
	margin-left: auto;
	margin-right: auto;
	top:-78%;
}
.scroll::after{
  content: "";
    /*描画位置*/
  position: absolute;
  top: 0;
    /*線の形状*/
  width: 1px;
  height: 30px;
	left: 0;
	right: 0;
	margin-left: 32%;
	margin-right: auto;
  background: #fff;
    /*線の動き1.4秒かけて動く。永遠にループ*/
  animation: pathmove 2.0s ease-in-out infinite;
  opacity:0;
}
@keyframes pathmove{
  0%{
    height:0;
    top:0;
    opacity: 0;
  }
  30%{
    height:30px;
    opacity: 1;
  }
  100%{
    height:0;
    top:50px;
    opacity: 0;
  }
}

.first-tex{
	margin-bottom: 130px;
}
.ttl-wrap{
	display: flex;
	margin-left: -11%;
	margin-bottom: 60px;
}
.ttl-wrap.even{
	display: flex;
	margin-left: 0;
	margin-right: -11%;
	flex-direction: row-reverse;
}
.ttl-box{
	padding-top: 32px;
	padding-bottom: 40px;
	border-radius: 5px;
	background: url("../images/nextchallenge/ttl_bg.jpg") no-repeat right top;
	background-size: cover;
	width: 52%;
	box-sizing: border-box;
}
.ttl-wrap.even .ttl-box{
	
	background: url("../images/nextchallenge/ttl_bg2.jpg") no-repeat right top;
	background-size: cover;
}
.ttl-box .ttl-img,.ttl-box .ttl-tex{
	padding-left: 18%;
}
.ttl-box .ttl-tex{
	color: #fff;
	font-size: 26px;
	line-height: 1.3;
	font-weight: 600;
}
.ttl-box .ttl-img{
	padding-bottom: 18px;
	margin-bottom: 36px;
	position: relative;
}
.ttl-box .ttl-img::before{
	z-index: 1;
	position: absolute;
	height: 1px;
	background: #fff;
	left: 0;
	width: 100%;
	bottom: 0;
	content:"";
}
.ttl-box .ttl-img::after{
	z-index: 0;
	position: absolute;
	height: 1px;
	background: #a4a1a0;
	left: 0;
	width: 100%;
	padding-right: 300%;
	margin-right: -300%;
	bottom: 0;
	content:"";
}
.ttl-wrap.even .ttl-box .ttl-img::before{
	left: auto;
	right:0;
}
.ttl-wrap.even .ttl-box .ttl-img::after{
	padding-right: 0;
	margin-right: 0;
	left: auto;
	right:0;
	padding-left: 300%;
	margin-left: -300%;
}
.ttl-box .ttl-img img{
	width: 55%;
	display: block;
}
.con-box{
	margin-bottom: 150px;
}
.img-1{
	width: 86%;
	margin-left: auto;
	margin-right: auto;
}
.ttl-tex1{
	font-size: 37px;
	line-height: 1.51;
	white-space: nowrap;
}
.mini-tex{
	font-size: 12px;
	line-height: 1.66;
}
.img-2{
	width: 86%;
	margin-left: auto;
	margin-right: auto;
	max-width: 334px;
}
.img-3{
	width: 100%;
	max-width: 934px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 100px;
}

.img-4{
	width: 74%;
	margin-left: auto;
	margin-right: auto;
}
.gr-bg.ptn1{
	margin-bottom: 220px;
}
.gr-bg.ptn2{
	margin-bottom: 100px;
}
.btn-area{
    margin-bottom: 100px;
	max-width: 460px;
	width: 86%;
	margin-left: auto;
	margin-right: auto;
}
.btn-area a{
	text-align: center;
	color: #fff;
	line-height: 1;
	background: #464646;
	display: block;
	width: 100%;
	padding:28px 0;
	font-size: 24px;
	position: relative;
}
.btn-area a::after{
	content: "";
	position: absolute;
	top: 50%;
    right: 8%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
	background: url("../images/nextchallenge/yajirushi.png") no-repeat right center;
	background-size: 100%;
	width: 42px;
	height: 18px;
}
.btn-area img{
	width: 28%;
	display: block;
	margin-left: auto;
	margin-right: auto;
}
.btn-text{
	text-align: center;
	font-size: 15px;
	line-height: 1;
	margin-top: 15px;
}
.ttl-wrap2{
	display: flex;
	margin-left: -11%;
	margin-bottom: 50px;
	position: relative;
}
.ttl-wrap2 .ttl-box{
	padding-top: 30px;
	padding-bottom: 20px;
	border-radius: 5px;
	background: url("../images/nextchallenge/ttl_bg.jpg") no-repeat right top;
	background-size: cover;
	width: 52%;
	box-sizing: border-box;
}
.ttl-wrap2 .ttl-box .ttl-img{
	padding-bottom: 0;
	margin-bottom: 0;
}
.ttl-wrap2 .ttl-box .ttl-img img{
	width: 66%;
	display: block;
}
.ttl-wrap2 .ttl-box .ttl-img::before,.ttl-wrap2 .ttl-box .ttl-img::after{
	display: none;
}
.ttl-wrap2::after{
	z-index: 0;
	position: absolute;
	height: 1px;
	background: #a4a1a0;
	left: 0;
	width: 100%;
	margin-left: 53%;
	padding-right: 300%;
	margin-right: -300%;
	bottom: 0;
	content:"";
}
.nm-list li{
	font-size: 15px;
	line-height: 2.3;
	text-align: justify;
	padding-left: 1em;
	text-indent: -1em;
}
.pic-flex{
	margin-top: 50px;
	display: flex;
}
.pic-flex li{
	width: 33%;
	margin-right: 0.4%;
}
.pic-flex li:last-child{
	margin-right: 0;
}

/*20220203追記*/
.gr-bg{
	background: #eeeeee;
	padding-top: 104px;
	padding-bottom: 40px;
}
.copy-tex{
	margin-bottom: 30px;
	font-weight: 700;
	line-height: 1.68;
	font-size: 21px;
}
.job{
	font-size: 14px;
	margin-bottom: 10px;
	line-height: 1.42;
}
.h-name{
	font-size: 26px;
	margin-bottom: 10px;
	line-height: 1;
}
.h-name span{
	margin-left: 1em;
	font-size: 14px;
}
.main-copy{
	font-size: 37px;
	line-height: 1.51;
	margin-bottom: 30px;
}
.main-copy.ptn2{
	margin-bottom: 90px;
}
.sub-copy{
	font-size: 19px;
	line-height: 1.47;
	margin-bottom: 75px;
}
.top-wrap{
	display: flex;
	justify-content: space-between;
	margin-bottom: 90px;
}
.top-wrap .top-box{
	box-sizing: border-box;
	width: 49%;
	padding: 20px 34px;
	background: #fff;
}
.top-wrap .top-box .sub-flex{
	display: flex;
	justify-content: space-between;
}
.top-wrap .top-box .sub-flex .tex{
	width: 65%;
}
.top-wrap .top-box .sub-flex .pic{
	width: 28%;
}
.en-name{
	font-size: 14px;
	color: #868686;
	line-height: 1;
}
.bl-ttl{
	color: #007ac9;
	font-size: 23px;
	line-height: 1;
	margin-bottom: 30px;
	font-weight: 700;
}
.bl-ttl .jp{
	font-size: 15px;
	line-height: 1;
	font-weight: 500;
}
.int-box{
	/*display: flex;
	justify-content: space-between;*/
	margin-bottom: 20px;
	letter-spacing: 0.01em;
}
.line-box{
	border-bottom: 2px solid #afb0b0;
	padding-bottom: 60px;
	margin-bottom: 60px;
}
.int-box.last{
	margin-bottom: 0;
}
.int-box .blue{
	color: #007ac9;
}
/*.int-box dt{
	width: 6%;
	font-size: 15px;
	line-height: 1.86;
	font-weight: bold;
}
.int-box dd{
	width: 91%;
	font-size: 15px;
	line-height: 1.86;
}*/
@media screen and (min-width: 769px) and (max-width: 1200px) {
	.sub-copy{
		font-size: 18px;
	}
.job{
	font-size: 12px;
}
.top-wrap .top-box{
	padding: 20px 20px;
}	
	.bl-ttl{
		font-size: 20px;
	}
}
@media print, screen and (min-width: 769px) {
	.flex-wrap{
		display: flex;
		justify-content: space-between;
		margin-bottom: 40px;
	}
	.flex-wrap.even{
		flex-direction: row-reverse;
	}
	.flex-wrap .box{
		width: 47%;
	}
	.flex-wrap.ex{
		align-items: center;
	}
	.right-tex{
		text-align: right;
		margin-top: 45px;
	}
	.gr-bg .flex-wrap{
		margin-bottom: 85px;
	}
	.gr-bg .flex-wrap.ex1{
		margin-bottom: 70px;
	}
	.gr-bg .tex-wrap{
		margin-bottom: 70px;
	}
	.gr-bg .flex-wrap .pic1{
		width: 30%;
	}
	.gr-bg .flex-wrap .pic2{
		width: 38%;
	}
	.gr-bg .flex-wrap .tex1{
		width: 65%;
	}
	.gr-bg .flex-wrap .tex2{
		width: 56%;
	}
	.copy-tex{
		white-space: nowrap;
	}
	/*20220203追記*/
	.int-box.ptn2 dt{
		width: 4%;
		font-size: 15px;
		line-height: 1;
		font-weight: bold;
	}
	.int-box.ptn2 dd{
		width: 93%;
		font-size: 15px;
		line-height: 1.86;
	}
	
}

@media screen and (min-width: 769px) and (max-width: 1200px) {
.copy-tex{
		white-space: normal;
	}
.ttl-tex1{
	white-space: normal;
	font-size: 26px;
}
	.copy-tex{
		font-size: 19px;
	} 
	.main-bg .tex-box .ttl-tex{
		font-size: 36px;
	}
}
@media only screen and (max-width: 768px) {
.main-bg{
	position: relative;
	background: url("../images/nextchallenge/bg.jpg") no-repeat 30% center;
	background-size: cover;
	height: 80vh;
	margin-bottom: 70px;
}
.main-bg .tex-box .ttl-tex{
	font-size: 6.0vw;
	color: #fff;
	line-height: 1.59;
}

.scroll{
	/*position: absolute;*/
	bottom: 3vw;
	/*width: 14%;
	max-width: 65px;*/
	right:10%;
}
.first-tex{
	margin-bottom: 70px;
}
.ttl-wrap{
	display: flex;
	margin-left: 0%;
	margin-bottom: 40px;
}
.ttl-wrap.even{
	display: flex;
	margin-left: 0;
	margin-right: 0%;
	flex-direction: row-reverse;
}
.ttl-box{
	padding-top: 5vw;
	padding-bottom:5vw;
	background: url("../images/nextchallenge/ttl_bg.jpg") no-repeat right top;
	background-size: cover;
	width: 76%;
	box-sizing: border-box;
}
.ttl-box .ttl-img,.ttl-box .ttl-tex{
	padding-left: 10%;
}
.ttl-box .ttl-tex{
	color: #fff;
	font-size: 3.9vw;
	line-height: 1.3;
	font-weight: 600;
}
.ttl-box .ttl-img{
	padding-bottom: 3vw;
	margin-bottom: 4vw;
	position: relative;
}
.ttl-box .ttl-img::before{
	z-index: 1;
	position: absolute;
	height: 1px;
	background: #fff;
	left: 0;
	width: 100%;
	bottom: 0;
	content:"";
}
.ttl-box .ttl-img::after{
	z-index: 0;
	position: absolute;
	height: 1px;
	background: #a4a1a0;
	left: 0;
	width: 100%;
	padding-right: 300%;
	margin-right: -300%;
	bottom: 0;
	content:"";
}
.ttl-wrap.even .ttl-box .ttl-img::after{
	padding-right: 0;
	margin-right: 0;
	padding-left: 300%;
	margin-left: -300%;
}
.ttl-box .ttl-img img{
	width: 64%;
	display: block;
}
.ttl-wrap2{
	display: flex;
	margin-left: 0%;
	margin-bottom: 35px;
	position: relative;
}
.ttl-wrap2 .ttl-box{
	padding-top: 5vw;
	padding-bottom: 3vw;
	width: 74%;
	box-sizing: border-box;
}
.ttl-wrap2 .ttl-box .ttl-img{
	padding-bottom: 0;
	margin-bottom: 0;
}
.ttl-wrap2 .ttl-box .ttl-img img{
	width: 78%;
	display: block;
}
.ttl-wrap2 .ttl-box .ttl-img::before,.ttl-wrap2 .ttl-box .ttl-img::after{
	display: none;
}
.ttl-wrap2::after{
	z-index: 0;
	position: absolute;
	height: 1px;
	background: #a4a1a0;
	left: 0;
	width: 100%;
	margin-left: 75%;
	padding-right: 300%;
	margin-right: -300%;
	bottom: 0;
	content:"";
}
.con-box{
	margin-bottom: 70px;
}
.flex-wrap .box{
	margin-bottom: 40px;
}

.ttl-tex1{
	font-size: 5.2vw;
	line-height: 1.51;
}
.mini-tex{
	font-size: 3.0vw;
	line-height: 1.66;
}
.img-2{
	width: 86%;
	margin-left: auto;
	margin-right: auto;
	max-width: none;
}
.img-3{
	width: 100%;
	max-width: 934px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 40px;
}
.right-tex{
	margin-top: 40px;
}
.btn-area{
    margin-bottom: 60px;
    max-width: none;
}
.btn-area a{
	padding:5vw 0;
	font-size: 4.8vw;
}
.btn-area a::after{
	content: "";
	position: absolute;
	top: 50%;
    right: 8%;
	background: url("../images/nextchallenge/yajirushi.png") no-repeat right center;
	background-size: 100%;
	width: 10vw;
	height: 6vw;
}
.btn-area img{
	width: 30%;
	display: block;
	margin-left: auto;
	margin-right: auto;
}
.btn-text{
	text-align: center;
	font-size: 3.6vw;
	line-height: 1;
	margin-top: 15px;
}
.nm-list li{
	font-size: 3.3vw;
	line-height: 1.85;
	text-align: justify;
	padding-left: 1.35em;
	text-indent: -1.35em;
	margin-bottom: 10px;
}
	.nm-list li:last-child{
		margin-bottom: 0;
	}
.pic-flex{
	margin-top: 40px;
	display: block;
}
.pic-flex li{
	width: 100%;
	margin-right: 0%;
	margin-bottom: 9px;
}
.pic-flex li:last-child{
	margin-right: 0;
	margin-bottom: 0;
}
	
/*20220203追記*/

.main-copy{
	line-height: 1.51;
	font-size: 5.2vw;
	margin-bottom: 18px;
}
.main-copy.ptn2{
	margin-bottom: 40px;
}
.sub-copy{
	font-size: 3.7vw;
	line-height: 1.47;
	font-weight: 500;
	margin-bottom: 40px;
}
.gr-bg{
	padding-top: 60px;
	padding-bottom: 45px;
}
.copy-tex{
	margin-bottom: 3vw;
	line-height: 1.51;
	font-size: 4.4vw;
	text-align: justify;
}
.job{
	font-size: 2.7vw;
	margin-bottom: 2vw;
	line-height: 1;
}
.h-name{
	font-size: 6.0vw;
	margin-bottom: 5vw;
	line-height: 1;
}
.h-name span{
	margin-left: 1em;
	font-size: 3.3vw;
}
.top-wrap{
	display: block;
	margin-bottom: 70px;
}
.top-wrap .top-box{
	box-sizing: border-box;
	width: 100%;
	padding: 20px 3vw;
	background: #fff;
	margin-bottom: 10px;
}
.top-wrap .top-box .sub-flex{
	display: flex;
	justify-content: space-between;
}
.top-wrap .top-box .sub-flex .tex{
	width: 65%;
}
.top-wrap .top-box .sub-flex .pic{
	width: 28%;
}
.en-name{
	font-size: 3.3vw;
	line-height: 1;
}
.bl-ttl{
	font-size: 5.0vw;
	line-height: 1;
	margin-bottom: 20px;
	font-weight: 700;
}
.bl-ttl .jp{
	font-size: 3.3vw;
	line-height: 1;
	font-weight: 500;
}
.int-box{
	/*display: flex;
	justify-content: space-between;*/
	margin-bottom: 20px;
	letter-spacing: 0.01em;
}
.gr-bg .flex-wrap .pic1{
    margin-bottom: 5vw;
}
.gr-bg .flex-wrap .pic2{
    margin-bottom: 21vw;
}
.gr-bg .flex-wrap .pic2.ex{
    margin-bottom: 7vw;
}
.gr-bg .flex-wrap .pic2.ex2{
    margin-bottom: 10vw;
}
.gr-bg .flex-wrap .pic2.ex3{
    margin-bottom: 25px;
}
.gr-bg .flex-wrap .tex1{
    margin-bottom: 10vw;
}
.gr-bg .flex-wrap .tex2{
    margin-bottom: 5vw;
}
.gr-bg.ptn1{
	margin-bottom: 70px;
}
.gr-bg.ptn2{
	margin-bottom: 50px;
}
.gr-bg.ptn2 .main-copy{
	padding-left: 0.4em;
}
}
@media print, screen and (min-width: 1201px) {

}


@media only screen and (max-device-width: 1024px) and (orientation: landscape){
	.main-bg{
		height: 250vh;
	}
}
