@charset "UTF-8";
/************************************************************/
/*   KV   */
/************************************************************/
.KV_BR{
    display: none;
}
@media screen and (max-width:320px) { /*SP*/
    .KV_BR{
        display: inline;
    }
}

@media screen and (max-width:767px) { /*SP*/
    #KV{
        height: 50vh;
        background-image: url(/process/img/kv.jpg);
        background-repeat: no-repeat;
        background-position: center bottom;
        background-size: cover;
    }
    .KV_set{
        width: 100%; height: 100%;
        padding-top: 50px;
        display: flex; flex-wrap: nowrap; justify-content: center; align-items: center;
        flex-direction: column;
        text-align: center;
    }
    .KV_icon{
        width: 20%;
        margin-bottom: 15px;
    }
    .KV_key{
        font-size: 2.4rem; font-weight: bold; color: #fff; letter-spacing: 0.6rem; line-height: 1.2;
        margin: 0 0 15px 0.6rem;
    }
    .KV_subkey{
        width: 70%;
    }
}
@media screen and (min-width:768px) , print { /*PC&TB*/
    #KV{
        height: 50vh; min-height: 550px;
        background-image: url(/process/img/kv.jpg);
        background-repeat: no-repeat;
        background-position: center bottom;
        background-size: cover;
    }
    .KV_set{
        width: 100%; height: 100%;
        padding-top: 80px;
        display: flex; flex-wrap: nowrap; justify-content: center; align-items: center;
        flex-direction: column;
    }
    .KV_icon{
        width: 80px;
        margin-bottom: 15px;
    }
    .KV_key{
        font-size: 3rem; font-weight: bold; color: #fff; letter-spacing: 0.6rem; line-height: 1;
        margin: 0 0 15px 0.6rem;
    }
    .KV_subkey{
        width: 300px;
    }
}

/************************************************************/
/*   COMMON   */
/************************************************************/
@media screen and (max-width:767px) { /*SP*/
    .PROCESS_key_set{
        width: 100%;
        margin-bottom: 20px;
        display: flex; flex-wrap: nowrap; justify-content: center; align-items: center;
        flex-direction: column;
    }
    .PROCESS_key_box{
        font-size: 2.2rem; font-weight: bold; color: #007440; letter-spacing: 0.3rem; line-height: 1;
        margin: 0 0 20px 0.3rem;
        padding-bottom: 20px;
        position: relative;
    }
    .PROCESS_key_box::before{
        content: ''; position: absolute;
        bottom: 0; left: 0; right: 0; margin: auto;
        width: 30px; height: 3px;
        background-color: #007440;
    }
    .PROCESS_subKey{
        width: 100%; font-size: 0;
        text-align: center;
    }
    .PROCESS_subKey img{
        width: auto; height: 10px;
    }
}
@media screen and (min-width:768px) , print { /*PC&TB*/
    .PROCESS_key_set{
        width: 100%;
        margin-bottom: 40px;
        display: flex; flex-wrap: nowrap; justify-content: center; align-items: center;
        flex-direction: column;
    }
    .PROCESS_key_box{
        font-size: 3rem; font-weight: bold; color: #007440; letter-spacing: 0.6rem; line-height: 1;
        margin: 0 0 30px 0.6rem;
        padding-bottom: 30px;
        position: relative;
    }
    .PROCESS_key_box::before{
        content: ''; position: absolute;
        bottom: 0; left: 0; right: 0; margin: auto;
        width: 60px; height: 3px;
        background-color: #007440;
    }
    .PROCESS_subKey{
        width: 110px; font-size: 0;
    }
}

/************************************************************/
/*   C1   */
/************************************************************/
.C1_BRSP{
    display: none;
}
@media screen and (max-width:767px) { /*SP*/
    .C1_BRSP{
        display: inline;
    }
}

