.blue-top-internship-container {
    background-color: #0033B3;
    padding-top: 14.3rem;
    padding-bottom: 11.3rem;
    margin-bottom: 10rem;
    clip-path: ellipse(56% 50%);
    width: 110%;
    transform: translateX(-11rem);
    position: relative;
    @media screen and (max-width: 767px) {
        padding-top: 7rem;
        padding-bottom: 7rem;
        margin-bottom: 4rem;
        clip-path: ellipse(167% 50%);
        width: 100%;
        transform: translateX(0rem);
    }
}

.blue-top-internship-container::before {
    content: "";
    position: absolute;
    top: 23rem;
    left: 22rem;
    width: 37.1rem;
    height: 29rem;
    background: url("../../img/page/internship/internship01.png") no-repeat center;
    background-size: cover;
}

.blue-top-internship-container::after {
    content: "";
    position: absolute;
    top: 29rem;
    right: 25rem;
    width: 39.7rem;
    height: 29.3rem;
    background: url("../../img/page/internship/internship02.png") no-repeat center;
    background-size: cover;
}

@media screen and (max-width: 767px) {
    .blue-top-internship-container::before {
        top: 9rem;
        left: 30rem;
        width: 7.1rem;
        height: 5rem;
        display: none;
    }      
    .blue-top-internship-container::after {
        top: 40rem;
        right: 22rem;
        width: 8.7rem;
        height: 6.3rem;
        display: none;
    }
    .link-top-img-flex-container {
        display: flex;
        margin: 6.8rem auto 6rem;
    }
    .top-intern-sp-img-container {
        width: 24.3rem;
    }
    .top-intern-sp-img-container2 {
        width: 25.5rem;
    }
}

.blue-top-internship-container h2 {
    font-family: 'Zen Kaku Gothic New';
    font-style: normal;
    font-weight: 700;
    font-size: 4.6rem;
    /* line-height: 67px; */
    letter-spacing: 0.04em;
    color: #FFFFFF;
    margin-bottom: 6.1rem;
    text-align: center;
    @media screen and (max-width: 767px) {
        font-size: 1.9rem;
        margin-bottom: 5rem;
    }
}

.blue-top-internship-container p {
    font-style: normal;
    font-weight: 500;
    font-size: 2rem;
    line-height: 3.6rem;
    text-align: center;
    letter-spacing: 0.1em;
    color: #FFFFFF;
    margin-bottom: 12.2rem;
    @media screen and (max-width: 767px) {
        font-size: 1.6rem;
        line-height: 2.6rem;
        text-align: left;
        margin-bottom: 0;
    }
}

.link-top-flex-container {
    display: flex;
    justify-content: space-between;
    @media screen and (max-width: 767px) {
        flex-wrap: wrap;
        row-gap: 0.8rem;
    }
}

.link-top-flex-container a {
    font-style: normal;
    font-weight: 700;
    font-size: 1.6rem;
    /* line-height: 16px; */
    letter-spacing: 0.05em;
    color: #E72D30;
    background: #F0F0F0;
    border: 2px solid #E72D30;
    border-radius: 0.8rem;
    position: relative;
    width: 22.1rem;
    height: 7rem;
    padding-left: 1.3rem;
    text-decoration: none;
    display: flex;
    align-items: center;
    @media screen and (max-width: 767px) {
        font-size: 1.4rem;
        width: 17rem;
        height: 4.5rem;
    }
}

.link-top-flex-container a::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0.7rem;
    margin: auto;
    background: url("../../img/page/internship/red-arrow.svg") no-repeat;
    background-size: 100%;
    width: 2.4rem;
    height: 2.4rem;
    transition: all 0.3s ease;
}

.link-top-flex-container a:hover::after {
    transform: translateY(1rem);
}

.internship-body-bk {
    background-color: #EAF8FF;
    margin-top: -32rem;
    padding-top: 40rem;
    padding-bottom: 22rem;
    @media screen and (max-width: 767px) {
        margin-top: -37rem;
        padding-bottom: 16rem;
    }
}

