@charset "utf-8";

/* mv */
.mv {
    position: relative;
    overflow: hidden;
}
.mv::after {
    content: '';
    display: block;
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 120rem;
}
.mv_inner {
    height: 100%;
    clip-path: polygon(0% 0%, 0% 100%, 100% 100%, 100% 0%);
}
.mv_box {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
}
.mv_ttl {
    color:#b09249;
    font-weight: 400;
}
.section_ttl_initial {
    color:#ca4928;
}
@media (min-width: 769px) {
    .mv {
        height: 800rem;
    }
    .mv::after {
        background: url(../images/mv_wave.svg) no-repeat 50% 100% / 100% 120rem;
    }
    .mv_box {
        background: url(../images/mv.jpg) no-repeat 50% -24rem / 100% auto;
    }
    .mv_content {
        margin-top: 186rem;
        margin-left: 118rem;
        width: 475rem;
    }
    .mv_ttl_wrap {
        margin-left: -6rem;
    }
    .mv_ttl {
        font-size: 110rem;
        line-height: 1;
        letter-spacing: 0.04em;
    }
}
@media (max-width: 768px) {
    .mv {
        height: 900rem;
    }
    .mv::after {
        background: url(../images/mv_wave_sp.svg) no-repeat 50% 100% / 100% 120rem;
    }
    .mv_box {
        background: url(../images/mv_sp.jpg) no-repeat 50% 0% / 100% auto;
    }
    .mv_content {
        margin-top: 216rem;
        margin-left: 22rem;
        width: 492rem;
    }
    .mv_ttl_wrap {
        margin-left: -6rem;
    }
    .mv_ttl {
        font-size: 112rem;
        line-height: 1;
        letter-spacing: 0.04em;
    }
}
.recruit_cont_inner {
    margin-inline: auto;
    position: relative;
}
@media (min-width: 769px) {
    .recruit_cont_inner {
        width: 1120rem;
    }
}

.section_ttl_decoration {
    margin-inline: auto;
    background: url(../images/ttl_decoration.svg) no-repeat;
    background-size: contain;
}
.section_ttl_jp {
    text-align: center;
    font-weight: 700;
}
.mv_txt_wrap {
    text-align: center;
}
@media (min-width: 769px) {
    .section_ttl_decoration {
        width: 83rem;
        height: 23rem;
        margin-top: 10rem;
    }
    .section_ttl_jp_wrap {
        margin-top: 18rem;
    }
    .section_ttl_jp {
        font-size: 36rem;
        letter-spacing: 0.1em;
    }
    .mv_txt_wrap {
        margin-top: 37rem;
    }
    .mv_txt {
        width: 420rem;
    }
}
@media (max-width: 768px) {
    .section_ttl_decoration {
        width: 115rem;
        height: 31rem;
        margin-top: 12rem;
    }
    .section_ttl_jp_wrap {
        margin-top: 18rem;
    }
    .section_ttl_jp {
        font-size: 46rem;
        letter-spacing: 0.1em;
        /* 背景で文字が読みにくいため追加 */
        text-shadow: 0 0 10rem rgba(255,255,255,0.3);
    }
    .mv_txt_wrap {
        margin-top: 72rem;
    }
    .mv_txt {
        width: 490rem;
    }
}

.section_ttl_animation_wrap {
    display:inline-block;
    overflow: hidden;
}
.animation_ready .section_ttl_animation_cover {
    display: block;
    transform: translateY(100%);
}
.animation_loaded .is_animated .section_ttl_animation_cover {
    transform:translateY(0%);
    transition: transform 1.2s cubic-bezier(0.33, 1, 0.68, 1);
}

