/*募集要項-start*/

.main_section02 {
    background-color: #f9f9f9;
}

.section--requirements {
    width: 100%;
    background:
        linear-gradient(to bottom, rgba(50 120 194 / 100%), rgba(198, 221, 244) 100%);
    position: relative;
    z-index: 1;
    overflow: hidden;
}

.auto-scroll_wrapper {
    padding: 150px 0;
    position: relative;
    width: 100%;
    overflow: hidden;
    z-index: 2;
}

.auto-scroll_contents {
    display: flex;
    gap: 8rem;
    white-space: nowrap;
    position: absolute;
    transition: transform 0.1s linear;
    z-index: 2;

}

.auto-scroll_contents span{
font-weight: 600;
}

.auto-scroll_contents.upper {
    top: 0;
    left: 20%;
}

.auto-scroll_contents.middle {
    top: 600px;
    right: 20%;
    /* または JS 側で補正 */
}

.auto-scroll_contents.down {
    top: 1200px;
    left: 100%;
}

.auto-scroll_contents.down02 {
    top: 1800px;
    right: 200%;

}

.auto-scroll_contents.down03 {
    top: 2400px;
    left: 200%;

}




.bg_tx {
    width: 100%;
    font-size: 12vw;
    display: inline-block;
    color: rgba(255, 255, 255, 0.1);

}

.section_width1300px {
    padding: 0 20px;
    max-width: 1320px;
    margin-inline: auto;
    position: relative;
    z-index: 3;
}

.recruit_h2--title.section_rec {
    color: #fff;
}

.recruit_h2--title_line.section_rec {
    background-color: #fff;

}

.section_rec_title span{
    display: inline;
    float: none;
    width: auto;
    margin: 0;
    color: #fff;
}

/*募集要項ボタン*/
.btn_rec {
    padding: 50px 20px;
    display: block;
    position: relative;
    z-index: 3;
}

.btn_rec li{
    margin-inline:auto;
    margin-bottom: 30px;
}

.btn_rec_item {
    width: 100%;
    max-width: 600px;
    background-color: #fff;
    border-radius: 10px;
    padding: 0;
    overflow: hidden;
    box-shadow: 0px 5px 10px rgba(51, 51, 51, 0.3);
    position: relative;

    transform: scale(1);
    transform-origin: center;
    transition: transform .2s ease-in-out;
}

