@charset "utf-8";

/* -----------------------------
	job 共通
-------------------------------- */



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

}

@media screen and (max-width: 768px) {
	.construction-job .page-title-area .page-title-en{
		font-size: 3rem;
	}
}

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




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



}

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



}

/* -----------------------------
	job　construction　nursing　共通
-------------------------------- */

/* intro-area------------------------- */
.intro-area{
    position: relative;
	/*margin: 60px 0 0;*/
}

.intro-img{
    position: absolute;
    border-left: 10px solid #FFF830;
    border-top: 10px solid #FFF830;
    padding: 50px 0 0 50px;
    border-radius: 60px 0 0 60px;
    right: 0;
    z-index: -1;
    margin: 25px auto 0;
}

#home-nursing-job .intro-img{
    border-left: 10px solid #FFF3F3;
    border-top: 10px solid #FFF3F3;
}

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

.intro-content{
    position: relative;
    /*border-right: 10px solid #00D6DE;
    border-bottom: 10px solid #00D6DE;*/
    padding: 0 50px 50px 0;
    border-radius: 0 60px 60px 0;
    left: 0;
    margin: 200px auto 0 ;
    /*min-width: 1300px;
    max-width: 1500px;*/
}
/*
#home-nursing-job .intro-content{
    border-right: 10px solid #FAFFE6;
    border-bottom: 10px solid #FAFFE6;
}*/

#home-nursing-job .intro-content{
	margin: 200px auto 0;	
}

.intro-bg{
	background: linear-gradient(90deg, rgba(21,201,199,0.08) 0%, rgba(80,232,231,0.04) 100%);
	padding: 30px 50px 50px 40px;
	background: #fff;
	border-radius: 50px;
	width: 600px;
}

#home-nursing-job .intro-bg{
    background:linear-gradient(190deg, rgba(255,243,243,0.12) 0%, rgba(250,255,230,0.6) 100%);
    z-index: 2;
    position: inherit;
	background: #fff;
}

.intro-ttl{
    margin: 0 auto 0;
	position: relative;
	z-index: 5;
}

.intro-ttl .en{
    color: #15c9c7;
    mix-blend-mode: multiply;
    font: 700 3rem / 1.2 'Montserrat', sans-serif;
    margin: 0 0 15px;
}

#home-nursing-job .intro-ttl .en{
    color: #f1887b;
}

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

.word-mt{
    /*mix-blend-mode: hard-light;*/
    color: #075958;
	color: #333;
}

#home-nursing-job .word-mt{
    color: #864c45;
	color: #333;
}

.intro-ttl .white-shadow{
    position: absolute;
    /*color: #fff;*/
    text-shadow: 
       3px  3px 1px #ffffff,
      -3px  3px 1px #ffffff,
       3px -3px 1px #ffffff,
      -3px -4px 1px #ffffff,
       3px  0px 1px #ffffff,
       0px  3px 1px #ffffff,
      -3px  0px 1px #ffffff,
       0px -3px 1px #ffffff;
    z-index: -1;
    top: 0;
    opacity: .7;
}

.intro-txt .txt{
    margin: 0 0 30px;  
}

.intro-txt .txt:last-child{
    margin: 0 0 0;  
}

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



}

@media screen and (max-width: 768px) {
    .intro-area{
        padding: 50px 0 0;
		margin: 0;
    }
	#home-nursing-job .intro-area{
        padding: 0 0 0;
		margin: 0;
    }
	#home-nursing-job .intro-content{
		margin: 120px auto 0;	
	}

	#home-nursing-job .intro-bg{
		background: none;
	}
    
    .intro-area .inner{
        padding: 0 20px 0;  
    }
	#home-nursing-job .intro-area .inner{
        padding: 50px 20px 0;  
	}	
	.condition .intro-area .inner{
		padding: 0 20px;
	}
	.condition .intro-area .intro-txt{
		padding: 0 20px;
	}
    
    .intro-ttl .en{
        font-size: 2rem;
        margin: 0 0 5px;
    }
    
    .intro-ttl h3{
        font-size: 3rem;
        line-height: 1.4;
    }
    
    .intro-img {
        border-left: 5px solid #FFF830;
        border-top: 5px solid #FFF830;
        padding: 13px 0 0 13px;
        border-radius: 40px 0 0 40px;
        margin: -38px auto 0 38px;
    }
	.intro-img img {
		height: 200px;
		object-fit: cover;
    }

    .intro-content{
        /*border-right: 5px solid #00D6DE;
        border-bottom: 5px solid #00D6DE;*/
        padding: 0 15px 20px 0;
        border-radius: 0 40px 40px 0;
        margin: 100px auto 0 0;
        min-width: 100%;
        max-width: 100%;
    }
    
    .intro-bg{
        padding: 30px 0;
		width: 100%;
    }
    
    .word-mt{
        /*color: #15c9c7;*/
        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;
    }
    
    #home-nursing-job .word-mt{
       /* color: #f1887b;*/
    }
}

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

