@charset "utf-8";
/*--京index.css--*/
/* ##########PC########## */
.main_visual_box{
    background-image: url("../shared/home/bg_mv.jpg");
    background-repeat: no-repeat;
    background-position: center top;
    background-size: 100% auto;
    padding: 6rem 0 0 0;
}

    .main_visual_box > .box_inner{
        display: flex;
        justify-content: center;
        align-items: center;
        position: relative;
        padding: 5rem 0 2.75rem 0;
    }

        .main_visual_box > .box_inner::after{
            content: "";
            display: block;
            width: 100%;
            height: 7.575rem;
            background: #fff;
            position: absolute;
            top: 14.175rem;
            left: 0;
            z-index: 1;
        }

        .main_visual_box > .box_inner::before{
            content: "";
            display: block;
            width: 100%;
            height: 14.375rem;
            background-image: url("../shared/home/bg_round_top.png");
            background-repeat: no-repeat;
            background-size: auto 14.375rem;
            background-position: center top;
            position: absolute;
            top: 0;
            left: 0;
            z-index: 1;
        }

        .main_visual_box > .box_inner .fig{
            z-index: 2;
            width: 19.25rem;
            margin: 0 3.5rem;
        }

        .main_visual_box > .box_inner .fig img{
            max-width: 100%;
            height: auto;
        }

        .main_visual_box > .box_inner p{
            z-index: 2;
        }

        .main_visual_box > .box_inner p .lbl1,
        .main_visual_box > .box_inner p .lbl2,
        .main_visual_box > .box_inner p .lbl3{
            font-size: 1.5rem;
            font-weight: 600;
            display: block;
            margin-bottom: 1.6rem;
        }

        .main_visual_box > .box_inner p .lbl3{
            margin-bottom: 0;
        }

        .main_visual_box > .box_inner p .lbl1 strong,
        .main_visual_box > .box_inner p .lbl2 strong,
        .main_visual_box > .box_inner p .lbl3 strong{
            color: #03306d;
            position: relative;
            font-weight: 700;
        }

        .main_visual_box > .box_inner p .lbl1 strong::before,
        .main_visual_box > .box_inner p .lbl2 strong::before,
        .main_visual_box > .box_inner p .lbl3 strong::before{
            content:"";
            width: 100%;
            height: 3px;
            background: #ea4807;
            position: absolute;
            bottom: -0.5rem;
            left: 0;
        }

/*common_box*/
.common_box{
    padding: 5rem 0 4.375rem 0;
}

    .common_box > .box_header{
        display: flex;
        justify-content: center;
        margin-bottom: 2rem;
    }

        .common_box > .box_header h2{}

            .common_box > .box_header h2 img{
                height: 3.25rem;
            }

    .common_box > .box_inner{
        width: 56.875rem;
        line-height: 1.5;
        margin: 0 auto;
    }

    .common_box > .box_inner h3{
        font-size: 1.3rem;
        color: #03306d;
        font-weight: 700;
        padding: 0.5rem;
        margin-bottom: 3rem;
        border-bottom: 2px solid #0d3072;
    }

/*生体情報研究センター概要*/
.about_us_box{
    background: #edf0f9;
}

    .about_us_box > .box_inner{}

    .about_us_box > .box_inner .block1{
        margin-bottom: 2rem;
    }

    .about_us_box > .box_inner .block1 p{
        line-height: 1.8;
    }

    .about_us_box > .box_inner .block2{
        display: flex;
        justify-content: flex-start;
        gap: 1.5rem;
    }

    .about_us_box > .box_inner .block2 .text{
        flex: 1;
    }

        .about_us_box > .box_inner .block2 .text ol{
            margin-bottom: 1.5rem;
        }

        .about_us_box > .box_inner .block2 .text ol li{
            position: relative;
            padding-left: 2rem;
            font-size: 1.2rem;
            color: #03306d;
            font-weight: 700;
            margin-bottom: 0.5rem;
        }

        .about_us_box > .box_inner .block2 .text ol li::before{
            content: "";
            font-size: 1.2rem;
            color: #03306d;
            font-weight: 700;
            position: absolute;
            top: 0;
            left: 0;
        }

        .about_us_box > .box_inner .block2 .text ol li:first-child:before{
            content:"1";
        }
        .about_us_box > .box_inner .block2 .text ol li:nth-child(2):before{
            content:"2";
        }
        .about_us_box > .box_inner .block2 .text ol li:nth-child(3):before{
            content:"3";
        }

        .about_us_box > .box_inner .block2 .text p{
            line-height: 1.8;
        }

        .about_us_box > .box_inner .block2 .fig{
            width: 24rem;
        }

        .about_us_box > .box_inner .block2 .fig img{
            max-width: 100%;
            height: auto;
        }