.internship-red-title {
    position: relative;
    font-style: normal;
    font-weight: 700;
    font-size: 4rem;
    /* line-height: 40px; */
    letter-spacing: 0.1em;
    color: #E72D30;
    width: 100%;
    height: 7.8rem;
    display: flex;
    align-items: center;
    padding-left: 9.7rem;
    background: #FFFFFF;
    border: 3px solid #E72D30;
    border-radius: 3.9rem;
    margin-bottom: 4rem;
    @media screen and (max-width: 767px) {
        font-size: 1.8rem;
        height: 4.8rem;
        padding-left: 5.5rem;
        margin-bottom: 2rem;
    }
}

.feature-intern-red-title::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: -0.1rem;
    margin: auto;
    width: 7.8rem;
    height: 7.8rem;
    background: url("../../img/page/internship/search-icon.svg") no-repeat center;
    background-size: cover;
}

.cost-intern-red-title::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: -0.1rem;
    margin: auto;
    width: 7.8rem;
    height: 7.8rem;
    background: url("../../img/page/internship/news-icon.svg") no-repeat center;
    background-size: cover;
}

.join-intern-red-title::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: -0.1rem;
    margin: auto;
    width: 7.8rem;
    height: 7.8rem;
    background: url("../../img/page/internship/stairs-icon.svg") no-repeat center;
    background-size: cover;
}

.question-intern-red-title::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: -0.1rem;
    margin: auto;
    width: 7.8rem;
    height: 7.8rem;
    background: url("../../img/page/internship/interogation-icon.svg") no-repeat center;
    background-size: cover;
}

.contact-intern-red-title::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: -0.1rem;
    margin: auto;
    width: 7.8rem;
    height: 7.8rem;
    background: url("../../img/page/internship/mail-icon.svg") no-repeat center;
    background-size: cover;
}

@media screen and (max-width: 767px) {
    .feature-intern-red-title::before {
        width: 4.8rem;
        height: 4.8rem;
    }      
    .cost-intern-red-title::before {
        width: 4.8rem;
        height: 4.8rem;
    }
    .join-intern-red-title::before {
        width: 4.8rem;
        height: 4.8rem;
    }
    .question-intern-red-title::before {
        width: 4.8rem;
        height: 4.8rem;
    }
    .contact-intern-red-title::before {
        width: 4.8rem;
        height: 4.8rem;
    }
}

.feature-internship-content-container h3 {
    font-style: normal;
    font-weight: 700;
    font-size: 2rem;
    /* line-height: 30px; */
    letter-spacing: 0.1em;
    color: #000000;
    margin-bottom: 2rem;
    @media screen and (max-width: 767px) {
        font-size: 1.6rem;
        line-height: 2.2rem;
    }
}

.feature-internship-content-container p {
    font-style: normal;
    font-weight: 500;
    font-size: 1.6rem;
    line-height: 3rem;
    letter-spacing: 0.06em;
    color: #000000;
}

.feature-flex-container {
    display: flex;
    justify-content: space-between;
    margin-top: 8.8rem;
    margin-bottom: 11rem;
    @media screen and (max-width: 767px) {
        margin-top: 4.5rem;
        flex-direction: column;
    }
}

.feature-box-container {
    position: relative;
    background: #FFFFFF;
    border-radius: 19.3rem 19.3rem 0 0;
    width: 38.5rem;
    height: 50rem;
    padding: 19.7rem 0 0;
    @media screen and (max-width: 767px) {
        width: 100%;
        height: auto;
        padding: 11rem 2rem 4rem;
    }
}

.feature-box-container h3 {
    font-style: normal;
    font-weight: 700;
    font-size: 2rem;
    line-height: 2.8rem;
    text-align: center;
    letter-spacing: 0.1em;
    color: #E72D30;
    height: 5.6rem;
    max-width: 33rem;
    margin: 0 auto;
    @media screen and (max-width: 767px) {
        font-size: 1.8rem;
        line-height: 2.6rem;
    }
}

