@charset "utf-8";

/* mv */
.mv {
    position: relative;
    overflow: hidden;
}
.mv_main {
    position: relative;
    z-index: 2;
}
.mv_ttl {
    font-weight: 900;
}
.mv_subttl {
    font-weight: 900;
}
.mv_subttl_jp {
    font-weight: 700;
}
.mv .content_inner {
    position: relative;
}
.mv_x {
    position: absolute;
    height: auto;
}
.blur_1 {
    filter: blur(1px);
}
.blur_2 {
    filter: blur(5px);
}
.anim_txt_cover {
    overflow: hidden;
    display: block;
}
.anim_txt_inner {
    display: block;
}
@media (min-width: 769px) {
    .mv {
        height: min(795rem, 795px);
        margin-top: -140rem;
    }
    .mv .content_inner {
        max-width: min(1440rem, 1440px);
        padding-inline: min(140rem, 140px);
    }
    .mv_main {
        margin-top: min(412rem, 412px);
    }
    .mv_ttl {
        font-size: min(100rem, 100px);
        line-height: 0.95;
        letter-spacing: calc(5 / 100 * 1em);
    }
    .mv_subttl {
        font-size: min(24rem, 24px);
        line-height: 1.2;
        letter-spacing: calc(1.2 / 24 * 1em);
        margin-top: 12px;
        margin-left: 10px;
    }
    .mv_subttl_jp {
        font-size: min(16rem, 16px);
        line-height: 1.77;
        letter-spacing: calc(-0.48 / 16 * 1em);
        margin-top: 4px;
        margin-left: 9px;
    }
    .mv_1 {
        top: min(254rem, 254px);
        left: calc(50% - min(792rem, 792px));
        width: calc(min(376rem, 376px) / 2);
    }

    .mv_2 {
        top: min(-57rem, -57px);
        left: calc(50% - min(584rem, 584px));
        width: calc(min(376rem, 376px) / 2);
    }

    .mv_3 {
        top: min(173rem, 173px);
        left: calc(50% - min(400rem, 400px));
        width: calc(min(220rem, 220px) / 2);
    }

    .mv_4 {
        top: min(103rem, 103px);
        left: calc(50% - min(215rem, 215px));
        width: calc(min(720rem, 720px) / 2);
    }

    .mv_5 {
        top: min(566rem, 566px);
        left: calc(50% - min(34rem, 34px));
        width: calc(min(220rem, 220px) / 2);
    }

    .mv_6 {
        top: min(-30rem, -30px);
        left: calc(50% + min(240rem, 240px));
        width: calc(min(220rem, 220px) / 2);
    }

    .mv_7 {
        top: min(-54rem, -54px);
        left: calc(50% + min(432rem, 432px));
        width: calc(min(720rem, 720px) / 2);
    }

    .mv_8 {
        top: min(317rem, 317px);
        left: calc(50% + min(183rem, 183px));
        width: calc(min(720rem, 720px) / 2);
    }

    .mv_9 {
        top: min(613rem, 613px);
        left: calc(50% + min(605rem, 605px));
        width: calc(min(360rem, 360px) / 2);
    }
}
@media (max-width: 768px) {
    .mv {
        height: 725rem;
        margin-top: -60rem;
    }
    .mv_main {
        margin-top: 459rem;
    }
    .mv_ttl {
        font-size: 54rem;
        line-height: 0.92;
        letter-spacing: calc(2.7 / 54 * 1em);
    }
    .mv_subttl {
        font-size: 20rem;
        line-height: 1.2;
        letter-spacing: calc(1 / 20 * 1em);
        margin-top: 8rem;
    }
    .mv_subttl_jp {
        font-size: 14rem;
        line-height: 1.77;
        letter-spacing: calc(-0.42 / 14 * 1em);
        margin-top: 3rem;
    }
    .mv_1 {
        top: 356rem;
        left: -50rem;
        width: 106rem;
    }
    .mv_2 {
        top: 18rem;
        left: 25rem;
        width: 110rem;
    }
    .mv_3 {
        top: 123rem;
        left: 143rem;
        width: 33rem;
    }
    .mv_4 {
        top: 185rem;
        left: 17rem;
        width: 183rem;
    }
    .mv_5 {
        top: 601rem;
        left: -26rem;
        width: 45rem;
    }
    .mv_6 {
        top: 238rem;
        left: 310rem;
        width: 40rem;
    }
    .mv_7 {
        top: -14rem;
        left: 204rem;
        width: 184rem;
    }
    .mv_8 {
        top: 308rem;
        left: 234rem;
        width: 183rem;
    }
    .mv_9 {
        top: 619rem;
        left: 244rem;
        width: 104rem;
    }
}
.animation_ready .anim_txt_inner {
    transform: translateY(100%);
}
.animation_loaded .anim_txt_inner {
    transition: transform 0.6s;
    transform: translateY(0%);
}
.animation_loaded .anim_1 {
    transition-delay: 0.4s;
}
.animation_loaded .anim_2 {
    transition-delay: 0.6s;
}
.animation_loaded .anim_3 {
    transition-delay: 0.8s;
}
.animation_loaded .anim_4 {
    transition-delay: 1s;
}
.animation_ready .mv_x {
    scale: 0;
}
.animation_loaded .mv_x {
    transition: scale 0.8s;
    scale: 1;
}
.animation_loaded .blur_0 {
    transition-delay: 1.2s;
}
.animation_loaded .blur_1 {
    transition-delay: 1.4s;
}
.animation_loaded .blur_2 {
    transition-delay: 1.6s;
}

