@charset "UTF-8";

#Recruit {
    overflow-x: clip;
    overflow-y: visible;
}
#Recruit .TopContentsLayout {
    margin-bottom: 63px;
}
#Recruit .TopContentsLayout .section-list-container {
    top: 100%;
    transform: translateY(-117px);
}
#Recruit .section_1 {
    position: relative;
    width: 100%;
    max-width: 1920px;
    margin: 0 auto;
    overflow: visible;
    overflow-x: clip;
}
#Recruit .section_1::before,
#Recruit .section_1::after {
    content: "";
    position: absolute;
    bottom: -224px;
    left: 0;
    z-index: -200;
    width: 100%;
    height: 812px;
    background-color: rgba(33, 60, 179, 0.1);
}
@media screen and (max-width: 1919px) {
    #Recruit .section_1::before {
        bottom: -20%;
    }
}
#Recruit .section_1::after {
    bottom: -11.667vw;
    z-index: -210;
    background: var(--baseColor);
}
#Recruit .section_1 .contents-box_1 {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    max-width: 1470px;
    height: 660px;
    padding: 0 15px;
    margin: 0 auto 143px;
    overflow-y: clip;
}
@media screen and (max-width: 767px) {
    #Recruit .section_1 .contents-box_1 {
        margin-bottom: 70px;
    }
}
#Recruit .section_1 .contents-box_1::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: -1;
    width: 100vw;
    height: 100%;
    background-color: rgba(130, 60, 150, 0.6);
}
#Recruit .section_1 .contents-box_1-inner h3 {
    font-size: 48px;
    font-weight: 700;
    line-height: 1.6em;
    letter-spacing: 0.05em;
    color: var(--baseColor);
    margin-bottom: 80px;
}
@media screen and (max-width: 1919px) {
    #Recruit .section_1 .contents-box_1-inner h3 {
        font-size: 3vw;
        margin-bottom: 4.375vw;
    }
}
@media screen and (max-width: 767px) {
    #Recruit .section_1 .contents-box_1-inner h3 {
        font-size: 20px;
        margin-bottom: 20px;
    }
}
#Recruit .section_1 .contents-box_1-inner p {
    width: 631px;
    font-size: 24px;
    font-weight: 400;
    line-height: 1.83em;
    letter-spacing: 0.05em;
    color: var(--baseColor);
}
@media screen and (max-width: 1919px) {
    #Recruit .section_1 .contents-box_1-inner p {
        font-size: 1.563vw;
    }
}
@media screen and (max-width: 767px) {
    #Recruit .section_1 .contents-box_1-inner p {
        width: 100%;
        font-size: 16px;
    }
}
#Recruit .section_1 .slider-container {
    position: absolute;
    top: 0;
    right: 0;
    width: 693px;
    height: 660px;
    overflow: hidden;
}
@media screen and (max-width: 1919px) {
    #Recruit .section_1 .slider-container {
        z-index: -100;
    }
}
#Recruit .section_1 .image-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
}
#Recruit .section_1 .image-grid {
    display: flex;
    flex-direction: column;
    animation: slideUp 20s linear infinite;
}

#Recruit .section_1 .image-row {
    display: flex;
    width: 100%;
}

#Recruit .section_1 .image-item {
    width: 345px;
    height: 345px;
    flex-shrink: 0;
    overflow: hidden;
}

#Recruit .section_1 .image-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* グラデーション効果でつなぎ目を自然に */
#Recruit .section_1 .slider-container::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 30px;
    background: linear-gradient(180deg, rgba(130, 60, 150, 0.6) 0%, transparent 100%);
    z-index: 1;
    pointer-events: none;
}