/*お知らせ・活動報告*/
.news_box{
    border-bottom: 2px solid #ebebeb;
}

    .news_box > .box_header{

    }

        .news_box > .box_header h2{}

    .news_box > .box_inner{
        margin: 0 auto 2.4rem;
    }

        .news_box > .box_inner .news_list{}

        .news_box > .box_inner .news_list ul{
            line-height: 1.6;
            font-size: 0.94rem;
        }

            .news_box > .box_inner .news_list ul li{
                border-bottom: 1px solid #ccc;
            }

            .news_box > .box_inner .news_list ul li a{
                display: flex;
                justify-content: flex-start;
                align-items: flex-start;
                padding: 0.8em;
                gap: 1.2rem;
                color: #222;
                text-decoration: none;
            }

            .news_box > .box_inner .news_list ul li .entry_date{
                color: #555;
                white-space: nowrap;
            }

            .news_box > .box_inner .news_list ul li .entry_cat{
                width: 6rem;
                color: #fff;
                font-size: 0.9rem;
                padding: 0.1rem 0;
                border-radius: 1rem;
                background: #e24707;
                text-align: center;
            }

            .news_box > .box_inner .news_list ul li .entry_cat.cat_news{
                background: #e24707;
            }
            .news_box > .box_inner .news_list ul li .entry_cat.cat_activity{
                background: #027d6e;
            }
            .news_box > .box_inner .news_list ul li .entry_cat.cat_report{
                background: #6a44ab;
            }

            .news_box > .box_inner .news_list ul li .entry_title{
                flex: 1;
            }

                .news_box > .box_inner .news_list ul li a .entry_title{
                    color: #222;
                    text-decoration: none;
                    transition: .3s all ease;
                }

                .news_box > .box_inner .news_list ul li a:hover .entry_title{
                    color: #5c74cc;
                    text-decoration: underline;
                }

    .news_box > .box_footer .goto_news{
        display: flex;
        justify-content: center;
        margin-bottom: 2rem;
    }

        .news_box > .box_footer .goto_news a{
            box-sizing: border-box;
            display: flex;
            align-items: center;
            color: #0a326e;
            height: 21px;
            padding-left: 30px;
            background-image: url("../shared/icon_cir_tri2.png");
            background-repeat: no-repeat;
            background-size: 21px auto;
            background-position: left center;
            font-size: 0.96rem;
            text-decoration: none;
            padding-bottom: 0.1rem;
            transition: .3s all ease;
        }

        .news_box > .box_footer .goto_news a:hover{
            filter: brightness(130%);
        }

    .news_box > .box_footer .goto_etc ul{
        display: flex;
        justify-content: center;
        gap: 2.5rem;
    }

    .news_box > .box_footer .goto_etc ul li{
        width: 17.125rem;
    }

    .news_box > .box_footer .goto_etc ul li a{
        display: block;
        font-size: 1.1rem;
        padding: 0.8rem 2rem;
        background: #fff;
        border: 2px solid #4b64c8;
        color: #4b64c8;
        font-weight: 600;
        text-align: center;
        border-radius: 2rem;
        position: relative;
        text-decoration: none;
        transition: .3s all ease;
    }

    .news_box > .box_footer .goto_etc ul li a::after{
        content:"";
        width: 1.25rem;
        aspect-ratio: 1 / 1;
        background: url(../shared/icon_arrow_blue.png) no-repeat;
        background-size: contain;
        position: absolute;
        top: calc(50% - 0.625rem);
        right: 1.3rem;
        transition: .3s all ease;
    }

    .news_box > .box_footer .goto_etc ul li a:hover::after{
        right: 1rem;
    }

