@charset "utf-8";
@import url("joint_institute_teacher_education.css");
/*--京course.css--*/
/* ##########PC########## */
.page_body h2 a{
    color: #333;
    text-decoration: none;
}

.page_body h2 a:hover{
    color: #333;
    text-decoration: underline;
}

.page_body h3 a{
    color: #0892bd;
    text-decoration: none;
}

.page_body h3 a:hover{
    color: #0892bd;
    text-decoration: underline;
}

.course_list_box {}

.course_list_box>ul {
    display: flex;
    flex-wrap: wrap;
    gap: 3rem;
}

.course_list_box>ul>li {
    padding: 0;
    width: calc((100% - 3rem) / 2);
}

.course_list_box>ul>li::before {
    content: none;
}

.course_list_box>ul>li a {
    display: block;
    text-decoration: none;
    color: #1a1a1a;
}

.course_list_box>ul>li a:hover {
    color: #1a1a1a;
}

.course_list_box>ul>li .fig {
    margin-bottom: 1em;
    overflow: hidden;
    border-radius: 1rem;
}

.course_list_box>ul>li .fig img {
    transition: .3s all ease;
}

.course_list_box>ul>li a:hover .fig img {
    transform: scale(1.03);
    filter: brightness(1.2);
}

.course_list_box>ul>li h2 {
    margin: 0 0 0.4em 0;
    padding: 0;
    border: none;
    font-size: 1.4em;
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.course_list_box>ul>li h2::after {
    box-sizing: border-box;
    content: "";
    display: inline-block;
    width: 2.5rem;
    height: 2.5rem;
    border: 2px solid #ff6e32;
    border-radius: 50%;
    background-color: #ff6e32;
    background-image: url(../shared/arr/arr_03.png);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: 1rem auto;
    transition: .3s all ease;
}

.course_list_box>ul>li a:hover h2::after {
    transform: translateX(0.25rem);
}

.course_list_box>ul>li p {
    margin: 0;
}


/*●の色*/
.kind1 {
    /*紫*/
    background: #bc95c3;
}

.kind2 {
    /*緑*/
    background: #c0d34e;
}

.kind3 {
    /*黄*/
    background: #ffef93;
}

.kind4 {
    /*オレンジ*/
    background: #ef8802;
}

.mark_exp_box {
    margin: 0 1.5em;
}

.mark_exp_box>.box_inner {
    display: flex;
}

.mark_exp_box>.box_inner>dl {}

.mark_exp_box>.box_inner>dl>dt {
    font-weight: 500;
    font-size: 1.1em;
    margin-bottom: 0.5em;
    text-align: center;
}

.mark_exp_box>.box_inner>dl>dd {
    display: flex;
    flex-wrap: wrap;
    font-size: 0.94em;
    line-height: 1.4;
}

.mark_exp_box .legend_license_kind {
    flex: 1;
    padding: 0 2em 0 0;
}

.mark_exp_box .legend_license_kind dl {
    display: flex;
    align-items: center;
    margin-bottom: 0.5em;
}

.mark_exp_box .legend_license_kind dl:last-child {
    margin-bottom: 0;
}

.mark_exp_box .legend_license_kind dl dt {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    text-indent: -9999px;
    margin-right: 0.5em;
}

.mark_exp_box .legend_license_kind dl dd {
    flex: 1;
}

.mark_exp_box .legend_license_teacher {
    box-sizing: border-box;
    border-left: 1px dotted #aaa;
    width: 36%;
    padding-left: 1em;
    display: flex;
    flex-wrap: wrap;
}

.mark_exp_box .legend_license_teacher dl {
    display: flex;
    align-items: center;
    width: 50%;
}

.mark_exp_box .legend_license_teacher dl dt {
    font-size: 1.125rem;
    font-weight: 700;
    margin-right: 0.25em;
}

.mark_exp_box .legend_license_teacher dl dd {}

.mark_exp_box>.box_footer {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 1em;
}

.mark_exp_box>.box_footer p {
    margin: 0;
}

.mark_exp_box>.box_footer p:last-child {
    margin-bottom: 0;
}

.mark_exp_box>.box_footer p .example {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    font-size: 1.125rem;
    font-weight: 700;
}


.license_list {}

.license_list ul {
    margin: 0;
    display: flex;
    line-height: 1;
}

.license_list ul li {
    padding: 0;
    margin: 0;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: 700;
    margin-right: 0.25em;
    font-size: 1.125rem;
}

.license_list ul li:last-child {
    margin-right: 0;
}

.license_list ul li::before {
    content: none;
}

.elementary_intro_box {
    margin-bottom: 5em;
}

.yakuwari_box {}

.yakuwari_box>.box_inner {
    background: rgba(253, 200, 25, 0.2);
    margin: 0 1.5em;
    border-radius: 1rem;
    display: flex;
    justify-content: space-between;
    padding: 1em 1em;
}

.yakuwari_box>.box_inner ul {
    margin: 0;
}

.yakuwari_box>.box_inner ul li {
    padding: 0;
    margin: 0;
}

.yakuwari_box>.box_inner ul li::before {
    content: none;
}

.yakuwari_box>.box_inner>ul {}

.yakuwari_box>.box_inner>ul>li {
    background: #fff;
    border-radius: 0.5rem;
    padding: 0.75em 1em;
    box-shadow: 0.125rem 0.125rem 0 0 rgba(0, 0, 0, 0.1);
}

.yakuwari_box>.box_inner>ul>li .lbl_title {
    display: block;
    font-size: 1.05em;
    font-weight: 500;
    text-align: center;
}

.yakuwari_box>.box_inner>ul>li .lbl_example {
    font-size: 0.9em;
    display: block;
    line-height: 1.4;
}

.yakuwari_box>.box_inner>ul.yakuwari1 {
    width: calc(64% - 1em);
}

.yakuwari_box>.box_inner>ul.yakuwari1>li .kyoka_katsudo {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.375em;
    line-height: 1.4;
    margin-top: 0.5em;
}

.yakuwari_box>.box_inner>ul.yakuwari1>li .kyoka_katsudo li {
    border-bottom: 1px solid rgba(0, 0, 0, 0.2);
    padding: 0 0.5em 0.2em;
}

.yakuwari_box>.box_inner>ul.yakuwari1>li .kyoka_katsudo_figs {
    margin-top: 1em;
    display: flex;
    gap: 0.5em;
}

.yakuwari_box>.box_inner>ul.yakuwari1>li .kyoka_katsudo_figs li {
    width: calc((100% - 1em) / 3);
}

.yakuwari_box>.box_inner>ul.yakuwari2 {
    display: flex;
    flex-direction: column;
    width: 36%;
    gap: 0.5em;
}


.major_course_title {
    display: flex;
    border-top: 4px solid #008ab9;
    border-bottom: 2px solid #d3d2d7;
    padding: 1.8em;
    margin: 3em 0 2.7em 0;
}

.major_course_title h2 {
    margin: 0 1em 0 0;
    padding: 0;
    border-top: none;
    border-bottom: 0;
}

.subject_box {
    padding-bottom: 1em;
    padding-right: 1.5em;
    margin-bottom: 3em;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.subject_box>.box_inner,
.course_box>.box_inner {
    display: flex;
}

.subject_box>.box_inner .text,
.course_box>.box_inner .text {
    flex: 1;
    padding-right: 2em;
}

.subject_box>.box_inner .text .subject_title {
    display: flex;
    align-items: center;
    margin-bottom: 1em;
}

.subject_box>.box_inner .text .subject_title h3 {
    margin-top: 0;
    margin-bottom: 0;
}

.subject_box>.box_inner .text h4,
.course_box>.box_inner .text h3 {
    margin-top: 0;
}

.subject_box>.box_inner .fig,
.course_box>.box_inner .fig {
    width: 24rem;
}

/*モーダル用調整*/
.mfp-inline-holder .mfp-content {
    max-width: 1000px;
}

#mark_exp .mark_exp_box {
    box-sizing: border-box;
    background: #fff;
    margin: 0 auto;
    padding: 1.5rem;
    width: 100%;
    line-height: 1.6;
}

#mark_exp .mark_exp_box>.box_header h2 {
    font-weight: 500;
    font-size: 1.18em;
    margin-bottom: 1em;
}

