  /* anchor */


#anchor{
    padding-top: 40px;
}


#anchor li{
    width: 24%;
    background: #FFF;
    text-align: center;
    border: #000 solid 1px;
    border-radius: 10px;
    padding: 15px 10px 20px;
}

#anchor li figure{
    width: 70px;
    margin: 0 auto;
}

#anchor li figcaption {
    font-size: 20px;
    line-height: 1;
    padding-top: 10px;
}


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

    #anchor{
        padding-top: 20px;
    }

    #anchor li{
        width: 49%;
        margin-bottom: 2%;
    }

    #anchor li a{
        display: flex;
        align-items: center;
        padding: 5px 0px 5px 5px;
    }

    #anchor li figure{
        width: 40px;
        margin: 0;
    }

    #anchor li figcaption {
        display: block;
        font-size: 19px;
        line-height: 1;
        padding-top: 0px;
        padding-left: 12px;
        text-align: left;
    }

}

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

    #anchor li a{
        display: block;
        align-items: center;
        padding: 0px;
    }

    #anchor li figure{
        width: 40px;
        margin: 0 auto;
    }

    #anchor li figcaption{
        display: block;
        font-size: 18px;
        padding-top: 10px;
        padding-left: 0px;
        text-align: center;
    }

}

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

    #anchor li figcaption {
        font-size: 17px;
        letter-spacing: 0px;
    }
}

/* anchor */



/* business */

.business_box{
    padding-top: 90px;
    padding-bottom: 65px;
    flex-direction: row-reverse;
}

.business_box:first-of-type{
    padding-top: 180px;
}

.business_box div{
    width: 48%
}

.business_box figure{
    width: 48.333333%;
}

.business_box figure span{
    display: block;
    overflow: hidden;
    border-radius: 15px;
}

.business_box h1{
    display: flex;
    align-items: center;
    padding-bottom: 45px;
}

.business_box h1 strong{
    display: block;
    width: 70px;
}

.business_box h1 span{
    display: inline-block;
    font-size: 50px;
    padding-left: 20px;
    line-height: 1;
}

#contents_area article div{
    flex-direction: row-reverse;
    padding-bottom: 65px;
}

#contents_area article div:last-of-type{
    padding-bottom: 0px;
}

#contents_area article h2{
    padding-bottom: 20px;
    letter-spacing: 0px;
}

#contents_area article h2 span{
    display: inline-block;
    font-size: 26px;
    line-height: 1.4;
}

#contents_area article div aside{
    padding-top: 8px;
    width: 440px;
}

#contents_area article div aside figure span{
    display: block;
    width: 210px;
    overflow: hidden;
    border-radius: 8px;
    line-height: 0;
}

#contents_area article div aside .b-radius{
	max-width: 440px;
	display: block;
	overflow: hidden;
    border-radius: 8px;
}


#contents_area article div p{
    width: calc(100% - 480px) ;
}



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

    .business_box{
        padding-top: 7.826087vw;
        padding-bottom: 5.6522vw;
    }
    
    .business_box:first-of-type{
        padding-top: 15.652174vw;
    }

    .business_box div{
        width: 48%
    }
    
    .business_box figure{
        width: 48.333333%;
    }

    #contents_area article div aside{
        padding-top: 8px;
        width: 47.826087%;
    }

    #contents_area article div p{
        width: 47.826087%;
    }

    #contents_area article div aside figure span{
        width: 47.27273%
    }
    
}


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


    .business_box h1 strong{
        display: block;
        width: 55px;
    }
    
    .business_box h1 span{
        display: inline-block;
        font-size: 40px;
        padding-left: 20px;
        line-height: 1;
    }

}


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

    .business_box.flex{
        display: block;
    }

    .business_box div{
        width: 100%
    }
    
    .business_box figure{
        width: 100%;
    }

    .business_box h1{
        padding-top: 30px;
        padding-bottom: 20px;
    }

    .business_box h1 strong{
        display: block;
        width: 40px;
    }
    
    .business_box h1 span{
        display: inline-block;
        font-size: 30px;
        padding-left: 15px;
        line-height: 1;
    }


    #contents_area article h2 span{
        font-size: 24px;
    }

    
    #contents_area article div.flex{
       display: block;
    }

    #contents_area article div aside{
        padding-top: 0px;
        width: 100%;
    }

    #contents_area article div p{
        width: 100%;
        padding-top: 20px;
    }

    #contents_area article div aside figure span{
        width: 48.5%
    }


    #contents_area article #map figure span {
        display: block;
        overflow-x: scroll;
        padding-bottom: 20px;
    }

    #contents_area article #map figure span img {
        display: block;
        width: 700px;
        max-width: 700px;
    }
}







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

    .business_box figure.flex{
        display: block;
    }

    #contents_area article div aside figure span{
        width: 100%;
        margin-bottom: 10px;
    }
   

}


/* business */



/* banner */

.banner{
    transition: all 500ms 0s ease;
    position: relative;
    width: 100%;
    max-width: 600px;
    height: 100px;
    margin: 30px auto 0 0;
    background: linear-gradient(90deg, rgba(234,247,244,1) 0%, rgba(229,245,253,1) 100%);
    overflow: hidden;
    border-radius: 10px;
    padding-left: 30px;
    flex-direction: row-reverse;
}

.pc .banner:hover{
    opacity: .7;
}

.banner figure{
    width: 240px;
    height: 100%;
    background-image: url(/recruit/company/img/img_business/banner_project3_photo.webp);
    background-size: cover;
    background-position: center center;
}

.banner div{
    position: relative;
    padding:10px 20px 0px;
}

.banner div small{
    display: block;
    font-size: 12px;
    line-height: 1;
}

.banner div small i{
    display: inline-block;
    font-size: 18px;
}

.banner div strong{
    display: inline-block;
    font-size: 18px;
    line-height: 1.3;
    padding-top: 15px;
}

.banner::before{
    content: "";
    position: absolute;
    display: block;
    width: 30px;
    height: 100%;
    background-color: #3b3b3b;
    left: 0;
    top: 0;
}

.banner::after{
    content: "";
    position: absolute;
    display: block;
    width: 14px;
    height: 14px;
    transform-origin: center center;
    border-top: #FFF solid 2px;
    border-left: #FFF solid 2px;
    left: 12px;
    top: 50%;
    transform: translateY(-50%) rotate(-45deg);
}


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

    .banner figure{
        width: 35%;
    }
    
    .banner div{
        width: 65%;
        position: relative;
        
    }
    

}


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

  

    .banner.flex{
        display: block;
        height: auto;
    }

    .banner figure{
        width: 100%;
        height: 80px;
    }
    
    .banner div{
        width: 100%;
        position: relative;
        padding:10px 0px 10px 15px;
    }

    .banner div strong{
        font-size: 16px;
        padding-top: 10px;
    }
    

}




/* banner */




.link_window{
    width: 100%;
    margin-top: 15px;
   
}

.link_window a{
    transition: all 500ms 0s ease;
    display: inline-block;
    position: relative;
    padding: 6px 10px 7px 24px;
    line-height: 1.4;
    background: linear-gradient(90deg, rgba(234,247,244,1) 0%, rgba(229,245,253,1) 100%);
}

.link_window a svg{
    transition: all 500ms 0s ease;
    position: absolute;
    width: 12px;
    height: 12px;
    left: 8px;
    top: 10px;
    z-index: 4;
}

.link_window a:hover{
    opacity: .7;
}