.type-area{
    margin: 20px auto 0;
}
.condition .type-area{
    margin: 270px auto 0;
}
#home-nursing-job .type-area{
    margin: 210px auto 0;
}

.opp-cell{
    background: linear-gradient(36deg, rgba(95,168,227,1) 0%, rgba(0,214,222,1) 100%);
    border-radius: 40px;
    padding: 30px 50px 25px;
    color: #fff;
    font-weight: bold;
    width: calc( ( 100% - 80px ) / 3);
    text-align: center;
    margin: 30px auto 0 0;
}

#home-nursing-job .opp-cell{
    width: calc( ( 100% - 80px ) / 4);
	/*
    background: linear-gradient(190deg, rgba(255,134,119,1) 0%, rgba(252,192,170,1) 61%, rgba(249,255,226,1) 100%);
	*/
	background: #FDA693;
}

.opp-cell:nth-child(3n){
    margin-right: 0;
}

#home-nursing-job .opp-cell:nth-child(3n){
    margin-right: auto;
}

#home-nursing-job .opp-cell:nth-child(4n){
    margin-right: 0;
}

.opp-cell h4{
    font-size: 3rem;
    font-weight: 700;
}

#home-nursing-job .opp-cell h4{
    font-size: 2.5rem;
}

.opp-cell img{
    margin: 15px auto;
}

.opp-txt{
    font-size: 1.8rem;
    line-height: 1.7;
    text-align: left;
}

#home-nursing-job .txt{
    margin: 25px auto 0;
}

#home-nursing-job .job-list{
    border: 6px solid #F1887B45;
    border-radius: 60px;
    position: relative;
    margin: 50px auto 0;
    max-width: 1400px;
    min-width: 1200px;
    padding: 60px 50px;
}

#home-nursing-job .job-list h3{
    position: absolute;
    background-color: #fff;
    padding: 5px 30px;
    width: fit-content;
    top: -33px;
    font-size: 3.2rem;
    font-weight: 700;
    margin: 0 auto;
    right: 0;
    left: 0;
}

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



}

@media screen and (max-width: 768px) {
	.condition .type-area{
		margin: 50px 0 0;
	}
    .opp-cell{
        width: 90%;
        text-align: left;
        margin: 20px auto 0;
        border-radius: 20px;
        padding: 25px 25px 25px;
    }

    .opp-cell h4{
        font-size: 2.2rem;
        margin: 0 0 10px 60px;
    }
    
    .opp-cell p{
        position: relative;
        font-size: 1.6rem;
        line-height: 1.6;
    }
    
    .opp-cell p img{
        margin: 0;
        position: absolute;
        width: 47px;
        height: 47px;
        top: -52px;
    }

    
    .opp-cell:nth-child(3n) {
        margin-right: auto;
    }
    
    #home-nursing-job .type-area{
        padding: 0 8px;
		margin: 30px 0 0;
    }
    
    #home-nursing-job .type-area .ttl-bubble-box{
        margin:0 10px;
    }

    #home-nursing-job .type-area .section-title{
        font-size: 3rem;
        letter-spacing: 1px;
    }
    
    #home-nursing-job .job-list {
        border-radius: 25px;
        margin: 25px auto 0;
        max-width: 100%;
        min-width: 100%;
        padding: 10px 10px;
        border: 3px solid #F1887B45;
    }
    
    #home-nursing-job .opp-cell{
        width: 100%;
    }
    
    #home-nursing-job .job-list h3{
        top: -26px;
        font-size: 2.2rem;
    }
    
    #home-nursing-job .opp-cell h4 {
        font-size: 2rem;
    }

}


/* recruit-area------------------------- */

.recruit-area{
    margin: 120px auto 0;
    position: relative;
}

.recruit-img{
    /*border-right: 10px solid #FFF830;
    border-top: 10px solid #FFF830;*/
    padding: 50px 0 0 0;
    left: 0;
    margin: 15px auto 0;
    width: 1200px;
}