.btn_mark_exp {
    position: fixed;
    bottom: 10rem;
    right: calc(50% - 700px);
    z-index: 11;
}

.btn_mark_exp a {
    display: block;
    text-align: center;
    text-decoration: none;
    line-height: 1.4;
    color: #1a1a1a;
    font-size: 0.9em;
    background: #fff;
    border-radius: 0.25rem;
    box-shadow: 3px 3px 0 0 rgba(0, 0, 0, 0.1);
    padding: 0.5em 0.6em 0.5em 2.25em;
    position: relative;
    border: 1px solid #194664;
    transition: .3s all ease;
}

.btn_mark_exp a::before {
    font-family: FontAwesome;
    content: "\f059";
    font-size: 1.25rem;
    display: inline-block;
    position: absolute;
    top: calc(50% - 0.625rem);
    left: 0.5em;
    line-height: 1;
    color: #194664;
}

.btn_mark_exp a:hover {
    color: #1a1a1a;
    background: rgba(10, 180, 230, 0.1);
}


/*202509改修*/
.contents.course.index .page_body hr.sep{
    border: none;
    margin: 2.5em 0;
}

.goto_outline{
    display: flex;
    justify-content: center;
}

    .goto_outline a{
        width: 500px;
        display: flex;
        flex-direction: column;
        align-items: center;
        transition: .3s all ease;
    }

    .goto_outline a:hover{
        opacity: 0.8;
    }