@media screen and (max-width:767px) { /*SP*/
    #C1{
        overflow: hidden;
    }
    .C1_set{
        width: 100%;
        padding: 30px 0;
        text-align: center;
    }
    .C1_tx01{
        font-size: 1.4rem;
    }
}
@media screen and (min-width:768px) , print { /*PC&TB*/
    #C1{
        overflow: hidden;
    }
    .C1_set{
        width: 100%;
        padding: 60px 0;
        text-align: center;
    }
    .C1_tx01{
        font-size: 1.6rem;
    }
}

/* FLOW */
@media screen and (max-width:767px) { /*SP*/
    .C1_flow_bgc01,
    .C1_flow_bgc02{
        position: relative; z-index: 1;
    }
    .C1_flow_bgc01::before{
        content: ''; position: absolute; z-index: -1;
        top: 0; left: -50vw;
        width: 200vw; height: 100%;
        background-color: #EDF7F5;
    }
    .C1_flow_bgc02::before{
        content: ''; position: absolute; z-index: -1;
        top: 0; left: -50vw;
        width: 200vw; height: 100%;
        background-color: #CFE9E4;
    }
    .C1_flow_set{
        width: 100%;
        padding: 30px 0 0;
        display: flex; flex-wrap: nowrap; justify-content: flex-start; align-items: stretch;
    }
    .C1_flow_boxL{
        width: 25%;
        padding-right: 20px;
        display: flex; flex-wrap: nowrap; justify-content: flex-start; align-items: center;
        flex-direction: column;
        position: relative;
    }
    .C1_flow_num{
        width: 100%; max-width: 132px;
        margin-bottom: 30px;
    }
    .C1_flow_icon01{
        width: 100%; max-width: 163px;
    }
    .C1_flow_icon02{
        width: 60%; max-width: 79px;
    }
    .C1_flow_icon03{
        width: 50%; max-width: 61px;
    }
    .C1_flow_arr{
        width: 25px;
        position: absolute;
        bottom: 20px; left: 0; right: 20px; margin: auto;
    }
    .C1_flow_boxR{
        width: 75%;
        padding: 0 0 30px;
    }
    .C1_flow_innerA{
        width: 100%;
    }
    .C1_flow_innerB{
        width: 100%;
    }
    .C1_flow_tx{
        width: 100%;
        margin-bottom: 20px;
    }
    .C1_flow_key{
        font-size: 2.0rem; font-weight: bold; color: #007440; letter-spacing: 0.3rem; line-height: 1.2;
        margin-bottom: 20px;
        padding-left: 25px;
        position: relative;
    }
    .C1_flow_key::before{
        content: ''; position: absolute;
        top: 0; left: 0;
        width: 10px; height: 100%;
        background-color: #007440;
        border-radius: 5px;
    }
    .C1_flow_tx p{
        font-size: 1.4rem;
    }
    .C1_flow_img{
        width: 100%;
    }
    .C1_flow_link_set{
        width: 100%;
        padding: 30px 0 0;
    }
    .C1_flow_link_set p{
        font-size: 1.4rem; color: #007440;
    }
    .C1_flow_link_box{
        width: 100%;
        padding: 30px 0 0;
    }
}
@media screen and (min-width:768px) and ( max-width:1023px) { /*TB*/
    .C1_flow_bgc01,
    .C1_flow_bgc02{
        position: relative; z-index: 1;
    }
    .C1_flow_bgc01::before{
        content: ''; position: absolute; z-index: -1;
        top: 0; left: -50vw;
        width: 200vw; height: 100%;
        background-color: #EDF7F5;
    }
    .C1_flow_bgc02::before{
        content: ''; position: absolute; z-index: -1;
        top: 0; left: -50vw;
        width: 200vw; height: 100%;
        background-color: #CFE9E4;
    }
    .C1_flow_set{
        width: 100%;
        padding: 60px 0 0;
        display: flex; flex-wrap: nowrap; justify-content: flex-start; align-items: stretch;
    }
    .C1_flow_boxL{
        width: 200px;
        padding-right: 100px;
        display: flex; flex-wrap: nowrap; justify-content: flex-start; align-items: center;
        flex-direction: column;
        position: relative;
    }
    .C1_flow_num{
        width: 132px;
        margin-bottom: 30px;
    }
    .C1_flow_icon01{
        width: 163px;
    }
    .C1_flow_icon02{
        width: 79px;
    }
    .C1_flow_icon03{
        width: 61px;
    }
    .C1_flow_arr{
        width: 50px;
        position: absolute;
        bottom: 60px; left: 0; right: 100px; margin: auto;
    }
    .C1_flow_boxR{
        width: calc(100% - 200px);
        padding: 0 0 60px;
    }
    .C1_flow_innerA{
        width: 100%;
    }
    .C1_flow_innerB{
        width: 100%;
    }
    .C1_flow_tx{
        width: 100%;
        margin-bottom: 40px;
    }
    .C1_flow_key{
        font-size: 2.6rem; font-weight: bold; color: #007440; letter-spacing: 0.6rem; line-height: 1.2;
        margin-bottom: 30px;
        padding-left: 30px;
        position: relative;
    }
    .C1_flow_key::before{
        content: ''; position: absolute;
        top: 0; left: 0;
        width: 12px; height: 100%;
        background-color: #007440;
        border-radius: 5px;
    }
    .C1_flow_tx p{
        font-size: 1.6rem;
    }
    .C1_flow_img{
        width: 100%;
    }
    .C1_flow_link_set{
        width: 100%;
        padding: 60px 0 0;
    }
    .C1_flow_link_set p{
        font-size: 1.6rem; color: #007440;
    }
    .C1_flow_link_box{
        width: 100%; max-width: 350px;
        padding: 60px 0 0;
        margin: 0 auto;
    }
}
@media screen and (min-width:1024px) , print { /*PC*/
    .C1_flow_bgc01,
    .C1_flow_bgc02{
        position: relative; z-index: 1;
    }
    .C1_flow_bgc01::before{
        content: ''; position: absolute; z-index: -1;
        top: 0; left: -50vw;
        width: 200vw; height: 100%;
        background-color: #EDF7F5;
    }
    .C1_flow_bgc02::before{
        content: ''; position: absolute; z-index: -1;
        top: 0; left: -50vw;
        width: 200vw; height: 100%;
        background-color: #CFE9E4;
    }
    .C1_flow_set{
        width: 100%;
        padding: 60px 0 0;
        display: flex; flex-wrap: nowrap; justify-content: flex-start; align-items: stretch;
    }
    .C1_flow_boxL{
        width: 200px;
        padding-right: 100px;
        display: flex; flex-wrap: nowrap; justify-content: center; align-items: center;
        flex-direction: column;
    }
    .C1_flow_num{
        width: 132px;
        margin-bottom: 30px;
    }
    .C1_flow_icon01{
        width: 163px;
        margin-bottom: 30px;
    }
    .C1_flow_icon02{
        width: 79px;
        margin-bottom: 30px;
    }
    .C1_flow_icon03{
        width: 61px;
        margin-bottom: 30px;
    }
    .C1_flow_arr{
        width: 50px;
        margin-bottom: 30px;
    }
    .C1_flow_boxR{
        width: calc(100% - 200px);
        padding: 0 0 60px;
    }
    .C1_flow_innerA{
        width: 100%;
        display: flex; flex-wrap: nowrap; justify-content: space-between; align-items: center;
        flex-direction: row-reverse;
    }
    .C1_flow_innerB{
        width: 100%;
        display: flex; flex-wrap: nowrap; justify-content: space-between; align-items: center;
    }
    .C1_flow_tx{
        width: calc(50% - 60px);
    }
    .C1_flow_key{
        font-size: 2.6rem; font-weight: bold; color: #007440; letter-spacing: 0.6rem; line-height: 1.2;
        margin-bottom: 30px;
        padding-left: 30px;
        position: relative;
    }
    .C1_flow_key::before{
        content: ''; position: absolute;
        top: 0; left: 0;
        width: 12px; height: 100%;
        background-color: #007440;
        border-radius: 5px;
    }
    .C1_flow_tx p{
        font-size: 1.6rem;
    }
    .C1_flow_img{
        width: 50%;
    }
    .C1_flow_link_set{
        width: 50%;
        padding: 60px 0 0;
    }
    .C1_flow_link_set p{
        font-size: 1.6rem; color: #007440;
    }
    .C1_flow_link_box{
        width: 100%; max-width: 350px;
        padding: 60px 0 0;
    }
}

