@charset "utf-8";

/*==================================================
[sp]mv
================================================== */
.mv {
    margin: 0 auto;
}

.mv_contents {
    position: relative;
    width: 100%;
    height: 133.333333333333333vw;
    background: #000;
}

.mv figure {
    display: none;
}

.mv .splide__slide img {
    width: auto;
    height: 133.333333333333333vw;
}

.splide__pagination,
#splide-play-pause {
    display: none !important;
}


.mv_copy {
    margin: 0 auto;
    width: 89.333333333333333vw;
    position: absolute;
    bottom: 5.333333333333333vw;
    left: 5.333333333333333vw;
    text-align: left;
}

.mv_copy_primary {
    margin-bottom: 2.666666666666667vw;
}

.mv_copy_primary p {
    font-family: var(--font-family-jp);
    font-size: 6.933333333333333vw;
    font-weight: 400;
    line-height: normal;
    white-space: nowrap;
    color: var(--color-white);
    background: linear-gradient(90deg, var(--color-secondary) 0%, var(--color-accent) 100%);
    padding: 2.666666666666667vw;
    display: inline-block;
}

.mv_copy_primary p+p {
    margin-top: 1.6vw;
}

.mv_copy_secondary p {
    color: var(--color-primary);
    font-size: 4.266666666666667vw;
    line-height: 1.8;
    background-color: var(--color-white);
    padding: 1.066666666666667vw 2.666666666666667vw;
    display: inline-block;
}

.mv_copy_secondary p+p {
    margin-top: 1.066666666666667vw;
}