#home-nursing-job .recruit-img{
    border: none;
    /*background: linear-gradient(90deg, rgba(255,243,243,1) 0%, rgba(255,243,243,1) 57%, rgba(250,255,230,1) 100%);*/
	padding: 30px 0 0;
}

.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;
}
#home-nursing-job .recruit-box{
    margin: 120px auto 0;
}
#home-nursing-job .recruit-ttl{
    color: #f1887b;
    font-size: 3rem;
    font-weight: 700;
    text-shadow: 
       2px  2px 1px #ffffff,
      -2px  2px 1px #ffffff,
       2px -2px 1px #ffffff,
      -2px -2px 1px #ffffff,
       2px  0px 1px #ffffff,
       0px  2px 1px #ffffff,
      -2px  0px 1px #ffffff,
       0px -2px 1px #ffffff;
    margin-top: -100px;
}

.recruit-box p{
    
}

.recruit-list{
    background-color: #FFFFC259;
    border-radius: 25px;
    padding: 30px 50px;
    margin: 15px auto;
    position: relative;
}

.recruit-list li{
    position: relative;
    margin: 0 0 0 45px;
    font-weight: bold;
    line-height: 2.3;
    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;
}

#home-nursing-job .recruit-list li::before{
    background: url("../img/check-icon02.png")no-repeat top center / 100%;
}

.recruit-list::after{
    content: "";
    position: absolute;
    display: block;
}

.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{
        margin: 60px auto 0;
    }
    
    .recruit-img {
        /*border-right: 5px solid #FFF830;
        border-top: 5px solid #FFF830;*/
        padding: 13px 13px 0 0;

        margin: 0 auto 0 0;
        width: 100%;
    }
	#home-nursing-job .recruit-img{
		padding: 10px 20px 0;
	}
    
	.recruit-img img{
		width: 100%;
		height: 200px;
		object-fit: cover;
		border-radius: 20px;
	}
    .recruit-box {
        margin: 15px 20px 0;
        line-height: 1.7;
        font-size: 1.6rem;
    }
    
    .recruit-list{
        border-radius: 15px;
        padding: 12px 20px 10px;
    }
    
    .recruit-list::after{
        background-size: 60%!important;
        right: 0!important;
        top: auto!important;
        bottom: -53px;
        z-index: -1;
    }
    
    .recruit-list.rl02::after{
        right: -20px!important;
    }
    
    .recruit-list li::before{
        top: 8px;
        left: -35px;
    }
    
    .recruit-list li {
        margin: 0 0 5px 35px;
        line-height: 1.8;
        font-size: 1.6rem;
    }
    
    #home-nursing-job .recruit-ttl{
        font-size: 2.2rem;
        line-height: 1.6;
        margin-top: -50px;
    }
	
	#home-nursing-job .recruit-box{
		margin: 70px 0 0;
	}
	#home-nursing-job .recruit-box .txt{
		margin: 15px 0 0;
	}

}

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

.schedule-area{
    padding: 50px 0 0;
    position: relative;
}
#home-nursing-job .schedule-area{
	padding: 0;	
}

.schedule-img{
    position: absolute;
    right: 0;
    z-index: -2;
    margin: -175px auto 0;
}

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

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

.schedule::before{
	background: #f8f8f8;
	width: 90%;
	height: calc(100% + 100px);
	position: absolute;
	content: '';
	z-index: -3;
	border-radius: 0 60px 60px 0;
	top: 50%;
    left: 0%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

.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;
}


.schedule-table {
	padding: 0 0;
	position: relative;
}

.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;
}
#home-nursing-job .schedule-table dl {
	padding: 50px 0 0;
}

.schedule-table dl dt {
	width: 90px;
	padding: 16px 10px 16px 0;
	position: relative;
    color: #4ABFBE;
    text-align: center;
    font-weight: bold;
    font-size: 1.8rem;
    letter-spacing: 1.5px;
    font-family: 'Montserrat', sans-serif;
}

#home-nursing-job .schedule-table dl dt{
    color: #ff9d91;
}

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

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

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

#home-nursing-job .schedule-table dl dt.sch-icon::after{
    border-color: #f1887b;
}

.schedule-table dl dd {
	width: calc(100% - 110px);
    padding: 13px 0 13px 25px;
    margin: 6px auto 6px 20px;
}

#home-nursing-job .schedule-table dl dd:nth-of-type(2n){
    background-color: #fff;
    border-radius: 20px;
}

.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;
    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;
}

.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;
}


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



}

