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

    /***mission***/
    /*gist*/
    .mission_gist {
        margin: 0 3%;
    }

    .mission_ttl {
        text-align: center;
        margin-bottom: 30px;
    }

    .mission_ttl_eng {
        font-size: 30px;
        line-height: 30px;
        font-weight: bold;
        color: #eee;
        margin-bottom: -13px;
        display: block;
    }

    .mission_ttl h2 {
        font-size: 20px;
        font-weight: bold;
        margin-bottom: 10px;
    }

    .mission_ttl p {
        font-size: 14px;
        line-height: 22px;
    }

    .mission_gist_box {
        background: #f5f5f5;
        padding: 20px 0;
    }

    .mission_gist_flex {
        margin-bottom: 20px;
        padding: 0 7%;
    }

    .mission_gist_flex:nth-child(2) {
        margin-bottom: 40px;
    }

    .mission_gist_flex p {
        font-size: 14px;
        line-height: 32px;
        position: relative;
        z-index: 1;
    }

    .mission_gist_flex img {
        opacity: 0.3;
        filter: blur(1px);
        margin-top: -300px;
    }

    .mission_gist_objective {
        display: flex;
        align-items: center;
        justify-content: center;
        flex-wrap: wrap;
        padding: 0 5%;
    }

    .mission_gist_objective li {
        width: 42%;
        border-radius: 50%;
        background: #D3EDFB;
    }

    .mission_gist_objective li:first-child {
        margin-right: 3%;
    }

    .mission_gist_height {
        position: relative;
        padding-top: 100%;
        height: 0;
    }

    .mission_gist_objective li img {
        width: 45%;
        position: absolute;
        top: 23%;
        left: 50%;
        transform: translateX(-50%);
        -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
    }

    .mission_gist_objective li p {
        font-size: 10px;
        line-height: 15px;
        text-align: center;
        margin-bottom: 10px;
        position: absolute;
        width: 100%;
        top: 56%;
        left: 50%;
        transform: translateX(-50%);
        -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
    }

    .mission_gist_arrow {
        width: 40px;
        margin: 0 auto;
        margin-top: 45px;
        margin-bottom: 30px;
    }

    /*vision*/
    .mission_vision {
        margin: 0 3%;
        margin-bottom: 60px;
    }

    .mission_vision>img {
        display: block;
        margin: 0 auto;
        margin-bottom: 20px;
    }

    .mission_vision>p {
        text-align: center;
        display: block;
    }

    /*bgimg*/
    .mission_bgimg {
        width: 100%;
        margin-bottom: 50px;
    }

    .mission_bgimg img {
        width: 100%;
        height: 100px;
        object-fit: cover;
        font-family: 'object-fit: cover';
        object-position: center;
    }

    /*policy*/
    .mission_policy {
        margin-bottom: 100px;
    }

    .mission_policy>p {
        display: block;
        margin: 0 3%;
        margin-bottom: 35px;
    }

    .mission_policy_figure {
        margin: 0 3%;
    }

    .mission_policy_figure ul {
        display: flex;
        align-items: center;
        justify-content: space-between;
        flex-wrap: wrap;
        border-bottom: 3px solid #707070;
        padding-bottom: 5px;
    }

    .mission_policy_figure ul li {
        width: 49%;
        height: 75px;
        background: #D3EDFB;
        display: flex;
        align-items: center;
        justify-content: center;
        margin-bottom: 7px;
    }

    .mission_policy_figure ul li:nth-child(2),
    .mission_policy_figure ul li:nth-child(3) {
        background: #FFE958;
    }

    .mission_policy_figure ul li p {
        display: block;
        text-align: center;
        font-size: 14px;
        line-height: 22px;
    }

    .mission_policy_dialog {
        position: relative;
        display: block;
        padding: 7px 4%;
        border: 3px solid #707070;
        margin: 0 auto;
        width: 275px;
        text-align: center;
        margin-top: 30px;
    }

    .mission_policy_dialog:before {
        content: "";
        position: absolute;
        top: -43px;
        left: 50%;
        margin-left: -10px;
        border: 10px solid transparent;
        border-bottom: 30px solid #707070;
    }

    .mission_policy_dialog p {
        font-weight: bold;
    }

    /***question***/
    .question_wrap {
        margin: 0 3%;
    }

    .question_box {
        margin-bottom: 50px;
    }

    .question_q {
        display: flex;
        align-items: flex-start;
        margin-bottom: 15px;
    }

    .question_a_ttl {
        display: flex;
        align-items: flex-start;
        margin-bottom: 10px;
    }

    .question_q>span,
    .question_a_ttl>span {
        width: 35px;
        height: 35px;
        font-size: 20px;
        line-height: 35px;
        font-weight: bold;
        color: #fff;
        display: block;
        text-align: center;
        margin-right: 3%;
        flex-shrink: 0;
        background: #004EA2;
    }

    .question_a_ttl>span {
        background: #DF3F3F;
    }

    .question_q h2,
    .question_a_ttl h2 {
        font-size: 18px;
        line-height: 27px;
        font-weight: bold;
        margin-top: 6px;
    }

    .question_a>p {
        width: 90%;
        margin: 0 0 0 auto;
    }

    /*question_figure*/
    .question_figure {
        position: relative;
        padding: 15px 0;
    }

    .question_figure_training {
        border-left: 2px solid #707070;
        position: absolute;
        height: 100%;
        left: 6.4%;
    }

    .question_figure_training::after {
        content: "";
        width: 8px;
        height: 8px;
        border-bottom: solid 2px #707070;
        border-right: solid 2px #707070;
        transform: rotate(45deg);
        position: absolute;
        left: -6px;
        bottom: 0;
    }

    .question_figure_training span {
        font-size: 12px;
        display: flex;
        align-items: center;
        width: 80px;
        position: absolute;
        left: -10px;
        top: -5px;
    }

    .question_figure_training span:nth-child(2) {
        top: 64.5%;
    }

    .question_figure_training span:nth-child(3) {
        top: 97%;
    }

    .question_figure_training span:before {
        content: '';
        width: 15px;
        height: 15px;
        border: 2px solid #707070;
        background: #fff;
        border-radius: 50%;
    }

    .question_figure_phase {
        position: relative;
        display: block;
        border: 1px solid #707070;
        width: 85%;
        margin: 20px 0 0 auto;
    }

    .question_figure_phase:before {
        content: "";
        position: absolute;
        top: 50%;
        left: -30px;
        margin-top: -15px;
        border: 15px solid transparent;
        border-right: 15px solid #707070;
    }

    .question_figure_phase::after {
        content: '';
        width: 10px;
        height: 94%;
        background: #FFE958;
        position: absolute;
        left: -12%;
        top: 3%;
    }

    .question_figure_phase:nth-child(2)::after {
        background: #A1DBF9;
    }

    .question_figure_phase:nth-child(3)::after {
        background: #679CD5;
    }

    .question_figure_phase h3 {
        line-height: 40px;
        background: #707070;
        text-align: center;
        font-weight: bold;
        color: #fff;
        width: 100%;
        font-size: 14px;
    }

    .question_figure_phase ul {
        padding: 10px 4%;
    }

    .question_figure_phase ul p {
        font-weight: bold;
        display: block;
        font-size: 14px;
    }

    .question_figure_phase ul li {
        font-size: 14px;
        padding-left: 6px;
    }

    .question_figure_phase ul li::before {
        content: '';
        position: relative;
        top: -2px;
        left: -5px;
        display: inline-block;
        width: 5px;
        height: 5px;
        border-radius: 50%;
        background: #111;
    }

    .question_figure_phase>img {
        width: 25px;
        margin: 0 auto;
        display: block;
    }

    /*question_a_list*/
    .question_a_list {
        width: 90%;
        margin: 0 0 0 auto;
    }

    .question_a_list li {
        margin-bottom: 20px;
    }

    .question_a_list li h3 {
        font-weight: bold;
        margin-bottom: 5px;
        padding-left: 5px;
    }

    .question_a_list li h3::before {
        content: '';
        position: relative;
        top: -3px;
        left: -5px;
        display: inline-block;
        width: 5px;
        height: 5px;
        border-radius: 50%;
        background: #111;
    }

    .question_link a {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 260px;
        height: 44px;
        line-height: 50px;
        color: #fff;
        background: #111;
        margin: 20px 0 0 auto;
        padding: 0 15px;
        font-size: 15px;
    }

    /***day***/
    .day_wrap {
        margin: 0 3%;
        margin-bottom: 70px;
    }

    .day_accordion_ttl {
        padding: 25px 5% 15px;
        transition: 0.4s;
        cursor: pointer;
        position: relative;
        display: flex;
        align-items: center;
        justify-content: space-between;
        border-bottom: 1px solid #707070;
        font-size: 15px;
        line-height: 24px;
    }

    .day_icon {
        display: block;
        position: relative;
        width: 24px;
        margin-left: 6px;
        flex-shrink: 0;
        transform-origin: center 43%;
        transition: transform 0.4s;
        color: #004EA2;
    }

    .day_accordion_ttl.active .day_icon {
        /*activeクラスが付与されたとき*/
        transform: rotate(180deg);
    }

    /*アコーディオンの中身*/
    .day_content {
        opacity: 0;
        height: 0;
        line-height: 0;
        transition: 0.4s;
    }

    .day_content>*+* {
        margin-top: 0;
    }

    .day_content img {
        height: 0;
    }

    .day_content.open {
        padding: 20px 0 30px;
        opacity: 1;
        line-height: normal;
        height: auto;
    }

    .day_content.open>*+* {
        margin-top: 10px;
    }

    .day_content ul {
        border-left: 2px solid #707070;
        height: 100%;
        margin-left: 5%;
    }

    .day_content ul li {
        margin-bottom: 20px;
    }

    .day_content ul li:last-child {
        margin-bottom: 0;
    }

    .day_content ul li span {
        font-weight: bold;
        display: flex;
        align-items: flex-start;
        margin-bottom: 10px;
    }

    .day_content ul li span::before {
        content: '';
        width: 10px;
        height: 10px;
        border: 2px solid #707070;
        background: #fff;
        border-radius: 50%;
        margin-left: -2.5%;
        margin-right: 10px;
        margin-top: 6px;
        flex-shrink: 0;
        display: block;
    }

    .day_content ul li p {
        margin: 0 5%;
    }

    .day_content>p {
        display: block;
        margin-bottom: 35px;
    }

}