@charset "UTF-8";

@media (min-width:768px) {

    .sp-only,
    .merit.sp-only {
        display: none;
    }

}


/*Mobile--------------------------------------------*/

@media only screen and (max-width: 767px) {


.wrapper{
overflow: hidden;}

    .pc-only,
    .merit.pc-only {
        display: none;
    }

    .hero {
        position: relative;
        width: 100vw;
        height: 100vh;
        overflow: hidden;
        background: #fff;
    }

    .hero video,
    .main_img,
    .hero .catchcopy {
        position: absolute;
        top: 0;
        left: 0;
        width: 100vw;
        height: 100dvh;
        object-fit: cover;
        transition: opacity 1.5s ease;
    }

    #catchcopy img {
        height: auto;
        position: relative;
        width: 300px;
        top: -10%;
    }

    .hero.image-mode {
        height: auto;
    }

    .hero.image-mode .main_img {
        position: relative;
        width: 100%;
        height: auto;
    }

    .merit {
        position: relative;
        display: block;
        background-color: #fff;
        border: #eaf4dc 20px solid;
        height: auto;
        padding-bottom: 40px;

    }

    .merit ul {
        display: block;
    }

    .merit li img {
        display: block;
        margin: 0 auto;
        width: 100%;
    }

    .merit p {
        font-size: 2.8rem;
        font-weight: bold;
        text-align: center;
        color: #32b4dc;
        margin-top: 10px;
        line-height: 1.4;
        font-feature-settings: "palt";
    }


    /* メリット */


    .merit.sp-only li {
        position: relative;
    }

    .merit.sp-only li:nth-child(2) {
        display: block;
        position: absolute;
        top: 23%;
        left: -25%;
        z-index: 1;
        overflow: hidden;
        width: 58%;
    }

    .merit.sp-only li:nth-child(4) {
        display: block;
        position: absolute;
        top: 62%;
        right: -30%;
        z-index: 1;
        overflow: hidden;
        width: 58%;
    }

    /* アンカーリンク */

    .anchorlink {
        height: 120px;
    }

    .anchorlink ul {
        display: flex;
        justify-content: center;
        padding-top: 10px;
    }

    .anchorlink ul li {
        position: relative;
        display: block;
        width: 30%;
        height: 80px;
        background-color: #32b4dc;
        margin-left: 2px;
        box-shadow: #333333 0px 2px;
        transition: 0.3s;
    }

    .anchorlink ul li img {
        display: block;
        height: 55%;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }



    /* features */

    #features {
        margin-top: 10px;
        padding: 0 20px;
    }

    .features_title {
        height: 60px;
        display: block;
        border-bottom: 1px solid #32b4dc;
    }

    .features_title img {
        transform: scale(0.6);
        transform-origin: 0% 50%;
    }

    .features_title_translation {
        font-size: 18px;
        margin: 0px;
    }

    .features_wrapper p {
        position: relative;
        margin: 10px 0px 0px 10px;
        font-size: 1.5rem;
        line-height: 2.6rem;
        font-weight: bold;
        font-feature-settings: "palt";
        color: #333;
    }

    .features_wrapper .features_02 p:nth-child(4) {
        position: relative;
        margin: 20px 0px 0px 10px;
        font-size: 1.5rem;
        line-height: 2.6rem;
        font-weight: bold;
        font-feature-settings: "palt";
        color: #333;
    }


    .features_01,
    .features_02,
    .features_03 {
        margin: 20px 0px 0px 0px;
        position: relative;
    }


    .features_01 .features_no_01,
    .features_02 .features_no_02,
    .features_03 .features_no_03 {
        transform: scale(0.8);
        transform-origin: center;
    }

    .features_01 .features_lead,
    .features_02 .features_lead,
    .features_03 .features_lead {
        font-size: 2rem;
        margin: 0 0 0 20px;
    }

    .no_01_outer,
    .no_02_outer,
    .no_03_outer {
        margin-top: 10px;
    }

    .features_01 ul {
        margin: 20px 0px 0px 30px;
        font-size: 1.4rem;
        line-height: 2.5rem;
        font-feature-settings: "palt";
    }

    .features_01 ul li {
        margin-top: 2px;
    }

    .features_02_outer {
        margin-left: 0;
    }

    .features_02 ul {
        margin: 20px 0px 0px 30px;
        font-size: 1.4rem;
        line-height: 2.2rem;
        font-feature-settings: "palt";
    }

    .features_02 ul li {
        margin-top: 10px;
    }

    .bold_blue {
        font-size: 1.5rem;
        font-weight: bold;
        color: #32b4dc;
    }


    .no_02_outer {
        display: flex;
        align-items: center;
        margin-left: 0px;
    }

    .features_03 .features_03_text {
        font-weight: normal;
        font-size: 1.3rem;
        margin: 10px 0px 0px 10px;
        line-height: 2.3rem;
        font-feature-settings: "palt";
        color: #333;
    }

    .features_img_mobile {
        width: 100%;
    }


    .business_partner {
        margin-top: 30px;
    }

    .business_partner_title {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 2rem;
        font-weight: bold;
        color: #32b4dc;
        letter-spacing: 5px;
    }

    .business_partner .cap {
        display: block;
        position: relative;
        font-size: 1.2rem;
        margin: 0px 0px 10px;
        top: -5px;
        text-align: center;
        font-weight: normal;
    }

    .business_partner_list {
        padding: 0 40px;
        position: relative;
        font-size: 1.3rem;
        line-height: 2.2rem;
    }

    .open-modal-btn {
        color: #fff;
        border: 0px;
        display: flex;
        justify-content: center;
        align-items: center;
        margin: auto;
        font-size: 16px;
        width: 250px;
        height: 70px;
        background-color: #32b4dc;
        box-shadow: #333333 0px 2px;
        transition: 0.3s;
        border-radius: 5px;
        cursor: pointer;
        font-weight: bold;
    }

    /* コンテンツエリアをスクロール可能にする */
    .modal-content {
        text-align: center;
        background: #fff;
        /* 内側に白背景をつけてもOK */
        width: 90%;
        max-width: 800px;
        max-height: 90vh;
        /* 高さ制限 */
        overflow-y: auto;
        /* 縦スクロール可 */
        border-radius: 8px;
        padding: 30px;
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
    }

    .modal-content_title {
        font-size: 1.8rem;
        font-weight: bold;
        color: #32b4dc;
    }

    .modal-content p {
        font-size: 1.3rem;
        line-height: 2.5rem;
        margin: 0;
        font-weight: normal;
    }

    .modal-content p:nth-of-type(1),
    .modal-content p:nth-of-type(12) {
        margin-top: 20px;
        color: #32b4dc;
        font-weight: bold;
    }



    /* 閉じるボタン */
    .modal-close {
        position: absolute;
    top: 3%;
    right: 3%;
        width: 50px;
        height: 50px;
        border: none;
        background: transparent;
        font-size: 50px;
        cursor: pointer;
        color: #000000;
    }


    /* description */

    #description {
        margin-top: 10px;
        padding: 0 20px;
    }

    .description_title {
        height: 60px;
        display: block;
        border-bottom: 1px solid #32b4dc;
    }

    .description_title img {
        transform: scale(0.6);
        transform-origin: 0% 50%;
    }

    .description_title_translation {
        font-size: 18px;
        margin: 0px;
    }

    .description_title_text {
        text-align: center;
        font-size: 16px;
        margin: 20px 0 0;
        line-height: 2.5rem;
        font-feature-settings: "palt";
    }

    .description_grid {
        display: grid;
        gap: 10px;
        grid-template-columns: 1fr 1fr;
        grid-template-rows: 150px 150px 150px 150px 130px 130px;
        justify-content: center;
        
        background-color: #eaf4dc;
        width: 100%;
        padding: 30px 30px;
        margin: 30px 0;
    }

    .description_item {
        background-color: #fff;
        display: flex;
        justify-content: center;
        align-items: center;
    }


    .description_itemx2.di_09 {
        margin-top: 0px;
        background-color: #fff;
        grid-column: 1 / 3;
        grid-row: 5 / 7;
    }

    .description_itemx2.di_10 {
        margin-top: 0px;

        background-color: #fff;
        grid-column: 1 / 3;
        grid-row: 7 / 9;
    }


    .description_itemx2 {
        display: grid;
        align-items: center;
        height: 270px;
    }



    .description_itemx2_title {
        text-align: center;
        font-size: 20px;
        line-height: 1.2em;
        font-weight: bold;
        color: #32b4dc;
        margin: 0;
    }

    .description_itemx2_text {
        margin-top: 10px;
        text-align: center;
        font-size: 14px;
        line-height: 1.6em;
        font-weight: normal;
        color: #333;
        font-feature-settings: "palt";
    }



    /* recruitments 応募要項表 */

    #recruitments {
        margin-top: 10px;
        padding: 0 20px;
    }

    .recruitments_title {
        height: 60px;
        display: block;
        border-bottom: 1px solid #32b4dc;
    }

    .recruitments_title img {
        transform: scale(0.6);
        transform-origin: 0% 50%;
    }

    .recruitments_title_translation {
        font-size: 18px;
        margin: 0px;
    }

    .recruitments_title_text {
        text-align: center;
        font-size: 16px;
        margin: 20px 0 0;
        line-height: 2.5rem;
        font-feature-settings: "palt";
    }

    .requirements_table {
        border-collapse: collapse;
        margin-left: auto;
        margin-right: auto;
        margin-top: 30px;
        margin-bottom: 30px;
        width: 100%;
        font-feature-settings: "palt";
        /* border-bottom: 1px solid #808080; */
        border-top: 1px solid #808080;
    }

    .requirements_table td {
        padding-top: 20px;
        padding-right: 15px;
        padding-left: 15px;
        padding-bottom: 20px;
        overflow: visible;
        line-height: 2.2rem;
        box-sizing: border-box;
        border-collapse: separate;
        font-size: 1.4rem;
        border-bottom: 1px solid #808080;
        border-top: 1px solid #808080;
        display: block;
    }

    .requirements_table th {
        display: block;
        background-color: #32b4dc;
        color: #ffffff;
        padding-top: 00px;
        text-align: center;
        padding: 5px;
        width: 100%;
        font-size: 1.4rem;
        font-weight: bold;
        border-bottom: 0 solid #808080;
        border-top: 0px solid #808080;
        line-height: 2rem;
    }


    .spacer {
        display: block;
        width: 100%;
        height: 150px;
        background-color: #32b4dc;
        background-blend-mode: multiply;
        background-size: cover;
        margin-top: 50px;
    }


    /* < !-- アコーディオン --> */

    .construction {
        width: 100%;
        margin: 0 auto 50px;
        font-feature-settings: "palt";
    }

    .construction_title {
        height: 25px;
        margin-bottom: 30px;
    }

    .construction_title p {
        font-size: 20px;
        text-align: center;
        font-weight: bold;
    }

    .bl_accordionContent {
        opacity: 0;
        height: 0;
        overflow: hidden;
        transition: all 0.3s ease;
        border-top: 1px solid #808080;
    }

    .bl_accordionContent.open {
        opacity: 1;
        height: auto;

    }

    .bl_accordionTitle {
        position: relative;
        cursor: pointer;
        padding: 0 50px 0;
        border-radius: 5px;
        background-color: #96c850;
        transition: background-color 0.3s ease;
        height: 60px;
        display: flex;
        justify-content: center;
        align-items: center;
        margin-bottom: 10px;
    }

    .bl_accordionTitle p {
        color: #fff;
        font-size: 15px;
        line-height: 1.6rem;
        transition: background-color 0.3s ease;
    }

    .bl_accordionTitle.active {
        background-color: #66ac00;
        margin-bottom: 20px;
    }

    .bl_accordionTitle p::after {
        display: block;
        position: absolute;
        font-size: 25px;
        top: 20px;
        bottom: 0;
        right: 15px;
        content: "\e313";
        font-family: "Material Icons";
        transition: 0.5s;
        color: rgb(255, 255, 255);
    }


    .bl_accordionTitle.active p::after {
        display: block;
        position: absolute;
        font-size: 25px;
        top: 20px;
        bottom: 0;
        right: 15px;
        content: "\e316";
        font-family: "Material Icons";
        transition: 0.5s;
        color: rgb(255, 255, 255);
    }



    /* アコーディオンテーブル */

    .tg {
        border-collapse: collapse;
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 30px;
        width: 100%;
    }

    .tg td {
        display: block;
        padding-top: 10px;
        padding-right: 15px;
        padding-left: 15px;
        padding-bottom: 20px;
        overflow: visible;
        line-height: 2.5rem;
        box-sizing: border-box;
        border-collapse: separate;
        font-size: 1.4rem;
        border-bottom: 0px solid #808080;
        border-top: 0px solid #808080;
    }

    .tg .midashi {
        display: block;
        background-color: #aaa;
        color: #ffffff;
        padding-top: 00px;
        text-align: center;
        padding: 5px;
        width: 100%;
        font-size: 1.4rem;
        font-weight: bold;
        border-bottom: 0 solid #808080;
        border-top: 0px solid #808080;
        line-height: 2rem;
    }

    .tg .honbun {
        width: 100%;
        padding-top: 20px;
        padding-right: 15px;
        padding-left: 15px;
        padding-bottom: 20px;
        overflow: visible;
        line-height: 2.2rem;
        box-sizing: border-box;
        border-collapse: separate;
        font-size: 1.4rem;
        display: block;
        border-bottom: 01px solid #808080;
        border-top: 1px solid #808080;
    }


}