.banner .img {
    width: 100%
}

.banner .img img {
    width: 100%
}

.re_title {
    font-weight: bold;
    font-size: 36px;
    color: #111111;
    position: relative;
    z-index: 1
}

.re_title:after {
    content: '';
    position: absolute;
    top: -25px;
    left: -44px;
    border-radius: 50%;
    z-index: -1;
    width: 86px;
    height: 86px;
    background: linear-gradient(130deg, rgba(200, 22, 29, 0.4), rgba(200, 22, 29, 0))
}

.recruit1 {
    background: #FAF7F7;
    padding: 101px 0 129px 0
}

.recruit1 .wrap {
    width: 1200px;
    margin: auto;
    display: flex;
    align-items: center;
    justify-content: space-between
}

.recruit1 .wrap .l {
    width: 522px
}

.recruit1 .wrap .l .text {
    font-weight: 500;
    font-size: 24px;
    color: #111111;
    line-height: 36px;
    margin: 33px 0 57px 0
}

.recruit1 .wrap .l .pick {
    font-weight: 400;
    font-size: 18px;
    color: #555555;
    line-height: 36px;
    text-indent: 36px
}

.recruit1 .wrap .img {
    width: 560px;
    height: 500px;
    overflow: hidden
}

.recruit1 .wrap .img:hover img {
    transform: scale(1.05)
}

.recruit1 .wrap .img img {
    width: 100%;
    height: 100%;
    transition: 1s
}

.recruit2 {
    padding: 109px 0 120px 0;
    position: relative;
    z-index: 1
}

.recruit2 .common_bg {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: -1
}

.recruit2 .wrap {
    width: 1200px;
    margin: auto;
    display: flex;
    justify-content: space-between
}

.recruit2 .wrap .l {
    width: 580px
}

.recruit2 .wrap .l .title .re_title:after {
    background: linear-gradient(130deg, rgba(173, 129, 103, 0.4), rgba(200, 22, 29, 0))
}

