@charset "utf-8";

/* -----------------------------
	job 共通
-------------------------------- */
main .section-title{
	font-size: 3.4rem;
	font-family: 'Noto Sans JP', serif;
}
.page-title-area{
	/*height: 430px;*/
	background: #ddd;
	position: relative;
	background: url(../img/job-bg06.png) no-repeat bottom left / cover,#00e0e9;
	   /* background: url(../img/job-construction02.png) no-repeat top right / cover,
			linear-gradient(270deg, rgba(170,255,92,1) 0%, rgba(21,201,199,1) 100%);*/
}
.page-title-area .title-area{
	padding: 80px 0 0;
	padding: 60px 0 0;
}
.page-title-area .pagetitle-img{
    position: absolute;
    right: 0;
    margin: 0 auto 0;
    width: 55vw;
	max-width: 1000px;
    height: 90%;
    top: 0;
    right: 0;
	border-radius: 0 0 0 30px;
}

.page-title-area .section-title .ja{
	color: #333;
	text-shadow: none;
	margin: 0 0 0;
}

.mv-title{
	font-size: 7.6rem;

	display: inline-block;
	margin: 0;
    line-height: 1.2;
    font-weight: bold;
    padding: 0;
	font-family:  'Montserrat', sans-serif;
}
.mv-title.two{
	margin: 0 0 0;
}
.mv-title .bgLRextendTrigger{
	background: none;
	color: #333;
	padding: 0;
}
.bgLRextend::before{
	background: #f9f9f9;
}
.mv-title .bgappearTrigger{
}
.mv-title.sp-display-b{
	display: none;
}


@media screen and (max-width: 1300px) {

}

@media screen and (max-width: 768px) {
	main .section-title{
		font-size: 2.1rem;
		line-height: 1.4;
	}
	.mv-title{
		font-size: 3.2rem;
	}
	.mv-title.two{
		margin: 10px 0 0;
	}
	/*.page-title-area{
		height: 250px;
		padding: 0 0 0 20px;
	}*/
	.page-title-area .title-area{
		padding: 120px 0 0;
		padding: 20px 10px 0 20px;
	}
	.page-title-area .pagetitle-img{
		width: 80%;
		height: 200px;
	}
	.page-title-area .pagetitle-img img{
		height: 200px;
		object-fit: cover;
	}
	.page-title-area .section-title{
		font-size: 3.2rem;
	}
	.page-title-area .section-title .ja{
		margin: 0;
	}
}

/* -----------------------------
	job TOP
-------------------------------- */




@media screen and (max-width: 1300px) {



}

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



}

/* intro-area------------------------- */
.intro-area{
    position: relative;
	margin: 0 0 0;
	padding: 80px 0 120px;
}
.intro-area::before{
content: '';
    position: absolute;
    background: url(../img/machi-bg03.png) no-repeat bottom right / contain;
    width: 1182px;
    height: 617px;
    mix-blend-mode: multiply;
    right: 0;
    bottom: 0;
    opacity: 0.5;
	z-index: -1;
}

.intro-img{
    position: absolute;
    right: 0;
    margin: 0 auto 0;
	width: 48vw;
	max-width: 1000px;
	height: 360px;
	top: 50%;
    right: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
	border-radius: 30px 0 0 30px;
}

.intro-img img{
    border-radius: 30px 0 0 30px;
}

    
.intro-ttl h3{
    font: 700 4.5rem / 1.2 'Noto Sans JP', sans-serif;
}

.intro-area .basic-txt{
	margin: 50px 0 0;
	width: 50%;
}

@media screen and (max-width: 1300px) {



}

@media screen and (max-width: 768px) {
	.intro-area{
		padding: 0;
	}
	
	.intro-area::before{
		width: 100%;
	}

	.intro-img{
		border-radius: 0;
		top: 0;
		position: relative;
		height: auto;
		width: 100%;
		transform: initial;
	}

	.intro-img img{
		border-radius: 0;
	}


	.intro-ttl h3{
	}

	.intro-area .txt-area{
		padding: 50px 0 30px;
	}
	.intro-area .basic-txt{
		width: 100%;
		margin: 0 0 0;
		 background-color:rgba(255,255,255,0.8);
		padding: 20px;
	}
    
}

/* description-area------------------------- */
.description-area{
	padding: 80px 0 80px ;
	/*background: url("../img/main-bg02.png")no-repeat top center / 100%;*/
	background: #f1f2f6; 
	position: relative;

}
.description-area .section-title{
	padding: 0 50px;	
}
.description-area .basic-txt{
	margin: 30px 0 0;
	background-color:#fff;
	box-shadow:0 0 0 2px #ccc;
	padding: 20px;
	font-weight: 700;
	font-size: 1.6rem;
	width: 800px;
	border-radius: 10px;
	text-align: center;
	margin: 30px auto 0;
}

.flow-wrap{
	margin: 30px 0 0;
	/*display: flex;
	justify-content: space-around;
	background: #ddd;
	padding: 30px;
	border-radius: 15px;
	background:  linear-gradient(90deg, rgba(21,201,199,1) 0%, rgba(62,210,170,1) 100%)*/
}
.flow-wrap .box{

}

.flow-wrap .first,
.flow-wrap .third{
	font-weight: bold;
	text-align: center;
	padding: 30px 20px;
    /*display: flex;
    align-items: center;*/
}
.flow-wrap .first:after,
.flow-wrap .second:after{
	content: '';
	position: absolute;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 25px 0 25px 25px;
	border-color: transparent transparent transparent #ffffff;
	right: -33px;
	top: 85px;
}

.flow-wrap .first{
	display: flex;
	align-items: center;
}

.flow-wrap .third img{
	width: 180px;
	margin: 10px 0 0;
}

.flow-wrap .second{
	width: 700px;
}
.flow-wrap .box ul{
	display: flex;
	justify-content: space-between;
	padding: 0 50px;
}
.flow-wrap .box ul li{
	width: calc((100% / 4) - 10px);
	border-radius: 15px;
	position: relative;
	background: #fff;
	padding: 20px 30px;
	border: solid 1px #ff7658;
}
.flow-wrap .box ul li.quality{
	border: solid 1px #5fa8e3;
}
.flow-wrap .box ul li.sche{
	border: solid 1px #ff9c3a;
}
.flow-wrap .box ul li.money{
	border: solid 1px #28b58e;
}

/*
.flow-wrap .box ul li::before{
	content: '';
	position: absolute;
	width: 220px;
	height: 220px;
	background: #fff;
	border-radius: 50%;
	top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
	border: solid 1px #ff7658;
}
.flow-wrap .box ul li.quality::before{
	border: solid 1px #5fa8e3;
}
.flow-wrap .box ul li.sche::before{
	border: solid 1px #ff9c3a;
}
.flow-wrap .box ul li.money::before{
	border: solid 1px #28b58e;
}
*/

.flow-wrap .box ul li > div{
	position: relative;
	
}

.flow-wrap .box ul li .sub-title{
	/*background: #ddd;*/
	display: block;
	text-align: center;
	font-weight: bold;
	font-size: 2rem;
	margin: 10px 0 0;
}
.flow-wrap .box ul li:first-of-type .sub-title{
	color: #ff7658;
}
.flow-wrap .box ul li:nth-child(2) .sub-title{
	color: #5fa8e3;
}
.flow-wrap .box ul li:nth-child(3) .sub-title{
	color: #ff9c3a;
}
.flow-wrap .box ul li:nth-child(4) .sub-title{
	color: #28b58e;
}

.flow-wrap .box ul li .txt{
	padding: 5px 0 0;
	text-align: center;
	font-size: 1.6rem;
	font-weight: 500;
}
.flow-wrap .box ul li .img{
	/*display: block;*/
	text-align: center;
	height: 74px;
	align-items: center;
    display: flex;
    justify-content: center;
}
.flow-wrap .box ul li img{
	width: 80px;
}
.flow-wrap .box ul li.quality img{
	width: 65px;
}
.flow-wrap .box ul li.sche img{
	width: 70px;
}
.flow-wrap .box ul li.money img{
	width: 50px;
}