/* career_vision common */
.career_content {
    display: flex;
    flex-direction: column;
}
.career_box {
    background: var(--color-white);
}
.career_box_ttl {
    font-weight: 700;
    border-bottom: 2rem solid rgba(0, 0, 0, 0.1);
}
@media (min-width: 769px) {
    .career_content {
        gap: 80rem;
    }
    .career_box {
        padding: 60rem 45rem;
    }
    .career_box_ttl {
        font-size: 32px;
        line-height: 1.3;
        padding-bottom: 30rem;
    }
}
@media (max-width: 768px) {
    .career_content {
        gap: 70rem;
    }
    .career_box {
        padding: 50rem 30rem;
    }
    .career_box_ttl {
        font-size: 24rem;
        line-height: 1.3;
        padding-bottom: 20rem;
    }
}

/* career_anchor */
.career_anchor_list {
    display: flex;
}
.career_anchor_list a {
    display: flex;
    align-items: center;
    width: 100%;
    color: var(--color-black);
    border-right: 2rem solid rgba(34, 34, 34, 0.1);
}
.career_anchor_txt {
    line-height: 1.77;
}
.career_anchor_arrow {
    width: 13rem;
}
@media (min-width: 769px) {
    .career_anchor_list {
        max-width: 813px;
        margin-inline: auto;
    }
    .career_anchor_list li {
        width: 100%;
    }
    .career_anchor_list a {
        justify-content: center;
        gap: 16rem;
        padding: 3rem 10rem;
    }
    .career_anchor_list li:first-child a {
        border-left: 2rem solid rgba(34, 34, 34, 0.1);
    }
    .career_anchor_txt {
        font-size: 18rem;
    }
}
@media (max-width: 768px) {
    .career_anchor_list {
        flex-wrap: wrap;
        gap: 20rem 0;
    }
    .career_anchor_list li {
        width: 50%;
    }
    .career_anchor_list a {
        padding-inline: 15rem;
        justify-content: space-between;
    }
    .career_anchor_list li:nth-child(odd) a {
        border-left: 2rem solid rgba(34, 34, 34, 0.1);
    }
    .career_anchor_txt {
        font-size: 14rem;
    }
}

/* about */
.about_note {
    line-height: 1.77;
    color: var(--color-red);
    text-align: center;
}
.about_left_pop {
    line-height: 1.6;
}
.about_left_txt {
    font-weight: 400;
    line-height: 1.77;
}
@media (min-width: 769px) {
    .about {
        margin-top: 122rem;
    }
    .about_note {
        font-size: 20px;
        margin-top: 42rem;
    }
    .about_left_pop {
        font-size: 28px;
        margin-top: 24rem;
    }
    .about_left_txt {
        font-size: 16px;
        margin-top: 40rem;
    }
}
@media (max-width: 768px) {
    .about {
        flex-direction: column;
        margin-top: 80rem;
    }
    .about_note {
        font-size: 16rem;
        margin-top: 58rem;
    }
    .about_left_pop {
        font-size: 24rem;
        margin-top: 30rem;
    }
    .about_left_txt {
        font-size: 16rem;
        margin-top: 35rem;
    }
}