.recruit_cont_ttl {
    display: flex;
    font-weight: 700;
}
.recruit_cont_num {
    line-height: 1;
    letter-spacing: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    border-radius: 50%;
    font-weight: 700;
}
.recruit_cont1 .recruit_cont_num {
    background-color: #da8c23;
}
.recruit_cont1 .recruit_check_item::before {
    border-color: #da8c23;
}
.recruit_cont2 .recruit_cont_num {
    background-color: #d4599a;
}
.recruit_cont2 .recruit_check_item::before {
    border-color: #d4599a;
}
.recruit_cont3 .recruit_cont_num {
    background-color: #55a86c;
}
.recruit_cont3 .recruit_check_item::before {
    border-color: #55a86c;
}
.recruit_cont4 .recruit_cont_num {
    background-color: #5972de;
}
.recruit_cont_num_in {
    transform: translateY(2rem);
}
.recruit_cont_ttl_txt {
    letter-spacing: 0.1em;
}
.recruit_check_list {
    display: flex;
    flex-wrap: wrap;
}
.recruit_check_item {
    position: relative;
    letter-spacing: 0.1em;
    font-weight: 500;
}
.recruit_check_highlight {
    background: linear-gradient(transparent 65%, #ffff7f 65%);
}
.recruit_check_item::before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4rem;
    border: 4rem solid;
}
.recruit_check_item::after {
    content: '';
    display: block;
    position: absolute;
    background: url(../images/check.png) no-repeat center center;
    background-size: contain;
}

.recruit_check_childlist {
    color: #55a86c;
}
.recruit_cont_img_wrap {
    border-radius: 16rem;
    overflow: hidden;
}
@media (min-width: 769px) {
    .recruit_check_list {
        gap: 28rem 0;
        margin-top: 41rem;
        padding: 0 90rem 0 90rem;
    }
    .recruit_cont3 .recruit_check_list {
        padding-right: 0;
    }
    .recruit_cont3 .recruit_check_list .recruit_check_item:nth-child(3) {
        width: 100%;
    }
    .recruit_check_childlist {
        display: inline-block;
        vertical-align: middle;
        font-size: 18rem;
    }
    .recruit_check_childlist>li {
        display: inline-block;
        margin-left: 6rem;
    }
    .recruit_cont_img_list {
        display: flex;
        justify-content: space-between;
        margin-top: 53rem;
    }
    .recruit_cont_img_wrap {
        width: 268rem;
        height: 180rem;
    }
    .recruit_check_item {
        padding-left: 45rem;
        font-size: 26rem;
        width: 50%;
    }
    .recruit_check_item::before {
        width: 32rem;
        height: 32rem;
        top: 2rem;
        left: -2rem;
    }
    .recruit_check_item::after {
        top: -6rem;
        left: 1rem;
        width: 37rem;
        height: 38rem;
        background-size: 33rem auto;
    }
    .recruit_cont_num {
        font-size: 36rem;
        width: 65rem;
        height: 65rem;
        margin-right: 24rem;
    }
    .recruit_cont_ttl_txt {
        font-size: 32rem;
    }
    .recruit_cont_ttl_large {
        font-size: 48rem;
    }
    .recruit_cont_ttl_slash {
        margin: 0 15rem;
    }
}

@media (max-width: 768px) {
    .recruit_check_list {
        gap: 33rem 0;
        margin-top: 60rem;
        flex-direction: column;
        padding: 0 36rem;
    }
    .recruit_cont3 .recruit_check_list {
        padding-right: 0;
    }
    .recruit_check_childlist {
        font-size: 26rem;
        margin-top: 10rem;
        line-height: 1.46;
    }
    .recruit_check_childlist>li {
        display: inline-block;
        margin-right: 10rem;
    }
    .recruit_cont_img_list_wrap {
        overflow: hidden;
        position: relative;
        padding-right: 25rem;
        padding-left: 25rem;
        margin-left: -25rem;
        width: calc(100% + 50rem);
        margin-top: 58rem;
        height: 241rem;
    }
    .recruit_cont_img_list {
        display: flex;
        gap: 20rem;
        justify-content: start;
    }
    .recruit_cont_img_list_copy {
        position: absolute;
        left: calc(100% + 20rem);
        top:0;
    }
    .recruit_cont_img_list_cover {
        position: absolute;
        top: 0;
        left: 0;
    }
    .animation_loaded .anim_roll {
        animation: img_roll 50s linear infinite;
    }
    .animation_loaded .anim_roll_re {
        animation: img_roll 50s reverse linear infinite;
    }
    @keyframes img_roll {
        0%{
            transform: translateX(0%);
        }
        100% {
            transform: translateX(calc(-100% - 20rem));
        }
    }
    .recruit_cont_img_wrap {
        width: 433rem;
        height: 241rem;
    }
    .recruit_check_item {
        padding-left: 60rem;
        font-size: 34rem;
    }
    .recruit_check_item::before {
        width: 42rem;
        height: 42rem;
        top: 4rem;
    }
    .recruit_check_item::after {
        top: -8rem;
        left: 6rem;
        width: 46rem;
        height: 47rem;
        background-size: 46rem auto;
    }
    .recruit_cont_num {
        font-size: 46rem;
        width: 81rem;
        height: 81rem;
        margin-right: 15rem;
    }
    .recruit_cont_ttl_txt {
        font-size: 42rem;
    }
    .recruit_cont_ttl_large {
        font-size: 58rem;
    }
    .recruit_cont_ttl_slash {
        margin: 0 10rem;
    }
}

