:root {
    --page-lr-space: min(120px, 8.3vw);
    --page-lr-space-sp: 5vw;
    --font-mincho: "Shippori Mincho", serif;
    --font-gothic: "Noto Sans JP", sans-serif;
    --font-english: "Cormorant", serif;
    --body-text-color: #0D293B;
    --body-title-color: #325D79;
    --body-font-size: min(1.25vw, 18px);
    --body-font-size-sp: 3.73vw;
    --body-line-height: 1.5;
    --body-letter-spacing: 0.1em;
    --body-background-color: #ffffff;
    --section-inner-width: 1440px;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

* a {
    text-decoration: none;
}

* a:hover {
    opacity: 0.7;
    text-decoration: none;
}

* section {
    width: 100%;
    padding: min(100px, 6.7vw) 0;
    margin: 0;
}

body {
    display: block;
    width: 100%;
    overflow-x: hidden;
    background: var(--body-background-color);
    color: var(--body-text-color);
    font-family: var(--font-gothic);
    letter-spacing: var(--body-letter-spacing);
    font-size: var(--body-font-size);
    line-height: var(--body-line-height);
}

@media screen and (max-width: 767px) {
    body {
        font-weight: normal;
        font-size: var(--body-font-size-sp);
        line-height: 1.5;
    }
}

.section-inner {
    width: 100%;
    max-width: var(--section-inner-width);
    height: 100%;
    margin: 0 auto;
    padding: 0 var(--page-lr-space);
}

@media screen and (max-width: 767px) {
    .section-inner {
        padding: 0 var(--page-lr-space-sp);
    }
}

.link-none {
    pointer-events: none;
}

@media screen and (max-width: 767px) {
    .pc {
        display: none !important;
    }
}

@media screen and (min-width: 768px) {
    .sp {
        display: none !important;
    }
}

.gray-arrow {
    position: relative;
}

.gray-arrow::after {
    content: "";
    display: inline-block;
    width: 3.75vw;
    max-width: 54px;
    height: 3.75vw;
    max-height: 54px;
    background-image: url('../images/recruit/recruit-gray-arrow.png');
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
}

.section-title {
    text-align: center;
    margin-bottom: min(60px, 4vw);
}

.section-title-en {
    font-family: var(--font-english);
    font-size: min(128px, 8.53vw);
    color: var(--body-title-color);
    line-height: 1;
}

.section-title-jp {
    font-family: var(--font-mincho);
    font-size: min(24px, 1.6vw);
    color: var(--body-title-color);
    line-height: 1;
    font-weight: 500;
}

@media screen and (max-width: 767px) {
    .section-title-en {
        font-size: 12vw;
    }

    .section-title-jp {
        font-size: 4vw;
    }

}



/* #recruit-fv FVセクション*/
#recruit-fv {
    padding: 0 !important;
}

#recruit-fv img {
    width: 100%;
    height: auto;
    display: block;
}

/* #recruit-cta CTAセクション */

#recruit-cta .recruit-cta-container {
    width: 100%;
    height: auto;
    padding: min(60px, 4vw) min(80px, 5.33vw);
    background-image: url(../images/recruit/recruit-cta-bg.png);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
}

#recruit-cta .recruit-cta-title {
    font-family: var(--font-english);
    font-size: min(80px, 5.3vw);
    color: #fff;
    margin-bottom: min(40px, 2.7vw);
}

#recruit-cta .recruit-cta-btn-list {
    width: 75%;
    display: flex;
    justify-content: space-around;
}

#recruit-cta .recruit-cta-tel-btn,
#recruit-cta .recruit-cta-entry-btn {
    display: block;
    align-content: center;
}

#recruit-cta .recruit-cta-tel-btn-inner,
#recruit-cta .recruit-cta-entry-btn-inner {
    position: relative;
}

#recruit-cta .recruit-tel-microcopy {
    position: absolute;
    border-radius: 999px;
    color: #fff;
    border: 1px solid #fff;
    padding: min(5px, 0.33vw) min(20px, 1.38vw);
    transform: translateY(-50%);
    top: 0;
    left: min(30px, 2vw);
    font-size: min(20px, 1.33vw);
    font-family: var(--font-mincho);
}

#recruit-cta .recruit-tel-num {
    font-size: min(48px, 3.2vw);
    color: #fff;
    font-style: italic;
    font-weight: 500;
    font-family: var(--font-mincho);
    padding: min(30px, 2vw) min(30px, 2vw) min(10px, 0.67vw);
}