.step_content {
    max-width: 950px;
    width: 100%;
    margin-inline: auto;
}
.step_block {
    display: flex;
    justify-content: space-between;
}
.step1 {
    --step-color: rgba(240, 211, 152, 0.1);
}
.step2 {
    --step-color: rgba(240, 211, 152, 0.2);
}
.step3 {
    --step-color: rgba(240, 211, 152, 0.35);
}
.step4 {
    --step-color: rgba(240, 211, 152, 0.46);
}
.step_arrow {
    background-color: var(--step-color);
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}
.step_block:has(+ .step_block) .step_arrow::after {
    content: '';
    display: block;
    width: 100%;
    position: absolute;
    top: 100%;
    left: 0;
    clip-path: polygon(0% 0%, 100% 0%, 50% 100%);
    background-color: var(--step-color);
}
.step_arrow_txt {
    text-align: center;
}
.step_txt_block {
    width: 100%;
    position: relative;
}
.step_label {
    display: flex;
}
.step_label_num {
    color: var(--color-red);
    line-height: 1.51;
    letter-spacing: 0.05em;
}
.step_label_txt {
    line-height: 1.8;
}
.step_txt {
    font-weight: 400;
    line-height: 1.8;
}
.step_txt a {
    color: var(--color-red);
    text-decoration: underline;
}
.step_txt_block::after {
    content: '';
    display: block;
    rotate: 45deg;
    position: absolute;
    left: 0;
    right: 0;
    margin-inline: auto;
    background-color: var(--color-white);
}
.step_content .step_block:last-child .step_txt_block:last-child::after {
    display: none;
}
@media (max-width: 1000px) {
    .step_arrow_txt {
        writing-mode: vertical-lr;
        font-size: 14px;
    }
    .step_arrow_txt_num {
        text-combine-upright: all;
    }
}
@media (min-width: 769px) {
    .step_content {
        margin-top: 40rem;
    }
    .step_block {
        gap: 60px;
    }
    .step_arrow {
        width: 225px;
        padding-top: 18px;
    }
    .step_block + .step_block .step_arrow {
        clip-path: polygon(0% 0%, 0% 10px, 50% 45px, 100% 10px, 100% 0%, 100% calc(100% + 35px), 0% calc(100% + 35px));
        padding-top: 48px;
    }
    .step_block:has(+ .step_block) .step_arrow::after {
        height: 35px;
    }
    .step_arrow_txt {
        font-size: 18px;
        line-height: 1.8;
    }
    .step_txt_area {
        width: 665px;
    }
    .step_block + .step_block .step_txt_area,
    .step_txt_block + .step_txt_block {
        padding-top: 30px;
    }
    .step_txt_block {
        padding: 0 20px 30px 4px;
        border-bottom: 1px solid var(--color-red);
    }
    .step_label {
        align-items: center;
        gap: 20px;
    }
    .step_label_num {
        font-size: 16px;
    }
    .step_label_txt {
        font-size: 24px;
    }
    .step_txt {
        font-size: 14px;
    }
    .step_txt_block::after {
        width: 16px;
        height: 16px;
        border-top: 1px solid transparent;
        border-left: 1px solid transparent;
        border-right: 1px solid var(--color-red);
        border-bottom: 1px solid var(--color-red);
        top: calc(100% - 8px);
    }
}
@media (max-width: 768px) {
    .step_content {
        margin-top: 20rem;
    }
    .step_block {
        gap: 20rem;
    }
    .step_arrow {
        width: 60rem;
    }
    .step_block + .step_block .step_arrow {
        clip-path: polygon(
            0% 0%,
            0% 6rem,
            50% 20rem,
            100% 10px,
            100% 0%,
            100% calc(100% + 14rem),
            0% calc(100% + 14rem)
        );
        padding-top: 10rem;
    }
    .step_block:has(+ .step_block) .step_arrow::after {
        height: 14rem;
    }
    .step_arrow_txt {
        font-size: 13rem;
        line-height: 1.16;
    }
    .step_txt_area {
        width: 207rem;
    }
    .step_block + .step_block .step_txt_area,
    .step_txt_block + .step_txt_block {
        padding-top: 25rem;
    }
    .step_txt_block {
        padding-bottom: 20rem;
        border-bottom: 1px solid var(--color-red);
    }
    .step_label {
        flex-direction: column;
    }
    .step_label_num {
        font-size: 11rem;
    }
    .step_label_txt {
        font-size: 18rem;
    }
    .step_txt {
        font-size: 12rem;
    }
    .step_txt_block::after {
        width: 16px;
        height: 16px;
        border-top: 1px solid transparent;
        border-left: 1px solid transparent;
        border-right: 1px solid var(--color-red);
        border-bottom: 1px solid var(--color-red);
        top: calc(100% - 8px);
    }
}