/* anchor */
.recruit_anchor {
    background-color: #fdfde8;
    position: relative;
    text-align: center;
}
.recruit_anchor::before {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    background: url(../images/bg_stripe_anchor.png) repeat 50% 0 / 178rem auto;
}
.recruit_anchor_txt {
    font-weight: 700;
    letter-spacing: 0.05em;
}
.recruit_anchor_txt_line {
    position: relative;
}
.recruit_anchor_txt_line::after {
    border-bottom: dotted #b09249;
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
}
.recruit_anchor_btn_list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.recruit_anchor_btn_list > li {
    position: relative;
}
.recruit_anchor_btn {
    background-color: #fff;
    display: block;
    text-decoration: none;
    color: #262626;
    position: relative;
    overflow: hidden;
}
.recruit_anchor_btn_list>li:nth-child(1) .recruit_anchor_btn {
    border-color: #da8c23;
}
.recruit_anchor_btn_list>li:nth-child(1) .recruit_anchor_btn_num,
.recruit_anchor_btn_list>li:nth-child(1) .recruit_anchor_btn::before {
    background-color: #da8c23;
}
.recruit_anchor_btn_list>li:nth-child(2) .recruit_anchor_btn {
    border-color: #d4599a;
}
.recruit_anchor_btn_list>li:nth-child(2) .recruit_anchor_btn_num,
.recruit_anchor_btn_list>li:nth-child(2) .recruit_anchor_btn::before {
    background-color: #d4599a;
}
.recruit_anchor_btn_list>li:nth-child(3) .recruit_anchor_btn {
    border-color: #55a86c;
}
.recruit_anchor_btn_list>li:nth-child(3) .recruit_anchor_btn_num,
.recruit_anchor_btn_list>li:nth-child(3) .recruit_anchor_btn::before {
    background-color: #55a86c;
}
.recruit_anchor_btn_list>li:nth-child(4) .recruit_anchor_btn {
    border-color: #5972de;
}
.recruit_anchor_btn_list>li:nth-child(4) .recruit_anchor_btn_num,
.recruit_anchor_btn_list>li:nth-child(4) .recruit_anchor_btn::before {
    background-color: #5972de;
}
.recruit_anchor_btn_num {
    pointer-events: none;
    z-index: 2;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: auto;
    color: #fff;
    font-weight: 700;
    border-radius: 50%;
}
.recruit_anchor_btn_num > span {
    transform: translateY(2rem);
}
.recruit_anchor_btn_txt {
    position: relative;
    letter-spacing: 0.1em;
    font-weight: 500;
}
.recruit_anchor_btn::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
}
.recruit_anchor_btn::after {
    content: '';
    position: absolute;
    left: 0;
    width: 0;
    height: 0;
    right: 0;
    margin: auto;
}
@media (min-width: 769px) {
    .recruit_anchor {
        padding: 60rem 0 40rem;
    }
    .recruit_anchor::before {
        height: 103rem;
    }
    .recruit_anchor_txt {
        font-size: 36rem;
        line-height: 1.7;
    }
    .recruit_anchor_txt_line {
        font-size: 44rem;
        padding-bottom: 3rem;
    }
    .recruit_anchor_txt_line::after {
        border-bottom-width: 4rem;
    }
    .recruit_anchor_btn_list {
        gap: 0 16rem;
        margin-top: 24rem;
    }
    .recruit_anchor_btn_list>li {
        width: calc((100% - 48rem) / 4);
        padding-top: 20rem;
    }
    .recruit_anchor_btn {
        padding: 35rem 0 52rem;
        border-radius: 16rem;
        border: 2rem solid;
    }
    .recruit_anchor_btn_num {
        width: 40rem;
        height: 40rem;
        font-size: 18rem;
    }
    .recruit_anchor_btn_txt {
        font-size: 24rem;
    }
    .recruit_anchor_btn::before {
        height: 32rem;
    }
    .recruit_anchor_btn::after {
        bottom: 10rem;
        border-top: 8rem solid #fff;
        border-left: 6.5rem solid transparent;
        border-right: 6.5rem solid transparent;
    }
    @media (hover:hover) {
        .recruit_anchor_btn::before {
            transition: height .4s;
        }
        .recruit_anchor_btn:hover::before {
            height: 100%;
        }
        .recruit_anchor_btn_txt {
            transition: color 0.3s;
        }
        .recruit_anchor_btn:hover .recruit_anchor_btn_txt {
            color: #fff;
        }
    }
}
@media (max-width: 768px) {
    .recruit_anchor {
        padding: 60rem 26rem 40rem;
    }
    .recruit_anchor::before {
        height: 329rem;
    }
    .recruit_anchor_txt {
        font-size: 46rem;
        line-height: 1.6;
        letter-spacing: 0;
    }
    .recruit_anchor_txt_line {
        font-size: 54rem;
        padding-bottom: 8rem;
    }
    .recruit_anchor_txt_line::after {
        border-bottom-width: 6rem;
    }
    .recruit_anchor_btn_list {
        gap: 24rem 20rem;
        margin-top: 25rem;
    }
    .recruit_anchor_btn_list>li {
        width: calc(100% / 2 - 10rem);
        padding-top: 25rem;
    }
    .recruit_anchor_btn {
        padding: 44rem 0 66rem;
        border-radius: 16rem;
        border: 4rem solid;
    }
    .recruit_anchor_btn_num {
        width: 52rem;
        height: 52rem;
        font-size: 23.4rem;
    }
    .recruit_anchor_btn_txt {
        font-size: 30rem;
    }
    .recruit_anchor_btn::before {
        height: 36rem;
    }
    .recruit_anchor_btn::after {
        bottom: 10rem;
        border-top: 11rem solid #fff;
        border-left: 8.5rem solid transparent;
        border-right: 8.5rem solid transparent;
    }
}