#recruit-cta .recruit-cta-person-image {
    position: absolute;
    bottom: 0;
    right: min(10px, 0.7vw);
    width: 19vw;
    max-width: 280px;
    height: auto;
}

#recruit-cta .recruit-entry-microcopy {
    position: absolute;
    border-radius: 999px;
    color: #fff;
    background: #CE9720;
    padding: min(10px, 0.67vw) min(30px, 2vw);
    transform: translate(-50%, -50%);
    top: 0;
    left: 50%;
    font-size: min(20px, 1.33vw);
    font-family: var(--font-mincho);
    z-index: 1;
    white-space: nowrap;
}

#recruit-cta .recruit-entry-text {
    font-size: min(48px, 3.2vw);
    color: #4F4330;
    background: #fff;
    font-style: italic;
    font-weight: 500;
    font-family: var(--font-mincho);
    padding: min(30px, 2vw) min(100px, 6.67vw) min(10px, 0.67vw) min(80px, 5.33vw);
}

#recruit-cta .recruit-cta-entry-btn-inner .gray-arrow::after {
    transform: translate(0%, -50%);
    top: 61%;
    right: min(20px, 1.33vw);
}

#recruit-cta .recruit-entry-text::before {
    content: "";
    display: inline-block;
    width: 2.8vw;
    max-width: 40px;
    height: 2.8vw;
    max-height: 40px;
    background-image: url('../images/recruit/recruit-icon-cta.png');
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    transform: translate(0%, -50%);
    top: 61%;
    left: min(20px, 1.33vw);
}


/* #recruit-charm CHARMセクション */
@media screen and (min-width: 767px) {
    #recruit-charm .recruit-charm-container {
        display: flex;
        justify-content: space-between;
    }

    #recruit-charm .recruit-charm-left,
    #recruit-charm .recruit-charm-right {
        width: 48%;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
    }
}

#recruit-charm .recruit-charm-item {
    display: block;
    padding: min(20px, 1.33vw);
    overflow: hidden;
    position: relative;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    margin-bottom: min(40px, 2.67vw);
}

#recruit-charm .gray-arrow::after {
    bottom: min(20px, 1.33vw);
    right: min(20px, 1.33vw);
}

#recruit-charm .recruit-charm-left .recruit-charm-item {
    width: 40vw;
    max-width: 580px;
    height: 28vw;
    max-height: 400px;
}

#recruit-charm .recruit-charm-right .recruit-charm-item {
    width: 40vw;
    max-width: 580px;
    height: 18vw;
    max-height: 250px;
}

#recruit-charm .recruit-charm-item-01 {
    background-image: url("../images/recruit/recruit-charm-bg-1.png");
}

#recruit-charm .recruit-charm-item-02 {
    background-image: url("../images/recruit/recruit-charm-bg-2.png");
}

#recruit-charm .recruit-charm-item-03 {
    background-image: url("../images/recruit/recruit-charm-bg-3.png");
}

#recruit-charm .recruit-charm-item-04 {
    background-image: url("../images/recruit/recruit-charm-bg-4.png");
}

#recruit-charm .recruit-charm-item-05 {
    background-image: url("../images/recruit/recruit-charm-bg-5.png");
}

#recruit-charm .recruit-charm-item-num {
    position: absolute;
    font-size: min(200px, 13.33vw);
    font-family: var(--font-english);
    color: rgba(255, 255, 255, 0.2);
    line-height: 1;
}

#recruit-charm .recruit-charm-left .recruit-charm-item-num {
    bottom: max(-2.36vw, -34px);
    left: 0;
}

#recruit-charm .recruit-charm-right .recruit-charm-item-num {
    top: max(-78px, -5.42vw);
    right: 0;
}

#recruit-charm .recruit-charm-item-title-en {
    font-family: var(--font-english);
    font-size: min(64px, 4.27vw);
    color: #fff;
    line-height: 1;
    margin-bottom: min(10px, 0.67vw);
}

#recruit-charm .recruit-charm-item-title-jp {
    font-family: var(--font-mincho);
    font-size: min(24px, 1.6vw);
    color: #fff;
}

@media screen and (max-width: 767px) {

    #recruit-charm .recruit-charm-left .recruit-charm-item,
    #recruit-charm .recruit-charm-right .recruit-charm-item {
        width: 100%;
        height: 36vw;
        max-width: none;
        max-height: none;
    }

    #recruit-charm .recruit-charm-right .recruit-charm-item {
        background-position: top center;
    }

    #recruit-charm .recruit-charm-item-title-en {
        font-size: 8vw;
    }

    #recruit-charm .recruit-charm-item-title-jp {
        font-size: 4vw;
    }

}