.feature-box-container p {
    font-style: normal;
    font-weight: 500;
    font-size: 1.6rem;
    line-height: 2.6rem;
    letter-spacing: 0.1em;
    color: #000000;
    margin-top: 1.6rem;
    margin-left: 3.7rem;
    max-width: 31.2rem;
    @media screen and (max-width: 767px) {
        font-size: 1.4rem;
        line-height: 2rem;
        max-width: 100%;
        margin-left: 0;
    }
}

.first-feature-box::before {
    position: absolute;
    content: "";
    background: url("../../img/page/internship/internship02.5.png") no-repeat;
    background-size: contain;
    width: 29rem;
    height: 19.4rem;
    top: -3rem;
    left: 0;
    right: 0;
    margin: auto;
}

.second-feature-box::before {
    position: absolute;
    content: "";
    background: url("../../img/page/internship/internship03.png") no-repeat;
    background-size: contain;
    width: 29rem;
    height: 19.4rem;
    top: -3.5rem;
    left: 9rem;
    right: 0;
    margin: auto;
}

.third-feature-box::before {
    position: absolute;
    content: "";
    background: url("../../img/page/internship/internship04.png") no-repeat;
    background-size: contain;
    width: 29rem;
    height: 19.4rem;
    top: -1rem;
    left: 3rem;
    right: 0;
    margin: auto;
}

@media screen and (max-width: 767px) {
    .first-feature-box::before {
        width: 21rem;
        height: 14.4rem;
    }    
    .second-feature-box {
        border-radius: 0;
    }  
    .second-feature-box::before {
        width: 17rem;
        height: 14.4rem;
        top: -3.5rem;
        left: 2rem;
    }
    .third-feature-box {
        border-radius: 0 0 19.3rem 19.3rem;
        padding: 11rem 2rem 10rem;
    }
    .third-feature-box::before {
        width: 21rem;
        height: 11.4rem;
        top: -1rem;
        left: 2rem;
    }
}

.cost-intern-flex-container {
    display: flex;
    justify-content: space-between;
    @media screen and (max-width: 767px) {
        flex-direction: column;
        gap: 1.6rem;
    }
}

.intern-nav-container {
    padding-top: 3.1rem;
    border-radius: 2rem 2rem 0 0;
    /* border: 3px solid #FF5F25; */
    width: 61.8rem;
    border-top: 3px solid #FF5F25;
    border-right: 3px solid #FF5F25;
    border-left: 3px solid #FF5F25;
    background-color: white;
    cursor: pointer;
    @media screen and (max-width: 767px) {
        padding-top: 2rem;
        border-radius: 2rem 2rem 2.4rem 2.4rem;
        width: 100%;
        border-top: 2px solid #FF5F25;
        border-right: 2px solid #FF5F25;
        border-left: 2px solid #FF5F25;
    }
}

.intern-nav-container h3 {
    font-style: normal;
    font-weight: 700;
    font-size: 2rem;
    line-height: 2.6rem;
    text-align: center;
    letter-spacing: 0.1em;
    color: #FF5F25;
    margin-bottom: 3rem;
    @media screen and (max-width: 767px) {
        font-size: 1.6rem;
        padding: 0 1.5rem;
        margin-bottom: 1.1rem;
    }
}

.intern-nav-container p {
    font-style: normal;
    font-weight: 500;
    font-size: 1.6rem;
    line-height: 2.6rem;
    letter-spacing: 0.1em;
    color: #000000;
    max-width: 55.6rem;
    margin-bottom: 3.3rem;
    padding-left: 3.5rem;
    @media screen and (max-width: 767px) {
        max-width: 27rem;
        font-style: normal;
        font-weight: 400;
        font-size: 1.2rem;
        line-height: 2rem;
        letter-spacing: 0.1em;
        color: #000000;
        padding-left: 0;
        margin: 0 auto 2rem;
    }
}