@media screen and (max-width: 768px){
    
    .schedule-area {
        padding: 0 0 0;
    }
    
    .schedule {
        margin: 50px auto 0;
		padding: 0 0 30px;
    }
	#home-nursing-job .schedule {
		margin: 50px 0 40px;
	}
	.schedule::before{
		border-radius: 0 15px 15px 0;
		width: 95%;
	}
	#home-nursing-job .schedule::before{
		height: calc(100% + -15px);
		margin: 15px 0 0;
	}
    
    .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;
    }
    
    
    .schedule .section-title {
        font-size: 2.8rem;
        letter-spacing: 0px;
    }
    
    #home-nursing-job .schedule .section-title{
        padding: 0 0 0 0px;
    }
    
    
    
	/* --------------history-box-------------- */
	
	.schedule-table {
		padding: 90px 0 0;
		margin: 0 0 0;
	}
    
    #home-nursing-job .schedule-table {
        padding: 0 0 0;
    }

	.schedule-table .inner {
		padding: 50px 20px;
		border-radius: 0 30px 0 0;
	}

	.schedule-table dl {
		display: inline-flex;
		width: 100%;
		margin: 30px 0 0;
		padding: 20px 0;
	}
    
    #home-nursing-job .schedule-table dl{
        margin: 0 0 0px;
        padding: 10px 0 0;
    }

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

	.schedule-table dl dd {
		width: calc(100% - 100px);
        padding: 5px 10px;
        margin: 8px auto 0px 15px;
	}
    
    #home-nursing-job .schedule-table dl dd {
        margin: 15px auto 0px 15px;
    }
    
    #home-nursing-job .schedule-table dl dt{
        padding: 22px 0 0 20px;
    }

	.schedule-table dl dd h2 {
		font-size: 22px;
		font-weight: bold;
		margin: 0 0 5px;  
	}
    
    #home-nursing-job .schedule-table dl dt.sch-icon::after{
        top: 6px;
    }

	.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: 22px;
        top: 4px;
	}
    
    #home-nursing-job .schedule-table dl dt::after{
        top: 12px;
    }
    
    .schedule-table dl dd:nth-of-type(2n) {
        border-radius: 10px;
    }

}


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

.flow-area{
    margin: 120px auto 0;
}

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

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

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

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

.flow-list li::before{
    position: absolute;
    content: "";
    display: block;
    width: 150px;
    height: 150px;
    display: block;
    transform: rotate(45deg);
    background-color: #F5F5F5;
    border-radius: 10px;
    top: -30px;
    left: -30px;
    z-index: -2;
}

.step-ttl{
    width: 150px;
    height: 150px;
    display: block;
    transform: rotate(45deg);
    position: absolute;
    background-color: #fff;
    border-radius: 10px;
    padding: 5px;
    top: -30px;
    left: -20px;
}

.step-ttl-box{
    transform: rotate(-45deg);
    text-align: center;
    position: absolute;
    left: 32px;
    top: 36px;
}

.step04 .step-ttl-box,.step05 .step-ttl-box{
    left: 22px;
}

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

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

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

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

.step-txt{
    font-size: 1.9rem;
    color: #fff;
    line-height: 2;
    font-weight: 700;
    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: 60px;
    background-color: #f8f8f8;
    border-radius: 25px;
    border-bottom: 10px solid #ddd;
    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-list {
        margin: 40px auto 0;
    }

    .flow-list li{
        width: 95%;
        margin: 0 auto 47px;
        padding: 42px 20px 20px;
        border-bottom: 6px solid #F5F5F5;
    }
    
    .step-ttl{
        width: 70px;
        height: 70px;
        left: 0;
        top: -37px;
        right: 0;
        margin: 0 auto;
    }
    
    .flow-list li::before{
        display: none;
    }
    
    .step-ttl-box,.step03 .step-ttl-box,.step04 .step-ttl-box, .step05 .step-ttl-box{
        left: 14px;
        top: 9px;
    }
    
    .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: #333;
        font-weight: 800;
        font-size: 1.9rem;
        line-height: 2;
        text-align: center;
        display: block;
    }
    
    .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;
	}


}


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

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

.dot-bg{
    background: url("../img/dot-bg.png") top right repeat;
    padding: 45px 0 10px;
}