#Recruit .section_1 .slider-container::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 30px;
    background: linear-gradient(0deg, rgba(130, 60, 150, 0.6) 0%, transparent 100%);
    z-index: 1;
    pointer-events: none;
}
#Recruit .section_1 .title-cover {
    position: relative;
    margin-bottom: 40px;
}
#Recruit .section_1 .title-cover::before {
    content: "";
    position: absolute;
    top: -100%;
    left: 43%;
    transform: translateY(-20px);
    width: 124px;
    height: 148px;
    background: url(../image/recruit/item_1.svg) no-repeat center center / contain;
}

@media screen and (max-width: 1919px) {
    @media screen and (max-width: 767px) {
        #Recruit {
            overflow-y: clip;
        }
    }
    #Recruit .TopContentsLayout {
        margin-bottom: 70px;
    }
    @media screen and (max-width: 767px) {
        #Recruit .TopContentsLayout .section-list-container {
            top: 110%;
            z-index: 1000;
        }
    }
    #Recruit .section_1 {
        position: relative;
        width: 100%;
        max-width: 100vw;
        margin: 0 auto;
        overflow: visible;
    }
    #Recruit .section_1 .contents-box_1 {
        max-width: 1100px;
        height: 650px;
        padding: 0 0.781vw;
    }
    @media screen and (max-width: 767px) {
        #Recruit .section_1 .contents-box_1 {
            justify-content: center;
            height: 80vw;
        }
        #Recruit .section_1 .contents-box_1-inner {
            padding: 0 15px;
        }
    }
    @media screen and (max-width: 767px) {
        #Recruit .section_1 .contents-box_1::before {
            width: 100vw;
        }
    }
    /* グラデーション効果でつなぎ目を自然に */
    #Recruit .section_1 .slider-container::after {
        content: "";
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        height: 1.563vw;
        background: linear-gradient(0deg, rgba(130, 60, 150, 0.6) 0%, transparent 100%);
        z-index: 1;
        pointer-events: none;
    }
    #Recruit .section_1 .title-cover {
        flex-direction: column;
        align-items: start;
        row-gap: 20px;
    }
    #Recruit .section_1 .title-cover::before {
        content: "";
        position: absolute;
        top: initial;
        bottom: 90%;
        left: 30%;
        transform: translateX(-50%);
        width: 70px;
        height: 70px;
        z-index: 900;
        background: url(../image/recruit/item_1.svg) no-repeat center center / contain;
    }
    @media screen and (max-width: 767px) {
        #Recruit .section_1 .title-cover::before {
            bottom: 70%;
            left: 40%;
            transform: translateX(-50%);
            width: max(10vw, 70px);
            height: max(10vw, 70px);
        }
    }
}

@keyframes slideUp {
    0% {
        transform: translateY(0);
    }
    100% {
        transform: translateY(-1035px); /* 6画像分（3行 × 345px） */
    }
}

/* レスポンシブ対応 */
@media (max-width: 1200px) {
    #Recruit .section_1 .slider-container {
        width: 580px;
    }

    #Recruit .section_1 .image-item {
        width: 290px;
        height: 290px;
    }

    @keyframes slideUp {
        0% {
            transform: translateY(0);
        }
        100% {
            transform: translateY(-870px); /* 6画像分（3行 × 290px） */
        }
    }
}