/*==================================================
[sp]about
================================================== */
.about_contents {
    width: 100%;
    background-image:
        url("../img/bg_top_sp.webp"),
        linear-gradient(180deg, #F6FDFF 0%, #D8EDFF 39.9%, #CCE6FD 70.19%, #A4CFF5 100%);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: 100% auto, 100% 100%;
    padding: 0 0 21.333333333333333vw;
}

.about {
    position: relative;
    width: 100%;
    padding: 11.733333333333333vw 5.333333333333333vw 0;
    text-align: center;
}

.about_title {
    font-family: var(--font-family-jp);
    font-size: 7.466666666666667vw;
    font-weight: 400;
    line-height: 1;
    color: var(--color-black);
    margin-bottom: 4.266666666666667vw;
}

.about_subtitle {
    font-family: var(--font-family-en);
    font-size: 4.266666666666667vw;
    font-weight: 600;
    line-height: 1;
    color: var(--color-primary);
    margin-bottom: 8.533333333333333vw;
}

.about_text {
    margin: 0 auto 8.533333333333333vw;
    width: 89.333333333333333vw;
}

.about_text p {
    font-family: var(--font-family-jp);
    font-size: 4.266666666666667vw;
    font-weight: 400;
    line-height: 2;
    color: var(--color-blue-dark);
    text-align: center;
    margin-bottom: 0;
}

/*==================================================
[sp]business
================================================== */
.business {
    margin: 0 auto 14.933333333333333vw;
    width: 89.333333333333333vw;
}

.business_card {
    position: relative;
    width: 89.333333333333333vw;
}

.business_card a {
    display: block;
    background-color: var(--color-white);
    margin-bottom: 6.4vw;
    padding: 4.266666666666667vw 4.266666666666667vw 6.4vw;
}

.business_card figure {
    width: 80.8vw;
    height: 53.866666666666667vw;
    border-radius: 2.133333333333333vw;
    overflow: hidden;
    margin-bottom: 8vw;
}

.business_card figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.business .business_card:last-child {
    margin-bottom: 0;
}

.business_card_content {
    position: relative;
    padding: 0 21.333333333333333vw 0 0;
}

.business_card_content::before {
    content: '';
    width: 13.333333333333333vw;
    height: 8.533333333333333vw;
    border-radius: 4.266666666666667vw;
    border: 0.266666666666667vw solid var(--color-primary);
    position: absolute;
    top: calc(50% - 4.266666666666667vw);
    right: 0;
    pointer-events: none;
}

.business_card_content::after {
    content: '';
    width: 4.266666666666667vw;
    height: 2.133333333333333vw;
    background-color: var(--color-primary);
    -webkit-mask: var(--icon-arrow-link);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    -webkit-mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    position: absolute;
    top: calc(50% - 1.066666666666667vw);
    right: 4.266666666666667vw;
    pointer-events: none;
}

.business_card_title_container {
    margin-bottom: 3.2vw;
    display: flex;
    align-items: center;
}

.business_card_title {
    font-family: var(--font-family-jp);
    font-size: 6.4vw;
    font-weight: 400;
    line-height: 1.5;
    color: var(--color-black);
}

.business_card_subtitle {
    margin-left: 4.266666666666667vw;
    font-family: var(--font-family-en);
    font-size: 3.733333333333333vw;
    font-weight: 600;
    line-height: 1;
    color: var(--color-primary);
}

.business_card_text {
    font-family: var(--font-family-jp);
    font-size: 4.266666666666667vw;
    font-weight: 400;
    line-height: 1.8;
    color: var(--color-black);
}

/*==================================================
[sp]contribution
================================================== */
.contribution {
    position: relative;
    width: 100%;
    padding: 12.8vw 5.333333333333333vw;
    background: var(--color-white-60);
}

.contribution_title_container {
    margin-bottom: 3.2vw;
    display: flex;
    align-items: center;
}

.contribution_title {
    font-family: var(--font-family-jp);
    font-size: 6.4vw;
    font-weight: 400;
    line-height: 1.5;
    color: var(--color-black);
}

.contribution_subtitle {
    margin-left: 4.266666666666667vw;
    font-family: var(--font-family-en);
    font-size: 3.733333333333333vw;
    font-weight: 600;
    line-height: 1;
    color: var(--color-primary);
}

.contribution_text {
    margin-bottom: 8.533333333333333vw;
    font-family: var(--font-family-jp);
    font-size: 4.266666666666667vw;
    font-weight: 400;
    line-height: 1.8;
    color: var(--color-black);
}

.contribution figure {
    border-radius: 2.133333333333333vw;
    overflow: hidden;
    margin-bottom: 8vw;
}

.contribution figure img {
    width: 100%;
    height: auto;
}

/*==================================================
[sp]company
================================================== */
.company {
    width: 100%;
    height: 198.133333333333333vw;
    position: relative;
    padding: 21.333333333333333vw 0 0;
    background: var(--color-blue-light);

    background: var(--color-blue-light) url('../img/illust_wheat.svg') no-repeat right -6.666666666666667vw bottom 2.666666666666667vw;
    background-size: auto 58.666666666666667vw;
}

.company_title {
    font-family: var(--font-family-jp);
    font-size: 7.466666666666667vw;
    font-weight: 400;
    line-height: 1;
    color: var(--color-black);
    text-align: center;
    margin-bottom: 4.266666666666667vw;
}

.company_subtitle {
    font-family: var(--font-family-en);
    font-size: 4.266666666666667vw;
    font-weight: 600;
    line-height: 1;
    color: var(--color-primary);
    text-align: center;
    margin-bottom: 8.533333333333333vw;
}

.company figure {
    width: 100vw;
    position: absolute;
    top: 45.333333333333333vw;
    left: 0;
}

.company figure img {
    width: 100%;
    height: auto;
}

.company_menu {
    width: 80.8vw;
    background: var(--color-white-85);
    padding: 8.533333333333333vw;
    z-index: 10;
    position: absolute;
    top: 91.466666666666667vw;
    left: calc(50% - 40.4vw);
}

.company_menu_item {
    position: relative;
    display: flex;
    align-items: center;
    padding: 4.266666666666667vw 0 4.266666666666667vw 6.4vw;
    border-bottom: 0.266666666666667vw solid var(--color-light-gray);
}

.company_menu_item::before {
    content: '';
    width: 2.133333333333333vw;
    height: 2.133333333333333vw;
    background-color: var(--color-primary);
    border-radius: 50%;
    position: absolute;
    top: calc(50% - 1.066666666666667vw);
    left: 1.066666666666667vw;
    pointer-events: none;
}

.company_menu_item a {
    font-family: var(--font-family-jp);
    font-size: 4.266666666666667vw;
    font-weight: 400;
    line-height: 8.533333333333333vw;
    color: var(--color-black);
    text-decoration: none;
    position: relative;
    display: block;
    width: 100%;
    min-height: 8.533333333333333vw;
}

.company_menu_item a::before {
    content: '';
    width: 13.333333333333333vw;
    height: 8.533333333333333vw;
    border-radius: 4.266666666666667vw;
    border: 0.266666666666667vw solid var(--color-primary);
    position: absolute;
    top: calc(50% - 4.266666666666667vw);
    right: 0;
    pointer-events: none;
}

.company_menu_item a:hover::before {
    background: var(--color-primary);
}

.company_menu_item a::after {
    content: '';
    width: 4.266666666666667vw;
    height: 2.133333333333333vw;
    background-color: var(--color-primary);
    -webkit-mask: var(--icon-arrow-link);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    -webkit-mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    position: absolute;
    top: calc(50% - 1.066666666666667vw);
    right: 4.266666666666667vw;
    pointer-events: none;
}

.company_menu_item a:hover::after {
    background-color: var(--color-white);
}

/*==================================================
[sp]news
================================================== */
.news {
    background: var(--color-white);
    padding: 21.333333333333333vw 0;
}

.news_title {
    font-family: var(--font-family-jp);
    font-size: 7.466666666666667vw;
    font-weight: 400;
    line-height: 1;
    color: var(--color-black);
    text-align: center;
    margin-bottom: 4.266666666666667vw;
}

.news_subtitle {
    font-family: var(--font-family-en);
    font-size: 4.266666666666667vw;
    font-weight: 600;
    line-height: 1;
    color: var(--color-primary);
    text-align: center;
    margin-bottom: 8.533333333333333vw;
}

.news_list {
    border-top: 0.266666666666667vw solid var(--color-light-gray);
    margin: 0 auto 10.666666666666667vw;
    width: 89.333333333333333vw;
}

.news_item {
    position: relative;
    padding: 6.4vw 0;
    border-bottom: 0.266666666666667vw solid var(--color-light-gray);
}

.news_item a {
    padding: 0 18.666666666666667vw 0 0;
    position: relative;
    display: block;
}

.news_item a::before {
    content: '';
    width: 13.333333333333333vw;
    height: 8.533333333333333vw;
    border-radius: 4.266666666666667vw;
    border: 0.266666666666667vw solid var(--color-primary);
    position: absolute;
    top: calc(50% - 4.266666666666667vw);
    right: 0;
    pointer-events: none;
}

.news_item a::after {
    content: '';
    width: 4.266666666666667vw;
    height: 2.133333333333333vw;
    background-color: var(--color-primary);
    -webkit-mask: var(--icon-arrow-link);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    -webkit-mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    position: absolute;
    top: calc(50% - 1.066666666666667vw);
    right: 4.266666666666667vw;
    pointer-events: none;
}

.news_label {
    display: flex;
    align-items: center;
    margin-bottom: 4.266666666666667vw;
}

.news_category {
    margin-left: 6.4vw;
    font-family: var(--font-family-jp);
    font-size: 3.733333333333333vw;
    font-weight: 400;
    line-height: 1;
    background: var(--color-blue-light);
    color: var(--color-black);
    padding: 2.133333333333333vw;
}

.news_date {
    font-family: var(--font-family-jp);
    font-size: 3.733333333333333vw;
    font-weight: 400;
    line-height: 1;
    color: var(--color-gray);
    display: block;
}

.news_text {
    font-family: var(--font-family-jp);
    font-size: 4.266666666666667vw;
    font-weight: 400;
    line-height: 1.8;
    color: var(--color-black);
}

.btn_news_more a {
    margin: 0 auto;
    padding: 0 5.333333333333333vw 0 0;
    width: 80.8vw;
    height: 17.066666666666667vw;
    border-radius: 10.666666666666667vw;
    border: 0.266666666666667vw solid var(--color-light-gray);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    font-size: 3.733333333333333vw;
    color: var(--color-black);
    text-decoration: none;
}

.btn_news_more a::before {
    content: '';
    width: 13.333333333333333vw;
    height: 8.533333333333333vw;
    border-radius: 4.266666666666667vw;
    border: 0.266666666666667vw solid var(--color-primary);
    position: absolute;
    top: calc(50% - 4.266666666666667vw);
    right: 4.266666666666667vw;
    pointer-events: none;
}

.btn_news_more a::after {
    content: '';
    width: 4.266666666666667vw;
    height: 2.133333333333333vw;
    background-color: var(--color-primary);
    -webkit-mask: var(--icon-arrow-link);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    -webkit-mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    position: absolute;
    top: calc(50% - 1.066666666666667vw);
    right: 8.533333333333333vw;
    pointer-events: none;
}

/*==================================================
[sp]contact
================================================== */
.contact {
    margin: 0 0 32vw;
    position: relative;
    width: 100%;
    height: 94.933333333333333vw;
    background-image: url('../img/bg_contact.webp');
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    overflow: hidden;
}

.contact_content {
    position: relative;
    z-index: 1;
    width: 89.333333333333333vw;
    height: 84.266666666666667vw;
    background: var(--color-white);
    margin: 5.333333333333333vw auto 0;
    padding: 12.8vw 5.333333333333333vw;
    text-align: center;
}

.contact_title {
    font-family: var(--font-family-en);
    font-size: 9.066666666666667vw;
    font-weight: 600;
    line-height: 1;
    background: linear-gradient(90deg, var(--color-secondary) 0%, var(--color-accent) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: 6.4vw;
}

.contact_text {
    margin-bottom: 12.8vw;
}

.contact_text p {
    font-family: var(--font-family-jp);
    font-size: 4.266666666666667vw;
    font-weight: 400;
    line-height: 1.8;
    color: var(--color-black);
    margin-bottom: 0;
}

.contact .btn_contact {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 80.8vw;
    height: 17.066666666666667vw;
    background: linear-gradient(90deg, var(--color-secondary) 0%, var(--color-accent) 100%);
    border-radius: 13.333333333333333vw;
    padding: 0 5.333333333333333vw;
    font-family: var(--font-family-jp);
    font-size: 4.8vw;
    font-weight: 400;
    line-height: 1.5;
    color: var(--color-white);
    position: relative;
}

.contact .btn_contact a {
    width: 80.8vw;
    height: 17.066666666666667vw;
    display: flex;
    align-items: center;
    justify-content: center;
}

.contact .btn_contact::before {
    content: '';
    width: 13.333333333333333vw;
    height: 8.533333333333333vw;
    border-radius: 4.266666666666667vw;
    border: 0.266666666666667vw solid var(--color-white);
    position: absolute;
    top: calc(50% - 4.266666666666667vw);
    right: 4.266666666666667vw;
    pointer-events: none;
}

.contact .btn_contact::after {
    content: '';
    width: 4.266666666666667vw;
    height: 2.133333333333333vw;
    background-color: var(--color-white);
    -webkit-mask: var(--icon-arrow-link);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    -webkit-mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    position: absolute;
    top: calc(50% - 1.066666666666667vw);
    right: 8.533333333333333vw;
    pointer-events: none;
}



/*==================================================
PC
================================================== */
@media (min-width: 768px) {

    .pc_item {
        display: block;
    }

    .top_contents {
        padding: 40px 0 0;
        background: var(--color-blue-light) url('../img/bg_top_pc.webp') no-repeat center top;
        background-size: 100% auto;
    }


    /*==================================================
    [pc]mv
    ================================================== */

    .mv {
        margin: 0 auto;
        padding: 0 90px;
        max-width: 1070px;
        min-width: 780px;
    }

    .mv_contents {
        margin: 0 auto;
        padding: 0;
        width: auto;
        height: auto;
        max-width: 980px;
        border-radius: 30px;
        background: none;
        display: flex;
        align-items: flex-end;
        justify-content: center;
        position: relative;
        overflow: visible;
    }

    .mv .splide {
        border-radius: 30px;
        overflow: hidden;
    }

    .mv .splide__slide img {
        width: auto;
        height: auto;
    }

    .splide_control {
        position: absolute;
        bottom: 30px;
        left: 30px;
        width: auto;
        height: 40px;
        display: flex;
        flex-wrap: nowrap;
        align-items: center;
        background: var(--color-white);
        border-radius: 4px;
        padding: 0 20px;
    }

    .no_slide .splide_control {
        display: none;
    }


    .splide__pagination,
    #splide-play-pause {
        display: block !important;
    }

    #splide .splide__pagination {
        position: static;
        margin-right: 12px;
        padding: 0;
        display: flex !important;
        flex-wrap: nowrap;
    }

    @property --p {
        syntax: '<angle>';
        inherits: false;
        initial-value: 0turn;
    }

    .splide__pagination button {
        margin: 0 12px 0 0;
        width: 22px;
        height: 22px;
        background: none;
        position: relative;
        opacity: 1;
    }

    .splide__pagination button::after {
        content: '';
        width: 22px;
        height: 22px;
        background-color: var(--color-primary);
        -webkit-mask: var(--icon-dot);
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        -webkit-mask-size: 100% 100%;
        -webkit-mask-repeat: no-repeat;
        -webkit-mask-position: center;
        position: absolute;
        top: 0;
        right: 0;
        pointer-events: none;
    }

    .splide__pagination button.is-active {
        width: 22px;
        height: 22px;
        border-radius: 50%;
        background: none;
        transform: scale(1);
    }

    .splide__pagination button.is-active::before {
        content: '';
        position: absolute;
        inset: 0;
        border-radius: 50%;
        pointer-events: none;
        background: conic-gradient(var(--color-primary) 0turn var(--p), transparent 0turn);
        -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 2px), #000 calc(100% - 2px));
        mask: radial-gradient(farthest-side, transparent calc(100% - 2px), #000 calc(100% - 2px));
        animation: circle-draw 5s ease-out forwards;
    }

    .splide__pagination button.is-active::after {
        content: '';
        width: 22px;
        height: 22px;
        position: absolute;
        top: 0;
        left: 0;
        pointer-events: none;
    }

    @keyframes circle-draw {
        to {
            --p: 1turn;
        }
    }

    @media (prefers-reduced-motion: reduce) {
        .splide__pagination button.is-active::before {
            animation: none;
            --p: 1turn;
        }
    }

    .splide__pagination__page:hover {
        opacity: 1;
    }

    .splide__toggle {
        width: 12px;
        height: 12px;
        position: relative;
    }

    .splide__toggle .splide__toggle__play {
        content: '';
        width: 9px;
        height: 10.5px;
        background-color: var(--color-primary);
        -webkit-mask: var(--icon-play);
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        -webkit-mask-size: 100% 100%;
        -webkit-mask-repeat: no-repeat;
        -webkit-mask-position: center;
        position: absolute;
        top: calc(50% - 5.25px);
        left: calc(50% - 4.5px);
    }

    .splide__toggle .splide__toggle__pause {
        content: '';
        width: 9px;
        height: 12px;
        background-color: var(--color-primary);
        -webkit-mask: var(--icon-pause);
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        -webkit-mask-size: 100% 100%;
        -webkit-mask-repeat: no-repeat;
        -webkit-mask-position: center;
        position: absolute;
        top: calc(50% - 6px);
        left: calc(50% - 4.5px);
    }

    .mv_copy {
        margin: 0;
        width: 620px;
        position: absolute;
        bottom: 60px;
        left: auto;
        right: -90px;
        z-index: 10;
    }

    .mv_copy_primary {
        margin-bottom: 10px;
    }

    .mv_copy_primary p {
        font-family: var(--font-family-jp);
        font-size: 50px;
        font-weight: 400;
        line-height: normal;
        white-space: nowrap;
        color: var(--color-white);
        background: linear-gradient(90deg, var(--color-secondary) 0%, var(--color-accent) 100%);
        padding: 10px;
        display: inline-block;
    }

    .mv_copy_primary p+p {
        margin-top: 10px;
    }

    .mv_copy_secondary {
        display: flex;
    }

    .mv_copy_secondary p {
        color: var(--color-primary);
        font-size: 20px;
        line-height: 1.8;
        background-color: var(--color-white);
        padding: 4px 0 4px 10px;
        display: inline-block;
    }

    .mv_copy_secondary p+p {
        margin-top: 0;
        padding: 4px 10px 4px 0;
    }


    /*==================================================
    [pc]about
    ================================================== */
    .about_contents {
        background: none;
        padding: 0;
    }

    .about {
        position: relative;
        width: 100%;
        min-width: 960px;
        margin: 0 auto;
        padding: 80px 20px 0;
        text-align: center;
    }

    .about_title {
        font-family: var(--font-family-jp);
        font-size: 36px;
        font-weight: 400;
        line-height: 1;
        color: var(--color-black);
        margin-bottom: 24px;
    }

    .about_subtitle {
        font-family: var(--font-family-en);
        font-size: 20px;
        font-weight: 600;
        line-height: 1;
        color: var(--color-primary);
        margin-bottom: 56px;
    }

    .about_text {
        margin: 0 auto 56px;
        width: 600px;
    }

    .about_text p {
        font-family: var(--font-family-jp);
        font-size: 20px;
        font-weight: 400;
        line-height: 2;
        color: var(--color-blue-dark);
        text-align: center;
        margin-bottom: 0;
    }

    /*==================================================
    [pc]business
    ================================================== */
    .business {
        margin: 0 auto;
        padding-bottom: 56px;
        width: 100%;
        max-width: 1164px;
        min-width: 960px;
        display: flex;
        justify-content: space-between;
        flex-wrap: nowrap;
        gap: 27px;
    }

    .business_card {
        width: auto;
        margin: 0;
        padding: 0;
        width: calc((100% - 54px) / 3);
    }

    .business_card a {
        position: relative;
        background-color: var(--color-white);
        width: 100%;
        display: block;
        margin: 0;
        padding: 24px 24px 40px;
        border: 6px solid var(--color-white);
        border-radius: 16px;
        transition: var(--transition-normal);
        box-sizing: border-box;
    }

    .business_card a:hover {
        border: 6px solid var(--color-primary);
    }

    .business_card figure {
        width: 100%;
        height: auto;
        border-radius: 8px;
        overflow: hidden;
        margin-bottom: 32px;
    }

    .business_card figure img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .business .business_card:last-child {
        margin-bottom: 0;
    }

    .business_card_content {
        position: relative;
        padding: 0 74px 0 0;
    }

    .business_card_content::before {
        content: '';
        width: 50px;
        height: 32px;
        border-radius: 16px;
        border: 1px solid var(--color-primary);
        position: absolute;
        top: calc(50% - 16px);
        right: 0;
        transform: translateX(0px);
        pointer-events: none;
        transition: var(--transition-normal);
    }

    a:hover .business_card_content::before {
        background: var(--color-primary);
        transform: translateX(8px);
    }

    .business_card_content::after {
        content: '';
        width: 16px;
        height: 8px;
        background-color: var(--color-primary);
        -webkit-mask: var(--icon-arrow-link);
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        -webkit-mask-size: 100% 100%;
        -webkit-mask-repeat: no-repeat;
        -webkit-mask-position: center;
        position: absolute;
        top: calc(50% - 4px);
        right: 16px;
        pointer-events: none;
        transition: var(--transition-normal);
        transform: translateX(0px);
    }

    a:hover .business_card_content::after {
        background-color: var(--color-white);
        transform: translateX(8px);
    }

    .business_card_title_container {
        margin-bottom: 0;
        display: flex;
        align-items: center;
    }

    .business_card_title {
        font-family: var(--font-family-jp);
        font-size: 28px;
        font-weight: 400;
        line-height: 1.5;
        color: var(--color-black);
        white-space: nowrap;
    }

    .business_card_subtitle {
        margin-left: 16px;
        font-family: var(--font-family-en);
        font-size: 14px;
        font-weight: 600;
        line-height: 1;
        color: var(--color-primary);
    }

    .business_card_text {
        font-family: var(--font-family-jp);
        font-size: 16px;
        font-weight: 400;
        line-height: 1.8;
        color: var(--color-black);
    }

    /*==================================================
    [pc]contribution
    ================================================== */
    .contribution {
        position: relative;
        width: auto;
        max-width: 1164px;
        min-width: 880px;
        margin: 0 auto;
        padding: 40px;
        background: var(--color-white-60);
    }

    .contribution_content_container {
        margin: 0 auto;
        width: auto;
        max-width: 930px;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .contribution_content {
        margin-right: 40px;
        width: auto;
        max-width: 590px;
    }

    .contribution_title_container {
        margin-bottom: 0;
        display: flex;
        align-items: center;
    }

    .contribution_title {
        font-family: var(--font-family-jp);
        font-size: 28px;
        font-weight: 400;
        line-height: 1.5;
        color: var(--color-black);
    }

    .contribution_subtitle {
        margin-left: 16px;
        font-family: var(--font-family-en);
        font-size: 14px;
        font-weight: 600;
        line-height: 1;
        color: var(--color-primary);
    }

    .contribution_text {
        margin: 0;
        font-family: var(--font-family-jp);
        font-size: 16px;
        font-weight: 400;
        line-height: 1.8;
        color: var(--color-black);
    }

    .contribution figure {
        width: 300px;
        height: 200px;
        border-radius: 8px;
        overflow: hidden;
        margin: 0;
    }

    .contribution figure img {
        width: 100%;
        height: auto;
    }

    /*==================================================
    [pc]company
    ================================================== */
    .company {
        width: 100%;
        min-width: 960px;
        height: 848px;
        position: relative;
        padding: 120px 0 0;
        background: var(--color-blue-light) url('../img/illust_wheat.svg') no-repeat right 20px bottom 50px;
        background-size: 262px auto;
    }


    .company_content {
        margin: 0 auto;
        padding: 0 40px;
        width: auto;
        max-width: 1244px;
        min-width: 1040px;
        min-width: 960px;
        height: 612px;
        position: relative;
    }

    .company_title {
        font-family: var(--font-family-jp);
        font-size: 36px;
        font-weight: 400;
        line-height: 1;
        color: var(--color-black);
        text-align: center;
        margin-bottom: 24px;
    }

    .company_subtitle {
        font-family: var(--font-family-en);
        font-size: 20px;
        font-weight: 600;
        line-height: 1;
        color: var(--color-primary);
        text-align: center;
        margin-bottom: 0;
    }

    .company figure {
        width: 840px;
        height: 472px;
        border-radius: 32px;
        overflow: hidden;
        position: absolute;
        top: 136px;
        left: 40px;
    }

    .company figure img {
        width: 100%;
        height: auto;
    }

    .company_menu {
        width: 440px;
        background: var(--color-white-85);
        padding: 40px 48px 56px;
        z-index: 10;
        position: absolute;
        top: 182px;
        left: auto;
        right: 40px;
    }

    .company_menu_item {
        position: relative;
        display: flex;
        align-items: center;
        padding: 16px 0 16px 24px;
        border-bottom: 1px solid var(--color-light-gray);
    }

    .company_menu_item::before {
        content: '';
        width: 8px;
        height: 8px;
        background-color: var(--color-primary);
        border-radius: 50%;
        position: absolute;
        top: calc(50% - 4px);
        left: 4px;
        pointer-events: none;
    }

    .company_menu_item a {
        font-family: var(--font-family-jp);
        font-size: 20px;
        font-weight: 400;
        line-height: 32px;
        color: var(--color-black);
        text-decoration: none;
        position: relative;
        display: block;
        width: 100%;
        min-height: 32px;
        transition: var(--transition-normal);
    }

    .company_menu_item a:hover {
        color: var(--color-primary);
        text-decoration: none;
    }

    .company_menu_item a::before {
        content: '';
        width: 50px;
        height: 32px;
        border-radius: 16px;
        border: 1px solid var(--color-primary);
        position: absolute;
        top: calc(50% - 16px);
        right: 0;
        pointer-events: none;
        transition: var(--transition-normal);
        transform: translateX(0px);
    }

    .company_menu_item a:hover::before {
        background: var(--color-primary);
        transform: translateX(8px);
    }

    .company_menu_item a::after {
        content: '';
        width: 16px;
        height: 8px;
        background-color: var(--color-primary);
        -webkit-mask: var(--icon-arrow-link);
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        -webkit-mask-size: 100% 100%;
        -webkit-mask-repeat: no-repeat;
        -webkit-mask-position: center;
        position: absolute;
        top: calc(50% - 4px);
        right: 16px;
        pointer-events: none;
        transition: var(--transition-normal);
        transform: translateX(0px);
    }

    .company_menu_item a:hover::after {
        transform: translateX(8px);
    }


    @media (max-width: 960px) {
        .company figure {
            width: 740px;
            height: 416px;
            border-radius: 32px;
            overflow: hidden;
            position: absolute;
            top: 136px;
            left: 40px;
        }

        .company_menu {
            position: absolute;
            top: 166px;
            left: auto;
            right: 40px;
        }
    }

    /*==================================================
    [pc]news
    ================================================== */
    .news {
        background: var(--color-white);
        padding: 120px 0;
    }

    .news_content {
        margin: 0 auto 32px;
        padding: 0 40px;
        width: auto;
        max-width: 1244px;
        min-width: 1040px;
        min-width: 960px;
        display: flex;
    }

    .news_title_container {
        margin-right: 136px;
    }

    .news_title {
        font-family: var(--font-family-jp);
        font-size: 36px;
        font-weight: 400;
        line-height: 1;
        color: var(--color-black);
        text-align: center;
        margin: 40px 0 24px;
        white-space: nowrap;
    }

    .news_subtitle {
        font-family: var(--font-family-en);
        font-size: 20px;
        font-weight: 600;
        line-height: 1;
        color: var(--color-primary);
        text-align: center;
        margin: 0;
    }

    .news_list {
        border-top: 1px solid var(--color-light-gray);
        margin: 0;
        width: 920px;
    }

    .news_item {
        position: relative;
        padding: 32px 0;
        border-bottom: 1px solid var(--color-light-gray);
    }

    .news_item a {
        padding: 0 90px 0 0;
        position: relative;
        display: block;
        transition: var(--transition-normal);
    }

    .news_item a:hover {
        color: var(--color-primary);
        text-decoration: none;
    }

    .news_item a::before {
        content: '';
        width: 50px;
        height: 32px;
        border-radius: 16px;
        border: 1px solid var(--color-primary);
        position: absolute;
        top: calc(50% - 16px);
        right: 0;
        pointer-events: none;
        transition: var(--transition-normal);
        transform: translateX(0px);
    }

    .news_item a:hover::before {
        background: var(--color-primary);
        transform: translateX(8px);
    }


    .news_item a::after {
        content: '';
        width: 16px;
        height: 8px;
        background-color: var(--color-primary);
        -webkit-mask: var(--icon-arrow-link);
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        -webkit-mask-size: 100% 100%;
        -webkit-mask-repeat: no-repeat;
        -webkit-mask-position: center;
        position: absolute;
        top: calc(50% - 4px);
        right: 16px;
        pointer-events: none;
        transition: var(--transition-normal);
        transform: translateX(0px);
    }

    .news_item a:hover::after {
        background-color: var(--color-white);
        transform: translateX(8px);
    }

    .news_label {
        display: flex;
        align-items: center;
        margin-bottom: 18px;
    }

    .news_category {
        margin-left: 24px;
        font-family: var(--font-family-jp);
        font-size: 14px;
        font-weight: 400;
        line-height: 1;
        background: var(--color-blue-light);
        color: var(--color-black);
        padding: 8px;
    }

    .news_date {
        font-family: var(--font-family-jp);
        font-size: 16px;
        font-weight: 400;
        line-height: 1;
        color: var(--color-gray);
        display: block;
    }

    .news_text {
        font-family: var(--font-family-jp);
        font-size: 18px;
        font-weight: 400;
        line-height: 1.8;
        color: var(--color-black);
        transform: var(--transition-normal);
    }

    .news_item a:hover .news_text {
        color: var(--color-primary);
        text-decoration: underline;
    }


    .btn_news_more {
        margin: 0 auto;
        width: 960px;
    }

    .btn_news_more a {
        margin: 0 auto;
        padding: 0 20px 0 0;
        width: 380px;
        height: 80px;
        border-radius: 40px;
        border: 1px solid var(--color-light-gray);
        display: flex;
        align-items: center;
        justify-content: center;
        position: relative;
        font-size: 16px;
    }

    .btn_news_more a:hover {
        color: var(--color-primary);
        text-decoration: none;
    }

    .btn_news_more a::before {
        content: '';
        width: 50px;
        height: 32px;
        border-radius: 16px;
        border: 1px solid var(--color-primary);
        position: absolute;
        top: calc(50% - 16px);
        right: 24px;
        pointer-events: none;
        transition: var(--transition-normal);
        transform: translateX(0px);
    }

    .btn_news_more a::after {
        content: '';
        width: 16px;
        height: 8px;
        background-color: var(--color-primary);
        -webkit-mask: var(--icon-arrow-link);
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        -webkit-mask-size: 100% 100%;
        -webkit-mask-repeat: no-repeat;
        -webkit-mask-position: center;
        position: absolute;
        top: calc(50% - 4px);
        right: 40px;
        pointer-events: none;
        transition: var(--transition-normal);
        transform: translateX(0px);
    }

    .btn_news_more a:hover::before {
        background: var(--color-primary);
        transform: translateX(8px);
    }

    .btn_news_more a:hover::after {
        background-color: var(--color-white);
        transform: translateX(8px);
    }


    /*==================================================
    [pc]contact
    ================================================== */
    .contact {
        margin: 0 0 180px;
        padding: 56px 40px;
        position: relative;
        width: 100%;
        height: auto;
        overflow: hidden;
        display: flex;
        align-items: center;
        justify-content: center;
        background-image: url('../img/bg_contact.webp');
        background-repeat: no-repeat;
        background-position: center;
        background-size: cover;
    }

    .contact_content {
        position: relative;
        z-index: 1;
        width: 100%;
        max-width: 1244px;
        min-width: 880px;
        margin: 0 auto;
        padding: 0 40px;
        height: 352px;
        background: var(--color-white);
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }

    .contact_title {
        font-family: var(--font-family-en);
        font-size: 40px;
        font-weight: 600;
        line-height: 1;
        background: linear-gradient(90deg, var(--color-secondary) 0%, var(--color-accent) 100%);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text;
        margin-bottom: 32px;
    }

    .contact_text {
        margin-bottom: 20px;
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
    }

    .contact_text p {
        font-family: var(--font-family-jp);
        font-size: 30px;
        font-weight: 400;
        line-height: 1.8;
        color: var(--color-black);
        margin-bottom: 0;
    }

    .contact .btn_contact {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 580px;
        height: 100px;
        border-radius: 50px;
        padding: 0;
        font-family: var(--font-family-jp);
        font-size: 30px;
        font-weight: 400;
        line-height: 1.5;
        color: var(--color-white);
        position: relative;
        transition: var(--transition-normal);
        border: 1px solid transparent;
        position: relative;
    }

    .contact .btn_contact a {
        display: block;
        width: 580px;
        height: 100px;
        border-radius: 50px;
        background: var(--color-white);
        color: var(--color-white);
        transition: var(--transition-normal);
        opacity: 1;
    }

    .contact .btn_contact a:hover {
        background: linear-gradient(90deg, var(--color-white) 0%, var(--color-white) 100%);
        color: var(--color-primary);
        text-decoration: none;
        border: 1px solid var(--color-primary);
    }

    .contact .btn_contact a .text {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 580px;
        height: 100px;
        position: absolute;
        top: 0;
        left: 0;
        z-index: 100;
        color: var(--color-white);
    }

    .contact .btn_contact:hover .text {
        color: var(--color-primary);
    }

    .contact .btn_contact .bg {
        width: 580px;
        height: 100px;
        border-radius: 50px;
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        background: linear-gradient(90deg, var(--color-secondary) 0%, var(--color-accent) 100%);
        pointer-events: none;
        z-index: 10;
        transition: var(--transition-normal);
        opacity: 1;
    }

    .contact .btn_contact:hover .bg {
        opacity: 0;
    }

    .contact .btn_contact::before {
        content: '';
        width: 50px;
        height: 32px;
        border-radius: 16px;
        border: 1px solid var(--color-white);
        position: absolute;
        top: calc(50% - 16px);
        right: 34px;
        z-index: 100;
        pointer-events: none;
        transition: var(--transition-normal);
        transform: translateX(0px);
    }

    .contact .btn_contact:hover::before {
        border: 1px solid var(--color-primary);
        background: var(--color-primary);
        transform: translateX(8px);
    }

    .contact .btn_contact::after {
        content: '';
        width: 14px;
        height: 6px;
        background-color: var(--color-white);
        -webkit-mask: var(--icon-arrow-link);
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        -webkit-mask-size: 100% 100%;
        -webkit-mask-repeat: no-repeat;
        -webkit-mask-position: center;
        position: absolute;
        top: calc(50% - 3px);
        right: 50px;
        pointer-events: none;
        transition: var(--transition-normal);
        transform: translateX(0px);
        z-index: 100;
    }

    .contact .btn_contact:hover::after {
        transform: translateX(8px);
    }


}
