/* --------------------
 Recruit
-------------------- */
.com-page-head:before {
    background-image: url(../images/pages/recruit/recruit-page-head.webp);
}

.overview {
    margin: 0 0 32vw;
    padding: 16vw 0 0;
}

@media (min-width: 768px) {
    .overview {
        margin: 0 0 150px;
        padding: 150px 0 0;
    }
}

.overview-container {
    position: relative;
}

@media (min-width: 1240px) {
    .overview-container {
        min-height: 460px;
        padding: 40px 0 0;
    }
}

.overview-container-inner {
    margin: 0 auto;
    padding: 0 var(--c-pad);
    width: 100%;
}

@media (min-width: 1240px) {
    .overview-container-inner {
        padding: 0 250px;
    }
}

.overview__title {
    color: var(--color-burnt-orange);
    font-size: 4.784vw;
    font-weight: 700;
    line-height: 1.4;
    margin: 0 0 10.6666666667vw;
    text-align: center;
}

@media (min-width: 768px) {
    .overview__title {
        font-size: var(--fs23);
        margin: 0 0 50px;
    }
}

.overview__subtitle {
    font-size: 5.824vw;
    font-weight: 700;
    line-height: 1.6;
    margin: 0 0 10.6666666667vw;
    text-align: center;
}

.overview__subtitle:has(wbr) {
    overflow-wrap: anywhere;
    word-break: keep-all;
}

@media (min-width: 768px) {
    .overview__subtitle {
        font-size: var(--fs28);
        margin: 0 0 45px;
    }
}

@media (min-width: 1240px) {
    .overview__subtitle {
        white-space: nowrap;
    }
}

.overview__content {
    margin: 0 0 13.3333333333vw;
}

@media (min-width: 768px) {
    .overview__content {
        margin: 0 0 60px;
    }
}

@media (min-width: 1240px) {
    .overview__content {
        margin-bottom: 0;
    }
}

.overview__content p {
    font-size: 3.744vw;
    letter-spacing: 0.05em;
    line-height: 1.66;
    margin: 0 0 1.75em;
    text-align: center;
}

@media (min-width: 768px) {
    .overview__content p {
        font-size: var(--fs18);
    }
}

.overview__content p:last-child {
    margin-bottom: 0;
}

.overview__gallery {
    align-items: flex-start;
    display: flex;
    flex-flow: row nowrap;
    justify-content: center;
    pointer-events: none;
    width: 100cqw;
}

@media (min-width: 1240px) {
    .overview__gallery {
        justify-content: space-between;
        left: 50%;
        min-width: 1500px;
        position: absolute;
        right: auto;
        top: 0;
        transform: translateX(-50%);
    }
}

.overview__gallery__item {
    flex: 0 1 auto;
}

@media (min-width: 1240px) {
    .overview__gallery__item {
        flex: 0 1 360px;
    }
}

@media (max-width: 767px) {
    .overview__gallery__item img {
        width: 100%;
    }
}

.job {
    margin: 0 0 32vw;
}

@media (min-width: 768px) {
    .job {
        margin: 0 0 150px;
    }
}

.job-container {
    margin: 0 auto;
    max-width: calc(var(--container-width) + var(--c-pad)*2);
    padding: 0 var(--c-pad);
    width: 100%;
}

.job__title {
    color: var(--color-burnt-orange);
    font-size: 4.784vw;
    font-weight: 700;
    line-height: 1.4;
    margin: 0 0 10.6666666667vw;
    text-align: center;
}

@media (min-width: 768px) {
    .job__title {
        font-size: var(--fs23);
        margin: 0 0 50px;
    }
}

.job__item-wrapper {
    align-items: stretch;
    display: flex;
    flex-flow: row wrap;
    gap: 10.6666666667vw 8vw;
    justify-content: flex-start;
    margin: 0 0 16vw;
}

