@charset "utf-8";

.sub {
    padding-top: 0;
}
.requirements_red {
    color: var(--color-red);
}
@media (min-width: 769px) {
    .section_ttl_en_pc {
        line-height: 1.2;
        padding-block: 8rem;
    }
    .section_ttl_en .section_ttl_en_pc:nth-of-type(1) {
        margin-bottom: -16rem;
    }
    .links_list {
        margin-top: 180rem;
    }
    .btn_back_wrap {
        margin-top: 160rem;
    }
}
@media (max-width: 768px) {
    .section_ttl_en {
        font-size: 40rem;
    }
    .section_ttl_en_sp {
        padding: 5rem 8rem 8rem 10rem;
        letter-spacing: 0;
    }
    .section_ttl_en_sp + br + .section_ttl_en_sp {
        margin-top: -8rem;
    }
    .links_list {
        margin-top: 140rem;
    }
    .btn_back_wrap {
        margin-top: 120rem;
    }
}

/* mv */
.mv {
    width: 100%;
}
@media (min-width: 769px) {
    .mv {
        height: 447rem;
        display: flex;
        align-items: center;
    }
}
@media (max-width: 768px) {
    .mv {
        position: relative;
        height: 470rem;
    }
    .mv .inner {
        height: 100%;
    }
    .section_ttl {
        position: absolute;
        left: 22rem;
        top: 80rem;
    }
}

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

/* requirements_cont */
.requirements_cont {
    display: flex;
    flex-direction: column;
}
.requirements_box {
    position: relative;
    background-color: var(--color-white);
}
.requirements_box_ttl {
    line-height: 1.3;
}
.requirements_box_flex {
    display: flex;
}
.requirements_cont_txt_cap {
    position: absolute;
    left: 0;
    color: var(--color-red);
    font-weight: 700;
    width: 100%;
    text-align: center;
}
@media (min-width: 769px) {
    .requirements_cont {
        margin-top: 100rem;
        gap: 80rem;
    }
    .requirements_box {
        padding: 50px 45px;
    }
    .requirements_box_ttl {
        font-size: 32px;
        padding-bottom: 30px;
        border-bottom: 2px solid rgba(34, 34, 34, 0.1);
    }
    .requirements_box_cont {
        margin-top: 40px;
    }
    .requirements_box_flex_block {
        width: 50%;
    }
    .requirements_box_flex_block:has(+ .requirements_box_flex_block) {
        padding-right: 40px;
    }
    .requirements_cont_txt_cap {
        top: -2.5em;
        font-size: 20px;
        line-height: 1.77;
    }
}
@media (max-width: 768px) {
    .requirements_cont {
        margin-top: 50rem;
        gap: 70rem;
    }
    .requirements_box {
        padding: 50rem 30rem;
    }
    .requirements_box_ttl {
        font-size: 24rem;
        padding-bottom: 20rem;
        border-bottom: 2rem solid rgba(34, 34, 34, 0.1);
    }
    .requirements_box_cont {
        margin-top: 20rem;
    }
    .requirements_box_flex {
        flex-direction: column;
        gap: 0rem;
    }
    .requirements_cont_txt_cap {
        top: -2.5em;
        font-size: 12rem;
        line-height: 1.77;
    }
}

/* course */
.requirements_course_tag {
    line-height: 1.8;
    color: var(--color-white);
    background-color: var(--color-red);
    display: inline-block;
    word-break: keep-all;
}
@media (min-width: 769px) {
    .requirements_course_tag {
        font-size: 18px;
        padding: 4px 10px;
    }
    .requirements_course_tag_s {
        font-size: 14px;
    }
}
@media (max-width: 768px) {
    .requirements_course_tag {
        font-size: 20rem;
        padding-inline: 8rem;
    }
    .requirements_course_tag_s {
        font-size: 13rem;
    }
}

/* step */
.requirements_box_step {
    width: 100%;
    margin-inline: auto;
    display: flex;
    flex-direction: column;
}
.requirements_box_step li {
    border-bottom: 1px solid var(--color-red);
    display: flex;
    flex-direction: column;
    position: relative;
}
.requirements_box_step li:has(+ li)::after {
    content: '';
    display: block;
    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);
    rotate: 45deg;
    position: absolute;
    top: calc(100% - 8px);
    left: 0;
    right: 0;
    margin-inline: auto;
    background-color: var(--color-white);
}
.requirements_box_step_ttl {
    display: flex;
    align-items: center;
    color: var(--color-red);
}
.requirements_box_step_num {
    letter-spacing: 0.05em;
    line-height: 1.5;
}
.requirements_box_step_ttl_txt {
    line-height: 1.8;
}
.requirements_box_step_txt {
    line-height: 1.8;
}
.requirements_box_step_txt a {
    color: var(--color-red);
    text-decoration: underline;
}
@media (min-width: 769px) {
    .requirements_box_step {
        max-width: 740px;
        gap: 30rem;
    }
    .requirements_box_step li {
        padding: 0 20rem 40rem;
        gap: 5px;
    }
    .requirements_box_step_ttl {
        gap: 20px;
    }
    .requirements_box_step_num {
        font-size: 21px;
    }
    .requirements_box_step_ttl_txt {
        font-size: 28px;
    }
    .requirements_box_step_txt {
        font-size: 16px;
    }
}
@media (max-width: 768px) {
    .requirements_box_step {
        gap: 30rem;
    }
    .requirements_box_step li {
        padding-bottom: 30rem;
        gap: 10rem;
    }
    .requirements_box_step_ttl {
        gap: 20rem;
    }
    .requirements_box_step_num {
        font-size: 16rem;
    }
    .requirements_box_step_ttl_txt {
        font-size: 18rem;
    }
    .requirements_box_step_txt {
        font-size: 14rem;
    }
}

/* requirements_description_list */
.requirements_description_list dl {
    display: flex;
}
.requirements_description_list dt {
    background-color: var(--color-red);
    color: var(--color-white);
    line-height: 1.77;
    text-align: center;
}
.requirements_description_list dd {
    position: relative;
    background-color: var(--color-white);
    flex: 1;
    overflow: hidden;
    line-height: 1.8;
}
.requirements_description_list dd a {
    text-decoration: underline;
    color: var(--color-red);
}
.requirements_list_note {
    font-weight: 400;
}
.requirements_ul li {
    padding-left: 1em;
    text-indent: -1em;
}
@media (min-width: 769px) {
    .requirements_description_list dt,
    .requirements_description_list dd {
        min-height: 72px;
        display: flex;
        align-items: center;
    }
    .requirements_description_list dt {
        font-size: 20px;
        justify-content: center;
        width: 300rem;
        min-width: 300rem;
        padding: 10px 30px;
    }
    .requirements_description_list dl:not(:first-child) dt {
        border-top: 2px solid var(--color-white);
    }
    .requirements_description_list dd {
        border-top: 2px solid var(--color-red);
        border-right: 2px solid var(--color-red);
        font-size: 18px;
        padding: 20px 30px;
    }
    .requirements_description_list dl:last-child dd {
        border-bottom: 2px solid var(--color-red);
    }
    .requirements_list_note {
        font-size: 16px;
    }
}
@media (max-width: 768px) {
    .requirements_description_list_box {
        padding-inline: 20rem;
    }
    .requirements_description_list dl {
        flex-direction: column;
    }
    .requirements_description_list dt {
        font-size: 16rem;
        padding: 15rem 20rem;
    }
    .requirements_description_list dd {
        border: 2rem solid var(--color-red);
        font-size: 16rem;
        padding: 40rem 30rem;
    }
    .requirements_list_note {
        font-size: 14rem;
    }
}