/*組織・メンバー*/
.member_box{}

.member_box .fig_org_chart{
    margin-bottom: 4rem
}

.member_box .fig_org_chart dl{
    width: 51.5rem;
    margin: 0 auto;
}

.member_box .fig_org_chart dl dt{
    font-size: 1.2rem;
    font-weight: 500;
    margin-bottom: 1rem;
}

.member_box .fig_org_chart dl dd{}

.member_box .fig_org_chart dl dd img{
    max-width: 100%;
    height: auto;
}

.member_box .member_list{
    display: flex;
    justify-content: flex-start;
    gap: 2.5rem;
    margin: 0 2rem;
}

.member_box .member_list dl{
    width: calc((100% - 2.5rem) / 2);
}

.member_box .member_list dl dt{
    font-size: 1.1rem;
    font-weight: 600;
    padding-left: 0.3rem;
    margin: 0 0 0.5rem 0;
}

.member_box .member_list dl dd table tr:nth-child(odd){
    background: #fafafa;
}

.member_box .member_list dl dd table tr:nth-child(even){
    background: #edf0f9;
}

.member_box .member_list dl dd table{
    width: 100%;
    border-top: 2px solid #cccccc;
    border-bottom: 2px solid #cccccc;
}

.member_box .member_list dl dd table th{
    width: 6rem;
    padding: 0.4rem 1rem;
    white-space: nowrap;
}

.member_box .member_list dl dd table th a{
    color: #222;
    text-decoration: none;
    transition: .3s all ease;
    position: relative;
    padding-right: 1.2rem;
}

.member_box .member_list dl dd table th a::before{
    font-family: FontAwesome;
    content: "\f1c1";
    color: #800000;
    font-size: 0.95rem;
    position: absolute;
    top: 0.1rem;
    right: 0;
}

.member_box .member_list dl dd table th a:hover{
    text-decoration: underline;
}

.member_box .member_list dl dd table td{
    padding: 0.4rem 1rem;
}

/*寄附のお願い*/
.contribute_box{
    box-sizing: border-box;
    height: 22.5rem;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
    padding: 4rem 0 0 0;
}

.contribute_box::before{
    content:"";
    width: 100vw;
    min-width: 68.75rem;
    aspect-ratio: 2200 / 720;
    background: url(../shared/home/bg_kifu.jpg) no-repeat;
    background-size: contain;
    position: absolute;
    top: 0;
    left: calc(50% - 50vw);
    z-index: -1;
}

.contribute_box .box_inner p{
    color: #fff;
    text-align: center;
    font-size: 0.9rem;
    line-height: 1.8;
}

.contribute_box .box_footer{
    display: flex;
    justify-content: center;
    margin-top: 2.5rem;
}

.contribute_box .box_footer .goto_kikin{
    width: 17.5rem;
}

.contribute_box .box_footer .goto_kikin a{
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 1rem 2rem;
    background: #fff;
    text-align: center;
    text-decoration: none;
    color: #00225b;
    font-weight: 600;
    border-radius: 2rem;
}

.contribute_box .box_footer .goto_kikin a::after{
    content: "";
    width: 0.8125rem;
    aspect-ratio: 1 / 1;
    background: url(../shared/icon_link_blue.png);
    background-size: contain;
    margin-left: 1rem;
}

/*お問い合わせ*/
.contact_box{}

.contact_box > .box_inner{
    display: flex;
    justify-content: flex-start;
    gap: 2.5rem;
}

.contact_box > .box_inner .gmap{
    width: 30rem;
    border: 1px solid #ccc;
    padding: 2px 2px 0 2px;
}

.contact_box > .box_inner .gmap iframe{
    max-width: 100%;
    height: 17.5rem;
}

.contact_box > .box_inner .text{
    margin-top: 1rem;
    flex: 1;
}

.contact_box > .box_inner .text .center_name{
    color: #4b64c8;
    margin-bottom: 1.5rem;
}

.contact_box > .box_inner .text .addr{
    margin-bottom: 1.5rem;
}

@media screen and (min-width:1px) and (max-width:1400px) {
}

/* ##########SP横向き########## */
@media screen and (min-width:1px) and (max-width:768px) {


}