.intern-nav-container .arrow-container {
    width: 100%;
    height: 4rem;
    display: flex;
    justify-content: center;
    background-color: #FF5F25;
    align-items: center;
    @media screen and (max-width: 767px) {
        border-radius: 0 0 2rem 2rem;
        height: 2.5rem;
    }
}

.arrow-nav-cost-container {
    width: 2.4rem;
    transition: all 0.3s ease;
    @media screen and (max-width: 767px) {
        width: 1.2rem;
    }
}

.intern-nav-container:hover .arrow-nav-cost-container {
    transform: translateY(0.3rem);
}

.cost-intern-bot-box-container {
    padding-top: 7.7rem;
    border: 3px solid #FF5F25;
    position: relative;
    background-color: white;
    padding-bottom: 8rem;
    z-index: 2;
    @media screen and (max-width: 767px) {
        padding-top: 5rem;
        margin-top: 2.9rem;
    }
}
#nav-green {
     border: 3px solid #4AAD96;
}

.cost-intern-bot-box-container::before {
    content: "";
    position: absolute;
    top: 5rem;
    right: 18rem;
    width: 26.1rem;
    height: 17.7rem;
    background: url(../../img/page/internship/internship05.png) no-repeat;
    background-size: contain;
    z-index: 3;
}

#nav-green::before {
    content: "";
    position: absolute;
    top: 2rem;
    right: 15rem;
    width: 28.5rem;
    height: 23.1rem;
    background: url(../../img/page/internship/internship05-green.png) no-repeat;
    background-size: contain;
    z-index: 3;
}

@media screen and (max-width: 767px) {
    .cost-intern-bot-box-container::before {
        top: 13rem;
        right: 0.5rem;
        width: 11.1rem;
        height: 8.7rem;
    } 
    #nav-green::before {
        top: 9rem;
        right: 0.5rem;
        width: 11.1rem;
        height: 8.7rem;
    }     
}

.cost-intern-bot-box-container h3 {
    padding-left: 5rem;
    font-style: normal;
    font-weight: 700;
    font-size: 2.4rem;
    line-height: 2.9rem;
    letter-spacing: 0.1em;
    color: #000000;
    position: relative;
    margin-bottom: 6.1rem;
    @media screen and (max-width: 767px) {
        padding-left: 2rem;
        font-size: 1.8rem;
        line-height: 2.2rem;
        margin-bottom: 3.1rem;
    }
}

.cost-intern-bot-box-container h3::before {
    content: "";
    position: absolute;
    width: 1.7rem;
    height: 8.7rem;
    left: -0.5rem;
    top: 0;
    bottom: 0;
    margin: auto;
    background: #FF5F25;
    border-radius: 0.9rem;
}
#nav-green  h3::before {
    content: "";
    position: absolute;
    width: 1.7rem;
    height: 8.7rem;
    left: -0.5rem;
    top: 0;
    bottom: 0;
    margin: auto;
    background: #4AAD96;
    border-radius: 0.9rem;
}
@media screen and (max-width: 767px) {
    .cost-intern-bot-box-container h3::before, #nav-green  h3::before {
        width: 1rem;
    }
      
}

.intern-title-bar-page-container {
    margin-bottom: 2rem;
    display: flex;
    gap: 1.7rem;
    align-items: center;
}


.intern-bar-page-title {
    font-style: normal;
    font-weight: 700;
    font-size: 2rem;
    /* line-height: 23px; */
    letter-spacing: 0.1em;
    color: #FF5F25;
    white-space: nowrap;
    @media screen and (max-width: 767px) {
        font-size: 1.8rem;
    }
}

.intern-bar-page-bar {
    background-color: #FF5F25;
    width: 100%;
    height: 0.3rem;
    @media screen and (max-width: 767px) {
        display: none;
    }
}

