/* ------------------------------
    RECRUIT career page
--------------------------------*/
.mo-recruit-career-page .p-recruit {
    margin: 133px 0 0;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-recruit {
        margin: 177px 0 0;
    }
}

/* sp */
@media screen and (max-width: 767px) {
    .mo-recruit-career-page .p-recruit .l-container:has(h2) {
        padding: 0 10px 0 19px;
    }
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-recruit .l-container__inner:has(h2) {
        padding: 0 40px;
    }
}

.mo-recruit-career-page h2.c-hdg-section__inner {
    display: block;
    font-family: var(--font-serif);
    font-weight: 400;
    font-size: 34px;
    line-height: 1.2;
    position: relative;
    z-index: 2;
    letter-spacing: 0;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page h2.c-hdg-section__inner {
        font-size: 80px;
    }
}

.mo-recruit-career-page h2.c-hdg-section__inner span {
    display: inline-block;
}

.mo-recruit-career-page .p-recruit__img {
    position: relative;
    margin: 23px 0 0;
    display: flex;
    flex-direction: column;
    flex-flow: column-reverse;
    background-color: var(--color-white01);
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-recruit__img {
        margin: 57px 0 0;
        justify-content: center;
        width: 100%;
        aspect-ratio: 1600/500;
        overflow: hidden;
    }
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-recruit__img .img {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }
}

.mo-recruit-career-page .p-recruit__img .txt {
    padding: 23px 0 27px;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-recruit__img .txt {
        padding: 0;
        width: 50%;
        position: relative;
        z-index: 1;
    }
}

.mo-recruit-career-page .p-recruit__img .main {
    font-family: var(--font-serif);
    font-size: 20px;
    line-height: 1.5;
    margin: 10px 0 0;
    letter-spacing: 0;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-recruit__img .main {
        font-size: 36px;
        letter-spacing: 0.12em;
        margin: 50px 0 0;
    }
}

.mo-recruit-career-page .p-recruit__img .sub {
    font-family: var(--font-serif);
    font-size: 16px;
    line-height: 1.5;
    padding: 0 0 8px;
    border-bottom: 1px solid var(--color-black01);
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-recruit__img .sub {
        font-size: 24px;
        letter-spacing: .12em;
        padding: 0 0 15px;
    }
}

.mo-recruit-career-page .p-recruit__container {
    background-color: var(--color-white01);
    padding: 8px 0 50px;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-recruit__container {
        padding: 130px 0 180px;
    }
}

.mo-recruit-career-page .p-recruit__container .l-container {
    padding: 0 17.5px;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-recruit__container .l-container {
        padding: 0 30px;
    }
}

/* TABLE */
.mo-recruit-career-page .table {
    width: 100%;
}

.mo-recruit-career-page .table tr {
    width: 100%;
    display: grid;
    grid-template-columns: 70px 1fr;
    gap: 0 23px;
    padding: 17px 0;
    border-bottom: 1px solid var(--color-gray05) !important;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .table tr {
        display: grid;
        grid-template-columns: 300px 1fr;
        gap: 0 30px;
        padding: 39px 0 40px;
    }
}

.mo-recruit-career-page .table .ttl {
    font-weight: 500;
    font-size: 12px;
    letter-spacing: .05em;
    line-height: 2;
    text-align: left;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .table .ttl {
        font-size: 16px;
        letter-spacing: 0;
    }
}

.mo-recruit-career-page .table .txt {
    font-size: 12px;
    letter-spacing: .05em;
    line-height: 2;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .table .txt {
        font-size: 16px;
        letter-spacing: 0;
    }
}

.mo-recruit-career-page .p-recruit__container .link {
    margin: 47px 0 0;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-recruit__container .link {
        margin: 78px 0 0;
    }
}

.mo-recruit-career-page .p-recruit__container .c-btn-primary {
    margin: 0 auto;
}

/* FAQ */
.mo-recruit-career-page .p-faq {
    margin: 55px 0 0;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-faq {
        margin: 172px 0 0;
    }
}