/* #recruit-numbers NUMBERSセクション */
#recruit-numbers .recruit-numbers-item-list {
    display: flex;
    justify-content: space-between;
}

#recruit-numbers .recruit-numbers-graph {
    width: 49%;
}

#recruit-numbers .recruit-numbers-data {
    width: 32%;
}

/* @media screen and (min-width: 767px) {
    #recruit-numbers .recruit-numbers-item-list {
        display: flex;
        justify-content: space-between;
    }

    #recruit-numbers .recruit-numbers-graph {
        width: 49%;
    }

    #recruit-numbers .recruit-numbers-data {
        width: 32%;
    }
} */

#recruit-numbers .recruit-numbers-item {
    display: block;
    padding: min(20px, 1.33vw);
    position: relative;
    margin-bottom: min(20px, 1.33vw);
    text-align: center;
    background: #F6F8FA;
}

#recruit-numbers .recruit-numbers-graph-image {
    width: 12.2vw;
    max-width: 175px;
    height: 12.2vw;
    max-height: 175px;
    aspect-ratio: 1 / 1;
    margin-bottom: min(30px, 2vw);
}

#recruit-numbers .recruit-numbers-data-image {
    width: 11.1vw;
    max-width: 160px;
    height: 11.1vw;
    max-height: 160px;
    aspect-ratio: 1 / 1;
    margin-bottom: min(30px, 2vw);
}

#recruit-numbers .recruit-numbers-title {
    font-size: min(24px, 1.6vw);
    font-family: var(--font-mincho);
    color: var(--body-text-color);
    margin-bottom: min(10px, 0.67vw);
    font-weight: 500;
}

#recruit-numbers .recruit-numbers-text {
    font-size: min(68px, 4.53vw);
    font-family: var(--font-mincho);
    color: var(--body-text-color);
    margin-bottom: min(10px, 0.67vw);
    line-height: 1;
}

#recruit-numbers .recruit-numbers-text-space {
    margin: 0 min(10px, 0.67vw);
}

#recruit-numbers .recruit-numbers-text-small {
    font-size: min(24px, 1.6vw);
    margin-left: min(5px, 0.33vw);
    font-weight: 500;
}

@media screen and (max-width: 767px) {
    #recruit-numbers .recruit-numbers-item-list {
        flex-direction: column;
    }

    #recruit-numbers .recruit-numbers-item {
        padding: 5vw;
    }

    #recruit-numbers .recruit-numbers-graph,
    #recruit-numbers .recruit-numbers-data {
        width: 100%;
    }

    #recruit-numbers .recruit-numbers-graph-image,
    #recruit-numbers .recruit-numbers-data-image {
        width: 100%;
        height: auto;
    }

    #recruit-numbers .recruit-numbers-title {
        font-size: 4vw;
    }

    #recruit-numbers .recruit-numbers-text {
        font-size: 8vw;
    }

    #recruit-numbers .recruit-numbers-text-small {
        font-size: 3vw;
    }

}



/* #recruit-message MESSAGEセクション */
#recruit-message {
    position: relative;
}

#recruit-message::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 95%;
    height: 80%;
    background: #F9F5F2;
    z-index: -1;
}

#recruit-message .section-title {
    text-align: left;
}

@media screen and (min-width: 768px) {
    #recruit-message .section-inner {
        display: flex;
        justify-content: space-between;
    }

    #recruit-message .recruit-message-content {
        width: 50%;
    }

    #recruit-message .recruit-message-image {
        width: 45%;
    }
}

#recruit-message .recruit-message-image {
    margin-top: 10%;
}

#recruit-message .recruit-message-image {
    aspect-ratio: 600 / 570;
}

#recruit-message .recruit-message-title {
    font-size: min(32px, 2.13vw);
    font-family: var(--font-mincho);
    color: var(--body-text-color);
    margin-bottom: min(40px, 2.67vw);
    font-weight: 500;
}

#recruit-message .recruit-message-text {
    color: var(--body-text-color);
    line-height: 1.8;
}

@media screen and (max-width: 767px) {
    #recruit-message {
        padding-bottom: 0;
    }

    #recruit-message .recruit-message-content {
        width: 100%;
    }

    #recruit-message .recruit-message-image {
        width: 100%;
        margin-top: 0;
    }

    #recruit-message .recruit-message-title {
        font-size: 5vw;
    }

}