#nav-green .intern-bar-page-title, #nav-green .toujitsu-container h4 span {
    color: #4AAD96;
}

#nav-green .intern-bar-page-bar {
    background-color: #4AAD96;
}

#nav-green .beige-buble-box-container {
    background-color: #DBF8F1;
}

.list-intern-container {
    margin-bottom: 4rem;
}

.inter-box-paragraph-program {
    font-style: normal;
    font-weight: 500;
    font-size: 1.6rem;
    line-height: 2.6rem;
    letter-spacing: 0.1em;
    color: #000000;
    margin-bottom: 4rem;
    @media screen and (max-width: 767px) {
        font-size: 1.4rem;
        line-height: 2rem;
    }
}

.list-intern-container li {
    font-style: normal;
    font-weight: 500;
    font-size: 1.6rem;
    line-height: 2.6rem;
    letter-spacing: 0.1em;
    color: #000000;
    list-style: disc;
    padding-left: 1rem;
    list-style-position: inside;
    text-indent: 0.5rem !important;
}

.tojitsu-box-mega-container {
    display: flex;
    gap: 3.7rem;
    margin-bottom: 4rem;
    margin-top: 4rem;
    @media screen and (max-width: 767px) {
        flex-direction: column;
    }
}

.toujitsu-container h4 {
    font-style: normal;
    font-weight: 700;
    font-size: 1.8rem;
    /* line-height: 18px; */
    text-align: left;
    letter-spacing: 0.1em;
    color: #000000;
    margin-bottom: 2rem;
    @media screen and (max-width: 767px) {
        font-size: 1.6rem;
        margin-bottom: 1rem;
        text-align: left;
    }
}

.toujitsu-container h4 span {
    color: #FF5F25;
}

.toujitsu-container p {
    font-style: normal;
    font-weight: 500;
    font-size: 1.4rem;
    line-height: 2.2rem;
    letter-spacing: 0.1em;
    color: #000000;
    max-width: 27.4rem;
}

.voices-top-container {
    margin-top: 4rem;
    display: flex;
    gap: 4rem;
    @media screen and (max-width: 767px) {
        gap: 1rem;
    }   
}

.beige-buble-box-container {
    font-style: normal;
    font-weight: 500;
    font-size: 1.6rem;
    line-height: 2.6rem;
    letter-spacing: 0.1em;
    color: #000000;
    padding: 1.7rem 3.4rem;
    background-color: #FFE9DB;
    border-radius: 3.1rem;
    position: relative;
    @media screen and (max-width: 767px) {
        font-size: 1.3rem;
        line-height: 2rem;
        padding: 1.7rem 3rem;
    }
}

.beige-buble-box-container::before {
    content: "";
    position: absolute;
    left: -1rem;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 2.2rem;
    height: 2.2rem;
    background: url("../../img/page/internship/beige-bubble.svg") no-repeat;
    background-size: contain;
}


.bubble-beige-reverse::before {
    left: auto;
    right: -1rem;
    transform: rotate(60deg);
}

#nav-green .beige-buble-box-container::before {
    background: url("../../img/page/internship/green-bubble.svg") no-repeat;
    background-size: contain;
}

.middle-bubble-container {
    margin: 2rem;
}

.bottom-bubble-container {
    display: flex;
    justify-content: flex-end;
}

.middle-bubble-container .beige-buble-box-container {
    border-radius: 5.1rem;
}

.bottom-bubble-container .beige-buble-box-container {
    border-radius: 7rem;
    max-width: 90.1rem;
}

.inter-button-red {
    width: 67.7rem;
    height: 6.8rem;
    position: relative;
    font-style: normal;
    font-weight: 700;
    font-size: 2rem;
    /* line-height: 23px; */
    letter-spacing: 0.1em;
    color: #FFFFFF;
    margin: 6rem auto 11rem;
    background-color: #E72D30;
    text-decoration: none;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 3.4rem;
    transition: all 0.3s ease;
    @media screen and (max-width: 767px) {
        width: 100%;
        height: 4rem;
        font-size: 1.2rem;
        margin: 6rem auto 9rem;
    }
}