.btn_rec_item::after {
    content: "";
    width: 30px;
    height: 30px;
    display: block;
    background-image: url(../images/rnew/arrow-right.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 2rem;

}

.btn_rec_item:hover {
    transform: scale(1.05);
}

.btn_rec_item a {
    display: flex;
    gap: 20%;
    border-radius: 10px;
}

.btn_rec_item.en a {
    display: flex;
    gap: 10%;
    border-radius: 10px;
}

/* .btn_rec_img {
    display: inline-block;
    width: 30%;
    max-width: 300px;
    overflow: hidden;
} */

.btn_rec_img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.btn_rec_img {
    display: none;
}

.btn_rec_item a {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 180px;
    padding: 30px 60px;
    border-radius: 10px;
}

.btn_rec_tx {
    display: inline;
    line-height: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.3rem;
    color: #333;
}

.btn_rec_tx::after {
    content: "";

}


.btn_tosection--ideal {
    padding: 10px;
    margin-top: 50px;
    text-align: center;

}

.btn_tosection--ideal a {
    padding: 10px 60px 10px 50px;
    border: 2px #fff solid;
    border-radius: 10px;
    color: #fff;
    position: relative;
}

.btn_down-arrow.btn_ideal {
    left: auto;
    right: 20px;
    bottom: 10px;
    transform: rotate(-180deg);
    transform-origin: center;
}



/*インターンシップ*/
.section--internship {
    padding: 100px 20px 0;
    position: relative;
    z-index: 3;
}

.section--internship h2 {
    font-size: 1.5rem;
    color: #fff;
    position: relative;
    padding-left: 40px;

}

.section--internship h2::before {
    content: "";
    width: 20px;
    height: 2px;
    background-color: #fff;
    position: absolute;
    top: 50%;
    left: 0px;
}

.title-icon.icon06::after {
    background-image: url(../images/rnew/title-logo06.svg);
}

.internship_noinfo {
    margin-top: 50px;
}

.internship_flexbox {
    display: block;
    margin-top: 50px;
}

.intern--article {
    width: 80%;
    margin-top: 20px;
    margin-left: auto;
    margin-right: auto;

}

.intern--article h4{
    font-size: 1rem;
    color: #333;
    padding-left: 30px;
    border-left: 10px #3278C2 solid;
    margin-left: 0;
}

.intern--article_toggle {
    width: 100%;
    padding: 40px 70px 40px 30px;
    font-size: 1rem;
    background-color: #fff;
    text-align: left;
    cursor: pointer;
    border-radius: 10px;
    position: relative;
    box-shadow: 0px 5px 10px rgba(51, 51, 51, 0.3);
    transform: scale(1);
    transition: transform .2s ease-in-out;
}

.intern--article_toggle.no-info {
    border-left: 10px #333 solid;
}

.intern--article_toggle:hover {
    transform: scale(1.02);
}

.intern--article_toggle::after {
    content: "";
    width: 40px;
    height: 40px;
    background-image: url(../images/rnew/open-close.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    display: block;
    position: absolute;
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
    right: 30px;

    transition: transform 0.3s ease;
}



.intern--info {
    width: 100%;
    background-color: #fff;
    margin-top: 10px;
    border-radius: 10px;
    font-size: 1rem;
    height: 0;
    opacity: 0;
    box-shadow: 0px 5px 10px rgba(51, 51, 51, 0.3);
    overflow: hidden;
    pointer-events: none;
}

.intern--info_padding {
    padding: 40px 30px;
}

.intern--article.active .intern--article_toggle::after {
    transform: translateY(-50%) rotate(90deg);
}

.intern--article dl {
    display: flex;
    padding: 10px 0;
    font-size: 1rem;
}


.intern--article dt {
    width: 15%;
    margin-right: 5%;
    font-weight: 600;
    text-align: right;
}

.intern--article dt::before {
content: none;
}

.intern--article dd {
    width: 80%;
    line-height: 1.8;
}

.entry_btn--internship {
    text-align: center;

}

.entry_btn--internship a{
    color: #333;
}

.entry_btn--internship_btn {
    display: block;
    width: 100%;
    max-width: 500px;
    background-color: rgba(50, 120, 194, 1);
    border-radius: 10px;
    color: #fff!important;
    padding: 20px;
    margin-top:10px;
    transition: background-color 0.3s ease-in-out;
}

.entry_btn--internship_btn:hover {
    background-color: rgba(50, 120, 194, 0.8);
}

.entry_btn--internship_tx {
    text-align: left;
}


.intern--info_dropdown {
    margin-top: 50px;
    text-align: left;
}



/*outリンクアイコン*/
.icon_outlink {
    content: "";
    width: 20px;
    height: 20px;
    background-image: url(../images/rnew/out-link.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    margin-top: 2px;
}


/*募集要項-fin*/

@media (max-width: 900px) {

    .auto-scroll_contents.upper,
    .auto-scroll_contents.middle,
    .auto-scroll_contents.down,
    .auto-scroll_contents.down02,
    .auto-scroll_contents.down03 {
        opacity: 0;
    }


}



@media (max-width: 600px) {
    .auto-scroll_wrapper {
        padding: 100px 0;
    }







    .auto-scroll_contents {
        gap: 3rem;
    }

    .btn_rec,
    .section--internship {
        padding: 50px 0px 0px;
    }

   .btn_rec li {
    margin-bottom: 20px;
}
    .btn_rec_item::after {
        width: 20px;
        height: 20px;
    }


    .intern--article {
        width: 100%;
        margin-top: 10px;
    }

    .intern--article_toggle {
        width: 100%;
        padding: 30px 50px 30px 20px;
    }

    .intern--article_toggle::after {
        width: 30px;
        height: 30px;
        right: 20px;
    }

    .intern--info_padding {
        padding: 20px;
    }

    .intern--article  dl {
        display: grid;
        gap: 5px;
    }

    .intern--article dt {
        width: 100%;
        margin-right: auto;
        text-align: left;
    }

    .intern--article  dd {
        width: 100%;
    }

}