@media screen and (max-width: 768px) {
	.description-area{
		padding: 30px 0 30px;
	}
	.description-area .section-title{
		padding: 0;
	}
	.description-area .basic-txt{
		width: 100%;
		margin: 10px 0 0;
	}

	.flow-wrap{
		display: block;
		margin: 20px 0 0;
		padding: 0;
	}
	.flow-wrap .box:nth-child(n + 2){
		margin: 40px 0 0;
	}
	.flow-wrap .box{
	}

	.flow-wrap .first,
	.flow-wrap .third{
		padding: 20px;
		
	}
	.flow-wrap .first:after,
	.flow-wrap .second:after{
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 20px 15px 0 15px;
		border-color: #ffffff transparent transparent transparent;
		left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
		top: auto;
		bottom: -30px;
	}

	.flow-wrap .second{
		width: 100%;
		padding: 15px;
	}
	.flow-wrap .box ul{
		display: flex;
		justify-content: space-between;
		padding: 0;
		flex-wrap: wrap;
	}
	.flow-wrap .box ul li{
		width: calc((100% / 2) - 5px);
		border-radius: 10px;
		background: #fff;
		padding: 10px;
		border: solid 1px #ff7658;
	}
	.flow-wrap .box ul li .sub-title{
		margin: 0;
	}
	.flow-wrap .box ul li.quality{
		border: solid 1px #5fa8e3;
	}
	.flow-wrap .box ul li.sche{
		border: solid 1px #ff9c3a;
	}
	.flow-wrap .box ul li.money {
		border: solid 1px #28b58e;
	}
	.flow-wrap .box ul li:nth-child(n + 3){
		margin: 10px 0 0;
	}
	.flow-wrap .box ul li::before{
		display: none;
	}
	.flow-wrap .box ul li .img{
		height: 60px;
	}
	.flow-wrap .box ul li img{
		width: 60px;
	}
	.flow-wrap .box ul li.quality img{
		width: 45px;
	}
	.flow-wrap .box ul li.sche img{
		width: 50px;
	}
	.flow-wrap .box ul li.money img{
		width: 35px;
	}
	.flow-wrap .box ul li .txt{
		font-size: 1.4rem;
	}
	
}

/* works-area------------------------- */
.works-area{
	padding: 100px 0 450px;
		background: #f9f9f9;
}

.figure-area{
	width: 750px;
	margin: 50px auto 0;

}

.figure-area .block{
	position: relative;
}