/* recruit_cont1 */
.recruit_cont1 {
    background-color: #fdf9f4;
    position: relative;
}
.recruit_cont1::before,
.recruit_cont2::before,
.recruit_cont3::before {
    position: absolute;
    width: 100%;
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
}
.recruit_cont1::before {
    background: url(../images/bg_stripe_1.png) repeat 50% 0 / 178rem auto;
}
.recruit_cont2::before {
    background: url(../images/bg_stripe_2.png) repeat 50% 0 / 178rem auto;
}
.recruit_cont3::before {
    background: url(../images/bg_stripe_3.png) repeat 50% 0 / 178rem auto;
}
@media (min-width: 769px) {
    .recruit_cont1 {
        padding: 76rem 0 80rem;
    }
    .recruit_cont1::before,
    .recruit_cont2::before,
    .recruit_cont3::before {
        height: 144rem;
    }
}
@media (max-width: 768px) {
    .recruit_cont1 {
        padding: 80rem 25rem;
    }
    .recruit_cont1::before,
    .recruit_cont2::before,
    .recruit_cont3::before {
        height: 176rem;
    }
}

/* recruit_cont2 */
.recruit_cont2 {
    background-color: #fdf7fa;
    position: relative;
}
@media (min-width: 769px) {
    .recruit_cont2 {
        padding: 76rem 0 80rem;
    }
}
@media (max-width: 768px) {
    .recruit_cont2 {
        padding: 80rem 25rem;
    }
}

/* recruit_cont3 */
.recruit_cont3 {
    background-color: #f6fbf8;
    position: relative;
}
@media (min-width: 769px) {
    .recruit_cont3 {
        padding: 76rem 0 80rem;
    }
}
@media (max-width: 768px) {
    .recruit_cont3 {
        padding: 80rem 25rem;
    }
}