@media (max-width: 768px) {
    #Recruit .section_1 .slider-container {
        width: 400px;
        height: 100%;
        right: auto;
        margin-top: 0;
    }
    #Recruit .section_1 .image-item {
        width: 200px;
        height: 200px;
    }

    @keyframes slideUp {
        0% {
            transform: translateY(0);
        }
        100% {
            transform: translateY(-600px); /* 6画像分（3行 × 200px） */
        }
    }
}
#Recruit .title-cover {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    column-gap: 62px;
    width: 100%;
    max-width: 1470px;
    margin: 0 auto;
    padding: 0 15px;
}
#Recruit .title-cover p.title-cover-text {
    font-size: 24px;
    font-weight: 700;
    line-height: 1.67em;
    letter-spacing: 0.05em;
    color: var(--mainTextColor_1);
    margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
    #Recruit .title-cover p.title-cover-text {
        font-size: 20px;
        margin-bottom: 0;
    }
}
#Recruit .ContentsTitle {
    display: flex;
    flex-direction: column-reverse;
    justify-content: space-between;
    width: 100%;
    max-width: 1470px;
    margin: 0 auto;
    padding: 0 15px;
    height: 100px;
}
@media screen and (max-width: 767px) {
    #Recruit .ContentsTitle {
        margin: initial;
        padding: 0;
    }
}
#Recruit .ContentsTitle-en {
    position: relative;
    font-size: 40px;
    padding-bottom: 10px;
    width: fit-content;
}
@media screen and (max-width: 767px) {
    #Recruit .ContentsTitle-en {
        margin-left: initial;
        margin-right: auto;
        margin-bottom: 0;
    }
}
#Recruit .under-line .ContentsTitle-en::before {
    content: "";
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 97%;
    height: 10px;
    background: url(../image/recruit/item_2.svg) no-repeat center center / contain;
}
#Recruit .ContentsTitle-ja {
    font-size: 18px;
}

/* ナンバリング */
#Recruit .ContentsTitle-ja::before {
    width: 21px;
    left: 30px;
}
#Recruit .section_1 .contents-box .ContentsTitle-ja::after {
    content: "01";
}
#Recruit .section_2 .contents-box .ContentsTitle-ja::after {
    content: "02";
}
#Recruit .section_3 .contents-box .ContentsTitle-ja::after {
    content: "03";
}
#Recruit .section_4 .contents-box .ContentsTitle-ja::after {
    content: "04";
}
#Recruit .contents-box .ContentsTitle-ja::after {
    position: absolute;
    left: 0;
    font-size: 18px;
    line-height: 1em;
    letter-spacing: 0.05em;
    color: var(--mainTextColor_1);
}