.course_list_r7_box {}

.course_list_r7_box > .box_header {}

.course_list_r7_box.for_bottom{
    margin-top: 5em;
}

    .course_list_r7_box.for_bottom > .box_header  h2{
        padding: 0.3em 0;
        text-align: center;
        border: none;
        background: #008ab9;
        color: #fff;
        font-size: 1.4em;
        border-radius: 0.25rem;
    }

.course_list_r7_box>.box_inner {}

.course_list_r7_box>.box_inner>ul {
    display: flex;
    flex-wrap: wrap;
    gap: 3rem;
}

.course_list_r7_box>.box_inner>ul>li {
    padding: 0;
    width: calc((100% - 3rem) / 2);

}

.course_list_r7_box>.box_inner>ul>li::before {
    content: none;
}

.course_list_r7_box>.box_inner>ul>li a {
    display: block;
    text-decoration: none;
    color: #1a1a1a;
}

.course_list_r7_box>.box_inner>ul>li a:hover {
    color: #1a1a1a;
}

.course_list_r7_box>.box_inner>ul>li .fig {
    margin-bottom: 1em;
    overflow: hidden;
    border-radius: 1rem;
}

.course_list_r7_box>.box_inner>ul>li .fig img {
    transition: .3s all ease;
}

.course_list_r7_box>.box_inner>ul>li a:hover .fig img {
    transform: scale(1.03);
    filter: brightness(1.2);
}

.course_list_r7_box>.box_inner>ul>li dl dt {
    margin: 0 0 0.4em 0;
    padding: 0;
    border: none;
    font-size: 1.4em;
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-weight: 600;
}

.course_list_r7_box>.box_inner>ul>li dl dt::after {
    box-sizing: border-box;
    content: "";
    display: inline-block;
    width: 2.5rem;
    height: 2.5rem;
    border: 2px solid #ff6e32;
    border-radius: 50%;
    background-color: #ff6e32;
    background-image: url(../shared/arr/arr_03.png);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: 1rem auto;
    transition: .3s all ease;
}

.course_list_r7_box>.box_inner>ul>li a:hover dl dt::after {
    transform: translateX(0.25rem);
}

.course_list_r7_box>.box_inner>ul>li p {
    margin: 0;
}

.page_body .goto_previous{
    display: flex;
    justify-content: center;
    margin-top: 4em;
}

    .goto_previous a{
        text-decoration: none;
        border: 1px solid #194664;
        font-size: 1.05em;
        color: #194664;
        padding: 0.5em 2em;
        box-shadow: 2px 2px 0 0 rgba(0, 0, 0, 0.2);
        transition: .3s all ease;
    }

    .goto_previous a:hover{
        color: #194664;
        box-shadow: 2px 2px 0 0 #194664;
    }


.content_title_wrap.for_jite{
    padding-top: 0;
    position: relative;
    z-index: 1;
    display: flex;
    align-items: flex-end;
    padding-bottom: 1.9rem;
}

    .content_title_wrap.for_jite  .top_parent_title {
        display: flex;
        align-items: flex-end;
    }

    .content_title_for_jite{
        position: relative;
        z-index: 1;
    }

        .content_title_for_jite .lbls{
            display: flex;
            margin-bottom: 0.75em;
            line-height: 1.1;
        }

            .content_title_for_jite .lbls .lbl_katei{
                border-right: 1px solid #333;
                padding-right: 0.6em;
                margin-right: 0.5em;
            }