/* recruit_guidelines */
.recruit_guidelines {
    background-color: #f0f5f9;
    position: relative;
}
.recruit_guidelines::before,
.recruit_guidelines::after {
    content: '';
    display: block;
    position: absolute;
    z-index: 1;
    width: 100%;
    left: 0;
}
.recruit_guidelines::before {
    top: -1px;
}
.recruit_guidelines::after {
    bottom: -1px;
}
.recruit_guidelines::before {
    height: 120rem;
    background: url(../images/guideline_top_wave.svg) no-repeat 50% 0% / 100% 120rem;
}
.recruit_guidelines::after {
    height: 120rem;
    background: url(../images/guideline_bottom_wave.svg) no-repeat 50% 0% / 100% 120rem;
}
.recruit_guidelines_ttl {
    text-align: center;
    font-weight: 700;
    letter-spacing: 0.05em;
}
.recruit_star_listitem {
    position: relative;
    font-weight: 500;
}
.recruit_star_listitem::before {
    content: '★';
    display: inline-block;
}
.recruit_star_highlight {
    background: linear-gradient(transparent 65%, #ffff7f 65%);
}
.recruit_guidelines_program {
    overflow: hidden;
    position: relative;
}
.recruit_guidelines_program_ttl_wrap {
    position: absolute;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.9);
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
}
.recruit_guidelines_program_ttl {
    color: #ca4928;
    font-weight: 700;
}
.recruit_guidelines_program_ttl_small {
    color: #262626;
    font-weight: 500;
}
.program_set {
    display: flex;
    justify-content: end;
    width: 100%;
    font-weight: 500;
}
.program_set > dt {
    color: #fff;
    display:flex;
    justify-content: center;
    align-items: center;
}
.program_set:nth-child(1) > dt {
    background:#b09249;
}
.program_set:nth-child(2) > dt {
    background:#da8c23;
}
.program_set:nth-child(3) > dt {
    background:#24aacb;
}
.program_set:nth-child(4) > dt {
    background:#55a86c;
}
.program_set:nth-child(5) > dt {
    background:#d4599a;
}
.program_set > dd {
    background: #fff;
    display: flex;
    justify-content: end;
    text-align: right;
    align-items: center;
}
.program_set:nth-child(1) > dd {
    justify-content: center;
}
.recruit_guidelines_tb {
    border: 1px solid #262626;
    width: 100%;
    background-color: #fff;
    letter-spacing: 0.1em;
}
.recruit_guidelines_tb th,
.recruit_guidelines_tb td {
    border-bottom: 1px solid #262626;
    font-weight: 500;
}
.recruit_guidelines_tb th {
    color: #fff;
}
.recruit_guidelines_content {
    background-color: #fff;
}
.recruit_tab_btn_list {
    display: flex;
    justify-content: center;
}
.recruit_tab_btn {
    -webkit-appearance: none;
    appearance: none;
    background-color: #fff;
    border: none;
    border: 2rem solid currentColor;
    cursor: pointer;
    -webkit-tap-highlight-color: rgba(0,0,0,0);
}
.recruit_tab_btn_txt {
    display: block;
    line-height: 1;
    font-weight: 500;
}
.recruit_tab_btn_active .recruit_tab_btn_txt {
    color: #fff;
}
.recruit_tab_theme_color_1{
    --recruit_tab_theme_color: #b09249;
}
.recruit_tab_theme_color_2{
    --recruit_tab_theme_color: #24aacb;
}
.recruit_tab_theme_color_3{
    --recruit_tab_theme_color: #d4599a;
}
.recruit_tab_btn,
.recruit_star_listitem::before {
    position: relative;
    color: var(--recruit_tab_theme_color);
    transition: color 0.4s;
}
.recruit_tab_btn::before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    margin-inline: auto;
    background:var(--recruit_tab_theme_color);
    clip-path: polygon(0% 0%, 50% 100%, 100% 0%);
    opacity: 0;
    transition: opacity 0.4s;
    bottom: -20rem;
    width: 35rem;
    height: 20rem;
}
.recruit_tab_btn img {
    width:100%;
}
.recruit_tab_btn.recruit_tab_btn_active::before {
    opacity: 1;
}
.recruit_tab_btn_active,
.recruit_guidelines_tb th {
    background-color: var(--recruit_tab_theme_color);
    transition: background-color 0.4s;
}
.recruit_tab_content {
    display: none;
}
.recruit_tab_content_active {
    display: block;
}
.recruit_guidelines_contact {
    background-color: #fff;
}
.recruit_guidelines_contact_top {
    display: grid;
}
.recruit_guidelines_contact_ttl {
    grid-area: ttl;
    font-weight: 700;
}
.recruit_guidelines_contact_txt {
    grid-area: txt;
    font-weight: 500;
}
.recruit_guidelines_contact_img {
    grid-area: img;
    overflow: hidden;
    position: relative;
    background: url(../images/recruit_guidelines_contact_img.jpg) no-repeat 50% 50% / cover;
}
.recruit_guidelines_contact_list {
    display: flex;
    font-weight: 500;
}
.recruit_guidelines_contact_list a {
    color: #c62a26;
    text-decoration: none;
}
@media (min-width: 769px) {
    .recruit_guidelines {
        border-top: 80rem solid #fdfde8;
        padding: 147rem 0 160rem;
    }
    .recruit_guidelines_ttl {
        font-size: 56rem;
    }
    .recruit_tab_btn_list {
        gap: 0 20rem;
        margin-top: 22rem;
        padding-bottom: 26rem;
        border-bottom: 1rem solid #b09249;
    }
    .recruit_tab_btn {
        width: 360rem;
        padding: 33rem 32rem 31rem;
        border-radius: 16rem;
    }
    .recruit_tab_btn_txt {
        font-size: 32rem;
        letter-spacing: 0.1em;
        margin-top: 10rem;
    }
    .recruit_star_list {
        margin-top: 72rem;
    }
    .recruit_star_listitem {
        font-size: 20rem;
        line-height: 1.5;
        letter-spacing: 0.1em;
        padding-left: 36rem;
        text-indent: -18rem;
    }
    .recruit_star_listitem::before {
        font-size: 20rem;
        margin-right: 6rem;
    }
    .recruit_guidelines_program {
        height: 428rem;
        margin-top: 83rem;
    }
    .recruit_guidelines_program_ttl_wrap {
        border: 4rem dotted #b09249;
        top: 4rem;
        left: 0rem;
        width: 204rem;
        height: 204rem;
    }
    .recruit_guidelines_program_ttl {
        font-size: 26rem;
        line-height: calc(40/26);
        letter-spacing: 0.1em;
    }
    .recruit_guidelines_program_ttl_small {
        font-size: 22rem;
        line-height: calc(40/22);
    }
    .program_set_wrap {
        margin-top: 60rem;
    }
    .program_set {
        height: 72rem;
    }
    .program_set + .program_set {
        margin-top: 2rem;
    }
    .program_set > dt {
        width: 120rem;
        font-size: 26rem;
        line-height: calc(40/26);
        letter-spacing: 0.1em;
    }
    .program_set > dd {
        padding-inline: 36rem;
        font-size: 26rem;
        line-height: calc(40/26);
        letter-spacing: 0.1em;
    }
    .program_set:nth-child(1) > dd {
        width: 520rem;
    }
    .program_set:nth-child(2) > dd {
        width: 640rem;
    }
    .program_set:nth-child(3) > dd {
        width: 760rem;
    }
    .program_set:nth-child(4) > dd {
        width: 880rem;
    }
    .program_set:nth-child(5) > dd {
        width: 1000rem;
    }
    .recruit_star_listitem + .recruit_star_listitem {
        margin-top: 11rem;
    }
    .recruit_star_note {
        font-size: 16rem;
        margin-top: 0rem;
        margin-left: 10rem;
    }
    .recruit_guidelines_tb {
        margin-top: 80rem;
    }
    .recruit_guidelines_tb th {
        width: 200rem;
        padding: 19rem 0;
    }
    .recruit_guidelines_tb th,
    .recruit_guidelines_tb td {
        font-size: 18rem;
    }
    .recruit_guidelines_tb td {
        padding: 19rem 26rem;
    }
    .recruit_guidelines_contact {
        margin-top: 80rem;
        padding: 74rem 80rem 82rem;
        border-radius: 16rem;
    }
    .recruit_guidelines_contact_top {
        grid-template-columns: 1fr 320rem;
        gap: 40rem 30rem;
        grid-template-areas:
        "ttl ttl"
        "txt img";
    }
    .recruit_guidelines_contact_ttl {
        margin-left: -6rem;
        font-size: 32rem;
        letter-spacing: 0.1em;
    }
    .recruit_guidelines_contact_txt {
        font-size: 16rem;
        line-height: 2;
        letter-spacing: 0.1em;
    }
    .recruit_guidelines_contact_img {
        margin-top: 10rem;
        width: 320rem;
        height: 228rem;
        border-radius: 16rem;
    }
    .recruit_guidelines_contact_bottom {
        margin-top: 52rem;
    }
    .recruit_guidelines_contact_list {
        gap: 82rem;
        font-size: 32rem;
        line-height: calc(38/32);
        letter-spacing: 0.1em;
    }
    @media(hover: hover){
        .recruit_tab_btn {
            transition: background-color 0.4s, color 0.4s;
        }
        .recruit_tab_btn:hover {
            background-color: var(--recruit_tab_theme_color);
            color: #fff;
        }
    }
}
@media (max-width: 768px) {
    .recruit_guidelines {
        border-top: 80rem solid #fdfde8;
        padding: 184rem 25rem 160rem;
    }
    .recruit_guidelines .section_ttl_decoration {
        margin-top: 10rem;
    }
    .recruit_guidelines_ttl {
        font-size: 72rem;
    }
    .recruit_tab_btn_list {
        gap: 0 8rem;
        margin-top: 22rem;
        padding-bottom: 33rem;
        border-bottom: 1rem solid #b09249;
    }
    .recruit_tab_btn {
        padding: 33rem 14rem 30rem;
        border-radius: 16rem;
        width: calc((100% - 16rem) / 3);
    }
    .recruit_tab_btn_txt {
        font-size: 30rem;
        margin-top: 10rem;
    }
    .recruit_star_list {
        margin-top: 70rem;
    }
    .recruit_star_listitem {
        font-size: 30rem;
        line-height: 1.5333;
        padding-left: 34rem;
        text-indent: -17rem;
    }
    .recruit_star_listitem+.recruit_star_listitem {
        margin-top: 22rem;
    }
    .recruit_star_listitem::before {
        font-size: 30rem;
        margin-right: 5rem;
    }
    .recruit_star_note {
        font-size: 24rem;
        margin-top: 1rem;
        margin-left: 20rem;
    }

    .recruit_guidelines_program {
        height: 631rem;
        margin-top: 65rem;
    }
    .recruit_guidelines_program_ttl_wrap {
        border: 6rem dotted #b09249;
        top: 4rem;
        left: 0rem;
        width: 204rem;
        height: 204rem;
    }
    .recruit_guidelines_program_ttl {
        font-size: 26rem;
        line-height: calc(40/26);
        letter-spacing: 0.1em;
    }
    .recruit_guidelines_program_ttl_small {
        font-size: 22rem;
        line-height: calc(40/22);
    }
    .program_set_wrap {
        margin-top: 63rem;
    }
    .program_set {
        height: 112rem;
    }
    .program_set + .program_set {
        margin-top: 2rem;
    }
    .program_set > dt {
        width: 120rem;
        font-size: 26rem;
        line-height: calc(40/26);
        letter-spacing: 0.1em;
    }
    .program_set > dd {
        padding-inline: 38rem;
        font-size: 26rem;
        line-height: calc(40/26);
        letter-spacing: 0.1em;
    }
    .program_set:nth-child(1) > dd {
        width: 340rem;
    }
    .program_set:nth-child(2) > dd {
        width: 400rem;
    }
    .program_set:nth-child(3) > dd {
        width: 460rem;
    }
    .program_set:nth-child(4) > dd {
        width: 520rem;
    }
    .program_set:nth-child(5) > dd {
        width: 580rem;
    }
    .recruit_guidelines_tb {
        margin-top: 80rem;
    }
    .recruit_guidelines_tb th {
        width: 20.5%;
        padding: 29.5rem 0rem;
    }
    .recruit_guidelines_tb th,
    .recruit_guidelines_tb td {
        font-size: 26rem;
        line-height: calc(49/26);
        letter-spacing:0.1em;
    }
    .recruit_guidelines_tb td {
        padding: 29.5rem 16rem;
    }
    .recruit_guidelines_contact {
        margin-top: 80rem;
        padding: 70rem 55rem 77rem;
        border-radius: 16rem;
    }
    .recruit_guidelines_contact_top {
        grid-template-columns: 1fr 192rem;
        gap: 45rem 50rem;
        grid-template-areas:
        "ttl img"
        "txt txt";
    }
    .recruit_guidelines_contact_ttl {
        margin-left: 1rem;
        font-size: 40rem;
        line-height: calc(64/40);
        letter-spacing: -0.05em;
        align-self: center;
    }
    .recruit_guidelines_contact_txt {
        font-size: 24rem;
        line-height: calc(40/24);
        letter-spacing: 0.1em;
    }
    .recruit_guidelines_contact_img {
        margin-top: 10rem;
        width: 192rem;
        height: 137rem;
        border-radius: 16rem;
    }
    .recruit_guidelines_contact_bottom {
        margin-top: 45rem;
    }
    .recruit_guidelines_contact_list {
        gap: 36rem;
        font-size: 36rem;
        line-height: calc(38/36);
        letter-spacing: 0.1em;
        flex-direction: column;
    }


}
.recruit_tab_content {
    opacity: 0;
}
.recruit_tab_content_active {
    display: block;
    animation: recruit_tab_content_active 1s forwards;
}
@keyframes recruit_tab_content_active {
    0%{
        opacity: 0;
    }
    100%{
        opacity: 1;
    }
}