#Recruit .contents-box_2 {
    display: flex;
    width: 100%;
    max-width: 1470px;
    padding: 0 15px;
    margin: 0 auto;
    border-radius: 10px;
    overflow: clip;
}
#Recruit .contents-box_2-inner {
    width: 50%;
}
@media screen and (max-width: 767px) {
    #Recruit .contents-box_2 {
        flex-direction: column;
        row-gap: 30px;
    }
    #Recruit .contents-box_2-inner {
        width: 100%;
    }
}
#Recruit .contents-box_2-inner .image-box {
    width: 100%;
    aspect-ratio: 720 / 480;
    overflow: clip;
    margin-bottom: -242px;
}
#Recruit .contents-box_2-inner .image-box img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
#Recruit .contents-box_2-inner .contents-box_2-inner-item {
    position: relative;
    z-index: 1;
    width: 100%;
    padding: 80px 42px 43px;
}
@media screen and (max-width: 767px) {
    #Recruit .contents-box_2-inner .contents-box_2-inner-item {
        padding: 80px 20px 30px;
    }
}
#Recruit .contents-box_2-inner.inner_1 {
    border-radius: 0 0 0 10px;
    overflow: clip;
}
#Recruit .contents-box_2-inner.inner_2 {
    border-radius: 0 0 10px 0;
    overflow: clip;
}
@media screen and (max-width: 767px) {
    #Recruit .contents-box_2-inner.inner_1,
    #Recruit .contents-box_2-inner.inner_2 {
        border-radius: 10px;
    }
}
#Recruit .contents-box_2-inner.inner_1 .contents-box_2-inner-item {
    background: linear-gradient(0deg, var(--mainColor_1) 0%, var(--mainColor_1) 80%, transparent 100%);
}
#Recruit .contents-box_2-inner.inner_2 .contents-box_2-inner-item {
    background: linear-gradient(0deg, var(--mainColor_2) 0%, var(--mainColor_2) 80%, transparent 100%);
}
#Recruit .contents-box_2-inner .contents-box_2-inner-item h4 {
    font-size: 48px;
    font-weight: 700;
    line-height: 1.6em;
    letter-spacing: 0.05em;
    color: var(--baseColor);
    margin-bottom: 41px;
}
@media screen and (max-width: 1300px) {
    #Recruit .contents-box_2-inner .contents-box_2-inner-item h4 {
        font-size: 30px;
        margin-bottom: 20px;
    }
}
#Recruit .contents-box_2-inner .contents-box_2-inner-item h5 {
    font-size: 24px;
    font-weight: 700;
    line-height: 1.6em;
    letter-spacing: 0.05em;
    color: var(--baseColor);
}
@media screen and (max-width: 1300px) {
    #Recruit .contents-box_2-inner .contents-box_2-inner-item h5 {
        font-size: 20px;
    }
}
#Recruit .contents-box_2-inner .contents-box_2-inner-item p.contents-box_2-inner-item-text {
    width: 100%;
    height: 200px;
    font-size: 18px;
    font-weight: 400;
    line-height: 2.2em;
    letter-spacing: 0.05em;
    color: var(--baseColor);
    margin-bottom: 22px;
}
@media screen and (max-width: 1300px) {
    #Recruit .contents-box_2-inner .contents-box_2-inner-item p.contents-box_2-inner-item-text {
        font-size: 16px;
        margin-bottom: 20px;
        line-height: 1.8em;
    }
}
#Recruit .contents-box_2-inner .contents-box_2-inner-item li {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 93px;
    border-top: 1px solid var(--baseColor);
}
@media screen and (max-width: 767px) {
    #Recruit .contents-box_2-inner .contents-box_2-inner-item li {
        height: initial;
        padding: 5px 0;
    }
}
#Recruit .contents-box_2-inner .contents-box_2-inner-item li:last-of-type {
    border-bottom: 1px solid var(--baseColor);
}
#Recruit .contents-box_2-inner .contents-box_2-inner-item li p {
    font-size: 18px;
    font-weight: 400;
    line-height: 2.2em;
    letter-spacing: 0.05em;
    color: var(--baseColor);
    white-space: nowrap;
}
@media screen and (max-width: 1300px) {
    #Recruit .contents-box_2-inner .contents-box_2-inner-item li p {
        font-size: 16px;
        line-height: 1.5em;
        white-space: normal;
    }
}
#Recruit .section_2 {
    position: relative;
    width: 100%;
    max-width: 1920px;
    margin: 0 auto;
    padding-top: 150px;
    overflow-x: clip;
}
@media screen and (max-width: 767px) {
    #Recruit .section_2 {
        padding-top: 100px;
    }
}
#Recruit .section_2 .title-cover {
    margin-bottom: 75px;
    row-gap: 20px;
}
@media screen and (max-width: 767px) {
    #Recruit .section_2 .title-cover {
        margin-bottom: 0;
        margin-left: initial;
        flex-direction: column;
        align-items: flex-start;
    }
}
#Recruit .section_2::before,
#Recruit .section_2::after {
    content: "";
    position: absolute;
    top: 224px;
    left: 0;
    z-index: -190;
    width: 100%;
    height: 200%;
    background-color: rgba(130, 60, 150, 0.1);
}
#Recruit .section_2::after {
    background: var(--baseColor);
    z-index: -191;
}
@media screen and (max-width: 1919px) {
    #Recruit .section_2::before,
    #Recruit .section_2::after {
        top: 20.6vw;
    }
}
#Recruit .section_2 .scrolling-text-wrapper {
    position: absolute;
    top: 20px;
    right: 0;
    z-index: -1;
    width: 100%;
    height: 358px;
}
#Recruit .contents-box_3 {
    position: relative;
    width: 100%;
    max-width: 1130px;
    margin: 0 auto;
    padding: 0 15px;
}
#Recruit .contents-box_3::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: -100px;
    transform: translate(-70%, 100%);
    width: 228px;
    height: 260px;
    background: url(../image/recruit/item_3.svg) no-repeat center center / contain;
}