.backto_course{
    margin-top: -1.5em;
    margin-bottom: 2em;
}

    .backto_course a{
        color: #111;
        text-decoration: none;
        display: inline-block;
        position: relative;
        padding: 0 0.3em 0 0.8em;
        transition: .3s all ease;
    }

    .backto_course a:hover{
        color: #194664;
    }

        .backto_course a::before{
            box-sizing: border-box;
            content: "";
            display: block;
            height: 25%;
            width: 100%;
            border-left: 2px solid #194664;
            border-bottom: 1px solid #194664;
            position: absolute;
            bottom: 0;
            left: 0;
            transform: skewX(-50deg);
            transform-origin: left bottom;
            transition: .3s all ease;
        }

        .backto_course a:hover::before{
            transform: skewX(-50deg) translateX(-0.25em);
        }

.course_outline_box{
    margin-bottom: 5em;
}

.senko_mv_box{
    margin-bottom: 4em;
}

    .senko_mv_box > .box_inner{
        display: flex;
        justify-content: flex-end;
        position: relative;
        background: #eff8ff;
    }

        .senko_mv_box > .box_inner .text{
            box-sizing: border-box;
            position: absolute;
            top: 0;
            left: 0;
            z-index: 1;
            width: 100%;
            height: 100%;
            display: flex;
            padding: 4em 0 0 2em;
        }

            .senko_mv_box > .box_inner .text p{
                display: flex;
                flex-direction: column;
                align-items: flex-start;
                font-size: 2.2em;
                margin: 0;
                font-weight: 700;
                gap: 0.5em;
            }

                .senko_mv_box > .box_inner .text p [class^="lbl"]{
                    background: rgba(255,255,255,0.9);
                    color: #333;
                    border-bottom: 1px solid #0081b9;
                    padding-left: 0.3em;
					padding-right: 0.3em;
                }

        .senko_mv_box > .box_inner .fig{
            position: relative;
            z-index: 0;
        }

.senko_intro_shoraizou_wrapper{
    display: flex;
    align-items: flex-start;
    gap: 3em;
    margin: 5em 0;
}

    .senko_intro_box{
        flex: 1;
    }

        .senko_intro_box > .box_header h2{
            margin: 0;
            padding: 0;
            border: none;
            color: #0081b9;
            font-weight: 700;
            margin: 0 0 1em 0.75em;
        }

    .shoraizou_box{
        box-sizing: border-box;
        width: 20rem;
        background: #fbf2e0;
        line-height: 1.6;
        padding: 1.5em;
        border-radius: 1rem;
    }

        .shoraizou_box > .box_header{
            display: flex;
            justify-content: center;
            border-top: 1px solid #0c4c69;
            border-bottom: 1px solid #0c4c69;
            padding: 0.7em 0;
            margin-bottom: 1em;
        }

            .shoraizou_box > .box_header h2{
                margin: 0;
                padding: 0;
                border: none;
                font-size: 1.4em;
                font-weight: 700;
                color: #0c4c69;
            }

        .shoraizou_box > .box_inner h3{
            margin: 0;
            color: #0c4c69;
            font-size: 1.14em;
            margin-bottom: 0.6em;
            text-align: center;
        }

        .shoraizou_box > .box_inner h4{
            font-size: 1em;
            margin: 0 0 0.5em 0;
            color: #0c4c69;
        }

            .shoraizou_box > .box_inner h4::before{
                content: none;
                font-family: FontAwesome;
                content:"\f0c8";
                font-weight: normal;
                margin-right: 0.3em;
            }

        .shoraizou_box > .box_inner p{
            font-size: 0.94em;
            margin: 0 0 1em 0;
        }