.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: 2rem;
	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: #5fa8e3;
	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: 0px 0 0;
    }

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

    .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: 50px;
        border-radius: 20px;
        padding-right: 0 10px;
    }
    
    .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: 20px 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-area{
	position: relative;
}
.condition .intro-area .inner{
	position: relative;
}
.condition .intro-ttl{
	width: 500px;
    margin: 10px 0 0 auto;

    color: #333;
	padding: 0;
	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;
}
.condition .intro-area::before{
	position: absolute;
    content: "";
    display: block;
    background: url("../img/job-condi-mv.jpg")no-repeat top center /cover;
    width: 800px;
    height: 440px;
	top: 40px;
	border-radius: 30px;
	left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
	margin: 0 0 0 -350px;
}

.condition .intro-ttl .section-catch {
    margin: 0 auto 10px;
    font-size: 3.6rem;
    letter-spacing: 1.6px;
	line-height: 1.6;
}

.condition .intro-img{
    border: none;
    padding: 0;
    border-radius:  30px;
    right: auto;
    left: -160px;
	top: -100px;
	    width: 800px;
}

.condition .intro-img img{
    border-radius: 30px;
	object-fit: cover;
    width: 910px;
    height: 440px;
	object-position: right;
}

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

.condition .intro-txt{
    line-height: 2.5;
    font-size: 1.6rem;

    margin: 0 0 0 auto;
    width: 500px;
    /*font-weight: 600;*/
    right: 0;
    position: absolute;
		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;
}

.condition .bgextend{
	background: none;
}
.condition .bgLRextend::before{
	background: #f9f9f9;
}

.condition .intro-content{
    border: none;
    margin: 0 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-area::before{
		display: none;
	}
    .condition .intro-ttl .section-catch {
        margin: 0 auto 0;
        font-size: 2.6rem;
    }
	.condition .intro-area .intro-txt{
		background: none;
		font-size: 1.6rem;
		padding: 0 0;
	}
	.condition .intro-area .intro-txt .txt{
		padding: 10px 0 0;
	}
    
    .condition .intro-content{
        margin: 0 0 0;
    }
    
    .condition .intro-bg{
        padding: 0 0 0 0;
    }
    
    .condition .intro-img{
        margin: 0 auto 0 0;
		width: 100%;
		left: 0;
		border-radius: 0;
		position: initial;
    }
    
    .condition .intro-img img{
        width: 100%;
		height: 200px;
		border-radius: 0;
		object-position: center;
    }
	.condition .intro-ttl{
		width: 100%;
		margin: 10px 0 0;
	}
    .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;
		width: 100%;
	}

    .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;
    }
}
/*    requirements-area
-------------------------------------------------------------- */
.requirements-area{
	margin: 150px 0 100px;
}

.requirements-area .box{
	border: solid 1px #ddd;
	margin: 30px 0 0;
	padding: 30px;
}
.requirements-area .box .title{
	font-size: 2rem;
	background: #ff9d91;
	color: #fff;
	display: inline-block;
	padding: 0 30px;
	margin: 0 0 5px;
	border-radius: 30px;
}
.requirements-area table {
	border-collapse: collapse;
	border: 1px solid #ddd;
	width: 100%;
	table-layout: fixed;
	margin: 30px 0 0;
}

.requirements-area table tr {
	display: flex;
}

.requirements-area table th {
	background: #F6F8F9;
	border-bottom: 1px solid #ddd;
	border-right: 1px solid #ddd;
	display: block;
	text-align: left;
	font-size: 1.7rem;
	font-weight: bold;
	padding: 20px;
	width: 190px;
	line-height: 2.1875;
}

.requirements-area table td {
	border-bottom: 1px solid #ddd;
	display: block;
	padding: 20px;
	width: calc( 100% - 190px );
	line-height: 2.1875;
}

.requirements-area table tr:last-child th,
.requirements-area table tr:last-child td {
	border-bottom: none;
}

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

	.requirements-area table tr {
		display: block;
	}
	
	.requirements-area table th {
		border-right: none;
		padding: 10px 15px;
		width: 100%;
	}
	
	.requirements-area table td {
		width: 100%;
		padding: 15px;
		line-height: 2;
	}
	
	.requirements-area dd {
		line-height: 1.7;
	}
	
	.requirements-area dl:not(:first-of-type) {
		margin-top: 15px;
	}
	
	.requirements-area dl:not(:first-of-type) {
		margin-top: 15px;
	}
	
	.requirements-area table tr:last-child th {
		border-bottom: 1px solid #ddd;
	}
}

/*20240410 河野追記*/
@media screen and (max-width: 768px){
	.recruit-img.careerpath img {
		width: 100%;
		height: 200px;
		object-fit: cover;
		object-position: top;
	}
	.office-img.loop {
		padding: 51px 0 150px;
	}
}