/************************************************************/
/*   C2   */
/************************************************************/
.C2_BRSP{
    display: none;
}
@media screen and (max-width:767px) { /*SP*/
    .C2_BRSP{
        display: inline;
    }
}

@media screen and (max-width:767px) { /*SP*/
    .C2_set{
        width: 100%;
        padding: 30px 0;
    }
    .C2_tx01{
        font-size: 1.4rem;
        margin-bottom: 30px;
        text-align: center;
    }
}
@media screen and (min-width:768px) , print { /*PC&TB*/
    .C2_set{
        width: 100%;
        padding: 60px 0;
    }
    .C2_tx01{
        font-size: 1.6rem;
        margin-bottom: 60px;
        text-align: center;
    }
}

/* FACILITY */
@media screen and (max-width:767px) { /*SP*/
    .C2_facility_set{
        width: 100%;
    }
    .C2_facility_box{
        width: 100%;
        margin-bottom: 30px;
    }
    .C2_facility_box:last-of-type{
        margin-bottom: 0;
    }
    .C2_facility_img{
        width: 100%;
        padding: 0 40px;
        position: relative;
    }
    .C2_facility_smallImg{
        position: absolute;
        bottom: -20px; right: 0;
        width: 35%;
    }
    .C2_facility_tx{
        width: 100%;
        padding: 20px 10px 0;
    }
    .C2_facility_key{
        font-size: 1.6rem; font-weight: bold; color: #007440;
        margin-bottom: 10px;
        text-align: center;
    }
    .C2_facility_tx p{
        font-size: 1.4rem;
    }
}
@media screen and (min-width:768px) and ( max-width:1023px) { /*TB*/
    .C2_facility_set{
        width: 100%;
        padding: 0 7%;
        display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: flex-start;
    }
    .C2_facility_box{
        width: calc((100% - (15% * 1)) /2);
        margin-right: 15%;
        margin-bottom: 40px;
    }
    .C2_facility_box:nth-of-type(2n){
        margin-right: 0;
    }
    .C2_facility_box:nth-last-of-type(-n+2){
        margin-bottom: 0;
    }
    .C2_facility_img{
        width: 100%;
        position: relative;
    }
    .C2_facility_smallImg{
        position: absolute;
        bottom: -20px; left: 80%; right: 0; margin: auto;
        width: 45%;
    }
    .C2_facility_tx{
        width: 100%;
        padding: 30px 10px 0;
    }
    .C2_facility_key{
        font-size: 1.8rem; font-weight: bold; color: #007440;
        margin-bottom: 10px;
        text-align: center;
    }
    .C2_facility_tx p{
        font-size: 1.6rem;
    }
}
@media screen and (min-width:1024px) , print { /*PC*/
    .C2_facility_set{
        width: 100%;
        display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: flex-start;
    }
    .C2_facility_box{
        width: calc((100% - (100px * 2)) /3);
        margin-right: 100px;
        margin-bottom: 40px;
    }
    .C2_facility_box:nth-of-type(3n){
        margin-right: 0;
    }
    .C2_facility_box:last-of-type{
        margin-bottom: 0;
    }
    .C2_facility_img{
        width: 100%;
        position: relative;
    }
    .C2_facility_smallImg{
        position: absolute;
        bottom: -20px; left: 80%; right: 0; margin: auto;
        width: 45%;
    }
    .C2_facility_tx{
        width: 100%;
        padding: 30px 10px 0;
    }
    .C2_facility_key{
        font-size: 1.8rem; font-weight: bold; color: #007440;
        margin-bottom: 10px;
        text-align: center;
    }
    .C2_facility_tx p{
        font-size: 1.6rem;
    }
}