/* course */
.course_flex {
    display: flex;
    justify-content: space-between;
}
.course_tag {
    line-height: 1.8;
    color: var(--color-white);
    background-color: var(--color-red);
    display: inline-block;
    word-break: keep-all;
}
.course_deadline_ttl {
    color: var(--color-red);
    font-weight: 700;
    line-height: 1.8;
}
.course_deadline {
    font-weight: 700;
    line-height: 1.8;
}
.course_list {
    display: flex;
    flex-direction: column;
}
.course_list li {
    line-height: 1.8;
    position: relative;
}
.course_list li::before {
    content: '';
    display: block;
    background-color: var(--color-red);
    position: absolute;
    border-radius: 50%;
}
@media (min-width: 769px) {
    .course_flex {
        margin-top: 30rem;
    }
    .course_flex_block:has(+ .course_flex_block) {
        padding-right: 40px;
    }
    .course_tag {
        font-size: 18px;
        padding: 4px 10px;
    }
    .course_deadline_ttl {
        font-size: 16px;
        margin-top: 22rem;
    }
    .course_deadline {
        font-size: 20px;
    }
    .course_flex_block {
        width: 50%;
    }
    .course_list {
        gap: 4rem;
    }
    .course_list li {
        padding-left: 20px;
        font-size: 16px;
    }
    .course_list li::before {
        top: 12px;
        left: 0;
        width: 5px;
        height: 5px;
    }
}
@media (max-width: 768px) {
    .course_flex {
        flex-direction: column;
        gap: 36rem;
        margin-top: 20rem;
    }
    .course_tag {
        font-size: 20rem;
        padding: 4rem 10rem;
    }
    .course_deadline_ttl {
        font-size: 14rem;
        margin-top: 10rem;
    }
    .course_deadline {
        font-size: 20rem;
    }
    .course_list {
        gap: 4rem;
    }
    .course_list li {
        padding-left: 35rem;
        font-size: 14rem;
    }
    .course_list li::before {
        top: 10rem;
        left: 0;
        width: 5rem;
        height: 5rem;
        margin-left: 10rem;
    }
}

/* position */
.tab_content {
    text-align: center;
    width: 100%;
    box-sizing: border-box;
}
.coming_soon {
    text-align: center;
    font-weight: 700;
}
@media (min-width: 769px) {
    .coming_soon {
        font-size: 44px;
        line-height: 1.3;
        padding-block: 58rem 10rem;
    }
}
@media (max-width: 768px) {
    .coming_soon {
        font-size: 38rem;
        line-height: 1.3;
        padding-block: 38rem 20rem;
    }
}

@media (min-width: 769px) {
    .link_area {
        margin-top: 195rem;
    }
    .btn_back_wrap {
        margin-top: 120rem;
    }
}
@media (max-width: 768px) {
    .link_area {
        margin-top: 120rem;
    }
    .btn_back_wrap {
        margin-top: 120rem;
    }
}

/* tab_link_set */
.tab_link_set > dt {
    text-align: center;
    font-weight: 700;
    line-height: 1.3;
}
.tab_link_list {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
}
.tab_link_list > li a {
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--color-black);
    background: linear-gradient(180deg, #f6f5f4 0%, #f3eee9 100%);
}
.tab_link_item_division {
    text-align: center;
    font-weight: 700;
    line-height: 1.3;
}
.tab_link_item_name {
    text-align: center;
    font-weight: 400;
    line-height: 1.3;
}
@media (min-width: 769px) {
    .tab_link_set {
        margin-top: 60rem;
    }
    .tab_link_set + .tab_link_set {
        margin-top: 80rem;
    }
    .tab_link_set > dt {
        font-size: 24px;
    }
    .tab_link_set > dd {
        margin-top: 40rem;
    }
    .tab_link_list {
        gap: 19rem;
    }
    .tab_link_list > li {
        width: calc((100% - 19rem * 3) / 4);
    }
    .tab_link_list > li a {
        height: 105rem;
        border-radius: 4rem;
    }
    .tab_link_item_division {
        font-size: 16rem;
    }
    .tab_link_item_name {
        font-size: 13rem;
        margin-top: 11rem;
    }
}
@media (max-width: 768px) {
    .tab_link_set {
        margin-top: 40rem;
    }
    .tab_link_set + .tab_link_set {
        margin-top: 60rem;
    }
    .tab_link_set > dt {
        font-size: 18rem;
    }
    .tab_link_set > dd {
        margin-top: 20rem;
    }
    .tab_link_list {
        gap: 20rem;
    }
    .tab_link_list > li {
        width: 100%;
    }
    .tab_link_list > li a {
        height: 85rem;
        border-radius: 4rem;
    }
    .tab_link_item_division {
        font-size: 14rem;
    }
    .tab_link_item_name {
        font-size: 12rem;
        margin-top: 8rem;
    }
}
@media (min-width: 769px) {
    @media (hover: hover) {
        .tab_link_list > li a:hover {
            border: 2rem solid var(--color-red);
            color: var(--color-red);
        }
    }
}