/* ##########SP########## */
@media screen and (min-width:1px) and (max-width:479px) {
    .main_visual_box{
        background-size: 200% auto;
        padding: 7vw 0 0 0;
    }

    .main_visual_box > .box_inner{
        padding: 5.25vw 0 6vw 0;
        flex-direction: column;
    }

    .main_visual_box > .box_inner:before {
        content: "";
        display: block;
        width: 100%;
        height: 28.75vw;
        background-image: url(../shared/home/bg_round_top.png);
        background-repeat: no-repeat;
        background-size: auto 28.75vw;
        background-position: center top;
        position: absolute;
        top: 0.5vw;
        left: 0;
        z-index: 1;
    }

    .main_visual_box > .box_inner:after{
        height: calc(100% - 28.75vw);
        top: 28.75vw;
    }

    .main_visual_box > .box_inner .fig{
        width: 46.2vw;
        margin: 0 auto 6vw auto;
    }

    .main_visual_box > .box_inner p .lbl1,
    .main_visual_box > .box_inner p .lbl2,
    .main_visual_box > .box_inner p .lbl3{
        font-size: 1.3rem;
        margin-bottom: 1.5rem;
    }

    .main_visual_box > .box_inner p .lbl1 strong::before,
    .main_visual_box > .box_inner p .lbl2 strong::before,
    .main_visual_box > .box_inner p .lbl3 strong::before{
        height: 2px;
        bottom: -0.4rem;
    }

    .common_box{
        padding: 10vw 0 8vw 0;
    }

    .common_box > .box_header{
        margin-bottom: 1.5rem;
    }

    .common_box > .box_inner{
        width: 90vw;
    }

    .common_box > .box_inner h3{
        margin-bottom: 6vw;
    }

    /*生体情報研究センター概要*/
    .about_us_box > .box_inner{
        display: block;
        width: 90vw;
        margin: 0 auto;
    }

    .about_us_box > .box_inner .block2{
        flex-direction: column;
    }

    .about_us_box > .box_inner .block2 .fig{
        width: 48vw;
        margin: 0 auto;
    }


    /*お知らせ・活動報告*/
    .news_box{
        padding: 14vw 5vw 12vw 5vw;
    }

    .news_box > .box_inner{
        width: auto;
    }

    .news_box > .box_inner .news_list ul li{
        display: block;
    }

    .news_box > .box_inner .news_list ul li a{
        flex-wrap: wrap;
        gap: 0.5rem 1.2rem;
    }

    .news_box > .box_inner .news_list ul li .entry_date{
        width: auto;
    }

    .news_box > .box_inner .news_list ul li .entry_title{
        width: 100%;
        flex: unset;
    }

    .news_box > .box_footer .goto_etc ul{
        align-items: center;
        flex-direction: column;
        gap: 4vw;
    }

    .news_box > .box_footer .goto_etc ul li{
        width: 60vw;
    }

    .news_box > .box_footer .goto_etc ul li a{
        font-size: 1rem;
    }

    /*組織・メンバー*/
    .member_box .fig_org_chart dl{
        width: auto;
        margin: 0 3vw;
    }

    .member_box .member_list{
        margin: 0 3vw;
        flex-direction: column;
    }

    .member_box .member_list dl{
        width: 100%;
    }

    /*寄附のお願い*/
    .contribute_box .box_inner p{
        text-align: left;
        line-height: 1.6;
    }

    .contribute_box .box_footer{
        margin-top: 5vw;
    }

    .contribute_box .box_footer .goto_kikin{
        width: 60vw;
    }

    .contribute_box .box_footer .goto_kikin a{
        padding: 0.8rem 2rem;
    }

    /*お問い合わせ*/
    .contact_box > .box_inner{
        flex-direction: column-reverse;
        gap: 5vw;
    }

    .contact_box > .box_inner .text{
        margin-top: 0;
    }

    .contact_box > .box_inner .text .center_name{
        margin-bottom: 1rem;
    }
    .contact_box > .box_inner .text .addr{
        margin-bottom: 1rem;
    }

    .contact_box > .box_inner .gmap{
        width: auto;
    }

}


/* ##########印刷用########## */
@media print{

}