.tokushokuwaku_box{
    background: #eff8ff;
    border-radius: 1rem;
    padding: 2em 1.5em 1.5em 1.5em;
    margin-bottom: 5em;
}

    .tokushokuwaku_box > .box_header{
        display: flex;
    }

        .tokushokuwaku_box > .box_header .text{
            flex: 1;
        }

            .tokushokuwaku_box > .box_header .text h2{
                padding: 0;
                margin: 0 0 0.9em 0.4em;
                border: none;
                color: #0c4c69;
                font-weight: 700;
            }

            .tokushokuwaku_box > .box_header .text h3{
                color: #0c4c69;
                margin-top: 0;
                display: flex;
                align-items: center;
            }

                .tokushokuwaku_box > .box_header .text h3::after{
                    content: "";
                    display: inline-block;
                    width: 3em;
                    border-bottom: 1px solid #0c4c69;
                    margin-left: 0.5em;
                }

        .tokushokuwaku_box > .box_header .fig{
            width: 19.25rem;
        }

.subject_contain {
    display: flex;
    flex-wrap: wrap;
    gap: 2em;
}

.subject_contain .subject_box {
    box-sizing: border-box;
    width: calc((100% - 2em) / 2);
    padding-top: 1.5em;
    padding-right: 0.5em;
    padding-left: 0.5em;
    padding-bottom: 0.5em;
    margin: 0;
    background: #fff;
    border-radius: 1rem;
    box-shadow: 3px 3px 0 0 rgba(0, 0, 0, 0.1);
}

    .subject_contain .subject_box:last-child {
        width: 100%;
    }

.subject_contain .subject_box .box_inner .text {
    padding-right: 0;
}

    .subject_contain .subject_box .box_inner .text .subject_title{
        margin-left: 1em;
        margin-right: 1em;
    }

    .subject_contain .subject_box .box_inner .text .subject_title h3{
        margin: 0;
        width: 7rem;
        aspect-ratio: 1 / 1;
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 1.4em;
        border-radius: 50%;
        background: #0892bd;
        color: #fff;
    }

    .subject_contain .subject_box .box_inner .text .subject_title h4{
        flex: 1;
        font-size: 1.25em;
    }

.kenshu_contain .kenshu_box{
    margin-bottom: 4em;
}

.kenshu_contain .kenshu_box .box_inner {
    display: flex;
}

.kenshu_contain .kenshu_box .box_inner .text {
    width: 100%;
}

.kenshu_contain .kenshu_box .box_inner h3 {
    margin-top: 0;
}

.senior_voice_box .box_inner {
    display: flex;
}

.kenshu_box .text_2 {
    margin: 3rem auto 5rem;
}

.kenshu_box .text_2 .kenshu_dl {
    position: relative;
}

.kenshu_box .text_2 .kenshu_dl .kenshu_dt {
    border: 1px solid #ffd700;
    border-radius: 10px;
    background: #ffd700;
    display: inline-block;
    padding: 0 0.8em;
    position: absolute;
    top: -0.9rem;
    left: 2rem;
}

.kenshu_box .text_2 .kenshu_dl .kenshu_dd {
    border: 1px solid #ccc;
    padding: 1.3em 1.5em 1em;
    border-radius: 20px;
}

.kenshu_box .box_inner .fig {
    width: 45rem;
}

.page_body .fig_sht{
    margin: 2em 3em 0 3em;
}


@media screen and (min-width:1px) and (max-width:1400px) {
    .btn_mark_exp {
        right: 1rem;
    }

}

@media screen and (min-width:1px) and (max-width:1200px) {}

/*ipad*/
@media screen and (min-width:1px) and (max-width:1024px) {}

/* ##########SP横向き########## */
@media screen and (min-width:1px) and (max-width:768px) {}