@media (min-width: 768px) {
    .job__item-wrapper {
        gap: 60px 30px;
        margin: 0 0 40px;
    }
}

@media (min-width: 992px) {
    .job__item-wrapper {
        gap: 60px 75px;
    }
}

.job__item {
    color: inherit;
    display: block;
    flex: 0 0 100%;
    text-decoration: none;
    transition: opacity var(--duration) var(--cubic) 0s;
}

@media (min-width: 768px) {
    .job__item {
        flex: 0 0 calc(33.33333% - 20px);
    }
}

@media (min-width: 992px) {
    .job__item {
        flex: 0 0 calc(33.33333% - 50px);
    }
}

.job__item__fig {
    border-radius: 4.2666666667vw;
    margin: 0 0 4.2666666667vw;
    overflow: hidden;
}

@media (min-width: 768px) {
    .job__item__fig {
        border-radius: 20px;
        margin: 0 0 20px;
    }
}

.job__item__fig img {
    aspect-ratio: 700/500;
    height: auto;
    object-fit: cover;
    object-position: center;
    transition: transform var(--duration) var(--cubic) 0s;
    width: 100%;
}

.job__item__title {
    color: var(--color-navy-blue);
    font-size: 4.2666666667vw;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.66;
    margin: 0 0 4.2666666667vw;
    text-align: center;
}

@media (min-width: 768px) {
    .job__item__title {
        font-size: var(--fs18);
        margin: 0 0 20px;
    }
}

.job__item__content p {
    font-size: 3.744vw;
    letter-spacing: 0.05em;
    line-height: 1.66;
    margin: 0;
}

@media (min-width: 768px) {
    .job__item__content p {
        font-size: var(--fs18);
    }
}

.info {
    margin: 0 0 32vw;
}

@media (min-width: 768px) {
    .info {
        margin: 0 0 200px;
    }
}

.info-container {
    margin: 0 auto;
    max-width: calc(var(--container-width) + var(--c-pad)*2);
    padding: 0 var(--c-pad);
    width: 100%;
}

.info__title {
    color: var(--color-burnt-orange);
    font-size: 4.784vw;
    font-weight: 700;
    line-height: 1.4;
    margin: 0 0 10.6666666667vw;
    text-align: center;
}

@media (min-width: 768px) {
    .info__title {
        font-size: var(--fs23);
        margin: 0 0 55px;
    }
}

.info__table-wrapper {
    margin: -2.6666666667vw -2.6666666667vw 10.6666666667vw;
}

@media (min-width: 768px) {
    .info__table-wrapper {
        margin: -10px -10px 40px;
    }
}

.info__table {
    border: none;
    border-collapse: separate;
    border-spacing: 2.6666666667vw;
    width: 100%;
}

@media (min-width: 768px) {
    .info__table {
        border-spacing: 10px;
    }
}

.info__table > tbody > tr > th, .info__table > tbody > tr > td {
    border-radius: 1.3333333333vw;
    font-size: 3.7333333333vw;
    letter-spacing: 0.05em;
    line-height: 1.66;
    margin: 0;
    vertical-align: middle;
    width: auto;
}

@media (min-width: 768px) {
    .info__table > tbody > tr > th, .info__table > tbody > tr > td {
        border-radius: 5px;
        font-size: var(--fs18);
    }
}

.info__table > tbody > tr > th {
    background-color: var(--color-navy-blue);
    color: var(--color-white);
    padding: 2.1333333333vw 2.1333333333vw;
    width: 26.6666666667vw;
}

@media (min-width: 768px) {
    .info__table > tbody > tr > th {
        padding: 8px 20px;
        width: 295px;
    }
}

.info__table > tbody > tr > td {
    background-color: #f2f3f1;
    padding: 2.1333333333vw 3.2vw;
    word-break: break-all;
}

@media (min-width: 768px) {
    .info__table > tbody > tr > td {
        padding: 8px 20px;
    }
}