/* index
--------------------------------------------------------- */

.recruit {
    /* .column {
    & + h2.l_ttl {
      margin-top: $baseSize * 16 + px;
    }
  } */
}

.recruit section.top_message {
    margin-top: 32px;
}

.recruit .intro {
    width: 1120px;
    height: 572px;
    margin: 0 auto;
    position: relative;
}

.recruit .intro_ttl {
    line-height: 1;
}

.recruit .intro_ttl span.en {
    font-weight: 800;
    font-size: 7.2rem;
    display: inline-block;
    position: absolute;
    z-index: 10;
    top: -40px;
}

.recruit .intro_ttl span.en:before {
    content: '';
    width: 60px;
    height: 54px;
    background: url(/cmn/img/icon_ttl.svg) no-repeat;
    display: inline-block;
    margin-right: 16px;
}

.recruit .intro_ttl span.txt {
    font-weight: bold;
    position: relative;
    line-height: 1;
    font-size: 2.0rem;
    display: block;
    letter-spacing: 1px;
    margin-top: 16px;
}

.recruit .intro_main {
    position: absolute;
    top: 0;
    left: 0;
}

.recruit .intro_sub {
    position: absolute;
    bottom: 0;
    right: 0;
}

.recruit .contact_box+* {
    margin-top: 128px;
}

.recruit h2.l_ttl {
    margin-top: 128px;
}

.recruit h2.l_ttl:first-child {
    margin-top: 32px;
}

.recruit .mynavi {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.recruit .mynavi a {
    display: block;
}

.recruit .mynavi a img {
    width: 195px;
    height: auto;
}

.recruit .mynavi span.txt {
    margin-left: 16px;
}

.recruit .job_category {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.recruit .job_category>li.job_list {
    width: 500px;
    margin-left: 40px;
    margin-top: 40px;
    background: #f5f4f0;
}

.recruit .job_category>li.job_list:first-child {
    margin-left: 0;
}

.recruit .job_category>li.job_list:nth-child(-n+2) {
    margin-top: 0;
}

.recruit .job_category>li.job_list:nth-child(odd) {
    margin-left: 0;
}

.recruit .job_category .job_detail {
    width: 100%;
    padding-bottom: 24px;
}

.recruit .job_category .job_detail>.ttl {
    background: #2a5a88;
    color: #ffffff;
    padding: 24px;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.5;
}

.recruit .job_category .job_detail>.ttl span {
    font-size: 1.4rem;
    width: 100%;
    display: block;
}

.recruit .job_category .job_detail>.txt {
    padding: 24px;
    min-height: 132px;
}

.recruit .job_category .job_detail>.message_wrap {
    background: #ffffff;
    margin: 0 24px;
    padding: 16px;
}

.recruit .job_category .job_detail>.message_wrap dl dt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.recruit .job_category .job_detail>.message_wrap dl dt>img {
    width: 80px;
    height: 80px;
}

.recruit .job_category .job_detail>.message_wrap dl dt>.ttl {
    font-weight: bold;
    margin-left: 24px;
}

.recruit .job_category .job_detail>.message_wrap dd {
    margin-top: 24px;
    font-size: 1.4rem;
    line-height: 2.4rem;
}

.recruit .recruit_message {
    width: 100%;
    text-align: center;
    font-size: 2.4rem;
    line-height: 4.4rem;
    font-weight: bold;
    margin: 64px auto 24px;
}

.bnr01 {
    width: 229px;
    display: block;
    margin: 24px auto 0;
}

.bnr01+h4.l_ttl {
    margin-top: 32px;
}

@media screen and (max-width: 768px) {
    .recruit .intro {
        width: 100%;
        height: 0;
        padding-top: 100%;
    }
    .recruit .intro_ttl span.en {
        font-size: 4.0rem;
        padding-left: 50px;
        top: -64px;
    }
    .recruit .intro_ttl span.en:before {
        width: 45px;
        height: 50px;
        background-size: 100%;
        position: absolute;
        left: 0;
    }
    .recruit .intro_ttl span.en img {
        width: 100%;
    }
    .recruit .intro_ttl span.txt {
        font-size: 1.6rem;
    }
    .recruit .intro_sub {
        width: 89%;
        bottom: 0;
        right: 0;
        left: 0;
        margin: 0 auto;
    }
    .recruit .intro_sub>img {
        width: 100%;
    }
    .recruit .mynavi {
        width: 100%;
        display: block;
        text-align: center;
    }
    .recruit .mynavi img {
        width: 100%;
    }
    .recruit .mynavi a img {
        width: 100%;
    }
    .recruit .mynavi span.txt {
        width: 100%;
        margin-left: 0;
        margin-top: 16px;
        text-align: center;
        display: block;
    }
    .recruit .job_category>li.job_list {
        margin-left: 0;
    }
    .recruit .job_category>li.job_list:nth-child(-n+2) {
        margin-top: 16px;
        margin-left: 0;
    }
    .recruit .job_category .job_detail>.message_wrap {
        padding: 24px;
    }
    .recruit .recruit_message {
        font-size: 1.6rem;
        line-height: 2.4rem;
        margin: 40px auto 24px;
    }
    .bnr01 {
        width: 100%;
        margin-left: 0;
        margin-top: 20px;
        text-align: center;
        display: block;
    }
}