/* ##########SP########## */
@media screen and (min-width:1px) and (max-width:479px) {
    .course_list_box>ul {
        flex-direction: column;
        gap: 2rem;
    }

    .course_list_box>ul>li {
        width: 100%;
    }

    .course_list_box>ul>li h2 {
        font-size: 1.2em;
    }

    .mark_exp_box {
        margin: 0 1em;
        line-height: 1.4;
    }

    .mark_exp_box .legend_license_kind {
        padding-right: 1em;
    }

    .mark_exp_box .legend_license_kind dl {
        align-items: flex-start;
    }

    .mark_exp_box .legend_license_teacher {
        flex-direction: column;
    }

    .mark_exp_box .legend_license_teacher dl {
        width: auto;
        margin-bottom: 0.5em;
    }

    .yakuwari_box>.box_inner {
        margin: 0 1em;
        flex-direction: column;
    }

    .yakuwari_box>.box_inner>ul.yakuwari1 {
        width: 100%;
        margin-bottom: 0.5em;
    }

    .yakuwari_box>.box_inner>ul.yakuwari2 {
        width: 100%;
    }

    .license_list ul li {
        width: 2rem;
        height: 2rem;
        font-size: 1rem;
    }

    .major_course_title {
        padding: 0.8em 0.6em;
        margin: 2em 0 1.5em 0;
    }

    .subject_box {
        padding-right: 0.5em;
        margin-bottom: 2em;
    }

    .subject_box>.box_inner,
    .course_box>.box_inner {
        flex-direction: column;
        align-items: center;
    }

    .subject_box>.box_inner .text,
    .course_box>.box_inner .text {
        padding-right: 0;
    }

    .subject_box>.box_inner .text .subject_title {
        justify-content: space-between;
    }

    .subject_box>.box_inner .fig,
    .course_box>.box_inner .fig {
        width: 75%;
    }

    .btn_mark_exp {
        bottom: auto;
        top: 20vw;
        right: 1vw;
    }


    .btn_mark_exp a {
        font-size: 0.7em;
    }

    .btn_mark_exp a::before {
        left: 0.3em;
        font-size: 1.1rem;
        top: calc(50% - 0.55rem);
    }

    /*202509改修*/
    .course_list_r7_box.for_bottom{
        margin-top: 3em;
    }

    .course_list_r7_box.for_bottom > .box_header h2{
        font-size: 1.2em;
        margin-bottom: 0;
    }


    .course_list_r7_box > .box_inner > ul{
        gap: 1em;
    }

    .course_list_r7_box > .box_inner > ul > li{
        width: calc((100% - 1.5em) / 2);
    }

        .course_list_r7_box>.box_inner>ul>li dl dt{
            font-size: 1.1em;
            line-height: 1.4;
        }

        .course_list_r7_box>.box_inner>ul>li dl dt .lbl{
            flex: 1;
        }

    .goto_previous a{
        padding: 0.5em 1em;
    }

    .backto_course{
        font-size: 0.9em;
    }

    .content_title_wrap.for_jite{
        padding-bottom: 1rem;
    }

    .content_title_for_jite .lbls{
        font-size: 0.7em;
        margin-left: 1rem;
    }

    .senko_mv_box > .box_inner .text{
        padding: 0 0 0.5em 0.5em;
        align-items: flex-end;
    }

    .senko_mv_box > .box_inner .text p{
        font-size: 1.4em;
        gap: 0.3em;
    }

    .senko_intro_shoraizou_wrapper{
        flex-direction: column;
        gap: 1.5em;
        margin-top: 2em;
    }

    .shoraizou_box{
        width: 100%;
    }

    .tokushokuwaku_box{
        margin-bottom: 2em;
    }

    .tokushokuwaku_box > .box_header{
        position: relative;
    }

    .tokushokuwaku_box > .box_header .text{
    }

        .tokushokuwaku_box > .box_header .text h2{
            padding-right: 30vw;
        }

        .tokushokuwaku_box > .box_header .text h3{
            display: block;
            font-size: 1.1em;
        }

            .tokushokuwaku_box > .box_header .text h3::after{
                content: none;
            }


    .tokushokuwaku_box > .box_header .fig{
        position: absolute;
        top: -25vw;
        right: -10vw;
        width: 40vw;
    }

    .subject_contain{
        flex-direction: column;
    }

    .subject_contain .subject_box{
        width: 100%;
    }

        .subject_contain .subject_box .box_inner .text .subject_title{
            margin-left: 0.5em;
        }

        .subject_contain .subject_box .box_inner .text .subject_title h3{
            width: 5rem;
            font-size: 1.1em;
        }

        .subject_contain .subject_box .box_inner .text .subject_title h4{
            font-size: 1.05em;
        }

    .kenshu_contain .kenshu_box{
        margin-bottom: 2.5em;
    }

    .kenshu_contain .kenshu_box .box_inner{
        flex-direction: column;
    }

        .kenshu_contain .kenshu_box .box_inner h4{
            margin-top: 0.5em;
        }

        .kenshu_contain .kenshu_box .box_inner .fig{
            margin-left: 1.5em;
            margin-right: 1.5em;
            width: auto;
        }

        .kenshu_box .text_2 {
            margin-bottom: 3rem;
        }

    .page_body .fig_sht{
        margin: 2em;
    }


}


/* ##########印刷用########## */
@media print {}