.inter-button-red:hover {
    opacity: 0.7;
}

.inter-button-red::before {
    position: absolute;
    content: "";
    width: 1.4rem;
    height: 1.4rem;
    right: 6.3rem;
    top: 0.3rem;
    bottom: 0;
    margin: auto;
    background: url("../../common/img/footer/goto-icon.svg") no-repeat;
    background-size: contain;
}

@media screen and (max-width: 767px) {
    .inter-button-red::before {
        width: 1.1rem;
        height: 1.1rem;
        right: 0.8rem;
        top: 0rem;
        bottom: 0;
    }
      
}

.join-flex-container {
    display: flex;
    justify-content: space-between;
    position: relative;
    margin-top: 5.7rem;
    margin-bottom: 11rem;
}

.join-flex-container::before {
    position: absolute;
    content: "";
    width: 100%;
    height: 2px;
    background-color: #E72D30;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    z-index: -1;
}

.join-box-container {
    width: 39rem;
    height: 13.1rem;
    background: #E72D30;
    padding-top: 2.2rem;
    padding-left: 2.9rem;
    padding-bottom: 2.2rem;
}

.join-box-title-flex-container {
    display: flex;
    gap: 1rem;
    margin-bottom: 0.6rem;
    align-items: center;
}

.join-box-number {
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 700;
    font-size: 1.8rem;
    /* line-height: 18px; */
    text-align: center;
    color: #E72D30;
    width: 3.7rem;
    height: 3.7rem;
    border-radius: 50%;
    background: #FFFFFF;
    display: flex;
    align-items: center;
    justify-content: center;
}

.join-box-title {
    font-style: normal;
    font-weight: 700;
    font-size: 1.8rem;
    line-height: 1.8rem;
    letter-spacing: 0.1em;
    color: #FFFFFF;
}

.join-box-main-text {
    font-style: normal;
    font-weight: 500;
    font-size: 1.4rem;
    line-height: 2.2rem;
    letter-spacing: 0.1em;
    color: #FFFFFF;
    max-width: 31.3rem;
}

.qAa-container {
    display: flex;
    flex-direction: column;
    margin-bottom: 11rem;
    gap: 2rem;
    @media screen and (max-width: 767px) {
        margin-bottom: 9rem;
    }
}

.qAa-box-container {
    padding: 3.6rem 4rem;
    background-color: white;
    @media screen and (max-width: 767px) {
        padding: 2.6rem 2rem;
    }
}

.qAa-box-container h3 {
    font-style: normal;
    font-weight: 700;
    font-size: 1.8rem;
    /* line-height: 18px; */
    letter-spacing: 0.1em;
    color: #0033B3;
    margin-bottom: 1.4rem;
    @media screen and (max-width: 767px) {
        font-size: 1.6rem;
        margin-bottom: 0.5rem;
    }
}

.qAa-box-container p {
    font-style: normal;
    font-weight: 500;
    font-size: 1.4rem;
    line-height: 2.2rem;
    letter-spacing: 0.1em;
    color: #000000;
}

.infos-contact {
    font-style: normal;
    font-weight: 700;
    font-size: 1.8rem;
    line-height: 2.8rem;
    letter-spacing: 0.1em;
    color: #000000;
    @media screen and (max-width: 767px) {
        font-size: 1.4rem;
        line-height: 2.2rem;
    }
}

.footer-up {
    margin-top: -8.5rem;
}

.infos-contact a {
/* font-family: 'Noto Sans JP';
font-style: normal;
font-weight: 700;
font-size: 18px;
line-height: 28px; */
letter-spacing: 0.1em;
text-decoration-line: underline;
color: #0033B3;
}

.infos-contact a:hover {
    opacity: 0.8;
    text-decoration: none;
}