.mo-recruit-career-page .p-faq .c-hdg-section__sub {
    letter-spacing: 0;
}

.mo-recruit-career-page .p-faq .c-hdg-section__inner::after {
    display: none;
}

/* ac */
.mo-recruit-career-page .p-faq .btnList {
    margin: 33px 0 0;
    border-top: 1px solid rgba(68, 64, 63, .08);
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-faq .btnList {
        margin: 70px 0 0;
    }
}

.mo-recruit-career-page .p-faq .btnList .expand {
    padding: 0 11px 0 13px;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-faq .btnList .expand {
        padding: 0 50px;
    }
}

.mo-recruit-career-page .p-faq .btnList .btn {
    position: relative;
    display: flex;
    align-items: center;
    padding: 19px 30px 22px 0;
    width: 100%;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-faq .btnList .btn {
        padding: 40px 50px 38px 0;
    }
}

/* sp */
@media screen and (max-width: 767px) {
    .mo-recruit-career-page .p-faq .btnList .btn .txt {
        display: flex;
        align-items: center;
    }
}

.mo-recruit-career-page .p-faq .btnList .btn .txt,
.mo-recruit-career-page .p-faq .btnList .expand__inner .txt {
    width: 100%;
    font-family: var(--font-serif);
    color: var(--color-black02);
    font-size: 12px;
    font-weight: 400;
    letter-spacing: .05em;
    line-height: 1.5;
    text-align: left;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-faq .btnList .btn .txt,
    .mo-recruit-career-page .p-faq .btnList .expand__inner .txt  {
        font-size: 16px;
        letter-spacing: .06em;
        margin: 16px 0 0;
    }
}

.mo-recruit-career-page .p-faq .btnList .btn__icon-toggle {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%)
}

.mo-recruit-career-page .p-faq .btnList .btn__icon-toggle {
    width: 15px;
    height: 15px
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-faq .btnList .btn__icon-toggle {
        width: 26px;
        height: 26px;
    }
}

.mo-recruit-career-page .p-faq .btnList .btn__icon-toggle:before,
.mo-recruit-career-page .p-faq .btnList .btn__icon-toggle:after {
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 1px;
    content: "";
    background: var(--color-black)
}

.mo-recruit-career-page .p-faq .btnList .expand:has(.open) .btn__icon-toggle::after {
    opacity: 0;
}

.mo-recruit-career-page .p-faq .btnList .btn__icon-toggle:after {
    transform: rotate(90deg)
}

.mo-recruit-career-page .p-faq .btnList .expand {
    border-bottom: 1px solid rgba(68, 64, 63, .08)
}

.mo-recruit-career-page .p-faq .btnList .expand__inner {
    padding: 0 30px 25px 0;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-faq .btnList .expand__inner {
        padding: 0 0 40px 0;
        width: 84%;
    }
}

.mo-recruit-career-page .p-faq .btnList .btn__txt,
    .mo-recruit-career-page .p-faq .btnList .expand__inner {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0 10px;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-faq .btnList .btn__txt,
    .mo-recruit-career-page .p-faq .btnList .expand__inner {
        gap: 0 20px;
    }
}

.mo-recruit-career-page .p-faq .btnList .txt-q,
.mo-recruit-career-page .p-faq .btnList .txt-a {
    font-family: var(--font-en);
    color: var(--color-white01);
    font-weight: 700;
    font-size: 12px;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 5px 0 0;
}

@media screen and (min-width: 768px) {
    .mo-recruit-career-page .p-faq .btnList .txt-q,
    .mo-recruit-career-page .p-faq .btnList .txt-a {
        font-size: 24px;
        width: 60px;
        height: 60px;
        margin: 0;
    }
}

.mo-recruit-career-page .p-faq .btnList .txt-q {
    background-color: var(--color-red01);
}

.mo-recruit-career-page .p-faq .btnList .txt-a {
    background-color: var(--color-black01);
}