/* #recruit-person PERSONセクション */
#recruit-person {
    background-image: url(../images/recruit/recruit-person-bg.png);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

@media screen and (min-width: 767px) {
    #recruit-person .recruit-person-flex-box {
        display: flex;
        justify-content: center;
    }

    #recruit-person .recruit-person-comment-box {
        width: calc(100% / 3);
    }

    #recruit-person .recruit-person-doctor {
        width: 20%;
    }
}

#recruit-person .recruit-person-doctor {
    margin: max(-120px, -8vw) min(20px, 1.33vw) 0;
}

#recruit-person .recruit-person-comment-box {
    padding: 0 min(20px, 1.33vw) min(60px, 4vw);
    height: fit-content;
    position: relative;
    margin-bottom: min(30px, 2vw);
}

@media screen and (min-width: 767px) {
    #recruit-person .comment-padding-top {
        padding-top: min(80px, 5.33vw);
    }
}

#recruit-person .recruit-person-comment-box::before {
    content: "";
    display: inline-block;
    width: 4.7vw;
    max-width: 68px;
    height: 7.6vw;
    max-height: 110px;
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    bottom: 0;
    right: min(30px, 2vw);
    z-index: 1;
}

#recruit-person .green-person::before {
    background-image: url('../images/recruit/recruit-person-green.png');
}

#recruit-person .yellow-person::before {
    background-image: url('../images/recruit/recruit-person-yellow.png');
}

#recruit-person .red-person::before {
    background-image: url('../images/recruit/recruit-person-red.png');
}

#recruit-person .purple-person::before {
    background-image: url('../images/recruit/recruit-person-purple.png');
}

#recruit-person .recruit-person-comment {
    padding: min(20px, 1.33vw) min(20px, 1.33vw) min(40px, 2.67vw);
    position: relative;
    border: 3px solid #d9d9d9;
    background: #fff;
    height: fit-content;
    color: var(--body-text-color);
    line-height: 1.5;
}

@media screen and (max-width: 767px) {
    #recruit-person .recruit-person-comment-box{
        padding: 5vw 3vw 10vw;
    }

    #recruit-person .recruit-person-comment-box::before{
        width: 9.4vw;
        max-width: none;
        height: 15.2vw;
        max-height: none;
        right: 5vw;
    }

    #recruit-person .recruit-person-flex-box{
        text-align: center;
    }

    #recruit-person .recruit-person-doctor{
        margin: 0 auto;
        width: 50%;
    }
    
}




/* #recruit-feature FEATUREセクション */
#recruit-feature {
    background-image: url(../images/recruit/recruit-feature-bg.png);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

@media screen and (min-width: 767px) {
    #recruit-feature .recruit-feature-item {
        display: flex;
        justify-content: space-between;
    }

    #recruit-feature .recruit-feature-item-box div:nth-child(odd) {
        flex-direction: row-reverse;
    }

    #recruit-feature .recruit-feature-item-image,
    #recruit-feature .recruit-feature-text-box {
        width: 50%;
    }
}

#recruit-feature .recruit-feature-item {
    margin-bottom: min(60px, 4vw);
}

#recruit-feature .recruit-feature-item-image {
    aspect-ratio: 600 / 400;
}

#recruit-feature .recruit-feature-text-box {
    padding: min(20px, 1.33vw) min(30px, 2vw);
    align-content: center;
    text-align: center;
}

#recruit-feature .recruit-feature-num {
    font-size: min(128px, 8.53vw);
    font-family: var(--font-english);
    color: var(--body-title-color);
    line-height: 1.2;
}

#recruit-feature .recruit-feature-title {
    font-family: var(--font-mincho);
    font-size: min(32px, 2.13vw);
    color: var(--body-text-color);
    line-height: 1.2;
    font-weight: 500;
    margin-bottom: min(40px, 2.67vw);
}

#recruit-feature .recruit-feature-text {
    font-size: min(18px, 1.2vw);
    color: var(--body-text-color);
    line-height: 1.5;
    text-align: left;
}

#recruit-feature .yellow-num {
    color: #C1A712;
}

@media screen and (max-width: 767px){
    #recruit-feature .recruit-feature-num{
        font-size: 20vw;
    }

    #recruit-feature .recruit-feature-title{
        font-size: 5vw;
    }

    #recruit-feature .recruit-feature-text{
        font-size: 3.73vw;
    }
}


/* #recruit-jobs JOBSセクション */

/*タブ切り替え全体のスタイル*/
#recruit-jobs .tabs {
    background-color: #fff;
    width: 100%;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