.recruit2 .wrap .l .title .more {
    margin: 41px 0 0 0;
    width: 160px;
    height: 52px;
    border-radius: 7px;
    border: 1px solid rgba(200, 22, 29, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: .6s ease
}

.recruit2 .wrap .l .title .more p {
    font-weight: 400;
    font-size: 16px;
    color: #111111;
    margin: 0 11px 0 0;
    transition: .6s ease
}

.recruit2 .wrap .l .title .more .iconfont {
    color: #C8161D;
    font-size: 12px;
    transition: .6s ease
}

.recruit2 .wrap .l .title .more:hover {
    background: #C8161D
}

.recruit2 .wrap .l .title .more:hover p, .recruit2 .wrap .l .title .more:hover .iconfont {
    color: #fff
}

.recruit2 .wrap .l .img {
    width: 100%;
    height: 380px;
    overflow: hidden;
    position: relative;
    margin: 100px 0 0 0;
    display: block
}

.recruit2 .wrap .l .img:hover img {
    transform: scale(1.05)
}

.recruit2 .wrap .l .img img {
    width: 100%;
    height: 100%;
    transition: 1s
}

.recruit2 .wrap .l .img .position {
    position: absolute;
    bottom: 24px;
    width: 100%;
    padding: 0 34px 0 30px;
    display: flex;
    align-items: center;
    justify-content: space-between
}

.recruit2 .wrap .l .img .position p {
    font-weight: 500;
    font-size: 18px;
    color: #FFFFFF
}

.recruit2 .wrap .l .img .position .time {
    font-weight: 400;
    font-size: 18px;
    color: #FFFFFF
}

.recruit2 .wrap .r {
    width: 580px;
    height: fit-content;
    background: #AD8167;
    padding: 40px 30px 31px 30px;
    margin: 28px 0 0 0
}

.recruit2 .wrap .r .headline {
    font-weight: bold;
    font-size: 24px;
    color: #FFFFFF;
    padding: 0 0 20px;
    border-bottom: 1px solid #fff
}

.recruit2 .wrap .r .flex {
    height: auto
}

.recruit2 .wrap .r .flex .list {
    width: 100%;
    height: 57px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px dashed rgba(255, 255, 255, 0.2);
    transition: .6s;
    position: relative;
    z-index: 2
}

.recruit2 .wrap .r .flex .list:after {
    content: '';
    position: absolute;
    width: 580px;
    height: 100%;
    left: 50%;
    transform: translateX(-50%);
    top: 0;
    z-index: -1;
    background: rgba(255, 255, 255, 0.1);
    opacity: 0;
    transition: 0.6s ease
}

.recruit2 .wrap .r .flex .list:hover:after {
    opacity: 1
}

.recruit2 .wrap .r .flex .list p {
    font-weight: 400;
    font-size: 16px;
    color: #FFFFFF;
    width: 400px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.recruit2 .wrap .r .flex .list .time {
    font-weight: 400;
    font-size: 14px;
    color: #FFFFFF;
    line-height: 36px;
    opacity: 0.8
}

.recruit3 {
    padding: 115px 0 68px 0;
    position: relative;
    z-index: 1;
    border-radius: 0 0 160px 0;
    overflow: hidden
}

.recruit3 .common_bg {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: -1
}

.recruit3 .wrap {
    width: 1200px;
    margin: auto
}

.recruit3 .wrap .top {
    display: flex;
    justify-content: space-between
}

.recruit3 .wrap .top .l {
    width: 514px
}

.recruit3 .wrap .top .l .re_title:after {
    background: linear-gradient(130deg, rgba(22, 93, 200, 0.4), rgba(200, 22, 29, 0))
}

.recruit3 .wrap .top .l .text {
    margin: 47px 0 0 0;
    font-weight: 400;
    font-size: 18px;
    color: #444444;
    line-height: 36px;
    text-indent: 36px
}

.recruit3 .wrap .top .img {
    width: 600px;
    height: 520px;
    overflow: hidden
}

.recruit3 .wrap .top .img:hover img {
    transform: scale(1.05)
}

.recruit3 .wrap .top .img img {
    width: 100%;
    height: 100%;
    transition: 1s
}

.recruit3 .wrap .content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 80px 0 0 0
}

.recruit3 .wrap .content .item {
    display: flex;
    align-items: center
}

.recruit3 .wrap .content .item .circle {
    width: 46px;
    height: 46px;
    background: #9C0C18;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 14px 0 0
}

.recruit3 .wrap .content .item .circle img {
    max-width: 50%;
    max-height: 50%;
    object-fit: contain
}

.recruit3 .wrap .content .item p {
    font-weight: 500;
    font-size: 20px;
    color: #111111
}

@media screen and (max-width: 1920px) {
    .re_title {
        font-size: 1.875vw;
    }
    
    .re_title:after {
        top: -1.3020833333vw;
        left: -2.2916666667vw;
        width: 4.4791666667vw;
        height: 4.4791666667vw;
    }
    
    .recruit1 {
        padding: 5.2604166667vw 0 6.71875vw 0
    }
    
    .recruit1 .wrap {
        width: 62.5vw;
    }
    
    .recruit1 .wrap .l {
        width: 27.1875vw
    }
    
    .recruit1 .wrap .l .text {
        font-size: 1.25vw;
        line-height: 1.875vw;
        margin: 1.71875vw 0 2.96875vw 0
    }
    
    .recruit1 .wrap .l .pick {
        font-size: 0.9375vw;
        line-height: 1.875vw;
        text-indent: 1.875vw
    }
    
    .recruit1 .wrap .img {
        width: 29.1666666667vw;
        height: 26.0416666667vw;
    }
    
    .recruit2 {
        padding: 5.6770833333vw 0 6.25vw 0;
    }
    
    .recruit2 .wrap {
        width: 62.5vw;
    }
    
    .recruit2 .wrap .l {
        width: 30.2083333333vw
    }
    
    .recruit2 .wrap .l .title .more {
        margin: 2.1354166667vw 0 0 0;
        width: 8.3333333333vw;
        height: 2.7083333333vw;
        border-radius: 0.3645833333vw;
    }
    
    .recruit2 .wrap .l .title .more p {
        font-size: 0.8333333333vw;
        margin: 0 0.5729166667vw 0 0;
    }
    
    .recruit2 .wrap .l .title .more .iconfont {
        font-size: 0.625vw;
    }
    
    .recruit2 .wrap .l .img {
        height: 19.7916666667vw;
        margin: 5.2083333333vw 0 0 0;
    }
    
    .recruit2 .wrap .l .img .position {
        bottom: 1.25vw;
        padding: 0 1.7708333333vw 0 1.5625vw;
    }
    
    .recruit2 .wrap .l .img .position p {
        font-weight: 500;
        font-size: 0.9375vw;
    }
    
    .recruit2 .wrap .l .img .position .time {
        font-size: 0.9375vw;
    }
    
    .recruit2 .wrap .r {
        width: 30.2083333333vw;
        padding: 2.0833333333vw 1.5625vw 1.6145833333vw 1.5625vw;
        margin: 1.4583333333vw 0 0 0
    }
    
    .recruit2 .wrap .r .headline {
        font-size: 1.25vw;
        padding: 0 0 1.0416666667vw;
    }
    
    .recruit2 .wrap .r .flex .list {
        height: 2.96875vw;
    }
    
    .recruit2 .wrap .r .flex .list:after {
        width: 30.2083333333vw;
    }
    
    .recruit2 .wrap .r .flex .list p {
        font-size: 0.8333333333vw;
        width: 20.8333333333vw;
    }
    
    .recruit2 .wrap .r .flex .list .time {
        font-size: 0.7291666667vw;
        line-height: 1.875vw;
    }
    
    .recruit3 {
        padding: 5.9895833333vw 0 3.5416666667vw 0;
        border-radius: 0 0 8.3333333333vw 0;
    }
    
    .recruit3 .wrap {
        width: 62.5vw;
    }
    
    .recruit3 .wrap .top .l {
        width: 26.7708333333vw
    }
    
    .recruit3 .wrap .top .l .text {
        margin: 2.4479166667vw 0 0 0;
        font-size: 0.9375vw;
        line-height: 1.875vw;
        text-indent: 1.875vw
    }
    
    .recruit3 .wrap .top .img {
        width: 31.25vw;
        height: 27.0833333333vw;
    }
    
    .recruit3 .wrap .content {
        margin: 4.1666666667vw 0 0 0
    }
    
    .recruit3 .wrap .content .item .circle {
        width: 2.3958333333vw;
        height: 2.3958333333vw;
        margin: 0 0.7291666667vw 0 0
    }
    
    .recruit3 .wrap .content .item p {
        font-size: 1.0416666667vw;
    }    
}

@media screen and (max-width: 1024px) {
    .recruit1 .wrap{
        width: 90%;
    }
    .re_title:after{
        width: 30px;
        height: 30px;
        top: -10px;
        left: -10px;
    }
    .recruit1{
        padding: 60px 0;
    }
    .recruit1 .wrap .l{
        width: 48%;
    }
    .recruit1 .wrap .img{
        width: 48%;
        height: auto;
    }
    .re_title{
        font-size: 24px;
    }
    .recruit1 .wrap .l .text{
        font-size: 16px;
        line-height: 1.6;
        margin: 10px 0 20px;
    }
    .recruit1 .wrap .l .pick{
        font-size: 14px;
        line-height: 1.6;
        text-indent: 2em;
    }
    .recruit2 .wrap{
        width: 90%;
    }
    .recruit2{
        padding: 60px 0;
    }
    .recruit2 .wrap .l{
        width: 49%;
    }
    .recruit2 .wrap .r{
        width: 49%;
        padding: 20px;
    }
    .recruit2 .wrap .l .title .more p{
        font-size: 14px;
        margin-right: 5px;
    }
    .recruit2 .wrap .l .title .more .iconfont{
        font-size: 12px;
    }
    .recruit2 .wrap .l .title .more{
        width: 120px;
        height: 40px;
        margin-top: 20px;
    }
    .recruit2 .wrap .l .img{
        margin-top: 30px;
    }
    .recruit2 .wrap .l .img .position .time,
    .recruit2 .wrap .l .img .position p{
        font-size: 12px;
    }
    .recruit2 .wrap .r .headline{
        font-size: 20px;
        padding-bottom: 10px;
    }
    .recruit2 .wrap .r .flex .list:after {
        width: 44.208333vw;
    }
    .recruit2 .wrap .r .flex .list p{
        font-size: 14px;
        line-height: 1.6;
    }
    .recruit2 .wrap .r .flex .list .time{
        font-size: 12px;
        line-height: 1.6;
    }
    .recruit2 .wrap .r .flex .list{
        height: 40px;
    }
    .recruit2 .wrap .r .flex .list p {
        width: 24.833333vw;
    }
    .recruit2 .wrap .r{
        margin-top: 20px;
    }
    .recruit2 .wrap .l .img{
        height: auto;
    }
    .recruit2 .wrap .l .img .position{
        bottom: 20px;
        padding: 0 20px;
    }
    .recruit3{
        padding: 60px 0;
    }
    .recruit3 .wrap{
        width: 90%;
    }
    .recruit3 .wrap .top .l{
        width: 49%;
    }
    .recruit3 .wrap .top .img{
        width: 49%;
        height: auto;
    }
    .recruit3 .wrap .top .l .text{
        font-size: 14px;
        margin-top: 20px;
        line-height: 1.6;
    }
    .recruit3 .wrap .content .item p{
        font-size: 14px;
    }
    .recruit3 .wrap .content{
        margin-top: 20px;
    }
    .recruit3 .wrap .content .item .circle{
        width:30px;
        height: 30px;
        margin-right: 10px;
    }
    
}

@media screen and (max-width: 767px) {
    .recruit1 .wrap{
        flex-direction: column;
    }
    .recruit1 .wrap .l{
        width: 100%;
    }
    .recruit1 .wrap .img{
        width: 100%;
        margin-top: 20px;
    }
    .recruit1{
        padding: 50px 0;
    }
    .re_title {
        font-size: 20px;
    }
    .recruit2 .wrap{
        flex-direction: column;
    }
    .recruit2 .wrap .r,
    .recruit2 .wrap .l{
        width: 100%;
    }
    .recruit2{
        padding: 50px 0;
    }
    .recruit2 .wrap .r .flex .list p {
        width: 100%;
    }
    .recruit2 .wrap .r .flex .list:after {
        width: calc(100% + 40px);
    }
    .recruit2 .wrap .r .flex .list{
        flex-direction: column;
        align-items: start;
        justify-content: center;
        height: 60px;
    }
    .recruit3{
        padding: 50px 0;
    }
    .recruit3 .wrap .top{
        flex-direction: column;
    }
    .recruit3 .wrap .top .l{
        width: 100%;
    }
    .recruit3 .wrap .top .img{
        width: 100%;
        margin-top: 20px;
    }
    .recruit3 .wrap .content{
        flex-wrap: wrap;
        gap:20px 0
    }
    .recruit3 .wrap .content .item{
        width: 50%;
    }

}

@media screen and (max-width: 540px) {
    .recruit3 .wrap .content .item{
        width: 100%;
    }
}