/* recruit_cont4 */
.recruit_cont4 {
    background-color: #ffffff;
    position: relative;
}
.recruit_cont4::before {
    width: 100%;
    content: '';
    position: absolute;
    left: 0;
    display: block;
}
.recruit_message_profile_name_jp {
    font-weight: 500;
    letter-spacing: 0.1em;
}
.recruit_message_profile_name_en {
    color: #5972de;
    font-weight: 700;
    letter-spacing: 0.1em;
}
.recruit_message_profile_post {
    background-color: #5972de;
    color: #fff;
    display: inline-block;
    font-weight: 500;
    letter-spacing: 0.1em;
}
.recruit_message_profile_img {
    overflow: hidden;
}
.recruit_message_txt {
    letter-spacing: 0.1em;
    font-weight: 500;
}
@media (min-width: 769px) {
    .recruit_cont4 {
        padding: 80rem 0 70rem;
    }
    .recruit_cont4::before {
        top: 345rem;
        height: 160rem;
        background: url(../images/bg_stripe_4.png) repeat 50% 0 / 178rem auto;
    }
    .recruit_message_profile {
        display: flex;
        justify-content: space-between;
        flex-direction: row-reverse;
        margin-top: 38rem;
    }
    .recruit_message_profile_txt_wrap {
        margin-top: 66rem;
    }
    .recruit_message_profile_name_jp {
        font-size: 48rem;
        margin-right: 22rem;
    }
    .recruit_message_profile_name_en {
        font-size: 22rem;
    }
    .recruit_message_profile_post {
        font-size: 20rem;
        padding: 6rem 14rem;
        border-radius: 4rem;
        margin-top: 22rem;
    }
    .recruit_message_profile_img {
        width: 640rem;
        height: 400rem;
        border-radius: 16rem;
    }
    .recruit_message_txt {
        font-size: 18rem;
        line-height: 2.1111;
        margin-top: -52rem;
    }
}
@media (max-width: 768px) {
    .recruit_cont4 {
        padding: 80rem 25rem 112rem;
    }
    .recruit_cont4::before {
        top: 520rem;
        height: 176rem;
        background: url(../images/bg_stripe_4_sp.png) repeat 50% 0 / 178rem auto;
    }
    .recruit_message_profile {
        margin-top: 56rem;
    }
    .recruit_message_profile_txt_wrap {
        margin-top: 60rem;
    }
    .recruit_message_profile_name_jp {
        font-size: 46rem;
        margin-right: 25rem;
    }
    .recruit_message_profile_name_en {
        font-size: 28rem;
    }
    .recruit_message_profile_post {
        font-size: 22rem;
        padding: 8rem 14rem;
        border-radius: 4rem;
        margin-top: 22rem;
    }
    .recruit_message_profile_img {
        width: 700rem;
        height: 440rem;
        border-radius: 16rem;
    }
    .recruit_message_txt {
        font-size: 26rem;
        line-height: 1.7692;
        margin-top: 47rem;
    }
}