/*タブのスタイル*/
#recruit-jobs .tab_item {
    width: calc(94%/3);
    aspect-ratio: 380 / 72;
    font-size: min(32px, 2.2vw);
    text-align: center;
    color: #fff;
    font-family: var(--font-mincho);
    font-weight: 500;
    display: block;
    float: left;
    text-align: center;
    align-content: center;
    transition: all 0.2s ease;
    position: relative;
}

#recruit-jobs .tab_item::before {
    content: "";
    display: inline-block;
    width: 1.1vw;
    max-width: 16px;
    height: 0.7vw;
    max-height: 10px;
    background: #fff;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: min(20px, 1.33vw);
}

#recruit-jobs .tab_item-red {
    background-color: #EE8080;
}

#recruit-jobs .tab_item-green {
    background-color: #6BBFA0;
}

#recruit-jobs .tab_item-blue {
    background-color: #52B1CA;
}

#recruit-jobs .tab_item:hover {
    opacity: 0.75;
}

/*ラジオボタンを全て消す*/
input[name="tab_item"] {
    display: none;
}

/*タブ切り替えの中身のスタイル*/
#recruit-jobs .tab_content {
    display: none;
    padding: min(50px, 3.33vw);
    clear: both;
    overflow: hidden;
    width: 100%;
    margin-top: min(30px, 2vw);
    background-color: #F9F5F2;
}


/*選択されているタブのコンテンツのみを表示*/
#tab_01:checked~#tab_01_content,
#tab_02:checked~#tab_02_content,
#tab_03:checked~#tab_03_content {
    display: block;
}

/*選択されているタブのスタイルを変える*/
#recruit-jobs .tabs input:checked+.tab_item {
    border: 3px solid #6D9184;
}

#recruit-jobs .tabs input:checked+.tab_item::before {
    clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

/* #recruit-jobs .tabs input:checked+.tab_item::after{
    content: "";
    display: inline-block;
    width: 1.1vw;
    max-width: 16px;
    height: 0.7vw;
    max-height: 10px;
    background: #fff;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    transform: translate(-50%, 100%);
    position: absolute;
    bottom: 0;
    left: 50%;
} */

#recruit-jobs .tab_content_container {
    background: #fff;
    padding: min(50px, 3.33vw);
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
}

#recruit-jobs .tab_content_title {
    text-align: center;
    font-size: min(32px, 2.13vw);
    font-family: var(--font-mincho);
    color: var(--body-text-color);
    margin-bottom: min(50px, 3.33vw);
    font-weight: 500;
}

#recruit-jobs .tab_content_dl {
    border: 2px solid #D4D4D4;
    font-family: var(--font-gothic);
    font-size: min(18px, 1.2vw);
}

#recruit-jobs .tab_content_text dl:nth-child(n+2) {
    border-top: none;
}

#recruit-jobs .tab_content_dt {
    padding: min(20px, 1.33vw);
    align-content: center;
    color: var(--body-text-color);
}

#recruit-jobs #tab_01_content .tab_content_dt {
    background: #f8c3c3;
}

#recruit-jobs #tab_02_content .tab_content_dt {
    background: #BCEDDB;
}

#recruit-jobs #tab_03_content .tab_content_dt {
    background: #BEE0F2;
}

#recruit-jobs .tab_content_dd {
    padding: min(20px, 1.33vw);
    align-content: center;
    color: var(--body-text-color);
}

@media screen and (min-width: 767px) {
    #recruit-jobs .tab_content_dl {
        display: flex;
    }

    #recruit-jobs .tab_content_dt {
        border-right: 2px solid #D4D4D4;
        width: 30%;
    }

    #recruit-jobs .tab_content_dd {
        width: 70%;
    }
}

@media screen and (max-width: 767px) {
    #recruit-jobs .tab_content_dt {
        border-bottom: 2px solid #D4D4D4;
    }

    #recruit-jobs .tab_item{
        font-size: 4vw;
        width: 100%;
        aspect-ratio: 6 / 1;
        margin-bottom: 3vw;
    }

    #recruit-jobs .tab_content_title{
        font-size: 5vw;
    }

    #recruit-jobs .tab_content_dl{
        font-size: 3.2vw;
    }
}




/* #recruit-flow flowセクション */
#recruit-flow .recruit-flow-image {
    width: 100%;
}

@media screen and (max-width: 767px) {
    #recruit-flow .section-inner{
        text-align: center;
    }

    #recruit-flow .recruit-flow-image {
        width: 50%;
        margin: 0 auto;
    }
}