.figure-area .img.toei{
	position: absolute;
	margin: 130px 0 0;
}
.figure-area .img.office{
	position: absolute;
	right: 0;
	margin: 130px 0 0;
}
.figure-area .img img{
	margin: 0 auto;
	display: block;
}
.figure-area .txt{
	position: absolute;
	font-size: 2.4rem;
	font-weight: bold;
	background: #fff;
	padding: 3px 10px;
	border: solid 3px #3ed2aa;
	color: #3ed2aa;
}
.figure-area .txt01{
	left: 0;
	top: 230px;
}
.figure-area .txt03{
	right: 0;
	top: 230px;
	border: solid 3px #2fb4d6;
	color: #2fb4d6;
}
.figure-area .txt02{
	bottom: -250px;
	left: 50%;

    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
	border-image-source: linear-gradient(90deg, #3ed2aa 0%, #2fb4d6 100%);
	border-image-slice: 1;
	
	background: linear-gradient(0deg, #3ed2aa 0%, #2fb4d6 100%);
  background: -webkit-linear-gradient(0deg, #3ed2aa 0%, #2fb4d6 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

#scroll-down {
    display: block;
    position: relative;
    padding-top: 79px;
  text-align:center;
}
.arrow-down {
    display: block;
    margin: 0 auto;
    width: 10px;
    height: 38px;
}
.arrow-down:after {
    content: '';
    display: block;
    margin: 0;
    padding: 0;
    width: 8px;
    height: 8px;
    border-top: 2px solid #b91a2f;
    border-right: 2px solid #b91a2f;
    behavior: url(-ms-transform.htc);
    -moz-transform: rotate(135deg);
    -webkit-transform: rotate(135deg);
    -o-transform: rotate(135deg);
    -ms-transform: rotate(135deg);
    transform: rotate(135deg);
}

@media screen and (max-width: 768px) {
	.works-area{
		margin: 30px 0 0;
	}
	
}

/* merit-area------------------------- */
.merit-area{
	/*margin: 100px 0 0;*/
	position: relative;
	background: #fdfff0;
	padding: 100px 0;
}
.merit-area .inner{

}

/* block */
.merit-area .block{
	display: flex;
	justify-content: space-between;
	margin: 50px 0 0;
}
.merit-area .block > div{
	width: calc((100% / 2) - 20px);
}
.merit-area .block .title{
	font-size: 2.6rem;
	font-weight: bold;
	position: relative;
}
.merit-area .block .title::before{
	content: '';
	position: absolute;
	background: url("../img/merit.png") no-repeat top center / contain;
	width: 140px;
	height: 100px;
	left: -50px;
	top: -50px;
}
.merit-area .block .demerit .title::before{
	background: url("../img/demerit.png") no-repeat top center / contain;
	width: 140px;
	height: 100px;
	left: -50px;
	top: -40px;
}

.merit-area .block li{
	position: relative;
	background: #ffead5;
	margin: 40px 0 0;
	padding: 50px 30px 30px;
	border-radius: 10px;
	height: 165px;
}
.merit-area .block .demerit li{
	background: #f1f9ff;
	padding: 50px 30px 30px;
}
.merit-area .block .merit li .catch{
	background:#FF8E3F;
	color: #fff;
	padding: 0 20px;
	border-radius: 50px;
	font-size: 2rem;
	font-weight: 700;
	display: inline-block;
	/*border: solid 5px #FF8E3F;*/
	position: absolute;
	top: -20px;
	height: 76px;
	line-height: 76px;
	width: 300px;
	text-align: center;
}
.merit-area .block .demerit li .catch{
	background: #EDEDED;
	color: #3C2C25;
	padding: 10px 20px;
	border-radius: 5px;
	font-size: 1.7rem;
	font-weight: 700;
	display: inline-block;
	position: absolute;
	top: -20px;
	width: 300px;
	border: solid 1px #fff;
}
.merit-area .block .demerit .catch::before{
	content: '';
	position: absolute;
	background: url("../img/demerit-title.png") no-repeat top center / contain;
	width: 60px;
	height: 30px;
	right: -65px;
	top: 30px;
}
.merit-area .basic-txt{
	margin: 20px 0 0;
	font-size: 1.8rem;
}
.merit-area .merit .basic-txt span{
	color: #ff7658;
	font-weight: bold;
}
.merit-area .demerit .basic-txt span{
	color: #ff7658;
	font-weight: bold;
}

.merit-area .box{
	background: #fff;
	padding: 15px;
	border-radius: 5px;
	font-weight: 500;
	line-height: 2;
	border: solid 1px #e97400;
	font-size: 1.8rem;
	background: #fff0e1;
}
.merit-area .box span{
	background: #e97400;
	padding: 2px 5px 3px;
	color: #fff;
}

.merit-area .block li::before{
	content: '';
	position: absolute;
	background: url("../img/merit01.png")no-repeat top center / contain;
	width: 90px;
	height: 120px;
	right: 50px;
	top: -20px;
}
.merit-area .block li.merit02::before{
	background: url("../img/merit02.png")no-repeat top center / contain;
	width: 85px;
	height: 120px;
	right: 50px;
	top: -20px;
}
.merit-area .block li.demerit01::before{
	background: url("../img/demerit01.png")no-repeat top center / contain;
	width: 90px;
	height: 105px;
	right: 50px;
	top: -20px;
}
.merit-area .block li.demerit02::before{
	background: url("../img/demerit02.png")no-repeat top center / contain;
	width: 90px;
	height: 105px;
	right: 50px;
	top: -20px;
}

@media screen and (max-width: 768px) {
	.merit-area{
		margin: 30px 0 0;
		position: relative;
		padding: 30px 0;
	}
	.merit-area .inner{

	}
	.merit-area .block{
		display: block;
		margin: 20px 0 0;
	}
	.merit-area .block > div{
		width: 100%;
	}
	.merit-area .block .title{
		font-size: 2rem;
	}
	
	.merit-area .block li{
		padding: 30px 15px 15px;
		margin: 30px 0 0;
		height: auto;
	}
	.merit-area .block .title::before{
		width: 80px;
		height: 60px;
		left: -15px;
		top: -30px;
	}
	.merit-area .block .merit li .catch{
		font-size: 1.8rem;
		padding: 13px 20px;
		height: auto;
		line-height: inherit;
		left: 0;
		text-align: left;
	}
	.merit-area .basic-txt{
		font-size: 1.6rem;
		margin: 10px 0 0;
	}
	
	.merit-area .block li::before{
		width: 70px;
		height: 80px;
		z-index: 1;
		right: 0;
		top: -50px;
	}
	.merit-area .block li.merit02::before{
		width: 70px;
		height: 80px;
		right: 0;
		top: -50px;
	}
	
	.demerit{
		margin: 30px 0 0;
	}
	.merit-area .block .demerit .title::before{
		left: -15px;
		width: 110px;
		height: 60px;
	}
	.merit-area .block .demerit li .catch{
		font-size: 1.6rem;
		left: 0;
	}
	.merit-area .block .demerit li{
		padding: 30px 15px 15px;
	}
	.merit-area .block .demerit .catch::before{
		display: none;	
	}
	.merit-area .block li.demerit01::before{
		width: 70px;
		height: 80px;
		right: -10px;
		top: -50px;
	}
	.merit-area .block li.demerit02::before{
		width: 70px;
		height: 80px;
		right: -10px;
		top: -50px;
	}
	.merit-area .demerit .basic-txt{
		margin: 30px 0 0;
	}
	
}

/* type-area------------------------- */

.type-area{
	margin: 0px 0 0;
    padding: 100px 0 100px;
	position: relative;
	/*background: url(../img/square-bg.png),#fff;*/
}
.type-area::before{
    content: '';
    position: absolute;
    background: url(../img/machi-bg02.png) no-repeat bottom right / auto;
    width: 663px;
    height: 667px;
    mix-blend-mode: multiply;
    left: 0;
    bottom: -100px;
    opacity: 0.3;
	z-index: -1;
}

.type-area .txt-area{
}

.type-list{
	margin: 50px auto 0;
}

.opp-cell{
    background: #ecffff;
    border-radius: 15px;
    padding: 50px 15px 20px;
    color: #333;
    font-weight: bold;
    width: calc( ( 100% - 30px ) / 6);
    text-align: center;
    margin: 30px auto 0 0;
	border: solid 2px #15c9c7;
	position: relative;
}
/*
.opp-cell:nth-child(3n){
    margin-right: 0;
}*/


.opp-cell h4{
    font-size: 2rem;
    font-weight: 700;
	text-align: center;
	position: relative;
	color: #009c9b;
}
/*
.opp-cell h4::before{
	content: '';
	position: absolute;
	background: url("../img/job-con-occ01.png")no-repeat top center / contain;
	width: 36px;
	height: 40px;
	left: 0;
}
.opp-cell.oc02 h4::before{
	background: url("../img/job-con-occ02.png")no-repeat top center / contain;
}
.opp-cell.oc03 h4::before{
	background: url("../img/job-con-occ03.png")no-repeat top center / contain;
}
.opp-cell.oc04 h4::before{
	background: url("../img/job-con-occ04.png")no-repeat top center / contain;
}
.opp-cell.oc05 h4::before{
	background: url("../img/job-con-occ05.png")no-repeat top center / contain;
}
.opp-cell.oc06 h4::before{
	background: url("../img/job-con-occ06.png")no-repeat top center / contain;
}
*/

.opp-cell .img{
	position: absolute;
	top: -40px;
	display: flex;
    justify-content: center;
	align-items: center;
	left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.opp-cell .img::before{
	content: '';
	position: absolute;
	width: 80px;
	height: 80px;
	background: #e7ffff;
	background: #fff;
	border-radius: 50%;
	border: solid 2px #15c9c7;
}

.opp-cell img{
    margin: 15px auto;
	width: 36px;
	height: 40px;
	z-index: 1;
	position: relative;
	object-fit: contain;
}

.opp-txt{
    font-size: 1.5rem;
    line-height: 1.7;
    text-align: left;
	margin: 10px 0 0;
	font-weight: normal;
}
/*
.type-list{
	background:#e4ffff;
	padding: 80px 50px 50px;
	border-radius: 30px;
}*/

/*
.type-area .img{
	position: absolute;
	text-align: center;
	margin: 0 auto;
	width: 300px;
}
.type-area .img img{
	width: 100%;
}
.type-area .img.opp-img01{
	left: 50px;
	top: 200px;
}
.type-area .img.opp-img02{
	right: 50px;
	top: -50px;
}*/

@media screen and (max-width: 1300px) {



}

@media screen and (max-width: 768px) {
	.type-area{
		margin: 0;
		padding: 40px 0;
	}

	.type-area .txt-area{
		top: -15px;
		margin: 0 0 0 20px;
	}

	.opp-cell{
		width: 100%;
		margin: 15px auto 0 0;
		padding: 15px;
	}

	.opp-cell:nth-child(3n){
	}


	.opp-cell h4{
		font-size: 1.8rem;
	}

	.opp-cell h4::before{
		width: 36px;
		height: 40px;
		left: 0;
	}
	.opp-cell.oc02 h4::before{
	}
	.opp-cell.oc03 h4::before{
	}
	.opp-cell.oc04 h4::before{
	}
	.opp-cell.oc05 h4::before{
	}
	.opp-cell.oc06 h4::before{
	}


	.opp-cell img{
		width: 25px;
		height: 30px;
	}
	.opp-cell .img::before{
		width: 60px;
		height: 60px;
	}
	.opp-cell .img{
		top: -10px;
		left: 40px;
		
	}

	.opp-txt{
	}

	.type-list{
		border-radius: 0;
		padding: 10px 20px 0;
		margin: 0;
	}
}
/* recruit-area------------------------- */

.recruit-area{
    margin: 0 auto 0;
    position: relative;
	padding: 50px 0;
	/*background: url("../img/main-bg02___.png")no-repeat top right / auto,#f6fbff;*/
    padding: 80px 0 100px;
	    background: linear-gradient(90deg, rgb(255 185 116) 0%, rgb(255 171 153) 100%);
}

.recruit-area .section-title{
	color: #fff;
}
/*
.recruit-area::before{
	position: absolute;
	width: 100%;
	height: 1300px;
	content: '';
	background: url(../img/dot-lightblue.jpg) top right repeat;
	z-index: -3;
	top: -300px;
}
*/
.recruit-area .txt-area{
	display: flex;
	justify-content: space-between;
}
.recruit-area .txt-area > div{
	width: 600px;
}
.recruit-area .txt-area .basic-txt{
	width: 600px;
}
/*
.recruit-img{
    padding: 50px 0 0 0;
    left: 0;
    margin: 15px auto 0;
    width: 1200px;
}
.recruit-img img{
	width: 1200px;
	height: 500px;
	object-fit: cover;
	border-radius: 50px;
}*/

.recruit-box{
    margin: 45px auto 0;
    line-height: 1.9;
    font-size: 1.7rem;
    position: relative;
}

.recruit-box p{
    
}
.recruit-area .wrap{
	display: flex;
	margin: 20px 0 0;
}
.recruit-list{
    background-color: #fff2e5;
    border-radius: 15px;
    padding: 30px 20px 20px;
    margin: 15px auto;
    position: relative;
	width: calc((100% / 3) - 20px);
    /*box-shadow: 10px 10px 30px rgb(0 0 0 / 16%);*/
}
.recruit-list::before{
	background: none;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 25px 5px 0 30px;
	border-color: #fff2e5 transparent transparent transparent;
	left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
	bottom: -25px;
	content: '';
	position: absolute;
}

.recruit-list::after{
	content: '';
	position: absolute;
	background: url("../img/recruit01.png")no-repeat top center / contain;
	width: 90px;
	height: 90px;
	right: 80px;
	bottom: -70px;
}
.recruit-list:nth-child(2)::after{
	background: url("../img/recruit02.png")no-repeat top center / contain;
	right: 80px;
}
.recruit-list:nth-child(3)::after{
	background: url("../img/recruit03.png")no-repeat top center / contain;
	right: 80px;
}

.recruit-list li{
    position: relative;
    margin: 0 0 0 20px;
    font-weight: 500;
    line-height: 2;
    font-size: 1.8rem;
}
/*.recruit-list li::before{
    content: "";
    position: absolute;
    display: block;
    background: url("../img/check-icon.png")no-repeat top center / 100%;
    width: 24px;
    height: 24px;
    top: 12px;
    left: -40px;
}*/
.recruit-list li::before{
    content: "・";
    position: absolute;
    display: block;
    width: 24px;
    height: 24px;
    left: -20px;
	color: #e97400;
}
.recruit-list::after{
    content: "";
    position: absolute;
    display: block;
}
.recruit-list .sub-catch{
	position: absolute;
	background: #e97400;
	background: linear-gradient(90deg, rgba(255,156,58,1) 0%, rgba(255,118,88,1) 100%);
	top: -20px;
	font-size: 1.8rem;
	font-weight: 500;
	border-radius: 50px;
	padding: 0 20px 1px;
	left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
	display: inline-block;
	width: 280px;
	text-align: center;
	margin: 0;
	color: #fff;

}

.recruit-list .sub-catch::before{
	/*background: none;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 15px 15px 0 15px;
	border-color: #e97400 transparent transparent transparent;
	left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
	top: 36px;*/
	content: '';
}
/*
.recruit-list.rl01::after{
    background: url("../img/job-con-r01.png")no-repeat top center / 100%;
	width: 100px;
    height: 120px;
    right: 59px;
    top: 12px;
}

.recruit-list.rl02::after{
    background: url("../img/job-con-r02.png")no-repeat top center / 100%;
	width: 100px;
    height: 120px;
    right: 59px;
    top: 46px;
}

.recruit-list.rl03::after{
    background: url("../img/job-con-r03.png")no-repeat top center / 100%;
	width: 80px;
    height: 120px;
    right: 72px;
    top: 36px;
}*/


@media screen and (max-width: 1300px) {



}

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

	.recruit-area{
		padding: 40px 0 10px;
	}
	.recruit-area::before{


	}
	.recruit-area .txt-area{
		display: block;
	}
	.recruit-area .txt-area > div{
		width: 100%;
	}
	.recruit-area .txt-area .basic-txt{
		width: 100%;
		margin: 20px 0 0;
	}
	.recruit-area .wrap{
		display: block;
		margin: 20px 0 0;
	}
	.recruit-list{
		border-radius: 15px;
		padding: 20px 10px 10px;
		width: 100%;
		margin: 0 0 30px;
	}
	.recruit-list li{
		font-size: 1.6rem;
	}
	.recruit-list::after{
		width: 60px;
		height: 60px;
		bottom: auto;
		top: -40px;
		right: -10px;
	}
	.recruit-list:nth-child(2)::after{
		right: -10px;
	}
	.recruit-list:nth-child(3)::after{
		right: -10px;
	}
	.recruit-list::before{
		display: none;
	}
}

/* schedule-area------------------------- */

.schedule-area{
    position: relative;
	background:#f1f2f6;
	padding: 100px 0 80px;
	margin: 0 0 0;
}
.schedule-area::before{
	content: '';
	position: absolute;
	background:url("../img/machi-bg.png") no-repeat bottom right / auto;
	width: 1182px;
	height: 617px;
	mix-blend-mode: multiply;
	right: 0;
	bottom: 0;
	opacity: 0.15;
}


.schedule-area .img-wrap{
    position: absolute;
    z-index: -2;
    margin: 0 auto 0;
	height: 300px;
	width: 800px;
    border-radius:  30px;
	
	left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.schedule-area .img-wrap img{
    border-radius:  30px;
	width: 100%;
}

.schedule-area .schedule-img01{
	top: -120px;
    margin: 0 0 0 360px;
}

.schedule{
    margin: 0 auto 0;
	position: relative;
}

/*
.schedule::before{
	background: #ddd;
	width: 90%;
	height: calc(100% + 380px);
	position: absolute;
	content: '';
	z-index: -3;
	border-radius: 0 60px 60px 0;
	top: -80px;
	background: linear-gradient(90deg, rgba(21,201,199,1) 0%, rgba(62,210,170,1) 100%);
}*/

.schedule .ttl-rhombus-box::before{
    border: none;
    background: linear-gradient(190deg, rgba(21,201,199,1) 0%, rgba(177,239,255,1) 100%);
    opacity: .42;
}

.schedule-icon{
    position: absolute;
    left: -43px;
    z-index: 2;
}

.schedule .section-title{
    /*padding: 0 0 0 90px;
    z-index: 2;
    text-shadow: 
            1px 1px 1px #fff,
            -1px 1px 1px #fff, 
            1px -1px 1px #fff, 
            -1px -1px 1px #fff, 
            1px 0px 1px #fff, 
            0px 1px 1px #fff, 
            -1px 0px 1px #fff, 
            0px -1px 1px #fff;
	color: #fff;
  text-shadow    : 
       1px  1px 0px #ccc,
      -1px  1px 0px #ccc,
       1px -1px 0px #ccc,
      -1px -1px 0px #ccc,
       1px  0px 0px #ccc,
       0px  1px 0px #ccc,
      -1px  0px 0px #ccc,
       0px -1px 0px #ccc;  */
}
.schedule .section-title .ja{
	color: #fff;	
	text-shadow: none;
}


.schedule-table {
	padding: 0 0;
	position: relative;
	margin: 30px auto 0;
}

.schedule-table .inner {
	background: #fff;
	padding: 100px;
	border-radius: 60px;
}

.schedule-table dl {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 30px 0 0;
}
.schedule-table dl dd{
	position: relative;
}
.schedule-table dl dt {
	width: 90px;
	padding: 32px 7px 16px 0;
	position: relative;
    color: #fff;
    text-align: center;
    font-weight: bold;
    font-size: 1.8rem;
    letter-spacing: 1.5px;
    font-family: 'Montserrat', sans-serif;
}

.schedule-table dl dt::before{
    content: "";
    position: absolute;
    display: block;
    width: 2px;
    height: 100%;
    left: 37px;
    top: 0px;
    background-color: #ddd;
    z-index: -2;
}

.schedule-table dl dt::after {
	content: "";
    display: block;
    width: 90px;
    height: 90px;
    border-radius: 50%;
	position: absolute;
    left: -5px;
    top: 0px;
	background-color: #333;
    z-index: -1;
}

.schedule-table dl dt.teime01::after {
	background: #a0d9ed;
}
.schedule-table dl dt.teime02::after {
	background: #b4deec;
}
.schedule-table dl dt.teime03::after {
	background: #dae283;
}
.schedule-table dl dt.teime04::after {
	background: #d7d93f;
}
.schedule-table dl dt.teime05::after {
	background: #f0cc20;
}
.schedule-table dl dt.teime06::after {
	background: #f0a128;
}
.schedule-table dl dt.teime07::after {
	background: #ac7068;
}
.schedule-table dl dt.teime08::after {
	background: #ac7068;
}
.schedule-table dl dt.teime08::after {
	background: #7d45a8;
}

.schedule-table dl dd.time02::before{
	content: '';
	position: absolute;
	background:url("../img/sche02.png") no-repeat bottom right / contain;
	width: 120px;
	height: 150px;
	z-index: 1;
	right: 50px;
	top: -40px;
}

.schedule-table dl dd.time04::before{
	content: '';
	position: absolute;
	background:url("../img/sche04.png") no-repeat bottom right / contain;
	width: 180px;
	height: 130px;
	z-index: 1;
	right: 150px;
	top: -100px;
}
.schedule-table dl dd.time05::before{
	content: '';
	position: absolute;
	background:url("../img/sche05.png") no-repeat bottom right / contain;
	width: 120px;
	height: 150px;
	z-index: 1;
	right: 50px;
	top: -40px;
}
.schedule-table dl dd.time08::before{
	content: '';
	position: absolute;
	background:url("../img/sche08.png") no-repeat bottom right / contain;
	width: 120px;
	height: 180px;
	z-index: 1;
	right: 150px;
	top: -40px;
}

/*
.schedule-table dl dt.sch-icon::after{
    content: "";
    display: block;
    position: absolute;
    width: 60px;
    height: 60px;
    background-color: #333;
    transform: rotate(45deg);
	left: 6px;
    top: -4px;
    border: 3px solid #333;
    border-radius: 10px;
    z-index: -1;
}*/

.schedule-table dl dd {
	width: calc(100% - 110px);
	padding: 25px 0 25px 25px;
    margin: 0px auto 30px 20px;
	background: #fff;
	border-radius: 5px;
	box-shadow: 10px 10px 30px rgb(0 0 0 / 16%);
	position: relative;
}

.schedule-table dl dd:nth-of-type(2n){
    
}


.schedule-table dl dd h2 {
	font-size: 22px;
	font-weight: bold;
	margin: 0 0 5px;
}

.schedule-table dl dd > div{
	display: flex;
}

.schedule-table dl dd p{
	line-height: 2;
    font-size: 1.7rem;
    font-weight: 500;
}
/*
.txt-s-white{
    text-shadow: 
            1px 1px 1px #fff,
            -1px 1px 1px #fff, 
            1px -1px 1px #fff, 
            -1px -1px 1px #fff, 
            1px 0px 1px #fff, 
            0px 1px 1px #fff, 
            -1px 0px 1px #fff, 
            0px -1px 1px #fff;
}*/

.schedule-table dl dd p span{
	font-size: 2rem;
	padding: 7px 40px 8px;
	border-radius: 30px;
	position: absolute;
	display: inline-block;
	line-height: 1;
	top: -15px;
}
/* 朝礼 */
.schedule-table dl dd p span.time01{
	background: #a0d9ed;
	color: #fff;
}
.schedule-table dl dd p span.time03{
	background: #dae283;
	color: #fff;
}
.schedule-table dl dd p span.time04{
	background: #d7d93f;
	color: #fff;
}
.schedule-table dl dd p span.time06{
	background: #f0a128;
	color: #fff;
}
.schedule-table dl dd p span.time08{
	background: #7d45a8;
	color: #fff;
}


@media screen and (max-width: 1300px) {



}

@media screen and (max-width: 768px){
    
    .schedule-area {
        padding: 0 0 0;
    }
	.schedule-area .schedule-img01{
		width: 100%;
		margin: 0;
	right: 0;
    transform: none;
    left: auto;
    text-align: right;
	}
    
    .schedule {
        margin: 50px auto 0;
		padding: 40px 0 40px;
    }

	.schedule::before{
		border-radius: 0 15px 15px 0;
		width: 98%;
	}
    
    .schedule-img{
        margin: -24px auto 0 55px;
    }
    
    .schedule-icon img{
        width: 60px;
    }
    
    .schedule .ttl-rhombus-box::before{
        left: -21px;
    }
    
    .schedule .ttl-rhombus-box::after{
        left: -59px;
    }
    
    .schedule-icon{
        left: 2px;
        top: -4px !important;
    }
   
    
    
	/* --------------history-box-------------- */
	
	.schedule-table {
		padding: 0 0 0;
		margin: 0 0 0;
	}
	.schedule-table .inner {
		padding: 50px 20px;
		border-radius: 0 30px 0 0;
	}

	.schedule-table dl {
		display: inline-flex;
		width: 100%;
		margin: 20px 0 0;
		padding: 0 0;
	}

	.schedule-table dl dt {
		width: 67px;
        padding: 17px 0 0 12px;
        line-height: 1.5;
        text-align: center;
        font-size: 1.4rem;
	}
	.schedule-table dl dt.sch-icon{
		padding: 11px 0 0 14px;
	}

	.schedule-table dl dd {
		width: calc(100% - 100px);
        padding: 5px 10px;
        margin: 8px auto 0px 15px;
	}
	.schedule-table dl dd p span{
		font-size: 1.5rem;
		position: inherit;
		display: table;
		line-height: 1;
		padding: 5px 40px 5px;
	}

	.schedule-table dl dd h2 {
		font-size: 22px;
		font-weight: bold;
		margin: 0 0 5px;  
	}

	.schedule-table dl dd > div{
		justify-content: space-between;
        display: flex;
        margin: 0 0 5px 0;
	}
    .schedule-table dl dd > div:last-child{
        margin: 0;
	}

	.schedule-table dl dd p{
		line-height: 1.6;
		width: calc(100% - 15px);
        font-size: 1.6rem;
	}
    
    .txt-s-white{
        text-shadow: none;
    }
    
    .schedule-table dl dt.sch-icon::after{
        width: 45px;
        height: 45px;
        top: -2px;
        left: 17px;
    }
    
    .schedule-table dl dt::before{
        left: 41px;
    }
    
    .schedule-table dl dt::after {
        left: 16px;
        top: 4px;
		width: 45px;
		height: 45px;
	}

    .schedule-table dl dd:nth-of-type(2n) {
        border-radius: 10px;
    }
	
	.schedule-table dl dd.time02::before{
		width: 50px;
		height: 70px;
		top: 40px;
		right: auto;
		left: -50px;
	}
	.schedule-table dl dd.time04::before{
		width: 70px;
		height: 60px;
		top: 0px;
		right: -2px;
	}
	.schedule-table dl dd.time05::before{
		width: 60px;
		height: 70px;
		top: 30px;
		right: auto;
		left: -60px;
	}
	.schedule-table dl dd.time08::before{
		width: 70px;
		height: 90px;
		top: 0px;
		right: 0;
	}

}


/* flow-area------------------------- */

.flow-area{
    margin: 200px auto 0;
	position: relative;
}

.flow-area::before{
background: #ddd;
    width: 90%;
    height: calc(100% + 140px);
    position: absolute;
    content: '';
    z-index: -2;
    border-radius: 60px 0 0 60px;
    top: 50%;
	right: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    background: #f7f7f7;
	background: url("../img/job-construction.png")no-repeat top center / cover,#f6fbff;
}

.flow-area .img-wrap{
    position: absolute;
    z-index: -2;
    margin: 0 auto 0;
	height: 300px;
	width: 800px;
    border-radius:  30px;
	
	left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.flow-area .img-wrap img{
    border-radius:  30px;
	width: 100%;
}

.flow-area .flow-img01{
	top: -100px;
    margin: 0 0 0 360px;
}

.flow-list{
    margin: 80px auto 0;
}

.flow-list li{
    display: flex;
    width: 100%;
    padding: 20px 30px 20px 170px;
    background-color: #15c9c7;
    border-radius: 5px;
    border-bottom: 10px solid #0b9d9b;
    position: relative;
    margin: 0 auto 55px;
}

.flow-list li::after{
    position: absolute;
    content: "";
    display: block;
    height: 35px;
    width: 35px;
    background: #15c9c7;
    border-radius: 5px;
    border-bottom: 10px solid #0b9d9b;
    border-right: 10px solid #0b9d9b;
    transform: rotate(45deg);
    margin: 0 auto;
    left: 0;
    right: 0;
    bottom: -30px;
}

.flow-list .last::after{
    display: none;
}



.step-ttl{
	position: absolute;
	left: 0;
}
.step01 .step-ttl,
.step03 .step-ttl,
.step05 .step-ttl{
	top: -5px;
}


.step-ttl::before{
	content: '';
    transform: rotate(45deg);
    position: absolute;
    background-color: #fff;
    width: 90px;
    height: 90px;
    display: block;

    border-radius: 10px;
    padding: 5px;
    top: -26px;
    left: -20px;
	z-index: 1;
	border: solid 1px #ddd;
}
/*
.step-ttl::after{
    position: absolute;
    content: "";
    display: block;
    width: 90px;
    height: 90px;
    display: block;
    transform: rotate(45deg);
    background-color: #aaa;
    border-radius: 10px;
    top: -10px;
    left: 10px;
}*/

.step-ttl-box{
    text-align: center;
    position: relative;
	z-index: 1;
    left: -10px;
    top: -5px;
}
.step03 .step-ttl-box{
	top: -20px;
}
/*
.step04 .step-ttl-box,.step05 .step-ttl-box{
    left: 22px;
}

.step03 .step-ttl-box{
    left: 22px;
    top: 23px;
}*/

.step-ttl-box p{
    font-size: 2rem;
    font-weight: 700;
    color: #ff9c3a;
    letter-spacing: 1.5px;
    font-family: 'Montserrat', sans-serif;
    
}

.step-ttl-box h5{
    font-weight: 700;
    font-size: 1.8rem;
    margin: -7px auto 0;
    font-family: 'Noto Sans JP', sans-serif;
    
}

.step03 .step-ttl-box h5{
    font-size: 1.5rem;
    line-height: 1.4;
    margin: -3px auto 0;
}

.step-txt{
    font-size: 1.8rem;
    color: #fff;
    line-height: 2;
    font-weight: 500;
    display: flex;
    justify-content: center;
    align-items: center;
}

.flow-area .job-btn{
    width: 450px;
    height: 70px;
    margin: 10px auto 0;
}

.flow-area .job-btn::before{
    width: 450px;
    height: 70px;
    background: linear-gradient(270deg, rgb(116, 244, 243) 0%, rgb(173, 232, 140) 100%);
    transition: .3s ease-in-out;
}

.flow-area .job-btn:hover::before{
    /*margin: -10px auto auto -10px;*/
    transition: .3s ease-in-out;
}

.flow-area .job-btn a{
    padding: 19px 0 0;
    text-align: center; 
	    transition: .3s ease-in-out;
}

.flow-area .job-btn a::after{
    display: none;
}
.job-btn a:hover{
    top: 10px;
	left: 10px;
	margin: 0;
}
.flow-area .job-btn .fa{
    margin-right: 10px;
}

/*.flow-area .job-btn a:hover{
    margin: 20px 20px 0 0px;
}*/

.step-after .title{
 	font-size: 2.6rem;
	padding: 0 0 20px;
}

.after-txt{
	   width: 100%;
    padding: 30px;
    background: linear-gradient(to right, #FFE5A6, #FFD8C1);
    border-radius: 15px;
    border-bottom: 10px solid #f3c598;
    position: relative;
    margin: 0 auto 65px;

}

@media screen and (max-width: 1300px) {



}

@media screen and (max-width: 768px) {
    .flow-area {
        margin: 50px auto 0;
    }
	.flow-area::before{
		width: 100%;
		border-radius: 0;
		    height: calc(100% + 70px);
	}
	
	.flow-area .flow-img01{
		margin: 0;
		width: 100%;
		height: auto;
	right: 0;
    transform: none;
    left: auto;
    text-align: right;
	}
	
	.flow-area .txt-area{
		padding: 100px 20px 0;
	}
    
    .flow-list {
        margin: 40px auto 0;
    }

    .flow-list li{
        width: 90%;
        margin: 0 auto 47px;
        padding: 42px 20px 20px;
        border-bottom: 6px solid #0b9d9b;
    }
	.flow-list li:last-of-type{
		margin: 0 auto 20px;
	}
    .step-ttl{
        width: 70px;
        height: 70px;
        left: 0;
        top: -37px;
        right: 0;
        margin: 0 auto;
    }
	.step01 .step-ttl,
	.step03 .step-ttl,
	.step05 .step-ttl{
		top: -37px;
	}

    
    .flow-list li::before{
        display: none;
    }
    
    .step-ttl-box,.step03 .step-ttl-box,.step04 .step-ttl-box, .step05 .step-ttl-box{
        left: -2px;
        top: 15px;
		line-height: 1.3;
    }
    
    .step-ttl-box p{
        font-size: 2rem;
        line-height: 0;
    }

    .step-ttl-box p span{
        font-size: 1.5rem;
    }
    
    .step-ttl-box h5 {
        font-size: 2rem;
        position: absolute;
    }
    
    .step-txt{
        font-size: 1.7rem;
        line-height: 1.5;
        display: block;
    }
    
    .step-txt .sp-display{
        color: #ff9c3a;
        font-weight: 500;
        font-size: 1.9rem;
        line-height: 2;
        text-align: center;
        display: block;
		background: #fff;
    }
    
    .flow-area .job-btn,.flow-area .job-btn::before{
        width: 100%;
    }
    
    .flow-area .job-btn{
        z-index: 2;
    }
    
    .flow-list li::after{
        display: none;
    }
	
	.step-after .title{
		font-size: 2rem;
		padding: 0 0 20px;
	}
	
	.step-ttl::before{
		width: 50px;
		height: 50px;
		border-radius: 5px;
		top: 4px;
		left: 0;
	}
	
	.after-txt{
		padding: 20px;
		margin: 0;
	}


}


/* faq-area------------------------- */

.faq-area{
    padding: 0 0 0;
}

.dot-bg{
    background: url("../img/dot-lightblue.jpg") top right repeat;
    padding: 60px 0 100px;
}

.faq-area .txt-area{
	position: relative;
}

.faq-box{
    /*margin-bottom: 80px;
    border-radius: 40px; */
    position: relative;
}
.faq-box::before{
    display: block;
    content: "";
    position: absolute;
    right: 30px;
    top: -40px;
    z-index: 1;
    width: 140px;
    height: 140px;
}

.faq-box .ttl .en {
	color: #71AFD1;
}

.faq-box .faq-list {
	margin: 30px 0 0;
}
.faq-box .faq-list .list {
	line-height: 1.7;
	border: #333 solid 1px;
	background: #fff;
	border-radius: 10px;
	margin: 0 0 20px;	
}

.faq-box .faq-list .list:last-child {
	margin: 0;	
}

.faq-box .faq-list .list p {
    font-size: 1.8rem;
	line-height: 1.7;
}

.faq-box .quest {
	padding: 20px 20px 20px 60px;
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	transition: 0.5s;
	font-family: "Noto Sans JP";
    font-weight: 500;
}

.faq-box .quest::before {
	content: "Q";
	color: #15c9c7;
	font-family: 'Jost', sans-serif;
	font-size: 2.8rem;
	font-weight: 500;
	position: absolute;
	top: 15px;
	margin: auto;
	left: 20px;
}


.faq-box .quest:hover {
	cursor: pointer;
	color: #15c9c7;
}

.faq-box .faq-accordion-icon {
	position: relative;
	height: 20px;
	width: 20px;
}

.faq-accordion-icon::before,
.faq-accordion-icon::after {
	background-color: #15c9c7;
    background: url("../img/faq-acc.png") no-repeat center center / auto;
	content: "";
	height: 2px;
	position: absolute;
	width: 100%;
	transition: all .3s;
	top: 0;
	bottom: 0;
	margin: auto;
}

.faq-accordion-icon::before {
	transform: rotate(0deg);
}

.faq-accordion-icon::after {
	transform: rotate(90deg);
}

.faq-box .quest.active .faq-accordion-icon::after {
	transform: rotate(180deg);
}

.faq-box .answer {
	padding: 0 20px 20px 60px;
	font-weight: 500;
	display: none;
	position: relative;
	font-family: "Noto Sans JP";
}

.faq-box .answer::before {
	content: "A";
	color: #ff3218;
	font-family: 'Jost', sans-serif;
	font-size: 2.8rem;
	font-weight: 500;
	position: absolute;
	top: -2px;
	margin: auto;
	left: 22px;
}

.faq-box .faq-list .list .answer p {
	line-height: 1.8;
}


@media screen and (max-width: 1300px) {



}

@media screen and (max-width: 768px) {
    
    .faq-area {
        padding: 0 0 0;
    }

    .faq-box::before{
        right: 20px;
        top: -40px;
        width: 100px;
        height: 100px;
    }
	.faq-area .txt-area{
		padding: 0 20px;
	}

    .faq-box .faq-box-dashedline .title-box .faq-title-en {
        font-size: 4.2rem;
        letter-spacing: 1px;
        white-space: nowrap;
    }
    
    .faq-box .faq-box-dashedline .title-box .faq-box-title {
        font-size: 2.5rem;
        /*margin: -23px 0 0 0;*/
    }
    
    .faq-box.cconeplus .faq-box-dashedline .title-box .faq-box-title {
        font-size: 2.3rem;
        margin: 0;
        padding: 0;
    }
    
    .faq-box .faq-box-dashedline {
        padding: 25px 15px 35px;
        border-radius: 22px;
    }
    
    .faq-box {
        margin-bottom: 30px;
        border-radius: 20px;
    }
    
    .faq-list .accordionlist .a {
        line-height: 1.7;
        padding: 0 20px 0 34px;
    }
    
    .faq-list .accordionlist .a::before {
        left: -7px;
        width: 35px;
        height: 35px;
        line-height: 35px;
    }
    
    .faq-list .accordionlist dt h3 {
        padding-left: 42px;
    }
    
    .faq-box-area {
		padding: 50px 5px 0;
        margin-top: -50px;
	}
	
    .faq-box-area.inner {
		width: 100%;
	}

    .faq-box-area.inner > .ttl {
		text-align: center;
    }   
    
    .faq-box .faq-list {
		margin: 20px;
	}

    .faq-box .faq-list .list {
		margin: 0 0 10px;	
	}

	.faq-box .faq-list .list p {
		font-size: 1.6rem;
	}

	.faq-box .quest {
		padding: 10px 20px 10px 40px;
	}

	.faq-box .quest::before {
		font-size: 2.2rem;
		top: 7px;
        left: 12px;
	}

	.faq-box .quest:hover {
		color: #15c9c7;
	}

	.faq-box .faq-accordion-icon {
		height: 20px;
		width: 20px;
	}

	.faq-accordion-icon::before,
	.faq-accordion-icon::after {
		width: 20px;
	}

	.faq-box .answer {
		padding: 0 20px 10px 40px;
	}

	.faq-box .answer::before {
		font-size: 2.2rem;
		top: -2px;
        left: 14px;
	}

	.faq-box .faq-list .list .answer p {
		line-height: 1.8;
	}

    .dot-bg{
        padding: 40px 0 10px;
    }
    
}

/* -----------------------------
	job　nursing
-------------------------------- */


/*  awa-wrap---------------------------- */

.awa-wrap{
    position: relative;
}

.awa{
    position: absolute;
}

.awa.l01{
    width: 145px;
    height: 145px;
    left: 76px;
    top: 19px;
    z-index: 1;
}

.awa.l02{
    width: 215px;
    height: 215px;
    left: -45px;
    top: 86px;
    z-index: 2;
}

.awa.c01{
    width: 212px;
    height: 212px;
    left: 51%;
    top: 434px;
    z-index: 2;
}

.awa.c02{
    width: 255px;
    height: 255px;
    left: 45%;
    top: 450px;
    z-index: 1;
}

.awa.r01{
    width: 212px;
    height: 212px;
    right: -75px;
    top: 80px;
    z-index: 2;
}

@media screen and (max-width: 1300px){

}

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

    .nurs-area {
        padding: 50px 0 0;
    }
    
    .nurs-area::before{
        height: 445px;
        width: 100%;
        top: 35px;
        border-radius: 0;
        z-index: -1;
    }
    
    .nurs-mv{
        height: 160px;
        width: 90%;
        top: 65px;
        right: 0;
        left: 0;
        margin: 0 auto;
    }
    
    .nurs-mv img {
        border-radius: 15px 15px 0 0;
    }
    
    .nurs-area .txt-area .section-title .ja{
        font-size: 2.5rem;
        padding: 120px 0 0;
    }
    
    .nurs-area::after{
        width: 90%;
        min-width: 90%;
        height: 270px;
        right: 0;
        margin: 0 auto;
        border-radius: 0 0 15px 15px;
    }
    
    .nurs-area .txt-area{
        width: 80%;
    }
    
    .nurs-area .txt-area .section-catch {
        font-size: 2rem;
        padding: 10px 0 0;
        width: 100%;
    }
    
    .nurs-area .btn-more a{
        margin: 15px auto 0;
    }
    
    .nurs-area .btn-more{
        width: 100%;
        
    }
    
    .awa.c01,.awa.r01{
        width: 118px;
        height: 118px;
    }
    
    .awa.c01{
        left: 0%;
        top: 327px;
        z-index: 0;
    }

    .awa.c02{
        width: 127px;
        height: 127px;
        left: -11%;
        top: 345px;
        z-index: -1;
    }

    .awa.r01{
        right: -59px;
        top: -20px;
        z-index: 2;
    }

}

/* environment-area------------------------- */
.environment-area{
	margin: 100px auto 0;
}

.environment-box{
	background: #fff;
	width: 600px;
	padding: 50px;
	border-radius: 50px;
	margin: 130px auto 0 0;
}

.environment-img{
    position: absolute;
    padding: 50px 0 0 50px;
    border-radius: 60px 0 0 60px;
    right: 0;
    z-index: -1;
    margin: -20px auto 0;
}
.environment-img img{
	border-radius: 50px 0 0 50px;
}

.environment-area ul{
	margin: 10px 0 20px;
}
.environment-area ul li{
	margin: 10px 0 0;
	
}
.environment-area ul li span{
	color: #f1887b;
}

@media screen and (max-width: 768px){
	.environment-area{
		margin: 50px 0 0;
	}
	.environment-box{
		background: none;
		width: 100%;
		padding: 0 20px;
		margin: 20px auto 0 0;
	}
		
	.environment-img{
		position: relative;
		border-radius: 0;
		padding: 10px 20px 0;
		margin: 0;
	}
	.environment-img img{
		border-radius: 20px;
		height: 200px;
		object-fit: cover;
	}
	
}

/* message-area------------------------- */

.message-area{
    margin: 50px auto 0;
}

.message-list{
    margin: 50px auto 0;
}

.message-list li{
    background-color: #FFF3F3;
    font: 500 1.9rem / 1.7 'Noto Sans JP', sans-serif;
    position: relative;
    border-right: 10px solid #f1887b;
    border-bottom: 10px solid #f1887b;
    border-radius: 25px;
    margin: 0px 70px 40px 0;
    padding: 25px 42px;
}

.message-list li::after{
    position: absolute;
    content: "";
    display: block;
    background: url("../img/job-nur-m-icon.png")no-repeat top center /contain;
    width: 71px;
    height: 82px;
    right: -100px;
    bottom: -20px;
}

@media screen and (max-width: 1300px){

}

@media screen and (max-width: 768px){
    .message-area {
        margin: 50px auto 0;
    }
    
    .message-list {
        margin: 32px auto 0;
    }
    
    .message-list li{
        font-size: 1.6rem;
        font-weight: 500;
        border-width: 5px;
        padding: 10px 20px;
        margin: 0px 60px 20px 0;
    }
    
    .message-list li::after{
        width: 60px;
        right: -76px;
    }
    
}


/* -----------------------------
	job　condition
-------------------------------- */

.condition .contents{
    padding: 70px 0 0;
}

.condition .intro-ttl{
    color: #fff;
	padding: 0;
}

.condition .intro-ttl .section-catch {
    margin: 0 auto 30px;
    font-size: 4.5rem;
    letter-spacing: 2px;
}

.condition .intro-img{
    border: none;
    padding: 0;
    border-radius: 0;
    right: auto;
    left: 0;
	top: 150px;
}

.condition .intro-img img{
    border-radius: 0 30px 30px 0;
}

.condition .intro-bg{
    background: none;
    padding: 65px 0 60px 0;
}

.condition .intro-txt{
background: #fff;
    line-height: 2.5;
    font-size: 1.8rem;
    padding: 20px 10vw 30px 50px;
    border-radius: 50px 0 0 50px;
    margin: -255px 0 0 auto;
    width: 800px;
    font-weight: 600;
    right: 0;
    position: absolute;
}

.condition .intro-content{
    border: none;
    margin: 470px 0 0 0;
	background: #f8f8f8;
	border-radius: 0;
	padding: 0;
}

.condition .txt{
    padding: 15px 0 0;
}


.condition .opp-cell{
    width: 100%;
    display: flex;
    text-align: left;
}

.condition .opp-cell img {
    margin: 15px 35px 15px 5px;
}

.condition .recruit-area {
    margin: 135px auto 0;
	padding: 30px 0;
}
.condition .recruit-area.recruit02{
	background: #f8f8f8;
	z-index: 0;
    margin: 100px 0 0;
    padding: 80px 0;
}

.condition .recruit-img{
    border: none;
    border-radius: 0;
    left: auto;
    right: 0;
	top: 0;
    padding: 0;
    margin: 0 0 0 auto;
    width: 800px;
    position: absolute;
    z-index: -2;
}

.condition .recruit-img img {
    border-radius: 30px 0 0 30px;
	width: 800px;
}

.common-ttl{
    color: #15c9c7;
    font-size: 2.5rem;
    font-weight: 700;
    padding: 15px 0 5px;
}

.common-ttl.welfare{
    padding-top: 30px;
}

.career-list{
    margin: 15px 0 0;
}

.career-list li{
    padding: 0 0 0 30px;
    position: relative;
    margin: 0 0 10px;
    font-weight: 600;
    font-size: 1.8rem;
}

.career-list li:last-child{
    margin-bottom: 0;
}

.career-list li::before{
    position: absolute;
    content: "";
    display: block;
    background: url("../img/job-condi-icon03.png")no-repeat top center / contain;
    width: 24px;
    height: 28px;
    left: 0px;
}

.condition .recruit-area .txt{
    text-shadow: 
            1px 1px 1px #fff,
            -1px 1px 1px #fff, 
            1px -1px 1px #fff, 
            -1px -1px 1px #fff, 
            1px 0px 1px #fff, 
            0px 1px 1px #fff, 
            -1px 0px 1px #fff, 
            0px -1px 1px #fff;
}

.welfare-list{
    margin: 15px 0;
	background: #fff;
	padding: 50px;
	border-radius: 50px;
}

.welfare-list li{
    position: relative;
    padding: 0 0 0 15px;
    margin: 0 0 5px;
}

.welfare-list li::before{
    content: "・";
    position: absolute;
    color: #15c9c7;
    left: -3px;
}

.img-loop{
	margin: 40px 0 0;
}
.office-img{
    padding: 152px 0 150px 0;
    margin: 10px 0 10px 0;
    display: block;
    background: url("../img/job-condi-img02.png") repeat-x top left;
    -webkit-animation: bgscroll 100s linear infinite, fadein 5s linear 0s 1;
    animation: bgscroll 100s linear infinite, fadein 5s linear 0s 1;
}

@media screen and (max-width: 768px){
    .condition .contents {
        padding: 40px 0 0;
    }
    .condition .intro-ttl .section-catch {
        margin: 0 auto 15px;
        font-size: 2.6rem;
    }
	.condition .intro-area .intro-txt{
		background: none;
		font-size: 1.6rem;
		padding: 0 0 20px;
	}
    
    .condition .intro-content{
        margin: 220px 0 0 0;
    }
    
    .condition .intro-bg{
        padding: 0 0 0 0;
    }
    
    .condition .intro-img{
        margin: -25px auto 0 0;
    }
    
    .condition .intro-img img{
        width: 95%;
    }
    
    .condition .intro-txt{
        line-height: 1.9;
        font-size: 1.7rem;
        padding: 0px 0;
        margin: 0 0 0 0;
        width: 100%;
        position: initial;
    }
    
    .condition .txt{
        padding: 15px 20px 0;
    }
    
    .condition .opp-cell {
        width: 90%;
    }
    
    .condition .opp-cell img{
        margin: 0 auto;
    }
    
    .condition .opp-cell p img{
        top: -10px;
    }
    
    .condition .recruit-area {
        margin: 0 auto 0;
		padding: 50px 0 30px;
    }
	.condition .recruit-area.recruit02{
		margin: 0 0 0;
		padding: 30px 0 ;
	}
    
    .condition .recruit-img{
        position: inherit;
        width: 100%;
    }
	.condition .recruit-img img{
		border-radius: 0;
	}

    .common-ttl {
        font-size: 2.2rem;
        padding: 20px 20px 0;

    }
    
    .career-list li {
        padding: 0 20px 0 45px;
        margin: 0 0 5px;
        font-size: 1.7rem;
    }
    
    .career-list li::before{
        left: 17px;
    }
    
    .common-ttl.welfare {
        padding-top: 0;
    }
    
    .welfare-list {
        margin: 10px 20px 15px;
		padding: 20px;
		border-radius: 15px;
    }
	.img-loop{
		margin: 20px 0 0;
	}
    
    .office-img{
        padding: 51px 0 100px;
        background-size: 300%;
        margin: 0;
    }
}


/*  flow  */
.flow{
	padding: 100px 0 ;
	background: #f9f9f9;
}
.flow .container {
  position: relative;
	margin: 30px 0 0;
}
.flow .container.second{
	
}


.flow .container .head_area {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 116px;
  background: linear-gradient(90deg, rgba(255, 65, 71, .6) 0%, rgba(255, 195, 0, .6) 100%);
  z-index: 1
}
.flow .container.second .head_area{
  background: linear-gradient(90deg, rgba(226, 207, 0, .6) 0%, rgba(0, 216, 255, .6) 100%);
}

.flow .container .head_area:before {
  position: absolute;
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 58px 58px 0;
  border-color: transparent #f9f9f9 transparent transparent;
  top: 0;
  right: 0
}

.flow .container .head_area:after {
  position: absolute;
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0 58px 58px;
  border-color: transparent transparent #f9f9f9;
  bottom: 0;
  right: 0
}

.flow .container .body_area {
  position: relative;
  padding: 72px 32px 0;
  display: flex;
  justify-content: space-between
}

.flow .container .body_area .item {
  width: 24.69%;
  position: relative;
  background: #fff;
  box-shadow: 0px 12px 12px 0px rgba(40, 47, 60, .03);
  border-radius: 15px;

	border: solid 1px #f4f4f4;

}

.flow .container .body_area .item .num {
  position: absolute;
  top: -50px;
  left: 24px;
  font-size: 20px;
  font-weight: 600;
  color: #fff;
  z-index: 2;
  display: flex;
  align-items: center;
	font-family: 'Montserrat', sans-serif;
}
.flow .container .body_area .item .num span{
	font-size: 3rem;
	padding: 0 0 0 5px;
}

.flow .container .body_area .item .txt {
  position: relative;
  background: #fff;
  border-radius: 8px;
  padding: 15px 20px;
  z-index: 3
}

.flow .container .body_area .item .txt .h {
  font-weight: 600;
  font-size: 22px;
  margin-bottom: 5px;
}

.flow .container .body_area .item .txt .strong {
  font-weight: 600;
  color: #ff4147
}

.flow .container .body_area .item.arrow:before {
  position: absolute;
  content: "";
  width: 72px;
  height: 134px;
  background: url("../img/flow-arrow-f9.png");
  background-repeat: no-repeat;
  top: -80px;
  right: -120px;
  z-index: 2;
  background-size: cover;
  background-position: center;
}

@media screen and (max-width:768px) {
	.flow{
		padding: 40px 0;
	}
  .flow .container {
    display: flex;
	      margin: 10px 0 0;
  }
  .flow .container .head_area {
    width: 60px;
    height: 100%;
    background: linear-gradient(180deg, rgba(255, 65, 71, .6) 0%, rgba(255, 130, 0, .6) 35%, rgba(226, 207, 0, .6) 60%, rgba(0, 216, 255, .6) 100%)
  }
	.flow .container.second .head_area{
		background: linear-gradient(180deg, rgba(226, 207, 0, .6) 0%, rgba(0, 216, 255, .6) 100%);
	}
  .flow .container .body_area {
    display: block;
    padding: 20px 0 5px 20px;
  }
  .flow .container .body_area .item {
    width: 100%;
    margin-bottom: 36px
  }
  .flow .container .body_area .item .txt {
    padding: 20px
  }
  .flow .container .body_area .item .txt .h {
    font-size: 16px;
    margin-bottom: 14px
  }
  .flow .container .head_area:before {
    top: auto;
    bottom: 0;
    left: 0;
    right: auto;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 30px 0 0 30px;
    border-color: transparent transparent transparent #f9fafc
  }
	.flow .container.first .head_area:before {
	  display: none;
	}
  .flow .container .head_area:after {
    bottom: 0;
    right: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 0 30px 30px;
    border-color: transparent transparent #f9fafc
  }
	.flow .container.first .head_area:after {
	  display: none;
	}
  .flow .container .body_area .item .num {
	color: #333;
	right: 0;
	left: auto;
	z-index: 4;
	  font-size: 1.6rem;
	  top: -20px;
  }
	.flow .container .body_area .item .num span{
		font-size: 2.5rem;
	}
	  .flow .container .body_area .item .num.num01 {
		color:  #fd8d8d;
	}
	  .flow .container .body_area .item .num.num02 {
		color:  #fdb379;
	}
	  .flow .container .body_area .item .num.num03 {
		color:  #fdcb6c;
	}
	  .flow .container .body_area .item .num.num04 {
		color:  #e9e168;
	}
	  .flow .container .body_area .item .num.num05 {
		color:  #91e4cb;
	}
  .flow .container .body_area .item .num.num06 {
		color:  #6de5f2;
	}
  .flow .container .body_area .item .num .large {
    font-size: 33px;
    margin-left: 0;
    padding-top: 8px
  }
  .flow .container .body_area .item.arrow:before {
    width: 36px;
    height: 67px;
    top: auto;
    right: auto;
    bottom: -42px;
    left: -8px;
    transform: rotate(90deg)
  }
}