#Recruit .contents-box_3 {
    height: 100%;
    padding-top: 40px;
}

#Recruit .contents-box_3 .list-cover {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin-bottom: 70px;
}
@media screen and (max-width: 767px) {
    #Recruit .contents-box_3 .list-cover {
        row-gap: 20px;
        margin-bottom: 0;
    }
}
#Recruit .contents-box_3 .list-cover::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -57%);
    z-index: -7;
    width: calc(100% + 112px);
    height: calc(100% + 90px);
    border-radius: 10px;
    background-color: var(--baseColor);
}
@media screen and (max-width: 767px) {
    #Recruit .contents-box_3 .list-cover::before {
        background: transparent;
    }
}
#Recruit .contents-box_3 .list-cover .list-item {
    width: 360px;
    height: 320px;
    margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
    #Recruit .contents-box_3 .list-cover .list-item {
        width: 80%;
        height: auto;
        aspect-ratio: 360 / 230;
        margin-bottom: 0;
    }
}
#Recruit .contents-box_3 .list-cover .list-item .img-cover {
    width: 100%;
    aspect-ratio: 360 / 236;
    overflow: clip;
    border-radius: 10px;
    margin-bottom: 23px;
}
@media screen and (max-width: 767px) {
    #Recruit .contents-box_3 .list-cover .list-item .img-cover {
        aspect-ratio: 360 / 150;
    }
}
#Recruit .contents-box_3 .list-cover .list-item .img-cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
@media screen and (max-width: 767px) {
    #Recruit .contents-box_3 .list-cover .list-item .img-cover img {
        width: 110%;
        height: 110%;
    }
}
#Recruit .contents-box_3 .list-cover .list-item h5,
#Recruit .contents-box_3 .list-cover .list-item small {
    color: var(--mainTextColor_1);
    text-align: center;
}
#Recruit .contents-box_3 .list-cover .list-item h5 {
    font-size: 24px;
    font-weight: 700;
    line-height: 1em;
    letter-spacing: 0.05em;
    margin-bottom: 15px;
}
#Recruit .contents-box_3 .list-cover .list-item small {
    display: block;
    font-size: 18px;
    font-weight: 400;
    line-height: 1em;
    letter-spacing: 0.05em;
}
#Recruit .section_2 .image-cover,
#Recruit .section_4 .image-cover {
    position: relative;
    top: 20px;
    width: 100%;
    max-width: 1920px;
    height: 498px;
    overflow: clip;
    margin: 0 auto;
}
#Recruit .section_2 .image-cover-inner,
#Recruit .section_4 .image-cover-inner {
    position: relative;
    width: 100%;
    height: 100%;
    max-width: 1130px;
    margin: 0 auto;
    padding: 0 15px;
}
@media screen and (max-width: 767px) {
    #Recruit .section_2 .image-cover,
    #Recruit .section_4 .image-cover {
        max-width: 1920px;
        height: initial;
        aspect-ratio: 1920 / 498;
    }
}
#Recruit .section_2 .image-cover img,
#Recruit .section_4 .image-cover img {
    position: absolute;
    top: 0;
    left: 15px;
    width: 1508px;
    height: 100%;
    object-fit: cover;
}
@media screen and (max-width: 767px) {
    #Recruit .section_2 .image-cover img,
    #Recruit .section_4 .image-cover img {
        left: 50%;
        transform: translateX(-50%);
    }
}
#Recruit .section_3 {
    position: relative;
    width: 100%;
    max-width: 1920px;
    margin: 0 auto;
    margin-top: -246px;
    padding-top: 267px;
    padding-bottom: 372px;
    overflow-x: clip;
}
@media screen and (max-width: 767px) {
    #Recruit .section_3 {
        padding-bottom: 320px;
    }
}
#Recruit .section_3::before,
#Recruit .section_3::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    z-index: -150;
    width: 100%;
    height: 100%;
    background-color: var(--baseColor);
}
#Recruit .section_3::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    z-index: -130;
    width: 100%;
    height: 100%;
    background-color: rgba(226, 224, 97, 0.2);
}
#Recruit .section_3 #section-03 {
    width: 100%;
    max-width: 1130px;
    padding: 0 15px;
    margin: 0 auto;
}
#Recruit .section_3 #section-03 .ContentsTitle {
    width: fit-content;
    height: fit-content;
    padding: 40px 383px 108px 0;
    background: url(../image/recruit/img_21.jpg) no-repeat center center / cover;
    margin-top: -113px;
    margin-left: 0;
}
@media screen and (max-width: 767px) {
    #Recruit .section_3 #section-03 .ContentsTitle {
        padding: 20px 30px 20px 15px;
        margin-top: -20px;
        margin-left: -15px;
    }
}
#Recruit .section_3 .flow-list {
    width: 100%;
    max-width: 1130px;
    margin: 0 auto;
    padding: 0 15px;
}
@media screen and (max-width: 767px) {
    #Recruit .section_3 .flow-list {
        max-width: 1130px;
    }
}
#Recruit .section_3 .flow-list li.flow-item {
    display: flex;
    column-gap: 156px;
    height: 215px;
    background-color: var(--baseColor);
    border-radius: 10px;
    padding: 0 73px;
}
@media screen and (max-width: 767px) {
    #Recruit .section_3 .flow-list li.flow-item {
        column-gap: 20px;
    }
}
#Recruit .section_3 .flow-list li.flow-item:not(:last-of-type) {
    margin-bottom: 60px;
}
@media screen and (max-width: 1000px) {
    #Recruit .section_3 .flow-list li.flow-item {
        align-items: center;
        height: initial;
        padding: 15px 20px;
    }
    #Recruit .section_3 .flow-list li.flow-item:not(:last-of-type) {
        margin-bottom: 20px;
    }
}
#Recruit .section_3 .flow-list li.flow-item .img-cover.icon_1 {
    width: 93px;
    aspect-ratio: 93 / 112;
    margin-top: 12px;
}
#Recruit .section_3 .flow-list li.flow-item .img-cover.icon_2 {
    width: 102px;
    aspect-ratio: 102 / 110;
    margin-top: 2px;
}
#Recruit .section_3 .flow-list li.flow-item .img-cover.icon_3 {
    width: 87px;
    aspect-ratio: 87 / 78;
    margin-top: 2px;
}
#Recruit .section_3 .flow-list li.flow-item .img-cover.icon_4 {
    width: 86px;
    aspect-ratio: 1 / 1;
    margin-top: 5px;
}
#Recruit .section_3 .flow-list li.flow-item .img-cover[class*="icon_"] {
    width: 30%;
    max-width: 80px;
}
#Recruit .section_3 .flow-list li.flow-item .img-cover img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
#Recruit .section_3 .flow-list li.flow-item .text-cover {
    margin-top: 51px;
}
@media screen and (max-width: 767px) {
    #Recruit .section_3 .flow-list li.flow-item .text-cover {
        width: 100%;
        margin-top: 0;
    }
}
#Recruit .section_3 .flow-list li.flow-item .text-cover h5 {
    font-size: 24px;
    font-weight: 400;
    line-height: 1em;
    letter-spacing: 0.05em;
    color: var(--mainTextColor_1);
    margin-bottom: 26px;
}
@media screen and (max-width: 767px) {
    #Recruit .section_3 .flow-list li.flow-item .text-cover h5 {
        font-size: max(1.25vw, 20px);
        margin-bottom: 15px;
    }
}
#Recruit .section_3 .flow-list li.flow-item .text-cover p {
    font-size: 18px;
    font-weight: 400;
    line-height: 2.2em;
    letter-spacing: 0.05em;
    color: var(--mainTextColor_1);
}
@media screen and (max-width: 767px) {
    #Recruit .section_3 .flow-list li.flow-item .text-cover p {
        font-size: max(0.938vw, 16px);
    }
}
#Recruit .section_4 {
    position: relative;
    width: 100%;
    max-width: 1920px;
    margin: 0 auto;
    overflow-x: clip;
    padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
    #Recruit .section_4 {
        padding-bottom: 50px;
    }
}
#Recruit .section_4::before,
#Recruit .section_4::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    z-index: -100;
    width: 100%;
    height: 100%;
    background-color: var(--mainColor_2);
    opacity: 0.2;
}
@media screen and (max-width: 767px) {
    #Recruit .section_4::before,
    #Recruit .section_4::after {
        height: 150%;
        top: -20%;
    }
}
#Recruit .section_4::after {
    z-index: -120;
    background-color: var(--baseColor);
    opacity: 1;
}
#Recruit .section_4 .image-cover {
    top: -282px;
}
#Recruit .section_4 #section-04 .ContentsTitle {
    width: fit-content;
    height: fit-content;
    padding: 57px 236px 90px 0;
    background: url(../image/recruit/img_22.jpg) no-repeat center center / cover;
    margin-top: -113px;
    margin-left: 0;
}
@media screen and (max-width: 767px) {
    #Recruit .section_4 #section-04 .ContentsTitle {
        margin-left: -15px;
        padding: 20px 30px 20px 15px;
        margin-top: -20px;
    }
}
#Recruit .section_4 .section_4-inner .contents-box {
    position: relative;
    width: 100%;
    max-width: 1130px;
    top: -285px;
    margin: 0 auto -285px;
    padding: 0 15px;
}
#Recruit .section_4 .contents-box-4 {
    width: 100%;
    max-width: 1130px;
    margin: 0 auto;
    padding: 0 15px;
}
#Recruit .section_4 .contents-box-4 .contents-box-4-list {
    width: 100%;
    border-radius: 10px;
    overflow: clip;
    background-color: var(--baseColor);
    margin-bottom: 69px;
}
@media screen and (max-width: 767px) {
    #Recruit .section_4 .contents-box-4 .contents-box-4-list {
        margin-bottom: 40px;
    }
}
#Recruit .section_4 .contents-box-4 .contents-box-4-list li {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 48px 67px;
    border-bottom: 0.5px solid #313131;
}
@media screen and (max-width: 767px) {
    #Recruit .section_4 .contents-box-4 .contents-box-4-list li {
        flex-direction: column;
        align-items: flex-start;
        row-gap: 10px;
        padding: 10px 15px;
    }
}
#Recruit .section_4 .contents-box-4 .contents-box-4-list li:last-of-type {
    border-bottom: none;
}
#Recruit .section_4 .contents-box-4 .contents-box-4-list li h4 {
    width: 237px;
    font-size: 24px;
    font-weight: 400;
    line-height: 1em;
    letter-spacing: 0.05em;
    color: var(--mainTextColor_1);
    padding-left: 15px;
}
@media screen and (max-width: 767px) {
    #Recruit .section_4 .contents-box-4 .contents-box-4-list li h4 {
        width: 100%;
        font-size: max(1.25vw, 20px);
        padding-left: 0;
    }
}
#Recruit .section_4 .contents-box-4 .contents-box-4-list li p {
    font-size: 18px;
    font-weight: 400;
    line-height: 2.2em;
    letter-spacing: 0.05em;
    color: var(--mainTextColor_1);
}
@media screen and (max-width: 767px) {
    #Recruit .section_4 .contents-box-4 .contents-box-4-list li p {
        font-size: max(0.938vw, 16px);
    }
}
#Recruit .section_4 .contents-box-4 .button-cover {
    display: grid;
    place-items: center;
    width: 100%;
    max-width: 1130px;
    margin: 0 auto;
}
